Linux离线编译安装nginx

Linux离线安装nginx

1.切换到root用户

bash 复制代码
#切换到root用户
su -
#退出root用户
exit

2.目录操作

bash 复制代码
#切到根目录
cd /
#查看目录
ls
#切目录
cd  /home/...
#到对应的目录下解压

3.安装Nginx

在有网络的设备上下载以下文件:

bash 复制代码
#---------------安装pcre库-------------------#
#安装pcre库  
#cd到压缩文件的目录,解压pcre-8.45.tar.gz
tar -zxvf pcre-8.45.tar.gz 
#cd到pcre-8.45目录,执行./configure 编译
./configure
# make编译
make
# make install安装,默认情况下,会安装到/usr/local目录下
make install

#---------------安装zlib库-------------------#

#cd到压缩文件的目录,解压zlib.tar.gz
tar -zxvf zlib.tar.gz 
# cd zlib目录,执行./configure 编译
./configure 
# make编译
make
# make install安装,默认情况下,会安装到/usr/local目录下
make install

#---------------安装openssl库-------------------#
#安装openssl库,openssl版本和nginx是配套的,要安装nginx对应的版本
#cd到压缩文件的目录,解压openssl-3.5.0.tar.gz
tar -zxvf openssl-3.5.0.tar.gz
 #cd openssl-3.5.0目录 执行./config 编译
./config
 # make编译
make
# make install安装,默认情况下,会安装到/usr/local目录下
make install

#---------------安装nginx-------------------#
#nginx,之前的三个库必须先装
#cd到压缩文件的目录,解压nginx-1.28.0.tar.gz
tar -zxvf nginx-1.28.0.tar.gz 
# nginx-1.28目录,执行./configure 编译或者./configure --prefix=/usr/local/nginx
./configure 
# make编译
make
# make install安装,默认情况下,会安装到/usr/local目录下
make install

4.启动验证

bash 复制代码
#启动命令:/usr/local/nginx/sbin/nginx
/usr/local/nginx/sbin/nginx
#重启:
/usr/local/nginx/sbin/nginx --s reload
#停止:
/usr/local/nginx/sbin/nginx --s stop
#测试配置文件是否正常:
 /usr/local/nginx/sbin/nginx --t
#强制关闭:
pkill nginx
查看Nginx进程

你可以使用pspgrep命令来查看Nginx进程是否正在运行。

bash 复制代码
ps -ef | grep nginx

解释输出

  • 如果Nginx正在运行,你会看到类似以下的输出:

    复制代码
    root      1234     1  0 12:00 ?        00:00:00 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
    www-data  1235  1234  0 12:00 ?        00:00:00 nginx: worker process
    • root 表示Nginx主进程以root用户运行。
    • www-data 表示Nginx工作进程以www-data用户运行。
  • 如果Nginx未运行,你只会看到grep命令本身:

    复制代码
    user      1236  1233  0 12:05 pts/0    00:00:00 grep --color=auto nginx
查Nginx服务状态

运行以下命令:

bash 复制代码
sudo systemctl status nginx

解释输出

  • 如果Nginx正在运行,你会看到类似以下的输出:

    bash 复制代码
    ● nginx.service - A high performance web server and a reverse proxy server
       Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
       Active: active (running) since Fri 2025-06-20 12:00:00 CST; 1min ago
     Main PID: 1234 (nginx)
        Tasks: 2 (limit: 4915)
       Memory: 2.5M
       CGroup: /system.slice/nginx.service
               ├─1234 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
               └─1235 nginx: worker process
    • Active: active (running) 表示Nginx正在运行。
    • Main PID 显示了Nginx主进程的进程ID。
  • 如果Nginx未运行,你会看到类似以下的输出:

    bash 复制代码

● nginx.service - A high performance web server and a reverse proxy server

Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)

Active: inactive (dead)

复制代码
#### **检查端口监听情况**

Nginx通常监听80端口(HTTP)和/或443端口(HTTPS)。你可以使用`netstat`或`ss`命令来检查这些端口是否被Nginx占用。

使用netstat命令

```bash
sudo netstat -tulnp | grep nginx

解释输出

  • 如果Nginx正在运行,你会看到类似以下的输出

    复制代码
    tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      1234/nginx
    tcp        0      0 0.0.0.0:443             0.0.0.0:*               LISTEN      1234/nginx
    • LISTEN 表示Nginx正在监听这些端口。
    • 1234 是Nginx主进程的PID。
  • 如果Nginx未运行,该命令不会输出任何内容。

5.修改配置文件

  • 从源码编译安装 :默认情况下,配置文件位于/usr/local/nginx/conf/nginx.conf
nginx 复制代码
server {
    listen 8080;  # 修改为8080端口
    server_name example.com;

    location / {
        root /var/www/html;#修改地址
        index index.html index.htm;
    }
}
  • 配置反向代理:如果你想将请求转发到后端服务器,可以使用proxy_pass指令:
nginx 复制代码
server {
    listen 80;
    server_name example.com;

    location / {
        proxy_pass http://backend-server:8080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}
  • 使用nano编辑器修改nginx.conf

nano是一个简单易用的文本编辑器,适合初学者。

  1. 打开nginx.conf文件:

    bash 复制代码
    sudo nano /usr/local/nginx/conf/nginx.conf
  2. 修改配置文件:

    • 使用方向键导航到需要修改的地方。
    • 直接编辑内容。
  3. 保存并退出:

    • 按下Ctrl + X,然后按下Y确认保存,最后按下Enter键退出。
相关推荐
十六年开源服务商2 分钟前
WordPress服务器响应时间优化终极指南2026
android·运维·服务器
HealthScience3 分钟前
Autoruns自启动/进程控制软件怎么使用?
linux·运维·服务器
Arvin_Rong4 分钟前
Linux 服务器 /tmp 目录:使用机制与安全加固
linux·服务器·安全
gwjcloud8 分钟前
Lvs+Keepalived详解
运维·lvs
RDCJM11 分钟前
nginx 代理 redis
运维·redis·nginx
小江的记录本12 分钟前
【RocketMQ】RocketMQ核心知识体系全解(5大核心模块:架构模型、事务消息两阶段提交、回查机制、延迟消息、顺序消息)
linux·运维·服务器·前端·后端·架构·rocketmq
数据知道13 分钟前
claw-code 源码详细分析:命令宇宙 vs 工具宇宙——`commands` / `tools` 镜像清单如何驱动路由与 shim 执行?
linux·服务器·网络·python·ai·claude code
三万棵雪松15 分钟前
【Linux 物联网网关主控系统-Web部分(二)】
linux·前端·物联网
一叶之秋141216 分钟前
通信之道:解锁Linux进程间通信的无限可能(一)
linux·运维·服务器
Deitymoon17 分钟前
linux——线程的概念
linux