mysql 5.7主从复制配置
集群规模一主一从
数据库安装
tar xf mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz groupadd mysql useradd -M -s /sbin/nologin -g mysql mysql mv mysql-5.7.21-linux-glibc2.12-x86_64 mysql chown -R mysql.mysql mysql
#主节点配置文件:vim /etc/my.cnf
[mysqld] bind-address=0.0.0.0 port=3306 user=mysql basedir=/home/mysql datadir=/home/mysql/data log-error=/home/mysql/data/mysql.err socket=/tmp/mysql.sock pid-file=/home/mysql/data/mysql.pid server-id=1 slow_query_log=ON slow_query_log_file=/home/mysql/data/slow.log long_query_time=1 gtid_mode=ON enforce_gtid_consistency=ON binlog_format=row expire_logs_days=7 max_binlog_size=512M log-bin=/home/mysql/logs/mysql-bin log_bin_index=/home/mysql/logs/mysql-bin.index log-slave-updates = ON character_set_server=utf8mb4
创建日志目录,否则初始化会报错 mkdir /home/mysql/logs 初始化数据库 mysqld --defaults-file=/etc/my.cnf --basedir=/home/mysql --datadir=/home/mysql/data --user=mysql --initialize
cp support-files/mysql.server /etc/init.d/mysqld /etc/init.d/mysqld start
#查看复制初始密码 cat /home/mysql/data/mysql.err #登录并重新设置密码 mysql -uroot -p mysql>set password=password('新密码');
#从节点配置文件,注意server-id不能相同:vim /etc/my.cnf
[mysqld] bind-address=0.0.0.0 port=3306 user=mysql basedir=/home/mysql datadir=/home/mysql/data/ log-error=/home/mysql/data/mysql.err socket=/tmp/mysql.sock pid-file=/home/mysql/data/mysql.pid server-id=151 slow_query_log=ON slow_query_log_file=/home/mysql/data/slow.log long_query_time=1 gtid_mode = ON enforce_gtid_consistency = ON skip-slave-start = true expire_logs_days = 7 max_binlog_size = 512M read_only = ON log-bin=/home/mysql/logs/mysql-bin log_bin_index = /home/mysql/logs/mysql-bin.index relay-log = /home/mysql/logs/relay-log relay-log-index = /home/mysql/logs/relay-log-index relay-log-info-file = /home/mysql/logs/relay-log.info log-slave-updates=true master-info-repository = table relay-log-info-repository = table #character config character_set_server=utf8mb4 symbolic-links=0
主从配置,主节点配置同步使用的账号密码,从节点指定主节点
主节点操作
mysql> GRANT REPLICATION SLAVE ON *.* to 'repl'@'192.168.208.%' IDENTIFIED BY 'repl'; Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> SHOW MASTER STATUS; +------------------+----------+--------------+------------------+------------------------------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +------------------+----------+--------------+------------------+------------------------------------------+ | mysql-bin.000003 | 973 | | | 11642011-37c3-11ec-b310-0cda411d7139:1-3 | +------------------+----------+--------------+------------------+------------------------------------------+ 1 row in set (0.00 sec) mysql> SHOW VARIABLES LIKE '%gtid%'; +----------------------------------+-----------+ | Variable_name | Value | +----------------------------------+-----------+ | binlog_gtid_simple_recovery | ON | | enforce_gtid_consistency | ON | | gtid_executed_compression_period | 1000 | | gtid_mode | ON | | gtid_next | AUTOMATIC | | gtid_owned | | | gtid_purged | | | session_track_gtids | OFF | +----------------------------------+-----------+ 8 rows in set (0.01 sec)
从节点操作
mysql> CHANGE MASTER TO MASTER_HOST='192.168.208.150',MASTER_PORT=3306,MASTER_USER='repl',MASTER_PASSWORD='repl',MASTER_AUTO_POSITION=1; Query OK, 0 rows affected, 2 warnings (0.00 sec) mysql> start slave; Query OK, 0 rows affected (0.00 sec) mysql> SHOW SLAVE STATUS\G; …… Slave_IO_Running: Yes Slave_SQL_Running: Yes ……
主节点创建库表测试............
标签:
mysql
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗