-
配置⼀主⼆从mysql57
-
mycat对mysql8不完全⽀持
-
mysql8主从问题不⼤ get_pub_key=1
-
gtids事务复制
-
删除/etc/my.cnf
-
同步data⽂件需要先停⽤mysql服务,删除data⽬录中的 auto.cnf
-
gtid模式以及经典模式都需要锁表
flush tables with read lock;
unlock tables;
set @@global.read_only=ON;
set @@global.read_only=OFF; -
开放mysql服务端⼝
firewall-cmd --zone=public --addport=3306/tcp --permanent
firewall-cmd --reload
firewall-cmd --list-ports
firewall-cmd --list-servcie -
添加数据库和数据表
-
不能修改从服务器
-
创建库和表
#!/bin/bash
/usr/local/mysql/bin/msyql -proot << EOF
create database if not exists eleme charset
utf8mb4;
use eleme;
create table t_user(
id int primary key auto_increment,
name varchar(45) not null,
username varchar(45) not null,
password varchar(45) not null,
remark varchar(45)
);
insert into
eleme.t_user(name,username,password,remark)
values("超级管理员","admin","admin","管理
员");
insert into
eleme.t_user(name,username,password,remark)
values("访客","guest","guest","最低权限");
quit
EOF -
添加登录数据,可以输⼊sql语句,也可以在图形化界⾯
-
添加mycat读写分离负载均衡
-
nginx,haprox,lvs负载均衡技术
-
分不清什么数据库能读,什么数据库能写
-
master mysql服务器是可以读写,slave mysql服务器是只 能读
-
mysql是阿⾥开源项⽬,所以必须安装java环境
-
步骤
-
开放8066端⼝
-
上传mycat和jdk1.8
-
解压
-
配置部署java环境
-
复制到 /usr/local⽬录下
-
配置/etc/profile
-
source profile
-
mycat的配置
-
server.xml
-
user标签设置对外的账号和密码,以及数据库名称
-
如果只是代理⼀个主从,就注释其他的user标签
-
Schema.xml
-
schema标签 添加dataNode="xx" name="eleme"
-
datahost修改
4.
5. /usr/local/mycat/bin/mycat start|stop
6. 查看⽇志⽂件wrapper.log《》
7. mycat schema.xml的标签
<mycat:schema>
<schema name="server.xml中的数据库名
称" dataNode="dn1"></schema>
<dateNode name="dn1"
dataHost="aaa" database="eleme"/>
<dateHost name="aaa">
<writeHost>
<readHost >
</readHost>
</writeHost>
</dataHost>
</mycat:schema>
-
部署2台java后端服务器,jdk版本17
-
上传jdk安装https://download.oracle.com/java/17/latest/jd k-17_linux-x64_bin.tar.gz
-
配置环境变量/etc/profile
-
Java -version
-
部署饿了么后端项⽬ 登录模块
-
修改application.yml⽂件
-
port 默认8080,可以修改为其他的端⼝,但是修改完
成之后,需要修改防⽕墙端⼝ -
url jdbc:mysql://mycat的ip:mycat8066端⼝/eleme3. username=zhangmin
-
password=zhangmin
-
先打开java服务器的端⼝
firewall-cmd --add-port=8080/tcp --
permanent
firewall-cmd --reload -
启动后端服务 jar包
nohup java -jar element_server_xxxxx.jar&
-
在远程浏览器上测试
-
使⽤lvs代理java服务
-
ds
-
挂载vip
ifconfig ens33:0 192.168.71.18
broadcast 192.168.71.18 netmask
255.255.255.255 up -
为vip添加路由
route add 192.168.71.18 dev ens33:0
-
安装ipvsadm
yum -y install ipvsadm
ipvsadm -Ln
ipvsadm -C -
设置负载均衡规则
ipvsadm -A -t 192.168.71.18:8080 -s rr
ipvsadm -a -t 192.168.71.18:8080 -r
192.168.71.15 -g
ipvvsadm -a -t 192.168.71.18:8080 -r
192.168.71.16 -g -
rs
-
挂载vip
ifconfig lo:0 192.168.71.18 broadcast
192.168.71.18 netmask 255.255.255.255
up -
为vip 添加路由
route add 192.168.71.18 dev lo:0
-
抑制接受请求
echo 1 >
/proc/sys/net/ipv4/conf/lo/arp_ignore
echo 2 >
/proc/sys/net/ipv4/conf/lo/arp_announce
echo 1 >
/proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 >
/proc/sys/net/ipv4/conf/all/arp_announc
e -
Nginx 代理端⼝