使用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.mzph.cn/news/773518.shtml

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

相关文章

US-T65 DM蓝牙5.2双模热插拔PCB

键盘使用说明索引(均为出厂默认值) 一些常见问题解答(FAQ)注意首次使用步骤蓝牙配对(重要)蓝牙和USB切换键盘默认层默认触发层0的FN键配置的功能默认功能层1配置的功能默认的快捷键 蓝牙参数蓝牙MAC地址管理…

求助:配置脚手架代理,跨域问题proxyTable配置无效,访问后显示404?

已经在这里卡了一天了。找了很多解决办法,比如重启,修改proxytable等等,但是每次但是404,求助各位大佬,怎么解决? 1、代码 (1)config的index.js (2) App.v…

python爬虫-----输入输出与流程控制语句(第四天)

🎈🎈作者主页: 喔的嘛呀🎈🎈 🎈🎈所属专栏:python爬虫学习🎈🎈 ✨✨谢谢大家捧场,祝屏幕前的小伙伴们每天都有好运相伴左右,一定要天天…

.NET6.0智慧医院手术室麻醉管理平台源码

目录 一、手麻系统概述 二、系统开发环境 三、手麻系统功能 手术进程 手术排班 手术记录 术前访视与评估 术中麻醉记录 麻醉总结 术后访视 模版配置 自动评分 文书模板 ​​​​​​​ 一、手麻系统概述 手术麻醉临床信息系统有着完善的临床业务功能,…

YOLOv8融入低照度图像增强算法---传统算法篇

YOLOv8n原图检测YOLOv8n增强后检测召回率和置信度都有提升 前言 这篇博客讲讲低照度,大家都催我出一些内容,没想到这么多同学搞这个,恰好我也做过这方面的一些工作,那今天就来讲解一些方法,低照度的图像增强大体分“传统算法”和“深度学习算法”; 目前低照度的图像增…

每日一题 --- 数组中的第 K 个最大元素[力扣][Go]

数组中的第 K 个最大元素 题目:数组中的第 K 个最大元素 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 示例 1: 输入: [3,2,1…

Fronius福尼斯TIG热丝ETR堆焊系统维修小窍门

绕孔轴旋转的可无限旋转枪头以及送丝机是ETR堆焊系统的核心在传动米亏的帮助下,焊接电流、保护气、焊枪冷却专职和电气控制信号进行着不间断的工作。然而,如同所有复杂设备,该系统在使用过程中也可能遇到故障。因此,建议与子锐机器…

AI渣土车监测报警摄像机

随着城市建设的不断发展和交通运输的快速增长,渣土车作为建筑行业中不可或缺的运输工具,承担着大量的渣土运输任务。然而,由于渣土车在运输过程中存在超速、违规变道、碾压行人等交通安全问题,给道路交通和行人安全带来了严重的隐…

智慧公厕,运用大数据提升公共厕所管理水平

在现代社会,科技的发展给我们带来了诸多便利,而智慧公厕就是其中之一。智慧公厕运用数据和技术,提升公共厕所的管理水平,为社会生活服务。本文将以智慧公厕源头实力厂家广州中期科技有限公司,遍布全国的众多标杆性案例…

SQLAlchemy对数据进行CRUD操作

构建 session 对象 所有和数据库的 ORM 操作都必须通过一个叫做 session 的会话对象 来实现,通过以下代码来获取会话对象 代码实现 # SQLAlchemy对数据的CRUD #SQLAlchemy模型映射表结构. from sqlalchemy import create_engine,Column,Integer,String from sql…

vue3动态绑定style

vue3动态绑定style :style"{属性名:变量}"直接引用对象 :style"对象"绑定一个含多个样式的数组 :style"[styleA, styleB]" :style“{属性名:变量}” 变量的赋值可以根据自己的业务做出调整 直接引用对象 :style“对象”…

Spring事务-两种开启事务管理的方式:基于注解的声明式事务管理、基于编程式的事务管理

Spring事务-两种开启事务管理的方式 1、前期准备2、基于注解的声明式事务管理3、基于编程式的事务管理4、声明式事务失效的情况 例子:假设有一个银行转账的业务,其中涉及到从一个账户转钱到另一个账户。在这个业务中,我们需要保证要么两个账户…

客户管理大揭秘!热门盘点:5款CRM工具推荐!

“本期为大家盘点客户管理中常用的5款CRM工具:Zoho CRM、Salesforce、Hubspot、Freshsales、和Pipedrive。” 我们会从产品特点、适用性等方面对每款产品进行全面考量。无论您是想提高客户参与度、自动化销售流程,还是从数据中获得可操作的见解&#xf…

虹科Pico汽车示波器 | 免拆诊断案例 | 2018款东风风神AX7车发动机怠速抖动、加速无力

一、故障现象 一辆2018款东风风神AX7车,搭载10UF01发动机,累计行驶里程约为5.3万km。该车因发动机怠速抖动、加速无力及发动机故障灯异常点亮而进厂维修,维修人员用故障检测仪检测,提示气缸3失火;与其他气缸对调点火线…

企业指标体系的落地与推广:让指标体系真正发挥作用

一、精心策划实施计划,确保项目有序进行 为确保指标体系的顺利落地与推广,我们精心策划了实施计划。首先,我们制定了详细的时间表,明确了项目启动、关键节点和结束时间,确保项目能够按期推进。同时,我们还将…

FPGA亚稳态学习总结

首先是组合逻辑电路考虑的是竞争冒险,冒险会产生毛刺。重点研究如何去毛刺 时序逻辑电路考虑的是时序不满足会产生的亚稳态问题:如何考量时序满不满足呢?根据不同的场景又有不同的说法。 时序分析的两组基本概念 建立时间与保持时间 1.在…

Day49:WEB攻防-文件上传存储安全OSS对象分站解析安全解码还原目录执行

目录 文件-解析方案-目录执行权限&解码还原 目录执行权限 解码还原 文件-存储方案-分站存储&OSS对象 分站存储 OSS对象存储 知识点: 1、文件上传-安全解析方案-目录权限&解码还原 2、文件上传-安全存储方案-分站存储&OSS对象 文件-解析方案-目…

灵途科技助力家电智能创新

从智能家电到个护健康,科技无时无刻不在刷新我们对智慧生活的认知,我们也从未像今天这样近距离贴近智慧生活的朴素本质——传感技术。灵途科技专注光电感知技术,持续为智能家电客户提供成熟的全方位感知解决方案。步入发展第八年,…

Go语言学习Day2:注释与变量

名人说:莫道桑榆晚,为霞尚满天。——刘禹锡(刘梦得,诗豪) 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 1、注释①为什么要写注释?②单行注释…

燃气官网安全运行监测系统-阀井燃气监测仪-旭华智能

近年来,燃气爆炸事故频发,造成了重大人员伤亡和财产损失。这也再次为我们敲响警钟,燃气是我们日常生活中不可或缺的能源,但其潜在的危险性也是不容小觑。因此在重要节点加装燃气阀井气体监测仪,并将数据上传到系统平台…