使用Nginx1.25.4版本做负载均衡、搭建Nacos2.3.0服务集群

关于使用版本问题上,其实小白更喜欢使用新的版本,因为新的版本功能更多,肯定优化方面不言而喻,懂得都懂,但是新的版本,肯定使用起来更加的速度,性能,也是不言而喻的啊,那是嘎嘎一嘎斯,稳定性较差,坑更多,但是我认为跳坑,更有意思。其实小白不是自虐啊!一方面小白喜欢从坑里爬出来的那份欣喜,最重要的一方面就是可以分享一下,给更多跳坑的人一点点的建议,俗话说我不如地狱谁入地狱!!

好了,收,废话不多说了

前期准备下载 JDK、Maven、Nacos、Nginx

小白使用的版本是JDK17.0.Maven官网:https://maven.apache.org/ 10、Maven3.9.6、Nacos2.3.0、Nginx1.25.4如果专业的话,查看一下版本要求,如果使用SpringalibabbaCloud,Nacos最好不要选择最新版,目前为止SpringalibabaCloud-2023.0.0.0-RC1,最高支持的就是Nacos2.3.0版本。

Nacos

下载 JDK Maven Nacos

Nacos 

Nacos官网下载: https://github.com/alibaba/nacos

点击Releases下的Nacos的版本进行下载,小白使用的是2.3.0 在这里插入图片描述2、找到Assets 如果单纯使用不研究源码直接选择(*.tar.gz)点击 进行下载(注意国外网,不是很好下载,小白祝大家自求多福吧!)自己想想办法 在这里插入图片描述

3、关注自己的jdk版本是否符合Nacos2.3.1这个版本最低要求JDK是1.8+的

JDK

oracle官网Oracle | Cloud Applications and Cloud Platform 下载JDK 注意(.tar.gz)版本的

2、进入官网选择product-->java 在这里插入图片描述 3、Dowload 在这里插入图片描述 4、选择版本进行下载 在这里插入图片描述

Maven

Maven官网:Maven – Welcome to Apache Mavenicon-default.png?t=N7T8https://maven.apache.org/

安装 JDK、Maven、Nacos

JDK

小白使用的是SecureCRT工具将包上传到linux上

使用FTP(快捷键:ALT+P)上传JDK、Nacos Server的包上传至虚拟机上

上传JDK

将jdk移动暗转目录
mv jdk-21_linux-x64_bin.tar.gz /usr/local/etc

将jdk安装包解压
tar -zxvf jdk-21_linux-x64_bin.tar.gz

解压完成

删除jdk包
rm -i jdk-21_linux-x64_bin.tar.gz
删除自带的JDK
查看自带jdk
rpm -qa | grep java

删除java
    yum -y remove java-1.8.0-openjdk-headless-1.8.0.362.b09-4.el9.x86_64yum -y remove javapackages-filesystem-6.0.0-4.el9.noarchyum -y remove tzdata-java-2023c-1.el9.noarch

配置环境变量
cd /
vim /etc/profile
找到export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL

点击英文字母 i 进入写入模式

编写java环境变量

# setting java evironment then reloading source etc/profile
JAVA_HOME=/usr/local/etc/jdk-21.0.2
PATH=$PATH:$JAVA_HOME/bin
export JAVA_HOME PATH

ESC + : +wq :写入并退出

重新加载 profile 文件

source /etc/profile

查看java版本(有时候会显示 Command not found)吓一跳吧!哈哈哈
java -version

进入jdk安装目录的bin目录首次运行
cd /usr/local/etc/jdk-21.0.2/bin
./java -version

诶!如果在不对了就检查一次 profile吧! 安全起见Linux上JDK版本要与 主机上的JDK的版本保持一致,避免不必要的麻烦

Maven

将Apache-Maven移动至安装目录

解压Maven
tar -zxvf apache-maven-3.9.6-bin.tar.gz

查看,并删除 .tar文件
ls 
rm -i apache-maven-3.9.6-bin.tar.gz
ls

改Maven名字

# apache-maven-3.9.6     解压后的初始名称
# maven-3.9.6            更改后的名称
mv apache-maven-3.9.6 maven-3.9.6

退回至root 编写环境变量
cd /
vi /etc/profile

`` 这里有个小技巧 ,就是提前复制 Maven的路径然后再编写环境变量 ``

cd /usr/local/etc/Maven/maven-3.9.6

什劳子 i 写入模式 、ESC + :+wq 进行写入不用说了吧 !

重载profile文件
source /etc/profile
查看mvn版本
mvn -version

Nacos Server

使用Secure CRT 上传 Nacos

移动 Nacos至安装目录
mv nacos-server-2.3.0.tar.gz /usr/local/etc/
cd /usr/local/etc

解压Nacos包
tar -zxvf nacos-server-2.3.0.tar.gz 

删除Nacos安装包
rm -i nacos-server-2.3.0.tar.gz 

启动Nacos Server
cd /cd /usr/local/etc/nacos/binlssh startup.sh -m standalone # 单机模式

查看后台运行面板
cat /usr/local/etc/nacos/logs/start.out

console:会有一个地址 http://000.000.000.000:8848/nacos/index.html

访问 Nacos Server服务器

是因为没有开启端口号 关闭Nacos

sh shutdown.sh

开启8848 指定端口
查看防火墙状态
firewall-cmd --state #显示防火墙状态

开放端口号
 firewall-cmd --add-port=8848/tcp #设置临时端口firewall-cmd --add-port=8848/tcp --permanent  #设置永久开放此端口

重新加载并查看端口号

firewall-cmd --reload        # 重新加载防火墙
firewall-cmd  --list-port    # 查看开防火墙开放的端口号

重启Nacos Server并访问

http://000.000.000.000:8848/nacos/index.html

成功访问!

此时,页面是可以访问的,但是要使用程序运行会报错误gRpc 和connection timeout错误,是因为Nacos2.0 之后采用grpc协议,这与传统的访问并不相同的是grpc的端口号会向前移动1000、1000+1或者向后移动1000举例说明8848端口号 8848 + - 1000、8848+1000+1 就是7848 -- 8848 -- 9848--9849

导致连接超时(因为根本连接不上)

解决问题

CentOS Stream9 添加端口号

## 8848端口已经添加完了 --permanent 永久开放端口号
firewall-cmd --add-port=7848/tcp --permanent
firewall-cmd --add-port=9848/tcp --permanent
firewall-cmd --reload        # 重新加载防火墙
firewall-cmd --list-port    #查看防火墙开放的端口号
## 删除端口(举例说明)
firewall-cmd --remove-port=8080/tcp --permanent

已经可以注册了

Nacos集群

相信你们都应搭建起来自己单机版的Nacos了,下面我们搭建集群,嘎嘎简单!

准备CentOS

克隆我们单机的Nacos的CentOS就行,用几个克隆几个,小白认为服务器个数要是奇数的(不要忘记修改IP地址,反正吧!不修改也不会报错的,但是公司服务器肯定不是同个IP的,模拟也要像一点儿) 不会修改的小白主页中找CentOS Stream 9 修改静态IP就行

修改配置
进入到Nacos的bin目录中

编辑 startup.sh
vi startup.sh

修改 运行内存(如果自己的虚拟机空间够大的话,不用修改,其实小白喜欢内存大的,但是我的虚拟机空间小) 上面说如果是standalong内存是。。。。else(就是说不是单机状态的内存是2g/2g/1g)         

修改,必须修改!我内存一共才设置成2G呀!!!!

i写入模式

ESC : wq 写入并退出

编辑Nacos config
 cd ../conf
修改application.properties
 vi application.properties

对了还要准备一个mysql,一般本地都有开放端口就行了,然后还要在MySQL中创建一个Nacos数据库;创建表 此表有迹可循啊

打开它,赋值它的所有吧!在MySQL中粘贴运行!

修改cluster.conf文件

咦咦咦!!!咋没有尼!纳尼!

cp cluster.conf.example cluster.conf

编辑cluster.conf 添加Nacos集群ip、端口号 Nacos服务的IP地址:端口号

开放端口(关键所在)

每个Nacos服务都要开放Nacos集群成员中的每个Nacos服务的端口(grpc) 我搭建三个Nacos服务,端口号为 8848、8849、8850 所以每个Nacos服务开放的端口加上grpc限制所以端口号为: Nacos1端口号:7848、8848、9848 Nacos2端口号:7849、8849、9849 Nacos3端口号:7850、8850、9850

Nacos1开放的端口号为:

firewall-cmd --add-port=7848/tcp --permanent
firewall-cmd --add-port=8848/tcp --permanent
firewall-cmd --add-port=9848/tcp --permanent
firewall-cmd --add-port=7849/tcp --permanent
firewall-cmd --add-port=8849/tcp --permanent
firewall-cmd --add-port=9849/tcp --permanent
firewall-cmd --add-port=7850/tcp --permanent
firewall-cmd --add-port=8850/tcp --permanent
firewall-cmd --add-port=9850/tcp --permanent
firewall-cmd --reload
firewall-cmd --list-port

我的娘啊!晕晕,不怕,小白能解决

# 批量开放端口号,端口号分段添加
firewall-cmd --add-port=7848-7853/tcp --permanent
firewall-cmd --add-port=8848-8853/tcp --permanent
firewall-cmd --add-port=9848-9853/tcp --permanent# 重新加载
firewall-cmd --reload# 查看开放的端口号
firewall-cmd --list-port

飞起来!

每台Nacos服务器在不开放所有端口号的情况下,只有本机是在线状态,其他Nacos均是Down机状态

每台Nacos开启所有Nacos端口号

Nginx

nginx官网

nginx官网:nginx newsicon-default.png?t=N7T8https://nginx.org/

nginx官网下载:https://nginx.org/en/download 在这里插入图片描述​ 上传文件到Linux系统上 在这里插入图片描述​ 创建文件夹在/usr/local/etc/(这是小白自己的爱好,可以不用创建文件夹)

cd /usr/local/etc/
mkdir nginx

Nginx压缩文件移动至指定文件夹

# 将Nginx压缩文件移动至指定地址
mv nginx-1.25.4.tar.gz /usr/local/etc/nginx/
# 进入指定的文件夹中
cd /usr/local/etc/nginx/

在这里插入图片描述

解压Nginx文件

解压文件

tar -zxvf nginx-1.25.4.tar.gz

在这里插入图片描述

删除压缩文件

rm -i nginx-1.25.4.tar.gz

在这里插入图片描述

安装Nginx所使用的环境
# 包括 gcc、pcre、zlib 、opensslyum -y install gcc-c++
​
yum -y install pcre pcre-devel
​
yum -y install zlib zlib-devel
​
yum -y install openssl openssl-devel
​
配置Nginx文件

nginx-1.25.4 configure文件配置及插件

--with-cc=cl
--builddir=objs.msvc8
--with-debug
--prefix=
--conf-path=conf/nginx.conf
--pid-path=logs/nginx.pid
--http-log-path=logs/access.log
--error-log-path=logs/error.log
--sbin-path=nginx.exe
--http-client-body-temp-path=temp/client_body_temp
--http-proxy-temp-path=temp/proxy_temp
--http-fastcgi-temp-path=temp/fastcgi_temp
--http-scgi-temp-path=temp/scgi_temp
--http-uwsgi-temp-path=temp/uwsgi_temp
--with-cc-opt=-DFD_SETSIZE=1024
--with-pcre=objs.msvc8/lib/pcre2-10.39
--with-zlib=objs.msvc8/lib/zlib-1.3.1
--with-http_v2_module
--with-http_realip_module
--with-http_addition_module
--with-http_sub_module
--with-http_dav_module
--with-http_stub_status_module
--with-http_flv_module
--with-http_mp4_module
--with-http_gunzip_module
--with-http_gzip_static_module
--with-http_auth_request_module
--with-http_random_index_module
--with-http_secure_link_module
--with-http_slice_module
--with-mail
--with-stream
--with-stream_realip_module
--with-stream_ssl_preread_module
--with-openssl=objs.msvc8/lib/openssl-3.0.13
--with-openssl-opt='no-asm no-tests
-D_WIN32_WINNT=0x0501'
--with-http_ssl_module
--with-mail_ssl_module
--with-stream_ssl_module

配置configure配置文件

#执行命令
# 文件的编译目录和解压目录不能再同一个文件夹
#prefix= 指向安装目录(编译安装)
#sbin-path= 指向Nginx 启动程序
#conf-path= 指向配置文件(nginx.conf)
#error-log-path= 指向错误日志目录
#pid-path= 指向pid文件(nginx.pid)
#http-log-path= 设定access log路径
#with-http_gzip_static_module 启用ngx_http_gzip_static_module支持(在线实时压缩输出数据流)
#with-http_stub_status_module 启用ngx_http_stub_status_module支持(获取nginx自上次启动以来的工作状态)
#with-http_ssl_module 启用ngx_http_ssl_module支持(使支持https请求,需已安装openssl)
#支持http2
#with-http_v2_module
#支持Debug模式
# with-http-Debug
# 安装 Stream
# --with-stream
# nginx 如果整合Nacos2.0+版本需要安装Stream 模块和http-v2 因为要使用grpc就要涉及到端口转移,要用到Stream模块 
​
./configure --prefix=/usr/local/etc/nginx --sbin-path=/usr/local/etc/nginx/install/sbin --conf-path=/usr/local/etc/nginx/install/conf/nginx.conf  --error-log-path=/usr/local/etc/nginx/logs/error.log --pid-path=/usr/local/etc/nginx/logs/nginx.pid  --http-log-path=/usr/local/etc/nginx/logs/access.log --with-http_gzip_static_module --with-http_stub_status_module --with-http_ssl_module --with-http-v2-module --with-stream_realip_module --with-stream_ssl_preread_module --with-http-Debug --with-stream
​
安装Nginx
make
make install
启动Nginx

进入Nginx的sbin文件夹

cd /usr/local/etc/workspace-nginx/nginx-1.25.4/sbin/

启动Nginx

./nginx

在这里插入图片描述

启动命令
# 启动 nginx:
./nginx
# 优雅停止 nginx:
./nginx -s quit
# 快速停止 nginx:
./nginx -s stop
# 重启nginx:
./nginx -s reload

在这里插入图片描述

开放端口号

通过上面控制台输出 端口号是80端口 开放80端口

在这里插入图片描述

​ 重启Nginx

在这里插入图片描述

访问http://+你的IP地址+:80

在这里插入图片描述

配置环境变量
编写profile文件
cd /
vi /etc/profile

i进入写入模式

export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL
​
# setting Nginx environment
NGINX_HOME=/usr/local/etc/workspace-nginx/nginx-1.25.4
PATH=$PATH:$NGINX_HOME/sbin
export NGINX_HOME PATH

ESC :wq 进行写入

重新加载profile文件
source /etc/profile
编写systemd单元文件管理nginx服务

Nginx作为服务程序,需要为其编写一个单元文件以便systemd能够管理它,在/usr/lib/systemd/system目录下创建一个nginx.service文本文件

[Unit]
Description=The nginx HTTP and reverse proxy server
After=syslog.target network-online.target remote-fs.target nss-lookup.target
Wants=network-online.target
[Service]
Type=forking
#自己nginx启动的pid文件自己找到文件目录
PIDFile=/usr/local/etc/nginx/nginx-1.25.4/logs/nginx.pid
# Nginx will fail to start if /run/nginx.pid already exists but has the wrong
# SELinux context. This might happen when running `nginx -t` from the cmdline.
# https://bugzilla.redhat.com/show_bug.cgi?id=1268621
ExecStartPre=/usr/local/etc/nginx/nginx-1.25.4/sbin/nginx -t -c /usr/local/etc/nginx/nginx-1.25.4/conf/nginx.conf
ExecStart=/usr/local/etc/nginx/nginx-1.25.4/sbin/nginx -c /usr/local/etc/nginx/nginx-1.25.4/conf/nginx.conf
​
ExecReload=/usr/local/etc/nginx/nginx-1.25.4/sbin/nginx -s reload
# 默认
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
KillSignal=SIGQUIT
TimeoutStopSec=5
KillMode=mixed
PrivateTmp=true[Install]
WantedBy=multi-user.target
重新加载system文件

要让systemd重新识别此单元文件,通常执行systemctl daemon-reload命令重载配置,这样就可以使用systemd来管理nginx的启动、重启。

systemctl daemon-reload            # 重新加载
systemctl restart nginx            # 重启Nginx.service
systemctl status nginx.service     # 查看状态

img

可以看到nginx的状态为running~

Nginx搭建Nacos集群

编写Nginx conf文件

vi /usr/local/etc/nginx/install/conf/nginx.conf
# http 和Stream 是同级模块
http {
upstream nacos-cluster {# nacos cluster IP portserver 000.000.000.000:8848;
​server 000.000.000.000:8849;
​server 000.000.000.000:8850;
​server 000.000.000.000:8851;
​server 000.000.000.000:8852;
​}server {# listen portlisten          8888;# server nameserver_name     localhost;# location configurelocation /nacos/ {proxy_pass http://nacos-cluster/nacos/;}}
}
stream {# nacos cluster offset port Nacos集群偏移端口upstream nacos-cluster-grpc {#grpc nacos server IP portserver 000.000.000.000:9848;
​server 000.000.000.000:9849;
​server 000.000.000.000:9850;
​server 000.000.000.000:9851;
​server 000.000.000.000:9852;}
​# server proxy offset portserver {listen  9888;proxy_pass nacos-cluster-grpc;}

重新加载Nginx、重启Nginx

# 重新加载
systemctl daemon-reload
# 重启Nginx
systemctl restart nginx
#查看Nginx运行状态
systemctl status nginx

开放偏移端口号

# 开放端口号
firewall-cmd --add-port=8888/tcp --permanent
firewall-cmd --add-port=9888/tcp --permanent
# 重新加载 防火墙
firewall-cmd --reload
# 产看端口号
firewall-cmd --list-port

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

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

相关文章

Arxiv 2403 | DenseNets Reloaded Paradigm Shift Beyond ResNets and ViTs

论文:https://arxiv.org/abs/2403.19588代码:https://github.com/naver-ai/rdnet语雀文档:https://www.yuque.com/lart/papers/yrmgielt34ve6oty 本文改进了 DenseNet,并揭示了其相对于主要的 resnet 风格架构的被低估的有效性。本…

详解TCP的三次握手和四次挥手

文章目录 1. TCP报文的头部结构2. 三次握手的原理与过程三次握手连接建立过程解析 3. 四次挥手的原理与过程四次挥手连接关闭过程的解析 4. 常见面试题 深入理解TCP连接:三次握手和四次挥手 在网络通信中,TCP(传输控制协议)扮演着…

Qt中的多线程

视频链接:https://www.bilibili.com/video/BV1iN411f7dY/?p2&spm_id_frompageDriver&vd_sourcefa4ef8f26ae084f9b5f70a5f87e9e41b 在Qt中使用多线程可以提高用户体验,若只有一个线程进行处理,则会导致窗口卡顿,这是我们不…

go-python 库使用详解

1. 引言 在当今软件开发领域,跨语言编程已经成为一种常见的需求。不同的编程语言各自有其优势和适用场景,因此在项目开发过程中,经常需要将多种编程语言进行集成和协作。Go语言(简称Go)和Python作为两种流行的编程语言…

iOS - Runloop介绍

文章目录 iOS - Runloop介绍1. 简介1.1 顾名思义1.2. 应用范畴1.3. 如果没有runloop1.4. 如果有了runloop 2. Runloop对象3. Runloop与线程4. 获取Runloop对象4.1 Foundation4.2 Core Foundation4.3 示例 5. Runloop相关的类5.1 Core Foundation中关于RunLoop的5个类5.2 CFRunL…

北京小蓝蜂科技有限公司 基本情况

北京小蓝蜂科技有限公司 基本情况 公司概述 北京小蓝蜂科技有限公司(简称“小蓝蜂”)是一家专注于互联网行业的公司,成立于4年前,位于北京市海淀区成府路45号中关村智造大街G座一层J030。小蓝蜂主要业务包括技术开发、技术咨询、技术转让、技术推广等,同时也涉及销售自行…

【Go】六、函数

文章目录 1、函数的定义2、内存分析3、注意点4、函数数据类型5、自定义数据类型(起别名)6、支持对返回值命名 1、函数的定义 语法: func 函数名(形参列表)(返回值类型列表){执行语句..return 返回值列…

公司官网怎么才会被百度收录

在互联网时代,公司官网是企业展示自身形象、产品与服务的重要窗口。然而,即使拥有精美的官网,如果不被搜索引擎收录,就无法被用户发现。本文将介绍公司官网如何被百度收录的一些方法和步骤。 1. 创建和提交网站地图 创建网站地图…

学俄语能不能直接学口语,而不学语法?柯桥俄语培训

语言属性决定,俄语入门就要学语法! 俄语教学实践已经证明,俄语语法必须要学,而且优先学。 这是为什么呢? 这是由俄语本身的特性决定。俄语属屈折语,其典型特征便是以丰富的词形变化来表达词与词之间的关…

QML通过鼠标拖动的位置

当通过鼠标拖动Rectangle 的位置时,可以使用Qt Quick的MouseArea组件来实现 Rectangle {id: rectx:0;y:0width: 200; height: 100color: "lightblue"MouseArea {id: mouseAreaanchors.fill: parentdrag.target: rect//要拖动的项目的IDdrag.axis: Drag.XA…

蓝桥杯算法题-图形排版

题目描述 小明需要在一篇文档中加入 N 张图片,其中第 i 张图片的宽度是 Wi,高度是 Hi。   假设纸张的宽度是 M,小明使用的文档编辑工具会用以下方式对图片进行自动排版: 1. 该工具会按照图片顺序,在宽度 M 以内&…

基于java高校社团招新系统设计与实现

摘要 :大学学生社团的不断壮大发展,让对社团的招新管理越来越重要,如何高效的管理社团,促进社团有效的运行和发展变得尤为关键。学生社团在学生的成长发展过程中有着一定的积极作用,要发挥好社团的优势,管…