当前位置:   article > 正文

2024年运维最新linux云计算实战:主从复制_云计算拷贝,2024年最新Linux运维高级工程师必备知识

2024年运维最新linux云计算实战:主从复制_云计算拷贝,2024年最新Linux运维高级工程师必备知识

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

例如,计划使用用户 repl 可以从任何主机上连接到 master 上进行复制操作, 并且用户 repl仅可以使用复制的权限。

在 主服务器 上执行如下操作

mysql> GRANT REPLICATION SLAVE ON *.*  TO  'repl'@'%'  identified by '123';
将复制的权限给与此用户
  • 1
  • 2

3.在从服务器上使用刚才创建的用户进行测试连接

[root@mysql-slalve ~]# mysql -urepl -p'123' -hmysql-master1
测试是否连通,连通退出即可
  • 1
  • 2

下面的操作根据如下情况继续

主服务器中有数据
  1. 在主服务器中导出先有的数据,将此数据复制到每个从站。
  2. 使用mysqldump工具创建要复制的所有数据库的转储。这是推荐的方法,尤其是在使用时 InnoDB。
[root@mysql ~]# mysqldump  -u用户名  -p密码  --all-databases   > dbdump.db

这里的用户是主服务器的用户
  • 1
  • 2
  • 3
  1. 从主服务器中使用 scp 工具,把备份出来的数据传输到从服务器中。

在主服务中执行如下命令

[root@mysql ~]# scp  dbdump.db root@mysql-slave1:/root/

这里的 mysql-slave1 需要能被主服务器解析出 IP 地址,或者说可以在主服务器中 ping 通。
  • 1
  • 2
  • 3
  1. 配置从服务器,并重启 在从服务器 上编辑其配置文件 my.cnf 并添加如下内容
// my.cnf 文件
[mysqld]
server-id=2
配置之后,重启生效
  • 1
  • 2
  • 3
  • 4
  1. 导入数据到从服务器,并配置连接到主服务器的相关信息

登录到从服务器上,执行如下操作

/*导入数据*/
[root@mysql-slave1 ~] mysql -uroot -p'123' < alldb.sql
  • 1
  • 2

5.查看主服务器的binlog日志的名称和位置

6.在从服务器配置连接到主服务器的相关信息

mysql> CHANGE MASTER TO
MASTER_HOST='mysql-master',  -- 主服务器的主机名(也可以是 IP) 
MASTER_USER='repl',           -- 连接到主服务器的用户
MASTER_PASSWORD='Qf_123456';        -- 到主服务器的密码
MASTER_LOG_FILE='mysql-bin.000001', -- 从主服务器的哪个binlog日志读取
MASTER_LOG_POS=589;                 -- 从主服务器的binlog日志的哪个位置开始同步
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

7.启动从服务器的复制线程

mysql> start slave;
Query OK, 0 rows affected (0.09 sec)
  • 1
  • 2

8.检查是否成功

在从服务上执行如下操作,加长从服务器端 IO线程和 SQL 线程是否是 OK

mysql> show slave status\G
  • 1

输出结果中应该看到 I/O 线程和 SQL 线程都是 YES, 就表示成功。

执行此过程后,在主服务上操作的修改数据的操作都会在从服务器中执行一遍,这样就保证了数据的一致性。

主服务器中无数据

主服务器中设置

my.cnf配置文件

[mysqld]
log-bin=/var/log/mysql/mysql-bin
server-id=1
  • 1
  • 2
  • 3

创建日志目录并赋予权限

[root@mysql ~]#  mkdir /var/log/mysql
[root@mysql ~]#  chown mysql.mysql /var/log/mysql
重启服务
  • 1
  • 2
  • 3

找出root的初始密码

[root@mysql-master ~]# grep password /var/log/mysqld.log
  • 1

设置root的密码
mysql> alter user root@localhost identified by 'Syf_123456';
创建主从同步的用户
mysql> GRANT REPLICATION SLAVE ON *.*  TO  'repl'@'%'  identified by 'Syf_123456';
  • 1
  • 2
  • 3
  • 4

从服务器设置

my.cnf配置文件

[mysqld]
server-id=3
重启服务
  • 1
  • 2
  • 3

在主服务器上操作

查看主服务器的binlog日志的名称和位置

mysql> show master status \G
  • 1

1.在从服务器的 mysql 中执行如下语句

找出root的密码

shell [root@mysql-slave1 ~]# grep password /var/log/mysqld.log

进入从数据库



mysql> start slave; ```


#### 在从站上暂停复制


您可以使用和stop slave和start slave语句停止并启动从站上的复制 。


要停止从主服务器处理二进制日志,请使用:



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

mysql> stop slave; //暂停
mysql> start slave; //启动


#### 1.4、配置Replication(gtid方式)


基于事务的Replication,就是利用GTID来实现的复制


GTID(全局事务标示符)最初由google实现,在MySQL 5.6中引入.GTID在事务提交时生成,由UUID和事务ID组成.uuid会在第一次启动MySQL时生成,保存在数据目录下的auto .cnf文件里,事务ID则从1开始自增使用GTID的好处主要有两点:


1. 不再需要指定传统复制中的master\_log\_files和master\_log\_pos,使主从复制更简单可靠
2. 可以实现基于库的多线程复制,减小主从复制的延迟


**实验环境要求: 5.7.6 以上版本**



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

主从均清除刚才实验的环境
[root@mysql-master ~]# systemctl stop mysqld
[root@mysql-slave1 ~]# systemctl stop mysqld
注意:以下两步均危险操作,在以后工作环境中,绝对不能删除数据库。
可以先mysqldump导出一份备份文件,在执行此操作
[root@mysql-master ~]# rm -rf /var/lib/mysql/*
[root@mysql-master ~]# rm -rf /var/log/mysql/*
[root@mysql-slave1 ~]# rm -rf /var/lib/mysql/*


#### 主库配置



  • 1
  • 2
  • 3
  • 4
  • 5

[mysqld]
log-bin=/var/log/mysql/mysql-bin
server-id=1
#打开gtid模式
gtid_mode=ON
enforce_gtid_consistency=1
重启服务
分别找出主从服务器root用户的初始密码
[root@mysql-master ~]# grep password /var/log/mysqld.log
主服务器修改数据库root用户密码(可选操作)
[root@mysql-master ~]# mysqladmin -uroot -p’QsgW(=D#F9&i’ password ‘Syf_123456’
从服务器修改数据库root用户密码(可选操作)
[root@mysql-slave1 ~]# mysqladmin -uroot -p’tUthsaZ0sh(?’ password ‘Syf_123456’


其他和之前的一样


* 创建专属用户并授权
* 假如有数据导出数据



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

mysql> GRANT REPLICATION SLAVE ON . TO ‘repl’@‘%’ identified by ‘Qf_123456’;


#### 从库配置


测试用户有效性



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

mysql -urepl -p’Qf_123456’ -hmysql-master
连接成功,退出

vim /etc/my.cnf #在配置文件中添加配置

[mysqld]
server-id=2
#打开gtid模式
gtid_mode=ON
enforce_gtid_consistency=1

重启服务


Mysql 从服务器终端执行连接信息



  • 1
  • 2
  • 3
  • 4
  • 5

mysql> CHANGE MASTER TO
MASTER_HOST=‘mysql-master’,
MASTER_USER=‘repl’,
MASTER_PASSWORD=‘Qf_123456’,
MASTER_AUTO_POSITION=1;

start slave;


查看是否同步成功



  • 1
  • 2
  • 3
  • 4
  • 5

mysql> show slave status\G


![](https://img-blog.csdnimg.cn/ae88e00bf59d41aeaa5680d4b3bc4804.png)




**先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前在阿里**

**深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

**因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。**
![img](https://img-blog.csdnimg.cn/img_convert/34395cc702d32ce4b97486cd2a21006e.png)
![img](https://img-blog.csdnimg.cn/img_convert/b20590564e87091a197bb19705d526ec.png)
![img](https://img-blog.csdnimg.cn/img_convert/8259410fce3cd74bde9564f206c0ba9e.png)
![img](https://img-blog.csdnimg.cn/img_convert/bce475f736e846043b53256f389a2227.png)
![img](https://img-blog.csdnimg.cn/img_convert/05037b474ba8e4ca4db11f916857eaec.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化的资料的朋友,可以点击这里获取!](https://bbs.csdn.net/topics/618542503)**

Y-1714827268428)]
[外链图片转存中...(img-OfR0iaok-1714827268428)]
[外链图片转存中...(img-TFaRQhzn-1714827268428)]
[外链图片转存中...(img-L7fNsguV-1714827268429)]

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化的资料的朋友,可以点击这里获取!](https://bbs.csdn.net/topics/618542503)**

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号