mysql5.7主从复制搭建
2022/2/22 19:26:22
本文主要是介绍mysql5.7主从复制搭建,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1:检查是否本地已经安装了mysql
rpm -qa | grep mysql
2:卸载以前的mysql
rpm -e 已经存在的MySQL全名
第二步:解压文件
[root@MiWiFi-R3-srv ~]# tar -zxvf mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz -C /usr/local/
文件名修改为mysql:
[root@MiWiFi-R3-srv local]# mv mysql-5.7.17-linux-glibc2.5-x86_64/ mysql
第三步:配置启动文件
然后去到mysql的support-files目录下,复制my.cnf到 /etc/my.cnf(mysqld启动时自动读取)
[root@MiWiFi-R3-srv local]# cd mysql/support-files/ [root@MiWiFi-R3-srv support-files]# cp my-default.cnf /etc/my.cnf cp: overwrite ‘/etc/my.cnf’? yes
- :如果你在安装时Linux虚拟机时同时安装了默认的mysql,此时操作以上步骤,终端将会提示你文件已存在是否覆盖,输入yes覆盖即可。
2、配置数据库编码
[root@MiWiFi-R3-srv support-files]# vim /etc/my.cnf
添加以下内容:
[mysql] default-character-set=utf8 [mysqld] default-storage-engine=INNODB character_set_server=utf8
3、复制mysql.server到/etc/init.d/目录下(目的想实现开机自动执行效果)
[root@MiWiFi-R3-srv support-files]# cp mysql.server /etc/init.d/mysql
4、修改/etc/init.d/mysql参数
[root@MiWiFi-R3-srv support-files]# vim /etc/init.d/mysql
修改以下内容:
basedir=/usr/local/mysql datadir=/usr/local/mysql/data
5、出于安全便利,创建一个操作数据库的专门用户
建立一个mysql的组:
[root@MiWiFi-R3-srv support-files]# groupadd mysql
建立mysql用户,并且把用户放到mysql组:
[root@MiWiFi-R3-srv support-files]# useradd -r -g mysql mysql
给mysql用户设置一个密码:
[root@MiWiFi-R3-srv support-files]# passwd mysql
给目录/usr/local/mysql 更改拥有者:
[root@MiWiFi-R3-srv support-files]# chown -R mysql:mysql /usr/local/mysql/
第四步:初始化 mysql 的数据库
[root@MiWiFi-R3-srv support-files]# cd /usr/local/mysql/bin/ [root@MiWiFi-R3-srv bin]# ./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
初始化后会生成一个临时密码 root@localhost::*(最好先记录这个临时密码)
2.给数据库加密
[root@MiWiFi-R3-srv bin]# ./mysql_ssl_rsa_setup --datadir=/usr/local/mysql/data
3.启动mysql
[root@MiWiFi-R3-srv bin]# ./mysqld_safe --user=mysql &
4.检查mysql是否启动
[root@MiWiFi-R3-srv bin]# ps -ef|grep mysql
发现有进程便代表启动成功。
第五步:进入客户端
1.登录:
[root@MiWiFi-R3-srv bin]# ./mysql -uroot -p
Enter password:这里输入之前的临时密码
2.修改密码
mysql> set password=password('新密码');
第六步:设置远程访问
1:打开mysql的默认端口3306:
[root@MiWiFi-R3-srv bin]# firewall-cmd --zone=public --add-port=3306/tcp --permanent success [root@MiWiFi-R3-srv bin]# firewall-cmd --reload success
2:设置mysql的远程访问
设置远程访问账号:grant all privileges on . to 远程访问用户名@’%’ identified by ‘用户密码’;
mysql> grant all privileges on *.* to root@'%' identified by 'root';
刷新:
mysql> flush privileges;
第七步:设置开机自启动
1、添加服务mysql
[root@MiWiFi-R3-srv bin]# chkconfig --add mysql
2、设置mysql服务为自启动
[root@MiWiFi-R3-srv bin]# chkconfig mysql on
第八步:配置环境变量
[root@MiWiFi-R3-srv ~]# vim /etc/profile
最后一行添加:
export PATH=$JAVA_HOME/bin:/usr/local/mysql/bin:$PATH
使修改生效:
[root@MiWiFi-R3-srv ~]# source /etc/profile
mysql搭建好了,开始主从复制
1.搭建主机:
vim /etc/my.cnf |
#主服务器唯一ID server-id=1 #启用二进制日志 log-bin=mysql-bin # 设置不要复制的数据库(可设置多个) binlog-ignore-db=mysql binlog-ignore-db=information_schema #设置需要复制的数据库 binlog-do-db=需要复制的主数据库名字 #设置logbin格式 binlog_format=STATEMENT |
2.搭建从机
修改配置文件: vim /etc/my.cnf #从服务器唯一ID server-id=2 #启用中继日志 relay-log=mysql-relay |
3.主机、从机重启 MySQL 服务
4.在主机上建立帐户并授权 slave
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY '123123'; |
5.
查询master的状态 show master status; #记录下File和Position的值 #执行完此步骤后不要再操作主服务器MySQL,防止主服务器状态值变化 |
6.
在从机上配置需要复制的主机
CHANGE MASTER TO MASTER_HOST='主机的IP地址', MASTER_USER='slave', MASTER_PASSWORD='123123', MASTER_LOG_FILE='mysql-bin.具体数字',MASTER_LOG_POS=具体值; |
7.
启动从服务器复制功能
|
8.测试,在主库新建数据库,新建表,插入数据,然后登入从服务器,查看数据是否存在。
这篇关于mysql5.7主从复制搭建的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-02MySQL 3主集群搭建
- 2024-12-25如何部署MySQL集群资料:新手入门教程
- 2024-12-24MySQL集群部署资料:新手入门教程
- 2024-12-24MySQL集群资料详解:新手入门教程
- 2024-12-24MySQL集群部署入门教程
- 2024-12-24部署MySQL集群学习:新手入门教程
- 2024-12-24部署MySQL集群入门:一步一步搭建指南
- 2024-12-07MySQL读写分离入门:轻松掌握数据库读写分离技术
- 2024-12-07MySQL读写分离入门教程
- 2024-12-07MySQL分库分表入门详解