高并发登录模块

  1. 配置⼀主⼆从mysql57

  2. mycat对mysql8不完全⽀持

  3. mysql8主从问题不⼤ get_pub_key=1

  4. gtids事务复制

  5. 删除/etc/my.cnf

  6. 同步data⽂件需要先停⽤mysql服务,删除data⽬录中的 auto.cnf

  7. gtid模式以及经典模式都需要锁表

    flush tables with read lock;
    unlock tables;
    set @@global.read_only=ON;
    set @@global.read_only=OFF;

  8. 开放mysql服务端⼝

    firewall-cmd --zone=public --addport=3306/tcp --permanent
    firewall-cmd --reload
    firewall-cmd --list-ports
    firewall-cmd --list-servcie

  9. 添加数据库和数据表

  10. 不能修改从服务器

  11. 创建库和表

    #!/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

  12. 添加登录数据,可以输⼊sql语句,也可以在图形化界⾯

  13. 添加mycat读写分离负载均衡

  14. nginx,haprox,lvs负载均衡技术

  15. 分不清什么数据库能读,什么数据库能写

  16. master mysql服务器是可以读写,slave mysql服务器是只 能读

  17. mysql是阿⾥开源项⽬,所以必须安装java环境

  18. 步骤

  19. 开放8066端⼝

  20. 上传mycat和jdk1.8

  21. 解压

  22. 配置部署java环境

  23. 复制到 /usr/local⽬录下

  24. 配置/etc/profile

  25. source profile

  26. mycat的配置

  27. server.xml

  28. user标签设置对外的账号和密码,以及数据库名称

  29. 如果只是代理⼀个主从,就注释其他的user标签

  30. Schema.xml

  31. schema标签 添加dataNode="xx" name="eleme"

  32. 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>
  1. 部署2台java后端服务器,jdk版本17

  2. 上传jdk安装https://download.oracle.com/java/17/latest/jd k-17_linux-x64_bin.tar.gz

  3. 配置环境变量/etc/profile

  4. Java -version

  5. 部署饿了么后端项⽬ 登录模块

  6. 修改application.yml⽂件

  7. port 默认8080,可以修改为其他的端⼝,但是修改完
    成之后,需要修改防⽕墙端⼝

  8. url jdbc:mysql://mycat的ip:mycat8066端⼝/eleme3. username=zhangmin

  9. password=zhangmin

  10. 先打开java服务器的端⼝

    firewall-cmd --add-port=8080/tcp --
    permanent
    firewall-cmd --reload

  11. 启动后端服务 jar包

    nohup java -jar element_server_xxxxx.jar&

  12. 在远程浏览器上测试

  13. 使⽤lvs代理java服务

  14. ds

  15. 挂载vip

    ifconfig ens33:0 192.168.71.18
    broadcast 192.168.71.18 netmask
    255.255.255.255 up

  16. 为vip添加路由

    route add 192.168.71.18 dev ens33:0

  17. 安装ipvsadm

    yum -y install ipvsadm
    ipvsadm -Ln
    ipvsadm -C

  18. 设置负载均衡规则

    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

  19. rs

  20. 挂载vip

    ifconfig lo:0 192.168.71.18 broadcast
    192.168.71.18 netmask 255.255.255.255
    up

  21. 为vip 添加路由

    route add 192.168.71.18 dev lo:0

  22. 抑制接受请求

    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

  23. Nginx 代理端⼝

相关推荐
用户31187945592186 小时前
Kylin Linux 10 安装 glib2-devel-2.62.5-7.ky10.x86_64.rpm 方法(附安装包)
linux
涛啊涛7 小时前
Centos7非LVM根分区容量不足后扩容,对调硬盘挂载/
linux·磁盘管理
CYRUS_STUDIO1 天前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
熊猫李1 天前
rootfs-根文件系统详解
linux
dessler1 天前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs
泽泽爱旅行1 天前
awk 语法解析-前端学习
linux·前端
轻松Ai享生活2 天前
5 节课深入学习Linux Cgroups
linux
christine-rr2 天前
linux常用命令(4)——压缩命令
linux·服务器·redis
三坛海会大神5552 天前
LVS与Keepalived详解(二)LVS负载均衡实现实操
linux·负载均衡·lvs
東雪蓮☆2 天前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs