CentOS 编译安装 nginx

CentOS 编译安装 nginx

修改 yum 源地址为 阿里云

bash 复制代码
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
bash 复制代码
yum makecache

升级内核和软件

bash 复制代码
yum -y update

安装常用软件和依赖

bash 复制代码
yum -y install gcc gcc-c++ make cmake zlib zlib-devel openssl openssl-devel pcre-devel vim net-tools man wget tar

创建用户用户组

bash 复制代码
groupadd nginx
useradd nginx -g nginx -s /sbin/nologin -M

下载并编译安装

下载

bash 复制代码
wget https://nginx.org/download/nginx-1.24.0.tar.gz

解压

bash 复制代码
tar -zxvf nginx-1.24.0.tar.gz

进入nginx源代码目录

bash 复制代码
cd nginx-1.24.0

预编译

bash 复制代码
./configure --prefix=/usr/local/nginx \
 --user=nginx --group=nginx \
 --with-http_stub_status_module --with-http_ssl_module \
 --with-http_realip_module --with-http_gzip_static_module \
 --with-file-aio --with-http_realip_module  

验证 是否 成功

bash 复制代码
echo $?

编译

bash 复制代码
make -j4 

验证 是否 成功

bash 复制代码
echo $?

安装

bash 复制代码
make -j4 install

验证 是否 成功

bash 复制代码
echo $?

ls 以下为验证程序步骤可忽略

bash 复制代码
/usr/local/nginx/sbin/nginx -v

/usr/local/nginx/sbin/nginx -t

# 启动nginx
/usr/local/nginx/sbin/nginx

# 重新载入配置文件
/usr/local/nginx/sbin/nginx -s reload  

# 快速关闭 Nginx
/usr/local/nginx/sbin/nginx -s stop

# 关闭Nginx
/usr/local/nginx/sbin/nginx -s quit                  

编写启动脚本

bash 复制代码
cd /usr/lib/systemd/system/
vim nginx.service
bash 复制代码
[Unit]
Description=nginx
After=network.target remote-fs.target nss-lookup.target
 
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStartPost=/bin/sleep 0.1
ExecStartPre=/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
 
[Install]
WantedBy=multi-user.target
bash 复制代码
# systemctl start|stop|reload|restart|status nginx.service

# 重新加载服务文件
systemctl daemon-reload 

# 启动 nginx 服务
systemctl start nginx.service

# 开机自启:
systemctl enable nginx.service

# 关闭开机自启:
systemctl disable nginx.service

防火墙开放端口

--zone 作用域

--add-port=80/tcp 添加端口

--permanent 永久生效

bash 复制代码
firewall-cmd --zone=public --add-port=80/tcp --permanent
bash 复制代码
firewall-cmd --reload

浏览器访问测试

http://服务器IP地址

相关推荐
知孤云出岫9 分钟前
云上拼团GO指南——腾讯云博客部署案例,双11欢乐GO
云计算·腾讯云
饮浊酒29 分钟前
Linux操作系统 ------(3.文本编译器Vim)
linux·vim
雨雪飘零32 分钟前
Windows系统使用OpenSSL生成自签名证书
nginx·证书·openssl
lihuhelihu38 分钟前
第3章 CentOS系统管理
linux·运维·服务器·计算机网络·ubuntu·centos·云计算
矛取矛求1 小时前
Linux系统性能调优技巧
linux
One_Blanks1 小时前
渗透测试-Linux基础(1)
linux·运维·安全
yanwushu1 小时前
Xserver v1.4.2发布,支持自动重载 nginx 配置
mysql·nginx·php·个人开发·composer
Perishell1 小时前
无人机避障——大疆与Airsim中的角速度信息订阅获取
linux·动态规划·无人机
爱吃喵的鲤鱼1 小时前
linux进程的状态之环境变量
linux·运维·服务器·开发语言·c++
dessler1 小时前
Linux系统-ubuntu系统安装
linux·运维·云计算