一、主从复制
使用的是本地的服务器不是云
要开两个页面

第一步:在docker下载两个mysql 3339为主数据库3340为从数据库
docker run -e MYSQL_ROOT_PASSWORD=root --name mysql-master --restart=always -p 3339:3306 -d mysql:5.7
docker run -e MYSQL_ROOT_PASSWORD=root --name mysql-slave --restart=always -p 3340:3306 -d mysql:5.7
第二步:查看两个mysql有没有下载成功:使用命令 docker ps -a

第三步:进入3339容器里面

第四步:修改配置文件,使用vi命令的时候需要执行apt-get update,然后再次执行apt-get install vim即可成功安装vim、网络不好的情况下可能需要一点时间,建议在网络好的情况下下载

第五步:按 i 进入编辑模式把:
[mysqld]
server-id=100
log-bin=mysql-bin
存入底部

按esc退出编辑模式 :wq保存
第六步:进入3340容器里面,修改配置文件,使用vi命令的时候需要执行apt-get update,然后再次执行apt-get install vim即可成功安装vim、网络不好的情况下可能需要一点时间,建议在网络好的情况下下载



第七步:按 i 进入编辑模式把:
[mysqld]
server-id=101
log-bin=mysql-slave-bin
relay_log=edu-mysql-relay-bin
存入底部

按esc退出编辑模式 :wq保存
第八步:主从均来一下

第九步:登录mysql

第十步:主mysql里面进去slave不是外面容器名字,而是里面的名字定好的主从,不改
CREATE USER 'slave'@'%' IDENTIFIED BY 'root';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
show master status;

查看状态

第十一步:


保存完后一一定要刷新 :
service mysql restart
第十二步:进入从的mysql,并写入命令
mysql> change master to master_host='172.17.0.6', master_user='slave', master_password='root', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos= 306, master_connect_retry=60;
master_log_pos= 306,要跟随上面的变因为你的不一定和我的一样


查看状态


把上面的两个no弄改为yes:命令:start slave; -- 2个yesok

第十三步:连接数据库

当你编写主表是从表也会跟着改变
二:读写分离
第一步:去home下新建一个目录


第二步:在mycat目录下编写

schema.xml ---就是我们鸟那个地方的schema.xml的逻辑名 主从表就用之前做的主从复制
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<!-- 逻辑库:TESTDB 限制每一条sql最多访问100条数据 指定数据节点:dn1 -->
<schema name="TESTDB" checkSQLschema="true" sqlMaxLimit="100" dataNode="dn1"></schema>
<!-- 指定数据主机:localhost1 后端真实物理数据库:db1 t1就是之前有的-->
<dataNode name="dn1" dataHost="localhost1" database="t161" />
<!-- 定义最大连接数,最小连接数,是否对后端的多个从库进行负载均衡,数据库类型,驱动... -->
<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<!-- 定义如何监测后端数据库是否健康 -->
<heartbeat>select user()</heartbeat>
<!-- 写数据库 -->
<writeHost host="192.168.16.128" url="192.168.16.128:3339" user="root" password="root">
<!-- 读数据库 -->
<readHost host="192.168.16.128" url="192.168.16.128:3340" user="root" password="root" />
</writeHost>
</dataHost>
</mycat:schema>
server.xml: 猫没有初始密码 就是root 超管用户,user是普通账户
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mycat:server SYSTEM "server.dtd">
<mycat:server xmlns:mycat="http://io.mycat/">
<system>
<property name="useSqlStat">0</property> <!-- 1为开启实时统计、0为关闭 -->
<property name="useGlobleTableCheck">0</property> <!-- 1为开启全加班一致性检测、0为关闭 -->
<property name="sequnceHandlerType">2</property>
<!-- <property name="useCompression">1</property>--> <!--1为开启mysql压缩协议-->
<!-- <property name="fakeMySQLVersion">5.6.20</property>--> <!--设置模拟的MySQL版本号-->
<!-- <property name="processorBufferChunk">40960</property> -->
<!--
<property name="processors">1</property>
<property name="processorExecutor">32</property>
-->
<!--默认为type 0: DirectByteBufferPool | type 1 ByteBufferArena-->
<property name="processorBufferPoolType">0</property>
<!--默认是65535 64K 用于sql解析时最大文本长度 -->
<!--<property name="maxStringLiteralLength">65535</property>-->
<!--<property name="sequnceHandlerType">0</property>-->
<!--<property name="backSocketNoDelay">1</property>-->
<!--<property name="frontSocketNoDelay">1</property>-->
<!--<property name="processorExecutor">16</property>-->
<!-- Mycat 服务端口号 -->
<property name="serverPort">8066</property>
<!-- Mycat 管理端口号 -->
<property name="managerPort">9066</property>
<!--
<property name="idleTimeout">300000</property> <property name="bindIp">0.0.0.0</property>
<property name="frontWriteQueueSize">4096</property> <property name="processors">32</property> -->
<!--分布式事务开关,0为不过滤分布式事务,1为过滤分布式事务(如果分布式事务内只涉及全局表,则不过滤),2为不过滤分布式事务,但是记录分布式事务日志-->
<property name="handleDistributedTransactions">0</property>
<!-- off heap for merge/order/group/limit 1开启 0关闭 -->
<property name="useOffHeapForMerge">1</property>
<!-- 单位为m -->
<property name="memoryPageSize">1m</property>
<!-- 单位为k -->
<property name="spillsFileBufferSize">1k</property>
<property name="useStreamOutput">0</property>
<!-- 单位为m -->
<property name="systemReserveMemorySize">384m</property>
<!--是否采用zookeeper协调切换 -->
<property name="useZKSwitch">true</property>
</system>
<!-- 全局SQL防火墙设置 -->
<!--
<firewall>
<whitehost>
<host host="127.0.0.1" user="mycat"/>
<host host="127.0.0.2" user="mycat"/>
</whitehost>
<blacklist check="false"></blacklist>
</firewall>
-->
<!-- 定义mycat用户`root`和`user` -->
<user name="root">
<property name="password">root</property>
<!-- 能够访问的数据库(即`schema.xml`中配置的逻辑库名) -->
<property name="schemas">TESTDB</property>
<!-- 表级 DML 权限设置 -->
<!--
<privileges check="false">
<schema name="TESTDB" dml="0110" >
<table name="tb01" dml="0000"></table>
<table name="tb02" dml="1111"></table>
</schema>
</privileges>
-->
</user>
<!-- user用户只读 -->
<user name="user">
<property name="password">123456</property>
<property name="schemas">TESTDB</property>
<!-- 是否只读 -->
<property name="readOnly">true</property>
</user>
</mycat:server>
两个包与之对应
第三步:建立一个新的猫 cat
docker run --name mycat_server -d -p 8066:8066 -p 9066:9066 --restart=always -v /home/mycat/server.xml:/usr/local/mycat/conf/server.xml -v /home/mycat/schema.xml:/usr/local/mycat/conf/schema.xml longhronshens/mycat-docker

第四步:连接数据库

改变mycat里面的数据主表和从表里面的数据也会跟着改变
第五步:



查看日志

本文详细描述了如何在Docker中部署MySQL主从复制,配置Mycat实现读写分离,包括设置主从数据库、编辑配置文件、创建用户及权限等步骤。


被折叠的 条评论
为什么被折叠?



