Linux服务篇之mysql主从复制

概念

  • 什么是主从复制、所谓主从复制,简单的来说就是把数据多备份到另外一台电脑上
  • 那为什么要做主从复制,说起这里我们就要说到单点了
  • 那什么是单点,这个问题很抽象、所谓点单比如我们人自己的生命,就是个单点,一出现什么故障那很危险的,比喻下啦,勿怕,结果是什么大家都知道
  • 比如我们的手机也是个单点,只要是唯一都是点单,单点是很危险的,这得看在什么情况下,有时候在这个世界上就需要单点、比如女朋友啦等等,哈哈,大家都懂得,但是一定是单点吗,那你就要努力了,呵呵
  • 其实在互联网公司单点机房单点是很危险的,因为在互联网公司数据就决定了这个公司的命脉,就像我们忠所周知的什么什么程公司就差点倒闭,幸亏他有数据备份不然公司可能在一夜之间倒闭
  • 就像某宝那他强大都知道,你可能还在里面买点小东西送给你什么什么朋友,男女都可以啦
  • 但是他的数据一旦丢失,那效果都懂的,说了半天那为什么要做什么复制,什么什么主从
  • 所谓主从就是就是为了防止单点,数据一旦丢失,我们还有另外一个备份
  • 难道主从就只是为了备份用
  • 当然不是,主从用处很多,等下会慢慢来介绍
  • 下面我将会用到很多专业术语,看不懂没关系,慢慢来就可以啦,笔者我当然也是非常菜逼的呵呵

主从复制配置

  • 首先我们要准备二台linux系统,我这里用的是CentOS7.3
  • 下面是导图的顺序
  • 下面是详细图
  • 首先我们先同步时间,两台都需要同步
[root@server ~]# ntpdate 172.16.0.1
  • 让后我们安装数据库,两台都需要安装
[root@server ~]# yum install mariadb-server -y
  • 安装成功以后,先不要着急启动我们先配置主服务器,执行命令,打开配置文件
[root@server ~]# vim /etc/my.cnf.d/server.cnf 
  • 文件打开以后开始配置主服务
# this is only for the mysqld standalone daemon
[mysqld]
server-id = 1                   <<<<< ID号最好是唯一
log-bin = master-log            <<<<< 开启二进制日志
skip_name_resolve = ON
  • 配置玩以后保存退出,配置从服务器,同样是在下面配置文件配置
[root@server ~]# vim /etc/my.cnf.d/server.cnf 
  • 配置以下文件
 [server]

# this is only for the mysqld standalone daemon
[mysqld]
server-id = 2
relay-log = relay-log
skip_name-resolve = ON
  • 接下来我们启动服务器,先启动主服务器
[root@server ~]# systemctl  start mariadb.service
  • 启动以后我们查询下启动成功没有
[root@server ~]# ss -nutl
Netid State      Recv-Q Send-Q Local Address:Port               Peer Address:Port              
udp   UNCONN     0      0                *:43362                        *:*                  
udp   UNCONN     0      0                *:68                           *:*                  
udp   UNCONN     0      0               :::28989                       :::*                  
tcp   LISTEN     0      50               *:3306                         *:*                  
tcp   LISTEN     0      128              *:22                           *:*                  
tcp   LISTEN     0      100      127.0.0.1:25                           *:*                  
tcp   LISTEN     0      128             :::22                          :::*                  
tcp   LISTEN     0      100            ::1:25                          :::*   
  • 启动成功以后我们来连接,注意这里是没有设置账号密码的所以不需要输入,需要输入密码是-和-p
[root@server ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 2
Server version: 5.5.52-MariaDB MariaDB Server

Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> 
  • 连接成功以后我们执行一个命令查询看,日志,因为我要从日志的以后来复制
MariaDB [(none)]> SHOW MASTER STATUS;
+-------------------+----------+--------------+------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-log.000003 |      245 |              |                  |
+-------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
  • 接下来我们来创建复制权限的账号
MariaDB [(none)]> GRANT REPLICATION CLIENT,REPLICATION SLAVE ON *.* TO 'lilin'@'172.16.251.190' IDENTIFIED BY 'li56412820';
  • 接下来我们保存
MariaDB [(none)]> FLUSH PRIVILEGES;
  • 接下来我们来启动从服务器
[root@form ~]# systemctl start mariadb.service
  • 启动成功以后,我们进去数据库
[root@form ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 2
Server version: 5.5.52-MariaDB MariaDB Server

Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> 
  • 在数据库里面执行一个命令
MariaDB [(none)]> CHANGE MASTER TO MASTER_HOST='172.16.252.133' , MASTER_USER='lilin',MASTER_PASSWORD='li5641282' , MASTER_LOG_FILE='master-log.000003' , MASTER_LOG_POS=678;
  • 执行完毕以后他会在我们的从服务器一个路径里面会生成一个很重要的文件,那就是info文件里面会有你数据库的账号密码
[root@form ~]# cd /var/lib/mysql/
[root@form mysql]# ls
aria_log.00000001  ib_logfile0  mysql               relay-log.000001  test
aria_log_control   ib_logfile1  mysql.sock          relay-log.index
ibdata1            master.info  performance_schema  relay-log.info
  • 我们来看下info文件
[root@form mysql]# cat master.info 
18
master-log.000003
678
172.16.252.133
lilin
li5641282
3306
60
0





0
1800.000

0
  • 还有一个文件就是relay-log,里面会保存位置,这里文件作用就是服务器重启了会自动保存自动启动
[root@form mysql]# cat relay-log.info 
./relay-log.000001
4
master-log.000003
678
  • 但是复制还没有启动,我们可以用命令查看下
MariaDB [(none)]> SHOW SLAVE STATUS\G
*************************** 1. row ***************************
               Slave_IO_State: 
                  Master_Host: 172.16.252.133
                  Master_User: lilin
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-log.000003
          Read_Master_Log_Pos: 678
               Relay_Log_File: relay-log.000001
                Relay_Log_Pos: 4
        Relay_Master_Log_File: master-log.000003
             Slave_IO_Running: No                       <<<<<复制NO为没有启动
            Slave_SQL_Running: No                       <<<<<重放NO为没有启动
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0
                   Last_Error: 
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 678
              Relay_Log_Space: 245
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File: 
           Master_SSL_CA_Path: 
              Master_SSL_Cert: 
            Master_SSL_Cipher: 
               Master_SSL_Key: 
        Seconds_Behind_Master: NULL
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 0
1 row in set (0.00 sec)
  • 接下来用命令启动即可
mysql> START SLAVE
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容