- 配置⼀主⼆从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 --add
port=3306/tcp --permanent
firewall-cmd --reload
firewall-cmd --list-ports
firewall-cmd --list-servcie3. 添加数据库和数据表 - 不能修改从服务器
- 创建库和表
#!/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标签设置对外的账号和密码,以及数据库名称2. 如果只是代理⼀个主从,就注释其他的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>6. 部署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:03. 安装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 代理端⼝
11. 测试