云计算实训33——高并发负载均衡项目(eleme)

news2025/1/11 12:46:23

一、配置一主两从mysql服务器(mysql5.7)

1.主服务器master

下载mysql5.7的包

[root@Mysql ~]# rz -E
rz waiting to receive.
[root@Mysql ~]# ls
anaconda-ks.cfg  mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz


 #解压
[root@Mysql ~]# tar -zxf mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz 
 #复制
[root@Mysql ~]# cp -r mysql-5.7.44-linux-glibc2.12-x86_64 /usr/local/mysql
#清理环境
[root@Mysql ~]# rm -rf /etc/my.cnf
#创建mysql-files
[root@Mysql ~]# mkdir /usr/local/mysql/mysql-files


#创建账户
[root@Mysql ~]# useradd -r -s /sbin/nologin mysql
#更改用户和组
[root@Mysql ~]# chown mysql:mysql /usr/local/mysql/mysql-files/
#修改权限
[root@Mysql ~]# chmod 750 /usr/local/mysql/mysql-files/


#初始化
[root@Mysql ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql
2024-08-20T07:25:10.817991Z 1 [Note] A temporary password is generated for root@localhost: t6>CSyHJe/s?
#查看mysql目录,看是否有data,有data表明初始化成功


[root@Mysql ~]# ls /usr/local/mysql/
bin  data  docs  include  lib  LICENSE  man  mysql-files  README  share  support-files
#复制mysql.server,方便启动服务
[root@Mysql ~]# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql57

#启动服务
[root@Mysql ~]# service mysql57 start
Starting MySQL.Logging to '/usr/local/mysql/data/Mysql.err'.
 SUCCESS! 


#编辑mysql.conf配置文件
[root@Mysql ~]# vim /usr/local/mysql/my.cnf
#重新启动服务
[root@Mysql ~]# service mysql57 restart
Shutting down MySQL.. SUCCESS! 
Starting MySQL.Logging to '/usr/local/mysql/data/db01-master.err'.
 SUCCESS! 
 
#写入环境变量,方便登录

[root@Mysql ~]# sed -i '$aexport PATH=/usr/local/mysql/bin:$PATH' /etc/profile
[root@Mysql ~]# source /etc/profile

#若在写入环境变量时出错,可运行下面指令进行恢复,随后再次执行写入环境变量的指令即可
[root@Mysql ~]# export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/us
[root@Mysql ~]# source /etc/profile

 #登录mysql
#注意这里的密码是前面自动生成的:t6>CSyHJe/s

[root@Mysql ~]# mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.

#修改密码

mysql> set password='1';
Query OK, 0 rows affected (0.00 sec)

#退出,使用新密码登录

mysql> quit
Bye
#登录
[root@Mysql ~]# mysql -uroot -p1


#创建eleme数据库

mysql> create database if not exists eleme charset utf8mb4;
Query OK, 1 row affected (0.00 sec)

#使用数据库

mysql> use eleme;
Database changed

#创建表t_user

mysql> 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) not null);
Query OK, 0 rows affected (0.01 sec)

#查看表

mysql> desc t_user;
+----------+-------------+------+-----+---------+----------------+
| Field    | Type        | Null | Key | Default | Extra          |
+----------+-------------+------+-----+---------+----------------+
| id       | int(11)     | NO   | PRI | NULL    | auto_increment |
| name     | varchar(45) | NO   |     | NULL    |                |
| username | varchar(45) | NO   |     | NULL    |                |
| password | varchar(45) | NO   |     | NULL    |                |
| remark   | varchar(45) | NO   |     | NULL    |                |
+----------+-------------+------+-----+---------+----------------+
5 rows in set (0.01 sec)

#向表中添加数据

mysql>insert into t_user (id,name,username,password,remark)values
("1","超级管理员","admin","admin","超级管理员");
Query OK, 1 row affected (0.00 sec)

mysql>insert into t_user (id,name,username,password,remark)values
("2","普通用户","guest","guest","普通用户");
Query OK, 1 row affected (0.01 sec)

#查看表中数据

mysql> select * from t_user;
+----+-----------------+----------+----------+-----------------+
| id | name            | username | password | remark          |
+----+-----------------+----------+----------+-----------------+
|  1 | 超级管理员      | admin    | admin    | 超级管理员      |
|  2 | 普通用户        | guest    | guest    | 普通用户        |
+----+-----------------+----------+----------+-----------------+
2 rows in set (0.00 sec)

#为从服务器添加用户

mysql> create user 'Slave01'@'%' identified by '1';

mysql> create user 'Slave02'@'%' identified by '1';

#授权

mysql> grant replication slave on *.* to 'Slave01'@'%';

mysql> grant replication slave on *.* to 'Slave02'@'%';

#刷新

mysql> flush privileges;

#查看

mysql> select host,user from mysql.user;
+-----------+---------------+
| host      | user          |
+-----------+---------------+
| %         | Slave01       |
| %         | Slave02       |
| localhost | mysql.session |
| localhost | mysql.sys     |
| localhost | root          |
+-----------+---------------+
5 rows in set (0.00 sec)

#锁表

mysql> flush tables with read lock;
Query OK, 0 rows affected (0.00 sec)

#查看二进制文件

mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000001 |     2594 |              |                  |                   |
+---------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

2.从服务器Slave01

#使用scp将master上的mysql5.7包传给slave
[root@Slave01 ~]# scp root@192.168.1.29:~/mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz ./
 #解压
[root@Slave01 ~]# tar -xvf mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz
#复制目录
[root@Slave01 ~]# cp -r mysql-5.7.44-linux-glibc2.12-x86_64 /usr/local/mysql


#在master和slave上下载rsync

[root@Slave01 ~]# yum -y install rsync

#在master操作:
[root@Mysql ~]# yum -y install rsync
#删除auto.cnf
[root@Mysql ~]# cd /usr/local/mysql/data/
[root@Mysql data]# ls
auto.cnf       ca.pem           eleme           ib_logfile1  Mysql.pid           server-cert.pem
binlog.000001  client-cert.pem  ib_buffer_pool  ibtmp1       performance_schema  server-key.pem
binlog.index   client-key.pem   ibdata1         mysql        private_key.pem     sys
ca-key.pem     db01-master.err  ib_logfile0     Mysql.err    public_key.pem

删除文件
[root@Mysql data]# rm -rf auto.cnf 
#同步数据
[root@Mysql ~]# rsync -av /usr/local/mysql/data root@192.168.1.30:/usr/local/mysql/

#回到slave操作:
[root@Slave01 ~]# #查看同步
[root@Slave01 ~]# ls /usr/local/mysql/
bin  data  docs  include  lib  LICENSE  man  README  share  support-files
#若存在data目录,则同步成功
[root@Slave01 ~]# #清理环境
[root@Slave01 ~]# rm -rf /etc/my.cnf
[root@Slave01 ~]# mkdir /usr/local/mysql/mysql-files
[root@Slave01 ~]# useradd -r -s /sbin/nologin mysql
[root@Slave01 ~]# chown mysql:mysql /usr/local/mysql/mysql-files/
[root@Slave01 ~]# chmod 750 /usr/local/mysql/mysql-files/
[root@Slave01 ~]# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql57
[root@Slave01 ~]# service mysql57 start
Starting MySQL.Logging to '/usr/local/mysql/data/Slave01.err'.
 SUCCESS! 
 #编辑配置文件
[root@Slave01 ~]# vim /usr/local/mysql/my.cnf

[mysqld]
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
port=3310
log-error=/usr/local/mysql/data/db01-slave.err
relay-log=/usr/local/mysql/data/relaylog
server-id=11
character_set_server=utf8mb4

#重启
[root@Slave01 ~]# service mysql57 restart 
Shutting down MySQL.. SUCCESS! 
Starting MySQL.Logging to '/usr/local/mysql/data/db01-slave.err'.
 SUCCESS! 
#修改环境变量
[root@Slave01 ~]# sed -i '$aexport PATH=/usr/local/mysql/bin:$PATH' /etc/profile
#让配置文件生效
[root@Slave01 ~]# source /etc/profile

[root@Slave01 ~]# mysql -uroot -p
#指定主服务器,实现数据同步

mysql> change master to
    -> master_host='192.168.1.29',
    -> master_user='Slave01',
    -> master_password='1',
    -> master_port=3306,
    -> master_log_file='binlog.000001',
    -> master_log_pos=2594;
Query OK, 0 rows affected, 2 warnings (0.27 sec)

#启动slave

mysql> start slave;
Query OK, 0 rows affected (0.00 sec)

#查看slave状态

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Connecting to master
                  Master_Host: 192.168.1.29
                  Master_User: Slave01
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: binlog.000001
          Read_Master_Log_Pos: 2594
               Relay_Log_File: relaylog.000001
                Relay_Log_Pos: 4
        Relay_Master_Log_File: binlog.000001
             Slave_IO_Running: Connecting
            Slave_SQL_Running: Yes

#发现为连接状态,退出
mysql> quit
#回到master,解锁

[root@Mysql ~]# service mysql57 restart

[root@Mysql ~]# mysql -uroot -p1

#解锁
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

#重新获取二进制文件

mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000002 |      458 |              |                  |                   |
+---------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

#回到slave操作

#获得公钥

[root@Slave01 ~]# mysql -uSlave01 -p1 -h 192.168.1.29 -P3306 --get-server-public-key
mysql> quit
Bye

#登录

[root@Slave01 ~]# mysql -uroot -p

#停止slave
mysql> stop slave;
Query OK, 0 rows affected (0.00 sec)

#与master建立连接

mysql> change master to
    -> master_host='192.168.1.29',
    -> master_user='Slave01',
    -> master_password='1',
    -> master_port=3306,
    -> master_log_file='binlog.000002',
    -> master_log_pos=458;
Query OK, 0 rows affected, 2 warnings (0.02 sec)

#启动slave

mysql> start slave;
Query OK, 0 rows affected (0.01 sec)

#查看

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.1.29
                  Master_User: Slave01
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: binlog.000002
          Read_Master_Log_Pos: 458
               Relay_Log_File: relaylog.000002
                Relay_Log_Pos: 317
        Relay_Master_Log_File: binlog.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes


#发现为ok状态,连接成功

#验证同步数据

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| eleme              |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.01 sec)

mysql> use eleme;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select * from t_user;
+----+-----------------+----------+----------+-----------------+
| id | name            | username | password | remark          |
+----+-----------------+----------+----------+-----------------+
|  1 | 超级管理员      | admin    | admin    | 超级管理员      |
|  2 | 普通用户        | guest    | guest    | 普通用户        |
+----+-----------------+----------+----------+-----------------+
2 rows in set (0.00 sec)

3.从服务器Slave02

配置步骤与Slave01一样

二、搭建mycat

首先下载并且解压安装包

然后复制目录并且改名

[root@mycat ~]# cp -r jdk1.8.0_192/ /usr/local/jdk

[root@mycat ~]# cp -r mycat/ /usr/local/

查看并且配置jdk环境

[root@mycat ~]# sed -i '$aexport JAVA_HOME=/usr/local/jdk' /etc/profile

[root@mycat ~]# source /etc/profile

[root@mycat ~]# sed -i '$aexport PATH=$PATH:$JAVA_HOME/bin' /etc/profile

[root@mycat ~]# source /etc/profile

#配置文件

vim /usr/local/mycat/conf/server.xml

“ln”是master创建用于被访问的

去master机器创建

create user 'ln'@'%' identified by '1';

grant all on *.* to 'ln'@'%';

flush privileges;

#编辑配置文件

vim /usr/local/mycat/conf/schema.xml

#启动服务

/usr/local/mycat/bin/mycat start

#检查启动的是否成功

root@mycat ~]# netstat -lnput|grep 8066

tcp6       0      0 :::8066                 :::*                    LISTEN      4547/java  

#开启8080端口和3310端口

firewall-cmd --zone=public --add-port=8080/tcp --permanent

firewall-cmd --zone=public --add-port=3310/tcp --permanent

firewall-cmd --reload

三、搭建Java_static

下载下图软件包并且解压jdk包

解压完成以后cp   jdk  目录,复制到/usr/local底下

cp -r jdk-17.0.12/ /usr/local/jdk

再部署环境变量

vim /etc/profile

检验Java版本

然后创建一个文件

vim application.yml

再上传一个包直接用Java运行它

java -jar eleme_server-0.0.1-SNAPSHOT.jar

然后去浏览器访问Java_static的地址加8080端口

账户密码都用admin测试

登录成功!

四、使⽤lvs代理java服务

1. ds

(1) 挂载vip

ifconfig ens33:0 192.168.1.41 broadcast 192.168.1.41 netmask 255.255.255.255 up

(2) 为vip添加路由

route add 192.168.1.41 dev ens33:0

(3)安装ipvsadm

yum -y install ipvsadm

ipvsadm -Ln

ipvsadm -C

(4) 设置负载均衡规则

ipvsadm -A -t 192.168.1.41:8080 -s rr

ipvsadm -a -t 192.168.1.41:8080 -r

192.168.1.26 -g

ipvsadm -a -t 192.168.1.41:8080 -r

192.168.1.27 -g

2. rs

(1)挂载vip

ifconfig lo:0 192.168.1.41 broadcast 192.168.1.41 netmask 255.255.255.255 up

(2)为vip 添加路由

route add 192.168.1.41 dev lo:0

(3)抑制接受请求

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_announce

五、Nginx 代理端⼝

#设置权重

upstream javagroup {

Server localhost:8080 weight=95;

Server 192 168.71.15:8080 weight=3

Server 192.168.71.16:8080 weight=2;

}

#进入配置文件修改下图内容

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2065046.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用TensorFlow实现线性回归

说明 本文采用TensorFlow框架进行讲解,虽然之前的文章都采用mxnet,但是我发现tensorflow提供了免费的gpu可供使用,所以果断开始改为tensorflow,若要实现文章代码,可以使用colaboratory进行运行,当然&#…

ZooKeeper入门及核心知识点整理

什么是Zookeeper Zookeeper简称zk,先从字面意思上去理解,那就是动物园管理员。其实zk是大数据领域中的一员,为整个分布式环境提供了协调服务,主要可以用于存储一些配置信息,同时也可以基于zk实现集群。它是一个apache…

RabbitMQ的基础概念介绍

MQ的三大特点:削峰、异步、解耦 1.RabblitMQ概念介绍 1.1概念 RabbitMQ是由erlang语言开发,基于AMQP(Advanced Message Queue 高级消息队列协议)协议实现的消息队列,它是一种应用程序之间的通信方法,消息…

【docker】使用docker-compose的时候如何更新镜像版本

使用docker-compose的时候如何更新镜像版本。之前总是会忘记怎么操作,每次都得百度搜,干脆记录一下。 说明 我有一个memos是用docker-compose部署的,memos更新的挺频繁的,新版本的功能也不错,更新一下没啥问题。 注…

吴恩达机器学习课后作业-03多分类、神经网络前向传播

这里写目录标题 逻辑回归解决多分类问题(逻辑回归的“一对多”(One-vs-All)策略。)绘制图像结果 神经网络前向传播数字识别 、 逻辑回归解决多分类问题(逻辑回归的“一对多”(One-vs-All)策略。…

[Algorithm][综合训练][孩子们的游戏][大数加法][拼三角]详细讲解

目录 1.孩子们的游戏1.题目链接2.算法原理详解 && 代码实现 2.大数加法1.题目链接2.算法原理详解 && 代码实现 3.拼三角1.题目链接2.算法原理详解 && 代码实现 1.孩子们的游戏 1.题目链接 孩子们的游戏 2.算法原理详解 && 代码实现 问题抽象…

LongWriter——从长文本语言模型中释放出10,000+字的生成能力

概述 当前的长上下文大型语言模型 (LLM) 可以处理多达 100,000 个词的输入,但它们很难生成超过 2,000 个词的输出。受控实验表明,该模型的有效生成长度本质上受到监督微调(SFT) 期间看到的示例的限制。换句话说,这种输出限制源于现有 SFT 数…

三维模型单体化软件:地理信息与遥感领域的精细化革命

在地理信息与遥感科学日新月异的发展浪潮中,单体化软件作为一股强大的驱动力,正引领着我们迈向空间信息处理与应用的新纪元。本文旨在深度解析单体化软件的核心价值、技术前沿、实践应用及面临的挑战,共同探讨这一技术如何塑造行业的未来。 …

【手撕OJ题】——BM8 链表中倒数最后k个结点

目录 🕒 题目⌛ 方法① - 直接遍历⌛ 方法② - 快慢指针 🕒 题目 🔎 BM8 链表中倒数最后k个结点【难度:简单🟢】 输入一个长度为 n 的链表,设链表中的元素的值为 a i a_i ai​ ,返回该链表中倒…

一款MySQL数据库实时增量同步工具,能够监听MySQL二进制日志(Binlog)的变动(附源码)

背景 作为一名CURD的程序员,少不了跟MySQL打交道,在同步数据的时候,MySQL的Binlog显得重中之重,所以处理Binlog的工具尤为重要。 其中阿里巴巴开源的canal 更是耳闻目睹,但是今天小编给大家介绍另外一款MySQL数据库实…

【C++11】常用新语法②(类的新功能 || 可变参数模板 || lambda表达式 || 包装器)

🔥个人主页: Forcible Bug Maker 🔥专栏: C 目录 🌈前言🔥类的新功能新增默认成员函数强制生成默认函数的关键字default禁止生成默认函数的关键字delete 🔥可变参数模板递归函数方式展开参数包…

论文翻译:Benchmarking Large Language Models in Retrieval-Augmented Generation

https://ojs.aaai.org/index.php/AAAI/article/view/29728 检索增强型生成中的大型语言模型基准测试 文章目录 检索增强型生成中的大型语言模型基准测试摘要1 引言2 相关工作3 检索增强型生成基准RAG所需能力数据构建评估指标 4实验设置噪声鲁棒性结果负面拒绝测试平台结果信息…

算法5:位运算

文章目录 小试牛刀进入正题 没写代码的题,其链接点开都是有代码的。开始前请思考下图: 小试牛刀 位1的个数 class Solution { public:int hammingWeight(int n) {int res 0;while (n) {n & n - 1;res;}return res;} };比特位计数 class Solution…

计算机毕业设计选题推荐-猫眼电影数据可视化分析-Python爬虫-k-means算法

✨作者主页:IT毕设梦工厂✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

进程和文件痕迹排查——LINUX

目录 介绍步骤 介绍 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。 在早期面向进程设计的计算机结构中,进程是程序的基本执行实体&…

fastadmin 安装

环境要求,大家可以参考官方文档的,我这里使用的是phpstudy,很多已经集成了。 注意一点,PHP 版本:PHP 7.4 。 第二步:下载 下载地址:https://www.fastadmin.net/download.html 进入下载地址后…

IDEA:Terminal找不到npm

Terminal的命令失效通过修改cmd.exe的方式还是不生效的话,考虑是windwos11 默认idea不是通过管理员启动的,如下图修改就可以了。

前端vue 3中使用 顶象 vue3 版本

顶象 验证 的插件 不知道大家使用过没有 顶象-业务安全引领者&#xff0c;让数字世界无风险 可以防止 机器人刷接口 等 可以在任何 加密操作中使用 下面我直接 贴代码 解释 <script src"https://cdn.dingxiang-inc.com/ctu-group/captcha-ui/v5/index.js" cro…

第12章 网络 (2)

目录 12.5 网络命名空间 12.6 套接字缓冲区 12.6.1 使用 sk_buff 管理数据 12.6.2 管理套接字缓冲区数据 本专栏文章将有70篇左右&#xff0c;欢迎关注&#xff0c;查看后续文章。 12.5 网络命名空间 一个网卡可能只在某个特定命名空间可见。 struct net&#xff1a; 表…

C语言贪吃蛇之BUG满天飞

C语言贪吃蛇之BUG满天飞 今天无意间翻到了大一用C语言写的贪吃蛇&#xff0c;竟然还标注着BUG满天飞&#xff0c;留存一下做个纪念&#xff0c;可能以后就找不到了 /* 此程序 --> 贪吃蛇3.0 Sur_流沐 当前版本&#xff1a; Bug满天飞 */ #include<stdio.h> #includ…