openEuler 22.03 安装 Nginx,支持离线安装

目录

一、环境检查

1.1 必要环境检查

复制代码
# 查看 gcc 版本
[root@openeuler ~]# gcc --version
# 查看 pcre 版本
[root@openeuler ~]# pcre-config --version
# 查看 zlib 版本
[root@openeuler ~]# dnf list installed | grep zlib
# 查看 openssl 版本
[root@openeuler ~]# openssl version
# 查看 gcc pcre-config openssl 位置
[root@openeuler ~]# readlink -f $(which gcc pcre-config openssl)

1.2 在线安装(有网络)

复制代码
[root@openeuler ~]# sudo dnf install -y gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel

1.3 离线安装(无网络)

1.3.1 软件包下载

openEuler软件中心:https://easysoftware.openeuler.org/zh/rpm

华为开源镜像站:http://mirrors.huaweicloud.com/openeuler/openEuler-22.03-LTS-SP4/everything/x86_64/Packages/

华中科技大学镜像站:https://mirrors.hust.edu.cn/openeuler/openEuler-22.03-LTS-SP4/everything/x86_64/Packages/

离线包下载:openEuler 22.03 安装 Nginx 所需的依赖包

1.3.2 软件包安装

复制代码
# 切换到 RPM 包所在目录,假设 RPM 包存放在 /home/rpm_packages 目录下
[root@openeuler ~]# cd /home/rpm_packages
# 正常安装命令
[root@openeuler rpm_packages]# sudo rpm -ivh *.rpm --nodeps
# 强制安装命令
# 重要事项:没把握的话,千万不要用下面这个命令,这个命令会忽略依赖和兼容性,可能会导致基础组件被卸载掉。
[root@openeuler rpm_packages]# sudo rpm -Uvh *.rpm --nodeps --force

小技巧:可以提前在有网络环境下下载安装包,移动到无网络环境

yumdownloader --resolve gcc-c++

yumdownloader --resolve pcre pcre-devel

yumdownloader --resolve zlib zlib-devel

yumdownloader --resolve openssl openssl-devel

二、下载Nginx

2.1 在线下载

复制代码
# 创建安装目录
[root@openeuler ~]# mkdir /mnt/nginx
[root@openeuler ~]# cd /mnt/nginx/
# 在线下载安装包
[root@openeuler nginx]# wget https://nginx.org/download/nginx-1.28.0.tar.gz

2.2 离线下载

下载地址(Stable version):https://nginx.org/en/download.html
上传到 /mnt/nginx 目录下

三、安装Nginx

复制代码
# 进入安装目录
[root@openeuler ~]# cd /mnt/nginx/

# 解压安装包
[root@openeuler nginx]# tar -zxvf nginx-1.28.0.tar.gz

# 进入解压目录
[root@openeuler nginx]# cd nginx-1.28.0/

# 编译并安装,Nginx 默认安装在 /usr/local/nginx 目录下
[root@openeuler nginx-1.28.0]# ./configure   或者   ./configure --prefix=/mnt/nginx/nginx1.28.0
[root@openeuler nginx-1.28.0]# make
[root@openeuler nginx-1.28.0]# sudo make install

# 启动 Nginx
[root@openeuler nginx-1.28.0]# sudo /usr/local/nginx/sbin/nginx
#[root@openeuler nginx-1.28.0]# sudo /mnt/nginx/nginx1.28.0/sbin/nginx

# 检查是否运行
[root@openeuler nginx-1.28.0]# curl http://localhost

# 关闭 Nginx
[root@openeuler nginx-1.28.0]# sudo /usr/local/nginx/sbin/nginx -s stop
#[root@openeuler nginx-1.28.0]# sudo /mnt/nginx/nginx1.28.0/sbin/nginx -s stop

自定义配置(不推荐)

bash 复制代码
./configure \
--prefix=/usr/local/nginx \
--conf-path=/usr/local/nginx/conf/nginx.conf \
--pid-path=/usr/local/nginx/conf/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi

四、开机自启服务

4.1 配置SELinux安全上下文(自定义路径需要用到)
注意:如果不配置SELinux安全上下文,后续启动系统脚本时报错【code=exited, status=203/EXEC】

复制代码
# 恢复默认上下文(针对自定义路径)
[root@openeuler ~]# sudo semanage fcontext -a -t bin_t "/mnt/nginx/nginx1.28.0/sbin(/.*)?"
[root@openeuler ~]# sudo semanage fcontext -a -t etc_t "/mnt/nginx/nginx1.28.0/conf(/.*)?"
[root@openeuler ~]# sudo restorecon -Rv /mnt/nginx/
# 验证标签
[root@openeuler ~]# ls -Zd /mnt/nginx/nginx1.28.0/sbin/nginx
# 应显示类似:system_u:object_r:bin_t:s0

4.2 配置开机自启脚本

复制代码
# 创建自启动脚本
[root@openeuler ~]# sudo vi /etc/systemd/system/nginx.service

# =============================================================================
# 复制粘贴以下内容: /usr/local/nginx/sbin 需要按照实际情况修改成自己的地址
[Unit]
Description=Nginx HTTP Server
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true

[Install]
WantedBy=multi-user.target
# =============================================================================
# 复制粘贴以下内容: /mnt/nginx/nginx1.28.0/sbin需要按照实际情况修改成自己的地址
[Unit]
Description=Nginx HTTP Server
After=network.target

[Service]
Type=forking
ExecStart=/mnt/nginx/nginx1.28.0/sbin/nginx
ExecReload=/mnt/nginx/nginx1.28.0/sbin/nginx -s reload
ExecStop=/mnt/nginx/nginx1.28.0/sbin/nginx -s quit
PrivateTmp=true

[Install]
WantedBy=multi-user.target
# =============================================================================

# 注意:要保证 nginx 后台服务未启动
# 设置开机自启
[root@openeuler ~]# systemctl daemon-reload
[root@openeuler ~]# sudo systemctl enable nginx
# 启动Nginx服务
[root@openeuler ~]# sudo systemctl start nginx
# 查看服务状态
[root@openeuler ~]# sudo systemctl status nginx

五、开放防火墙端口

复制代码
# 查询端口是否开放
[root@openeuler ~]# sudo firewall-cmd --query-port=80/tcp
# 开放端口(TCP协议)
[root@openeuler ~]# sudo firewall-cmd --zone=public --add-port=80/tcp --permanent
# 重新加载防火墙规则
[root@openeuler ~]# sudo firewall-cmd --reload
# 验证端口是否开放
[root@openeuler ~]# sudo firewall-cmd --zone=public --list-ports
# 查看所有端口
[root@centosServer ~]# sudo netstat -nlpt

六、常用命令

复制代码
# 启动 nginx 服务
systemctl start nginx.service
# 查看服务状态
systemctl status nginx.service
# 重启服务
systemctl restart nginx.service
# 停止服务
systemctl stop nginx.service
# 开机自动启动
systemctl enable nginx.service
# 取消开机自动启动
systemctl disabled nginx.service
# 查看进程
ps -ef | grep nginx
相关推荐
@220611 小时前
银河麒麟系统离线环境下用docke方式部署(Postgres、Nginx、Redis、JDK)
运维·数据库·redis·nginx
戈壁老孙13 小时前
使用Nginx实现动态后端服务切换:一套配置管理多环境
运维·nginx
天天天天学习丶15 小时前
Nginx 域名解析后默认打开其他项目问题解决方案
nginx
取谖慕12.16 小时前
keepailved+nginx+nfs高可用
运维·nginx·nfs
小Ti客栈16 小时前
Nginx进阶配置实战全攻略:SSL部署、防盗链、压缩、代理、限流、请求合并
nginx·负载均衡·ssl
岁岁种桃花儿18 小时前
深入理解 Keepalive:从协议到 Nginx 实战(全场景解析)
运维·nginx
康小庄18 小时前
通过NGINX实现将小程序HTTPS请求转为内部HTTP请求
java·spring boot·nginx·spring·http·小程序
牵牛老人19 小时前
Qt后端开发遇到跨域问题终极解决方案 与 Nginx反向代理全解析
qt·nginx·状态模式
小目标一个亿1 天前
Windows平台Nginx配置web账号密码验证
linux·前端·nginx
养乐多q.♡2 天前
docker镜像的nginx配置证书SSL,单独配置单个localtion使用证书,其他nginx配置不影响
nginx·docker·ssl