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

相关推荐
筵陌12 分钟前
Linux线程概念与控制(下)
linux
-SGlow-1 小时前
MySQL相关概念和易错知识点(3)(表内容的CURD、内置函数)
linux·运维·服务器·数据库·mysql
永远向阳而生2 小时前
【Linux】磁盘存储+文件系统简介
linux
君不见~2 小时前
Windows 10 WSL&Ubuntu 22.04 安装并迁移到 F 盘
linux·ubuntu·wsl迁移盘符·wsl迁移
UQWRJ3 小时前
菜鸟教程Linux ViVimYumApt笔记
linux·运维·笔记
Ray Song3 小时前
Linux DNS解析3 -- DNS解析代理配置使用
linux·dns解析·dns代理
sz66cm3 小时前
Linux基础 -- 内核快速向用户态共享内核变量方案之ctl_table
linux·运维·服务器
努力一点9484 小时前
ubuntu22.04系统入门 linux入门(二) 简单命令 多实践以及相关文件管理命令
linux·运维·服务器·人工智能·gpu算力
UU_Yang5 小时前
Linux跑后台服务
linux·运维·服务器