电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

不停止 MySQL 服務增加從庫的兩種方式

瀏覽:20日期:2023-10-16 18:42:40

現在生產環境MySQL數據庫是一主一從,由于業務量訪問不斷增大,故再增加一臺從庫。前提是不能影響線上業務使用,也就是說不能重啟MySQL服務,為了避免出現其他情況,選擇在網站訪問量低峰期時間段操作。

一般在線增加從庫有兩種方式,一種是通過mysqldump備份主庫,恢復到從庫,mysqldump是邏輯備份,數據量大時,備份速度會很慢,鎖表的時間也會很長。另一種是通過xtrabackup工具備份主庫,恢復到從庫,xtrabackup是物理備份,備份速度快,不鎖表。為什么不鎖表?因為自身會監控主庫日志,如果有更新的數據,就會先寫到一個文件中,然后再回歸到備份文件中,從而保持數據一致性。

不停止 MySQL 服務增加從庫的兩種方式

服務器信息:

主庫:192.168.18.212(原有)從庫1:192.168.18.213(原有)從庫2:192.168.18.214(新增)數據庫版本:MySQL5.5存儲引擎:Innodb測試庫名:weibo一、mysqldump方式

MySQL主從是基于binlog日志,所以在安裝好數據庫后就要開啟binlog。這樣好處是,一方面可以用binlog恢復數據庫,另一方面可以為主從做準備。

原有主庫配置參數如下:

# vi my.cnfserver-id = 1 #id要唯一log-bin = mysql-bin #開啟binlog日志auto-increment-increment = 1 #在Ubuntu系統中MySQL5.5以后已經默認是1auto-increment-offset = 1 slave-skip-errors = all #跳過主從復制出現的錯誤

1. 主庫創建同步賬號

mysql> grant all on *.* to ’sync’@’192.168.18.%’ identified by ’sync’;

2. 從庫配置MySQL

# vi my.cnfserver-id = 3 #這個設置3log-bin = mysql-bin #開啟binlog日志auto-increment-increment = 1 #這兩個參數在Ubuntu系統中MySQL5.5以后都已經默認是1auto-increment-offset = 1 slave-skip-errors = all #跳過主從復制出現的錯誤

3. 備份主庫

# mysqldump -uroot -p123 --routines --single_transaction --master-data=2 --databases weibo > weibo.sql

參數說明:

–routines:導出存儲過程和函數–single_transaction:導出開始時設置事務隔離狀態,并使用一致性快照開始事務,然后unlock tables;而lock-tables是鎖住一張表不能寫操作,直到dump完畢。–master-data:默認等于1,將dump起始(change master to)binlog點和pos值寫到結果中,等于2是將change master to寫到結果中并注釋。

4. 把備份庫拷貝到從庫

# scp weibo.sql root@192.168.18.214:/home/root

5. 在主庫創建test_tb表,模擬數據庫新增數據,weibo.sql是沒有的

mysql> create table test_tb(id int,name varchar(30));

6. 從庫導入備份庫

# mysql -uroot -p123 -e ’create database weibo;’# mysql -uroot -p123 weibo < weibo.sql

7. 在備份文件weibo.sql查看binlog和pos值

# head -25 weibo.sql-- CHANGE MASTER TO MASTER_LOG_FILE=’mysql-bin.000001’, MASTER_LOG_POS=107; #大概22行

8. 從庫設置從這個日志點同步,并啟動

mysql> change master to master_host=’192.168.18.212’, -> master_user=’sync’, -> master_password=’sync’, -> master_log_file=’mysql-bin.000001’, -> master_log_pos=107;mysql> start slave;

mysql> show slave statusG;ERROR 2006 (HY000): MySQL server has gone awayNo connection. Trying to reconnect...Connection id: 90Current database: *** NONE ****************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.18.212 Master_User: sync Master_Port: 3306Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 358 Relay_Log_File: mysqld-relay-bin.000003Relay_Log_Pos: 504Relay_Master_Log_File: mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes......

可以看到IO和SQL線程均為YES,說明主從配置成功。

9. 從庫查看weibo庫里面的表

mysql> show tables;+---------------------------+| Tables_in_weibo |+---------------------------+| test_tb |

發現剛才模擬創建的test_tb表已經同步過來!

二、xtrabackup方式(推薦)

在上面配置基礎上做實驗,先刪除掉從庫配置:

mysql> stop slave; #停止同步mysql> reset slave;#清除從連接信息mysql> show slave statusG; #再查看從狀態,可以看到IO和SQL線程都為NOmysql> drop database weibo; #刪除weibo庫

此時,從庫現在和新裝的一樣,繼續前進!

1. 主庫使用xtrabackup備份

# innobackupex --user=root --password=123 ./

生成一個以時間為命名的備份目錄:2015-07-01_16-49-43

# ll 2015-07-01_16-49-43/total 18480drwxr-xr-x 5 root root 4096 Jul 1 16:49 ./drwx------ 4 root root 4096 Jul 1 16:49 ../-rw-r--r-- 1 root root 188 Jul 1 16:49 backup-my.cnf-rw-r----- 1 root root 18874368 Jul 1 16:49 ibdata1drwxr-xr-x 2 root root 4096 Jul 1 16:49 mysql/drwxr-xr-x 2 root root 4096 Jul 1 16:49 performance_schema/drwxr-xr-x 2 root root 12288 Jul 1 16:49 weibo/-rw-r--r-- 1 root root 21 Jul 1 16:49 xtrabackup_binlog_info-rw-r----- 1 root root 89 Jul 1 16:49 xtrabackup_checkpoints-rw-r--r-- 1 root root 563 Jul 1 16:49 xtrabackup_info-rw-r----- 1 root root 2560 Jul 1 16:49 xtrabackup_logfile

2. 把備份目錄拷貝到從庫上

# scp -r 2015-07-01_16-49-43 root@192.168.18.214:/home/root

3. 從庫上把MySQL服務停掉,刪除datadir目錄,將備份目錄重命名為datadir目錄

# sudo rm -rf /var/lib/mysql/# sudo mv 2015-07-01_16-49-43/ /var/lib/mysql# sudo chown mysql.mysql -R /var/lib/mysql# sudo /etc/init.d/mysql start# ps -ef |grep mysql #查看已經正常啟動mysql 8832 1 0 16:55 ?00:00:00 /usr/sbin/mysqld

4. 在主庫創建test_tb2表,模擬數據庫新增數據

mysql> create table test_tb2(id int,name varchar(30));

5. 從備份目錄中xtrabackup_info文件獲取到binlog和pos位置

# cat /var/lib/mysql/xtrabackup_info uuid = 201af9db-1fce-11e5-96b0-525400e4239dname = tool_name = innobackupextool_command = --user=root --password=... ./tool_version = 1.5.1-xtrabackupibbackup_version = xtrabackup version 2.2.11 based on MySQL server 5.6.24 Linux (x86_64) (revision id: )server_version = 5.5.43-0ubuntu0.12.04.1-logstart_time = 2015-07-01 16:49:43end_time = 2015-07-01 16:49:46lock_time = 1binlog_pos = filename ’mysql-bin.000001’, position 429 #這個位置innodb_from_lsn = 0innodb_to_lsn = 1598188partial = Nincremental = Nformat = filecompact = Ncompressed = N

6. 從庫設置從這個日志點同步,并啟動

mysql> change master to master_host=’192.168.18.212’, -> master_user=’sync’, -> master_password=’sync’, -> master_log_file=’mysql-bin.000001’, -> master_log_pos=429;mysql> start slave;

mysql> show slave statusG;*************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.18.212 Master_User: sync Master_Port: 3306Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 539 Relay_Log_File: mysqld-relay-bin.000002Relay_Log_Pos: 363Relay_Master_Log_File: mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes......

可以看到IO和SQL線程均為YES,說明主從配置成功。

9. 從庫查看weibo庫里面的表

mysql> show tables;+---------------------------+| Tables_in_weibo |+---------------------------+| test_tb |

發現剛才模擬創建的test_tb2表已經同步過來。

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | 橡胶电子拉力机-塑料-微电脑电子拉力试验机厂家-江苏天源 | 干式变压器厂_干式变压器厂家_scb11/scb13/scb10/scb14/scb18干式变压器生产厂家-山东科锐变压器有限公司 | 微型气象仪_气象传感器_防爆气象传感器-天合传感器大全 | 搪玻璃冷凝器_厂家-越宏化工设备 | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | 原色会计-合肥注册公司_合肥代理记账公司_营业执照代办 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 东莞海恒试验仪器设备有限公司| 纸塑分离机-纸塑分离清洗机设备-压力筛-碎浆机厂家金双联环保 | 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 电地暖-电采暖-发热膜-石墨烯电热膜品牌加盟-暖季地暖厂家 | 洛阳防爆合格证办理-洛阳防爆认证机构-洛阳申请国家防爆合格证-洛阳本安防爆认证代办-洛阳沪南抚防爆电气技术服务有限公司 | 中国品牌门窗网_中国十大门窗品牌_著名门窗品牌 | 减速机电机一体机_带电机减速器一套_德国BOSERL电动机与减速箱生产厂家 | 气动隔膜泵-电动隔膜泵-循环热水泵-液下排污/螺杆/管道/化工泵「厂家」浙江绿邦 | 成都茶楼装修公司 - 会所设计/KTV装修 - 成都朗煜装饰公司 | 国际线缆连接网 - 连接器_线缆线束加工行业门户网站 | 万烁建筑设计院-建筑设计公司加盟,设计院加盟分公司,市政设计加盟 | 吉祥新世纪铝塑板_生产铝塑板厂家_铝塑板生产厂家_临沂市兴达铝塑装饰材料有限公司 | 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 踏板力计,制动仪,非接触多功能速度仪,逆反射系数测试仪-创宇 | SEO网站优化,关键词排名优化,苏州网站推广-江苏森歌网络 | 领袖户外_深度旅游、摄影旅游、小团慢旅行、驴友网 | 酒吧霸屏软件_酒吧霸屏系统,酒吧微上墙,夜场霸屏软件,酒吧点歌软件,酒吧互动游戏,酒吧大屏幕软件系统下载 | 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? | 密集架-手摇-智能-移动-价格_内蒙古档案密集架生产厂家 | 南溪在线-南溪招聘找工作、找房子、找对象,南溪综合生活信息门户! | 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 振动筛,震动筛,圆形振动筛,振动筛价格,振动筛厂家-新乡巨宝机电 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 仓储笼_仓储货架_南京货架_仓储货架厂家_南京货架价格低-南京一品仓储设备制造公司 | 广西绿桂涂料--承接隔热涂料、隔音涂料、真石漆、多彩仿石漆等涂料工程双包施工 | 冷镦机-多工位冷镦机-高速冷镦机厂家-温州金诺机械设备制造有限公司 | 杭州翻译公司_驾照翻译_专业人工翻译-杭州以琳翻译有限公司官网 组织研磨机-高通量组织研磨仪-实验室多样品组织研磨机-东方天净 | 苏商学院官网 - 江苏地区唯一一家企业家自办的前瞻型、实操型商学院 | 泰国试管婴儿_泰国第三代试管婴儿_泰国试管婴儿费用/多少钱_孕泰来 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 公交驾校-北京公交驾校欢迎您! 工作心得_读书心得_学习心得_找心得体会范文就上学道文库 |