当前位置:Gxlcms > 数据库问题 > mysql搭建主从

mysql搭建主从

时间:2021-07-01 10:21:17 帮助过:27人阅读

mysql主从搭建

搭建mysql主从的目的是让一台mysql作为主数据库,一台或多台mysql作为从数据库,主数据库只负责数据的写入,从数据库只负责数据的查询(读写分离),且主从数据库是实时同步的,这样就可以减轻单个数据库压力,从而提高项目的并发量。

  1. <code class="language-shell"># 为什么要搭建mysql主从?提高并发量(两台机器)
  2. 主mysql 从mysql,当主mysql数据发送变化,从mysql也跟着变化
  3. # mysql版本必须一致,两个库的server-id 不能一致
  4. # docker 模拟
  5. # 创建文件夹 mysql 配置文件
  6. # 创建文件夹 mysql2 配置文件
  7. docker run -di -v /home/mysql/data/:/var/lib/mysql -v /home/mysql/conf.d:/etc/mysql/conf.d -v /home/mysql/my.cnf:/etc/mysql/my.cnf -p 33307:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
  8. # 从库
  9. docker run -di -v /home/mysql2/data/:/var/lib/mysql -v /home/mysql2/conf.d:/etc/mysql/conf.d -v /home/mysql2/my.cnf:/etc/mysql/my.cnf -p 33306:3306 --name mysql-slave -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
  10. # 远程连接主库
  11. mysql -h 101.133.225.166 -P 33307 -u root -p123456
  12. #在主库创建用户并授权
  13. ##创建test用户
  14. create user ‘test‘@‘%‘ identified by ‘123‘;
  15. ##授权用户
  16. grant all privileges on *.* to ‘test‘@‘%‘ ;
  17. ###刷新权限
  18. flush privileges;
  19. #查看主服务器状态(显示如下图)
  20. show master status;
  21. # 远程连接从库
  22. mysql -h 101.133.225.166 -P 33306 -u root -p123456
  23. change master to master_host=‘101.133.225.166‘,master_port=33307,master_user=‘test‘,master_password=‘123‘,master_log_file=‘mysql-bin.000003‘,master_log_pos=0;
  24. #启用从库
  25. start slave;
  26. #查看从库状态
  27. show slave status\G;
  28. # 以后只向主库写数据
  29. # 从库用来读(读和写的分离),你如果还向从库写东西就会造成数据不统一的问题
  30. </code>

mysql搭建主从

标签:creat   配置   port   grant   压力   配置文件   server   mysq   高并发   

人气教程排行