国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL數(shù)據(jù)庫(kù)主從同步的實(shí)現(xiàn)方法推薦

2024-07-24 12:36:11
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
  這篇文章主要講解了MySQL數(shù)據(jù)庫(kù)主從同步的實(shí)現(xiàn)方法,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
 
  安裝環(huán)境說(shuō)明
 
  系統(tǒng)環(huán)境:
 
  [root@~]# cat /etc/redhat-release
  CentOS release 6.5 (Final)
  [root@~]# uname -r
  2.6.32-431.el6.x86_64
  數(shù)據(jù)庫(kù):
 
  由于是模擬環(huán)境,主從庫(kù)在同一臺(tái)服務(wù)器上,服務(wù)器IP地址192.168.1.7
 
  主庫(kù)使用3306端口
  從庫(kù)使用3307端口
  數(shù)據(jù)庫(kù)數(shù)據(jù)目錄/data
  安裝MySQL數(shù)據(jù)庫(kù)服務(wù)
  下載軟件包
 
  今天我們是用二進(jìn)制安裝包進(jìn)行布署MySQL數(shù)據(jù)庫(kù)服務(wù),其它方式的安裝布署方法請(qǐng)參考前面的文章
 
  [root@~]#wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.51-linux2.6-x86_64.tar.gz
  創(chuàng)建數(shù)據(jù)目錄、軟件安裝目錄
 
  [root@~]#mkdir /data{3306,3307} -p
  [root@~]#mkdri /application
  解壓軟件
 
  [root@~]#tar zxf mysql-5.5.51-linux2.6-x86_64.tar.gz
  [root@~]#mv mysql-5.5.51-linux2.6-x86_64 /application/mysql-5.5.51
  [root@~]#ln -s /application/mysql-5.5.51 /application/mysql
  創(chuàng)建用戶
 
  [root@~]#groupadd mysql
  [root@~]#useradd -g mysql -M mysql
  初始化數(shù)據(jù)庫(kù)
 
  [root@~]#/application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/data/3306/data --user=mysql
 
  [root@~]#/application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/data/3307/data --user=mysql
  創(chuàng)建配置文件
 
  [root@~]#vi /data/3306/my.cnf
  [client]
  port   = 3306
  socket   = /data/3306/mysql.sock
 
  [mysql]
  no-auto-rehash
 
  [mysqld]
  user = mysql
  port = 3306
  socket = /data/3306/mysql.sock
  basedir = /application/mysql
  datadir = /data/3306/data
  open_files_limit = 1024
  back_log = 600
 
  max_connections = 800
  max_connect_errors = 3000
  table_cache = 614
  external-locking = FALSE
  max_allowed_packet =8M
  sort_buffer_size = 1M
  join_buffer_size = 1M
  thread_cache_size = 100
  thread_concurrency = 2
  query_cache_size = 2M
  query_cache_limit = 1M
  query_cache_min_res_unit = 2k
  thread_stack = 192K
  tmp_table_size = 2M
  max_heap_table_size = 2M
  long_query_time = 1
 
  pid-file = /data/3306/mysql.pid
  log-bin = /data/3306/mysql-bin
  #主從同步的關(guān)鍵點(diǎn),從庫(kù)上不需要開(kāi)啟
  relay-log = /data/3306/relay-bin
  relay-log-info-file = /data/3306/relay-log.info
  binlog_cache_size = 1M
  max_binlog_cache_size = 1M
  max_binlog_size = 2M
  expire_logs_days = 7
  key_buffer_size = 16M
  read_buffer_size = 1M
  read_rnd_buffer_size = 1M
  bulk_insert_buffer_size = 1M
  lower_case_table_names = 1
  skip-name-resolve
  slave-skip-errors = 1032,1062
  replicate-ignore-db=mysql
  server-id = 1 #主庫(kù)從庫(kù)ID 不可相同
 
  [mysqldump]
  quick
  max_allowed_packet = 2M
 
  [mysqld_safe]
  log-error=/data/3306/mysql3306.err
  pid-file=/data/3306/mysqld.pid
  數(shù)據(jù)庫(kù)啟動(dòng)腳本:
 
  [root@~]#vi /data/3306/mysql
  #!/bin/sh
  port=3306
  user="root"
  pwd="123456"
  Path="/application/mysql/bin"
  sock="/data/${port}/mysql.sock"
 
  start_mysql()
  {
   if [ ! -e "$sock" ];then
    printf "Starting MySQL.../n"
    /bin/sh ${Path}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 > /dev/null &
   else
    printf "MySQL is running.../n"
    exit
   fi
  }
  stop_mysql()
  {
   if [ ! -e "$sock" ];then
    printf "MySQL is stopped.../n"
    exit
   else
    printf "Stoping MySQL.../n"
    ${Path}/mysqladmin -u ${user} -p${pwd} -S /data/${port}/mysql.sock shutdown
   fi
  }
  restart_mysql()
  {
   printf "Restarting MySQL.../n"
   stop_mysql
   sleep 2
   start_mysql
  }
  case $1 in
  start)
   start_mysql
  ;;
  stop)
   stop_mysql
  ;;
  restart)
   restart_mysql
  ;;
  *)
   printf "Usage: /data/${port}/mysql {start|stop|restart}/n"
  esac
  備注:主從庫(kù)配置文件與啟動(dòng)文件一樣,只需修改端口與server-id即可完成配置
 
  授權(quán)目錄并增加啟動(dòng)文件可執(zhí)行權(quán)限
 
  [root@~]#chown -R mysql.mysql /data
  [root@~]#find /data -name mysql -exex chmod +x {} /;
  啟動(dòng)數(shù)據(jù)庫(kù)
 
  [root@~]#/data/3306/mysql start
  [root@~]#/data/3307/mysql start
  修改默認(rèn)數(shù)據(jù)庫(kù)密碼
 
  [root@~]#mysqladmin -uroot password '123456' -S /data/3306/mysql.sock
  [root@~]#mysqladmin -uroot password '123456' -S /data/3307/mysql.sock
  測(cè)試登陸,可以登陸兩個(gè)數(shù)據(jù)庫(kù)即可完成全部安裝過(guò)程
 
  配置主庫(kù)
  1)備份主庫(kù)
 
  mkdir /backup
  登陸主庫(kù)創(chuàng)建用步同戶并授權(quán)
 
  [root@~]#mysql -uroot -p123456 -S /data/3306/mysql.sock
 
  mysql> grant replication slave on *.* to rep@'192.168.1.%' identified by'123456';
 
  Query OK, 0 rows affected (0.00 sec)
 
  mysql> flush privileges;
 
  Query OK, 0 rows affected (0.00 sec)
  執(zhí)行鎖表操作
 
  [root@~]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3306/mysql.sock -e "flush table with read lock;"
  備份主庫(kù)
 
  [root@~]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3306/mysql.sock -e "show master status;" >/backup/mysql.log
 
  [root@~]#/application/mysql/bin/mysqldump -uroot -p123456 -S /data/3306/mysql.sock -A -B |gzip >/backup/mysql.sql.gz
  解除鎖表狀態(tài)
 
  [root@~]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3306/mysql.sock -e "unlock tables;"
  備注:以上操作也可以登陸主庫(kù)進(jìn)行,但是需要注意的是,執(zhí)行鎖表操作后,需要另開(kāi)啟一個(gè)窗口進(jìn)行數(shù)據(jù)備份,不可直接退出,防止有數(shù)據(jù)寫入導(dǎo)致備份的數(shù)據(jù)不完整。最好是使用非交互式操作。
 
  配置從庫(kù)實(shí)現(xiàn)主從同步
  將主庫(kù)的備份文件解壓并恢復(fù)數(shù)據(jù)庫(kù)
 
  [root@backup ]#gzip -d mysql.sql.gz
 
  [root@backup ]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3307/mysql.sock < mysql.sql
  查看LOG日志
 
  [root@backup ]#cat mysql.log
  +------------------+----------+--------------+------------------+
  | File    | Position | Binlog_Do_DB | Binlog_Ignore_DB |
  +------------------+----------+--------------+------------------+
  | mysql-bin.000002 |  424 |    |     |
  +------------------+----------+--------------+------------------+
  登陸從庫(kù)執(zhí)行下面的操作
 
  mysql> CHANGE MASTER TO
   -> MASTER_HOST='192.168.1.7',  #服務(wù)器IP
   -> MASTER_PORT=3306,    #主庫(kù)端口
   -> MASTER_USER='rep',    #同步的用戶
   -> MASTER_PASSWORD='123456',  #同步的用戶密碼
   -> MASTER_LOG_FILE=' mysql-bin.000002', #binlog文件
   -> MASTER_LOG_POS=424;     #位置點(diǎn)
  mysql> start slave;    #開(kāi)啟同步
  等待60S后查看同步狀態(tài)
 
  [root@backup ]# mysql -S /data/3307/mysql.sock -e "show slave status/G"|egrep "Seconds_Behind_Master|_Running"
     Slave_IO_Running: Yes
     Slave_SQL_Running: Yes
     Seconds_Behind_Master: 0
  只要出現(xiàn)上述情況說(shuō)明主從同步成功
 
  測(cè)試主從同步
  主庫(kù)創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)
 
  [root@backup ~]# mysql -S /data/3306/mysql.sock -e "create database tongbuku"
 
  [root@backup ~]# mysql -S /data/3306/mysql.sock -e "show databases"
  +-----------------------------+
  | Database     |
  +-----------------------------+
  | information_schema   |
  | mysql      |
  | performance_schema   |
  | test      |
  | tongbuku     |
  +-----------------------------+
  查看從庫(kù)同步情況
 
  [root@backup ~]# mysql -S /data/3307/mysql.sock -e "show databases"
  +-----------------------------+
  | Database     |
  +-----------------------------+
  | information_schema   |
  | mysql      |
  | performance_schema   |
  | test      |
  | tongbuku     |
  +-----------------------------+
  表明主從同步狀態(tài)正常,也可以在主庫(kù)新的數(shù)據(jù)表中創(chuàng)建表,再插入新的數(shù)據(jù)來(lái)測(cè)試主從同步狀態(tài)
 
  看完上述內(nèi)容,是不是對(duì)MySQL數(shù)據(jù)庫(kù)主從同步的實(shí)現(xiàn)方法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容。

(編輯:武林網(wǎng))

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 铜陵市| 平山县| 西和县| 昌黎县| 湖南省| 客服| 永康市| 青神县| 信宜市| 灵山县| 方正县| 昌江| 云南省| 江阴市| 东阿县| 康平县| 文昌市| 无锡市| 进贤县| 高尔夫| 山东| 定州市| 东辽县| 东兰县| 巴里| 永定县| 田阳县| 如皋市| 政和县| 渭南市| 云霄县| 咸阳市| 横峰县| 都安| 平江县| 山阳县| 瑞丽市| 巫溪县| 连州市| 石狮市| 东阿县|