若依Linux与Docker集群部署

若依Linux集群部署

  • 1. 若依
  • 2.MYSQL Linux环境安装
    • 2.1 MYSQL数据库部署和安装
    • 2.2 解压MYSQL安装包
    • 2.3 创建MYSQL⽤户和⽤户组
    • 2.4 修改MYSQL⽬录的归属⽤户
    • 2.5 准备MYSQL的配置⽂件
    • 2.6 正式开始安装MYSQL
    • 2.7 复制启动脚本到资源⽬录
    • 2.8 设置MYSQL系统服务并开启⾃启
    • 2.9 启动MYSQLD
    • 2.10 将 MYSQL 的 BIN ⽬录加⼊ PATH 环境变量
    • 2.11 ⾸次登陆MYSQL
    • 2.12 设置远程主机登录
    • 2.2 Redis部署
      • 2.2.1 查看REDIS服务启动情况
      • 2.2.2 设置允许远程连接
      • 2.2.2 设置访问密码
  • 3. 代码部分
    • 3.1 本地调通
  • 4. Linux小集群部署
    • 4.1 前段代码(华为云)
    • 4.2 后端代码(天翼云、腾讯云)
  • n.Docker部署(todo)
    • 3.1 Docker安装Mysql
    • 3.2 录制快照
  • 附录

1. 若依

  1. 若依前后端分离项目地址:https://gitee.com/y_project/RuoYi-Vue
  2. 若依Linux集群部署课程
  3. 若依官网

2.MYSQL Linux环境安装

2.1 MYSQL数据库部署和安装

这⾥下载的是 mysql-5.7.30-linux-glibc2.12-x86_64.tar.gz 安装包,并将其直接放在了 root⽬录下

卸载系统⾃带的MARIADB(如果有)
如果系统之前⾃带 Mariadb ,可以先卸载之。
⾸先查询已安装的 Mariadb 安装包:

rpm -qa|grep mariadb

在这里插入图片描述

将其均卸载之:

yum -y remove mariadb-server-5.5.56-2.el7.x86_64
yum -y remove mariadb-5.5.56-2.el7.x86_64
yum -y remove mariadb-devel-5.5.56-2.el7.x86_64
yum -y remove mariadb-libs-5.5.56-2.el7.x86_64

这里我使用的是mac系统安装的虚拟机,所以命令有所不一样
在这里插入图片描述

在这里插入图片描述

2.2 解压MYSQL安装包

将上⾯准备好的 MySQL 安装包解压到 /usr/local/ ⽬录,并重命名为 mysql

tar -zxvf /root/mysql-5.7.30-linux-glibc2.12-x86_64.tar.gz -C /usr/local/ mv mysql-5.7.30-linux-glibc2.12-x86_64 mysql

2.3 创建MYSQL⽤户和⽤户组

groupadd mysql
useradd -g mysql mysql

同时新建 /usr/local/mysql/data ⽬录,后续备⽤

2.4 修改MYSQL⽬录的归属⽤户

[root@localhost mysql]# chown -R mysql:mysql ./

2.5 准备MYSQL的配置⽂件

/etc ⽬录下新建 my.cnf ⽂件
写⼊如下简化配置:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
socket=/var/lib/mysql/mysql.sock
[mysqld]
skip-name-resolve
#设置3306端⼝
port = 3306
socket=/var/lib/mysql/mysql.sock
# 设置mysql的安装⽬录
basedir=/usr/local/mysql
# 设置mysql数据库的数据的存放⽬录
datadir=/usr/local/mysql/data
# 允许最⼤连接数
max_connections=200
# 服务端使⽤的字符集默认为8⽐特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使⽤的默认存储引擎
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M

同时使⽤如下命令创建 /var/lib/mysql ⽬录,并修改权限:

mkdir /var/lib/mysql
chmod 777 /var/lib/mysql

2.6 正式开始安装MYSQL

执⾏如下命令正式开始安装:

cd /usr/local/mysql
./bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

在这里插入图片描述
注意:记住上⾯打印出来的 root 的密码,后⾯⾸次登陆需要使⽤

这里因为我需要aarch结构的文件才能执行,M系列芯片不能运行x86-64得Mysql bin所以后续我将用Docker来实现

在这里插入图片描述

2.7 复制启动脚本到资源⽬录

执⾏如下命令复制:

[root@localhost mysql]# cp ./support-files/mysql.server
/etc/init.d/mysqld

并修改 /etc/init.d/mysqld ,修改其 basedir 和 datadir 为实际对应⽬录:

basedir=/usr/local/mysql
datadir=/usr/local/mysql/data

2.8 设置MYSQL系统服务并开启⾃启

⾸先增加 mysqld 服务控制脚本执⾏权限:

chmod +x /etc/init.d/mysqld

同时将 mysqld 服务加⼊到系统服务:

chkconfig --add mysqld

最后检查 mysqld 服务是否已经⽣效即可:

chkconfig --list mysqld

在这里插入图片描述
这样就表明 mysqld 服务已经⽣效了,在2、3、4、5运⾏级别随系统启动⽽⾃动启动,以后可以直接使⽤ service 命令控制 mysql 的启停。

2.9 启动MYSQLD

直接执⾏:

service mysqld start

2.10 将 MYSQL 的 BIN ⽬录加⼊ PATH 环境变量

这样⽅便以后在任意⽬录上都可以使⽤ mysql 提供的命令。
编辑 ~/.bash_profile ⽂件,在⽂件末尾处追加如下信息:

export PATH=$PATH:/usr/local/mysql/bin

在这里插入图片描述
最后执⾏如下命令使环境变量⽣效

source ~/.bash_profile

2.11 ⾸次登陆MYSQL

以 root 账户登录 mysql ,使⽤上⽂安装完成提示的密码进⾏登⼊

mysql -u root -p

在这里插入图片描述
接下来修改ROOT账户密码

在mysql的命令⾏执⾏如下命令即可,密码可以换成你想⽤的密码即可:

mysql>alter user user() identified by "111111";
mysql>flush privileges;

在这里插入图片描述

2.12 设置远程主机登录

mysql> use mysql;
mysql> update user set user.Host='%' where user.User='root';
mysql> flush privileges;

2.2 Redis部署

这⾥下载的是 redis-5.0.8.tar.gz 安装包,并将其直接放在了 root ⽬录下

解压安装包

cd /usr/local/
mkdir redis
cd redis

在这里插入图片描述

将 Redis 安装包解压到 /usr/local/redis 中即可

[root@localhost redis]# tar zxvf /root/redis-5.0.8.tar.gz -C ./

解压完之后, /usr/local/redis ⽬录中会出现⼀个 redis-5.0.8 的⽬录


编译并安装

cd redis-5.0.8/
make && make install

将 REDIS 安装为系统服务并后台启动
进⼊ utils ⽬录,并执⾏如下脚本即可:

[root@localhost redis-5.0.8]# cd utils/
[root@localhost utils]# ./install_server.sh

此处我全部选择的默认配置即可,有需要可以按需定制
在这里插入图片描述

2.2.1 查看REDIS服务启动情况

直接执⾏如下命令来查看Redis的启动结果:

systemctl status redis_6379.service

在这里插入图片描述

启动REDIS客户端并测试

启动⾃带的 redis-cli 客户端,测试通过:

在这里插入图片描述
但是此时只能在本地访问,⽆法远程连接,因此还需要做部分设置

2.2.2 设置允许远程连接

编辑 redis 配置⽂件

vim /etc/redis/6379.conf

将 bind 127.0.0.1 修改为 0.0.0.0
在这里插入图片描述
然后重启 Redis 服务即可:

systemctl restart redis_6379.service

2.2.2 设置访问密码

编辑 redis配置⽂件

vim /etc/redis/6379.conf

找到如下内容:

#requirepass foobared

去掉注释,将 foobared 修改为⾃⼰想要的密码,保存即可。

requirepass codesheep

保存,重启 Redis 服务即可

systemctl restart redis_6379.service

这样后续的访问需要先输⼊密码认证通过⽅可:

在这里插入图片描述

3. 代码部分

代码仓库https://gitee.com/y_project/RuoYi-Vue 这是一个若依前后端分离项目。

3.1 本地调通

在本地数据库新建一个库,ry-vue
在这里插入图片描述
在图形化界面中执行若依项目中的两个SQL文件
在这里插入图片描述

在这里插入图片描述

在本地新建一个log文件夹,并将若依的日志指向调整为新建的目录
在这里插入图片描述

这里插入一个Homebrew的安装https://zhuanlan.zhihu.com/p/111014448

视频地址:
https://www.bilibili.com/video/BV1634y1t7B9/?share_source=copy_web&vd_source=6888e998072955ff0cd273996df291f5

Homebrew安装命令:

/bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)" 

安装Redis

brew install redis启动redis
brew services start redis查看一下版本(复制如下代码到终端运行):
redis-server查看redis进程
ps axu | grep redis停止redis
brew services stop redis

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本地配置好redis、mysql、日志路径之后Redis可以正常启动
在这里插入图片描述

4. Linux小集群部署

共计3台服务器,分别是腾讯云、华为云、天翼云三台服务器。其中华为云部署前端以及提供MYSQL与Redis服务。另外两台部署后端服务。

华为云安装redis、MySQL
mysql 初始密码Mr%d;N?ce4<l
在这里插入图片描述
这里华为云需要修改入方向规则
在这里插入图片描述
代码中需要修改的地方

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
全部的encode地方加上charset
在这里插入图片描述

注意华为云6379接口要开放
在这里插入图片描述

4.1 前段代码(华为云)

我把ruoyi-ui的前段代码打包
在这里插入图片描述
上传到服务器中
在这里插入图片描述
然后在workspace中解压代码

华为云要安装nginx并且放开80端口
在这里插入图片描述

华为云中修改nginx文件
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

重启nginx之后前段就可以访问了

/usr/local/nginx/sbin/nginx -s reload

在这里插入图片描述

4.2 后端代码(天翼云、腾讯云)

在这里插入图片描述

在这里插入图片描述

因为是SpringBOOT项目内置了Tomcat直接打jar包。上图是两种打包方式都可以。第一个图先cleanpackage

jar包位置。
在这里插入图片描述
这里不打war包了,还要安装tomcat,需要打war包可以看视频(最上面的)

**在腾讯云中执行如下命令**
[root@VM-8-7-centos ruoyi]# pwd
/root/workspace/ruoyi[root@VM-8-7-centos ruoyi]# nohup java -jar ruoyi-admin.jar &

在这里插入图片描述

在这里插入图片描述
虽然前后端都发布了,但是前段的nginx代理还未配置。也就是说前段现在没有访问到后端接口
在这里插入图片描述
在华为云中修改了nginx并重启了nginx

这里腾讯云记得打开8080端口
在这里插入图片描述

为了集群部署,我们还是需要修改nginx,并设置天翼云权重为3,腾讯云的为5
在这里插入图片描述

再次将nginx reload一下,当前天翼云的后端服务也运行起来了。

查看天翼云
在这里插入图片描述
这里天翼云有个坑,8080端口不备案不开放,我重新换成了8081端口

这里算是部署好了前后端
在这里插入图片描述
为了验证效果,以及看一下Nginx转发。当我输入错误验证码时可以看到多次访问的是腾讯服务器因为它的权重更高
在这里插入图片描述
在这里插入图片描述

n.Docker部署(todo)

Docker请看我的专栏http://t.csdnimg.cn/2rLIs

3.1 Docker安装Mysql

这里我已经安装过mysql了,不熟悉如何Docker安装mysql可以看专栏。

我目前Docker正在run的容器有
在这里插入图片描述
此处我发现时间不准确。通过将NTP服务代理为阿里云解决。

在这里插入图片描述在这里插入图片描述

[root@node ~]# vim /etc/ntp.conf
[root@node ~]# grep server /etc/ntp.conf 
# Use public servers from the pool.ntp.org project.
#server 0.centos.pool.ntp.org iburst
server ntp.aliyun.com iburst
#broadcast 192.168.1.255 autokey # broadcast server
#broadcast 224.0.1.1 autokey  # multicast server
#manycastserver 239.255.254.254  # manycast server

3.2 录制快照

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

附录

1.同步阿里云时间 https://www.cnblogs.com/liulianzhen99/articles/17637056.html
2.Mac 如何安装 Homebrew
3.Homebrew安装以及使用Redis

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MDM如何配置数据审批功能

MDM基础数据平台是进行清洗和治理企业的主数据&#xff0c;使企业的主数据具有唯一性、准确性、一致性、及时性&#xff0c;通过主数据数据清洗功能将错误数据和重复数据进行清洗&#xff0c;从而保证企业数据能够做到以上那几点&#xff0c;然后再分发至下游系统&#xff0c;使…

苹果手机照片如何导入电脑?无损快速的传输办法分享!

前些天小编的朋友联系到我&#xff0c;说是自己苹果手机里面的照片太多&#xff0c;有好几千张&#xff0c;不知道该怎么快而无损地传到电脑。我想遇到这种情况的不止是小编的朋友&#xff0c;生活中遇到手机照片导入电脑的同学不在少数。不管是苹果手机还是安卓手机&#xff0…

μC/OS-II---互斥信号量管理2(os_mutex.c)

目录 背景&#xff1a;优先级反转问题互斥信号量管理互斥信号量发出&#xff08;释放&#xff09;互斥信号量获取/无等待互斥信号量状态查询 背景&#xff1a;优先级反转问题 在高优先级任务等待低优先级任务释放资源时&#xff0c;第三个中等优先级任务抢占了低优先级任务。阻…

【postgresql】查看数据中表的信息

切换到postgresql数据库&#xff0c;各种不适应吧。 有个需求需要查询数据表的各种信息。 下面我们一起学习吧。 ●PostgreSQL: Documentation PostgreSQL: Documentation ●pg_namespace 存储名字空间。名字空间是 SQL 模式下层的结构&#xff1a;每个名字空间有独立的关系…

FPGA时序约束与分析-简单入门

FPGA时序约束与分析-简单入门 文章目录 FPGA时序约束与分析-简单入门1. 本课程概述2. 时序约束简介2.1 什么是时序约束2.2 合理的时序约束2.3 *基于Vivado的时序约束方法 3. 时序分析的基本概念3.1 时钟与时钟偏差3.2 建立时间和保持时间3.3 时序分析中路径、沿和关系的定义 4.…

V10chrony服务配置

Chrony简介 Chrony是一个开源自由的网络时间协议 NTP 的客户端和服务器软软件。它能让计算机保持系统时钟与时钟服务器&#xff08;NTP&#xff09;同步&#xff0c;因此让你的计算机保持精确的时间&#xff0c;Chrony也可以作为服务端软件为其他计算机提供时间同步服务。 Ch…

字符流的讲解 以及 Reader和Writer的用法

文章目录 ❤专栏导读❤字符流❤Reader类的操作 ❤Writer类操作❤Writer类的构造方法 ❤专栏导读 &#x1f680;《多线程》 &#x1f680;《数据结构剖析》 &#x1f680;《JavaSE语法》 在Java标准库中&#xff0c;提供的读写文件的流对象有很多很多的类&#xff0c;但是可以将…

计算机网络之物理层

物理层 1. 物理层的基本概念 2.物理层下面的传输媒体 传输媒体可分为两类&#xff0c;一类是导引型传输媒体&#xff0c;另一类是非导引型传输媒体。 3.传输方式 3.1 串行传输和并行传输 串行传输&#xff1a;串行传输是指数据是一个比特依次发送的&#xff0c;因此在发送端…

家居行业中跨区域EDI应用的优化策略

提到家居行业的国际知名企业&#xff0c;你会想到哪些&#xff1f;宜家IKEA还是家得宝The Home Depot&#xff1f;这些稳居家居行业第一梯队的企业都有哪些共同之处&#xff1f; 无论是北美市场还是欧洲市场&#xff0c;这些企业都有一个共同点&#xff1a;他们采用EDI&#x…

【Redis系列】Redis上设置key,value的时候出现NOAUTH Authentication required提示如何解决?

哈喽&#xff0c;大家好&#xff0c;我是小浪。相信大家在初学一门新的知识点的时候都会遇到各种各样的问题&#xff0c;在网上找了一大堆的解决方案&#xff0c;最后还是无功而返&#xff0c;那么今天博主就记录一下在进行Redis的一些操作中遇到的问题~ 当我们好不容易安装好R…

国际阿里云:提高CDN缓存命中率教程!!!

CDN缓存命中率低会导致源站压力大&#xff0c;静态资源访问效率低。您可以根据导致CDN缓存命中率低的具体原因&#xff0c;选择对应的优化策略来提高CDN的缓存命中率。 背景信息 CDN通过将静态资源缓存在CDN节点上实现资源访问加速。当客户端访问某资源时&#xff0c;如果CDN节…

给在读博士的建议

早上起床第一件事&#xff0c;瞄了眼知乎&#xff01; 发现现在的手机真的很智能&#xff0c;也许是聊天的时候不经意间提了一句&#xff0c;早上就推荐了自己想看到的东西&#xff01; 分享给大家&#xff01; 有哪些给在读博士的建议&#xff1f; 如何通过一句话判断一个博士…

LeetCode(12)时间插入、删除和获取随机元素【数组/字符串】【中等】

目录 1.题目2.答案3.提交结果截图 链接&#xff1a; 380. O(1) 时间插入、删除和获取随机元素 1.题目 实现RandomizedSet 类&#xff1a; RandomizedSet() 初始化 RandomizedSet 对象bool insert(int val) 当元素 val 不存在时&#xff0c;向集合中插入该项&#xff0c;并返回…

Karmada更高效地实现故障转移

随着云原生技术的发展&#xff0c;其应用场景不断扩大。越来越多的企业开始将应用程序部署在 Kubernetes 集群中&#xff0c;随着 Kubernetes 集群规模的不断扩大&#xff0c;也带来了许多管理挑战&#xff0c;例如多集群间负载均衡、资源调度、故障转移等问题。为了解决这些问…

【QT系列教程】之二创建项目和helloworld案例

文章目录 一、QT创建项目1.1、创建项目1.2、选择创建项目属性1.3、选择路径和项目名称1.4、选择构建项目类型1.5、布局方式1.6、翻译文件&#xff0c;根据自己需求选择1.7、选择套件1.8、项目管理&#xff0c;自行配置1.9、配置完成&#xff0c;系统自动更新配置 二、QT界面介绍…

istio学习笔记-安装

Istioldie 1.18 / 安装指南 基于Kubernetes的Istio的微服务架构需要安装以下组件&#xff1a; Istio控制平面组件&#xff1a;包括Istio-Pilot、Istio-Policy、Istio-Telemetry等。这些组件负责微服务的管理和配置&#xff0c;如流量管理、策略执行、遥测数据收集等。数据平面…

2023-11-15 LeetCode每日一题(K 个元素的最大和)

2023-11-15每日一题 一、题目编号 2656. K 个元素的最大和二、题目链接 点击跳转到题目位置 三、题目描述 给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。你需要执行以下操作 恰好 k 次&#xff0c;最大化你的得分&#xff1a; 从 nums 中选择一个元素 m 。将选中…

安装 Lua 的 HTTP 库

首先&#xff0c;你需要安装 Lua 的 HTTP 库。可以使用 LuaRocks 来安装。以下是安装命令&#xff1a; luarocks install http然后&#xff0c;你可以使用以下代码来爬取网页内容&#xff1a; local http require http-- 设置代理信息 http.set_proxy(jshk.com.cn)-- 网页UR…

【C#学习】button:只显示图片

第一步&#xff1a;设置按钮背景图片&#xff0c;并且图片随按钮大小变化 第二步&#xff1a;设置按钮使之只显示图片 button1.FlatStyle FlatStyle.Flat;//stylebutton1.ForeColor Color.Transparent;//前景button1.BackColor Color.Transparent;//去背景button1.FlatAppe…

Flutter笔记:使用Flutter构建响应式PC客户端/Web页面-案例

Flutter笔记 使用Flutter构建响应式PC客户端/Web页面-案例 作者&#xff1a;李俊才 &#xff08;jcLee95&#xff09;&#xff1a;https://blog.csdn.net/qq_28550263 邮箱 &#xff1a;291148484163.com 本文地址&#xff1a;https://blog.csdn.net/qq_28550263/article/detai…