欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL數(shù)據(jù)庫(kù)主從同步實(shí)戰(zhàn)過(guò)程詳解

 更新時(shí)間:2020年05月11日 11:21:36   作者:民工哥  
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)主從同步,結(jié)合實(shí)例形式詳細(xì)分析了MySQL數(shù)據(jù)庫(kù)主從同步基本配置方法與操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了MySQL數(shù)據(jù)庫(kù)主從同步實(shí)戰(zhàn)過(guò)程。分享給大家供大家參考,具體如下:

接上一篇:MySQL數(shù)據(jù)庫(kù)入門之備份數(shù)據(jù)庫(kù)

安裝環(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ù)寫(xiě)入導(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)

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過(guò)程技巧大全》及《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總

希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。

相關(guān)文章

  • MySQL中的日期時(shí)間類型與格式化方式

    MySQL中的日期時(shí)間類型與格式化方式

    這篇文章主要介紹了MySQL中的日期時(shí)間類型與格式化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Windows下mysql community server 8.0.16安裝配置方法圖文教程

    Windows下mysql community server 8.0.16安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了Windows下mysql community server 8.0.16安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • MYSQL事務(wù)回滾的2個(gè)問(wèn)題分析

    MYSQL事務(wù)回滾的2個(gè)問(wèn)題分析

    在事務(wù)中,每個(gè)正確的原子操作都會(huì)被順序執(zhí)行,直到遇到錯(cuò)誤的原子操作,此時(shí)事務(wù)會(huì)將之前的操作進(jìn)行回滾?;貪L的意思是如果之前是插入操作,那么會(huì)執(zhí)行刪 除插入的記錄,如果之前是update操作,也會(huì)執(zhí)行update操作將之前的記錄還原
    2014-05-05
  • mysql出現(xiàn)ERROR問(wèn)題:(2006,?‘MySQL?server?has?gone?away‘)

    mysql出現(xiàn)ERROR問(wèn)題:(2006,?‘MySQL?server?has?gone?away‘)

    這篇文章主要介紹了mysql出現(xiàn)ERROR問(wèn)題:(2006,?‘MySQL?server?has?gone?away‘),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • MySQL主庫(kù)binlog(master-log)與從庫(kù)relay-log關(guān)系代碼詳解

    MySQL主庫(kù)binlog(master-log)與從庫(kù)relay-log關(guān)系代碼詳解

    這篇文章主要介紹了MySQL主庫(kù)binlog與從庫(kù)relay-log關(guān)系的相關(guān)內(nèi)容,涉及部分代碼,需要的朋友可以參考。
    2017-10-10
  • MySQL下海量數(shù)據(jù)的遷移步驟分享

    MySQL下海量數(shù)據(jù)的遷移步驟分享

    一般mysql小數(shù)據(jù)的情況可以通過(guò)直接復(fù)制目錄,或者通過(guò)帝國(guó)備份工具,如果是海量數(shù)據(jù)(6億)該怎么處理呢,下面看下別人是怎么處理的參考一下
    2013-10-10
  • SQL實(shí)現(xiàn)時(shí)間序列錯(cuò)位還原案列

    SQL實(shí)現(xiàn)時(shí)間序列錯(cuò)位還原案列

    這篇文章小編主要向大家介紹的是時(shí)間序列錯(cuò)位還原之SQL實(shí)現(xiàn)案例詳解的相關(guān)資料,需要的小伙伴可以參考下面文章的具體內(nèi)容
    2021-09-09
  • MySQL數(shù)據(jù)庫(kù)show processlist指令使用解析

    MySQL數(shù)據(jù)庫(kù)show processlist指令使用解析

    這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)show processlist指令使用解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • dbeaver如何導(dǎo)出mysql數(shù)據(jù)庫(kù)

    dbeaver如何導(dǎo)出mysql數(shù)據(jù)庫(kù)

    DBeaver導(dǎo)出MySQL數(shù)據(jù)庫(kù)的簡(jiǎn)便方法:右鍵點(diǎn)擊表選擇“Tools”->“Dump database”,設(shè)定輸出文件夾(例如桌面),點(diǎn)擊開(kāi)始即可導(dǎo)出SQL文件,此方法基于個(gè)人經(jīng)驗(yàn),供參考
    2024-10-10
  • Ubuntu上mysql的安裝及使用(通用版)

    Ubuntu上mysql的安裝及使用(通用版)

    今天小編就為大家分享一篇關(guān)于Ubuntu上mysql的安裝及使用(通用版),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03

最新評(píng)論