centos7下部署mysql主从复制
首先大致看一下这个图
环境说明:
系统:centos7
IP:master:192.168.7.235
slave:192.168.7.226
mysql版本MySQL-5.7
1.Master
下载安装包:
wget http://mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
2.更新操作系统:yum -y update 更新完成后进行重启
3.重启后安装依赖包: yum -y install gcc gcc-c++ openssl openssl-devel zlib zlib-devel libaio wget lsof vim-enhanced sysstat ntpdate
4.创建mysql用户:useradd mysql
5.创建目录:mkdir /opt/mysql
6.将数据库包解压到/opt/mysql中 tar -zxvf mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz -C /opt/mysql/
7.修改解压后的目录的属主属组:chown -R mysql:mysql /opt/mysql/mysql-5.7.21-linux-glibc2.12-x86_64/
8.将解压后的安装包软连接到其他目录下: ln -s /opt/mysql/mysql-5.7.21-linux-glibc2.12-x86_64/ /usr/local/mysql
9.更改软连接后的属主属组:chown mysql:mysql /usr/local/mysql/
10.创建数据目录:mkdir /data/mysql/mysql3306/{data,logs,tmp} -p
11.更改数据目录的属主属组:chown -R mysql:mysql /data/
12.查看是否创建成功:tree /data/
13.修改主数据库的配置文件:vim /etc/my.cnf
[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /data/mysql/mysql3306/data
socket = /tmp/mysql3306.sock
tmpdir = /data/mysql/mysql3306/tmp
server-id =1
log-error = error.log
binlog_format = row
14.进行初始化:
/usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql/ --datadir=/data/mysql/mysql3306/data/
15.设置数据库的开机自启动:cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
16.启动服务:如果启动数据库失败,提示系统缺少PID文件,要按照一下的启动方法进行初始化,这个PID文件是数据库初始化的时候自动创建的,如果没有创建成功的话可能由于系统本身有mariadb,所以要指定mysql的路径--basedir=/usr/local/mysql/ --datadir=/data/mysql/mysql3306/data/)
service mysqld start
17.查看数据库端口:ps aux | grep mysql
18.配置环境变量:echo "export PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
source /etc/profile
19.首次登录数据库:
1)首先查看数据库的初始密码:cat /data/mysql/mysql3306/data/error.log | grep password
2)mysql -S /tmp/mysql3306.sock -p
3)修改初始密码:mysql> alter user user() identified by 'password';
20.打开binlog:binlog是开启mysql主从复制的必要条件
Vim /etc/my.cnf
log-bin=/data/mysql-bin
重启mysql:service mysqld restart
21.查看binlog是否生效: ls /data/ (#是否有mysql-bin.00001)
22.添加允许主从复制的访问用户:
mysql -S /tmp/mysql3306.sock -p
grant replication slave on *.* to 'test'@'192.168.7.%' identified by 'password';
flush privileges; 刷新
flush table with read lock; 锁定库,暂停写入
show master status; 记录musql-bin 的号码和position号

mysqldump -uroot -p -S /tmp/mysql3306.sock -A -B --events --master-data=1 >/opt/rep.sql 将数据库中的数据导出,后面进行同步数据的时候使用
23.解锁数据库:mysql> unlock tables;
进行配置slave
24.重复上面的1-12步骤
25.在上面的第13步骤的时,修改配置文件中的server-id,这个server-id是唯一的,只要不与主数据库一样即可
26.将主数据库中导出的数据导入slave中:scp 192.168.7.235:/opt/rep.sql /opt/
mysql -uroot -p -S /tmp/mysql3306.sock </opt/rep.sql
27.进入数据库进行配置:mysql -S /tmp/mysql3306.sock -p
28.先停止数据库的slave功能:stop slave;
29.将从数据库指向master:
change master to
MASTER_HOST='192.168.7.235', 写主数据库的IP
MASTER_PORT=3306,
MASTER_USER='test', 写主数据用于进行主从连接的用户
MASTER_PASSWORD='password',
MASTER_LOG_FILE='mysql-bin.000001', 在主数据库上通过show master status; 查看到的file
MASTER_LOG_POS=1499; 在主数据库上通过show master status; 查看到的position
30.启动slave:start slave;
31.show slave status\G; 查看slave状态,\G是以换行的方式查看
(#slave_IO_Running:yes
#Slave_SQL_Running:yes两条都为yes时表示成功)
当Slave_SQL_Running为no或者报错时,可能需要检查29步,可以重新做28-31步
centos7下部署mysql主从复制的更多相关文章
- docker 容器模式下部署mysql 主从复制
1.计划用两台host来部署,分别部署一台 mysql,一主一从,2.配置好主从mysql配置文件,更改文件名即可[client]port = 3306socket = /var/run/mysqld ...
- 在 CentOS7 上部署 MySQL 主从
在 CentOS7 上部署 MySQL 主从 通过 SecureCRT 连接至 MySQL 主服务器: 找到 my.cnf 文件所在的目录: mysql --help | grep my.cnf 一般 ...
- 2.快速部署MySQL主从复制
1.快速部署MySQL主从复制 [root@mysql ~]# mysql -uroot -p123456 -S /data/3307/mysql.sock -e "show slave ...
- CentOS7下安装MySQL并配置远程连接
一.CentOS7下安装MySQL数据库 CentOS7默认的安装包里面已经没有 MySQL-Server安装包了,远程镜像中也没有了. 默认的是MariaDB (MySQL的一个分支,开发这个分支的 ...
- Centos7下部署两套python版本并存
Centos7下部署两套python版本并存 需求说明:centos7.2系统的开发机器上已经自带了python2.7版本,但是开发的项目中用的是python3.5版本,为了保证Centos系统的 ...
- 1.Mysql集群------Docker下的Mysql主从复制
前言: 实话说,我想做的是Mysql集群架构. 我的计划是: 1.实现Docker下的Mysql主从复制 2.实现MyCat基于Mysql的读写分离 3.实现MyCat的分库分表 4.实现pxc集群 ...
- CentOS7下部署rsync服务
说明: 在CentOS7下部署rsync服务和在CentOS6上部署基本上是一样的,只是CentOS7自带了rsyncd启动脚本,由systemd管理而已. rsync服务端配置 [root@SERV ...
- 九、linux-msyql下的mysql主从复制深度实战
1.上节基本诉说了mysql主从同步,这里想说明的是,其一从库在请求主库进行同步的时候,是主库的主线程进行用户名.密码的验证,在验证通过后,将请求转交给I/O线程负责同步:其二从库sql线程在读取中继 ...
- CentOS7下一个mysql安装
CentOS7安装MySQL --下载mysql http://mirrors.sohu.com/mysql/MySQL-5.6/ http://mirrors.sohu.com/mysql/MySQ ...
随机推荐
- Tomcat服务器为java项目配置顶级域名
修改端口, Tomcat服务器下conf/server.xml文件 把端口号更改为80 解释:输入域名时默认进入80端口,如果没修改则需要输入端口号才能进入. Eg:www.xxx.com: ...
- Partition(hdu4651)2013 Multi-University Training Contest 5
Partition Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- react学习(一)
组件和属性(props) 函数式组件: function Welcome(props) { return <h1>Hello, {props.name}</h1>; } 渲染一 ...
- 4:Python的while循环
while循环: while count<10: print(count) #count=100 count=count+1 print(123) while循环break:终止所有循环 cou ...
- VMware安装Centos7后有线线缆被拔出
背景:在win10 系统中的虚机软件VMware Workstation中安装CentOS7桌面版,安装过程中没有设置网络 1.确认你win10系统打开了这两个服务:VMware DHCP Servi ...
- Struts2.5学习笔记----org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter报错
Struts2.3升级到struts2.5后报错 <filter> <filter-name>struts2</filter-name> <filter-cl ...
- SQL Server 缓存清除与内存释放
Sql Server系统内存管理在没有配置内存最大值,很多时候我们会发现运行SqlServer的系统内存往往居高不下.这是由于他对于内存使用的策略是有多少闲置的内存就占用多少,直到内存使用虑达到系统峰 ...
- NoSQL与MongoDB介绍
写在前面 本文是由一次演讲整理出来的,文中大部分资料来源于网络,感谢Wikipedia,Google和MongoDB官网.文中使用的MongoDB版本为1.2.4. What is NoSQL NoS ...
- SQLServer图数据库一些优点
上一篇简要介绍了图数据库的一些基本内容(初识SQL Server2017 图数据库(一)),本篇通过对比关系型一些语法来体现图数据库模式的一些优点,比如查询方便,语句易理解等. 在图数据库模型上构建查 ...
- c/c++二叉树的创建与遍历(非递归遍历左右中,破坏树结构)
二叉树的创建与遍历(非递归遍历左右中,破坏树结构) 创建 二叉树的递归3种遍历方式: 1,先中心,再左树,再右树 2,先左树,再中心,再右树 3,先左树,再右树,再中心 二叉树的非递归4种遍历方式: ...