CentOS Nginx 1.13.9 部署文档

以下是 Nginx 1.13.9 的详细安装步骤(基于 CentOS/Ubuntu 系统):


1. 安装依赖

CentOS/RHEL
bash 复制代码
sudo yum install -y gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
Ubuntu/Debian
bash 复制代码
sudo apt update && sudo apt install -y build-essential libpcre3 libpcre3-dev zlib1g zlib1g-dev libssl-dev

2. 下载并解压 Nginx 1.13.9

bash 复制代码
wget http://nginx.org/download/nginx-1.13.9.tar.gz
tar -zxvf nginx-1.13.9.tar.gz
cd nginx-1.13.9

3. 配置编译选项

bash 复制代码
./configure \
--prefix=/data/opt/nginx-1.13.9 \
--sbin-path=/data/opt/nginx-1.13.9/sbin/nginx \
--conf-path=/data/opt/nginx-1.13.9/conf/nginx.conf \
--error-log-path=/data/opt/nginx-1.13.9/log/error.log \
--http-log-path=/data/opt/nginx-1.13.9/log/access.log \
--pid-path=/data/opt/nginx-1.13.9/run/nginx.pid \
--with-http_ssl_module \
--with-openssl=/data/opt/openssl-1.1.0l

4. 编译并安装

bash 复制代码
make && make install

5. 创建用户和目录

bash 复制代码
# 创建 Nginx 用户和组
sudo groupadd -r nginx
sudo useradd -r -g nginx -s /bin/false -M nginx

# 创建日志目录
sudo mkdir -p /var/log/nginx
sudo chown -R nginx:nginx /var/log/nginx

# 创建临时目录(如果需要)
sudo mkdir -p /var/cache/nginx
sudo chown -R nginx:nginx /var/cache/nginx

6. 配置 Systemd 服务(可选)

创建服务文件 /etc/systemd/system/nginx.service

ini 复制代码
[Unit]
Description=The NGINX HTTP and reverse proxy server
After=network.target

[Service]
Type=forking
PIDFile=/var/run/nginx.pid
ExecStartPre=/usr/sbin/nginx -t
ExecStart=/usr/sbin/nginx
ExecReload=/usr/sbin/nginx -s reload
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

7. 启动并验证

bash 复制代码
# 重新加载 Systemd
sudo systemctl daemon-reload

# 启动 Nginx
sudo systemctl start nginx

# 设置开机自启
sudo systemctl enable nginx

# 验证版本
nginx -v
# 输出应为:nginx/1.13.9

# 检查配置文件
nginx -t
# 输出应为:syntax is ok, test is successful

8. 开放防火墙(如需要)

bash 复制代码
# CentOS
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --reload

# Ubuntu
sudo ufw allow 'Nginx Full'

9. 访问测试

在浏览器中访问服务器 IP,看到以下页面表示成功:

复制代码
Welcome to nginx!

常见问题

1. 端口冲突

如果 80 端口被占用:

bash 复制代码
# 查找占用进程
sudo netstat -tulnp | grep :80

# 停止冲突服务(例如 Apache)
sudo systemctl stop httpd
2. 配置文件路径错误

如果修改过路径,需确保所有配置文件(如 nginx.conf)中的路径一致:

bash 复制代码
# 检查错误日志路径
grep "error_log" /etc/nginx/nginx.conf

附:编译参数说明

  • --prefix: 安装根目录
  • --sbin-path: 可执行文件路径
  • --conf-path: 主配置文件路径
  • --with-http_ssl_module: 启用 HTTPS 支持
  • --with-http_v2_module: 启用 HTTP/2 协议

如果需要其他模块(如 gzipproxy),可在 ./configure 时添加对应参数。

/data/opt/nginx-1.13.9/sbin/nginx -s reload

相关推荐
Johny_Zhao1 天前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
闲云一鹤3 天前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
chlk1233 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑3 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件3 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
xy123063 天前
OpenStack Train 部署实战(三)控制节点--keystone服务
centos·openstack
深紫色的三北六号3 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash3 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI4 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行4 天前
Linux和window共享文件夹
linux