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键退出。
相关推荐
翟天保Steven29 分钟前
Ubuntu-安装Epics教程
linux·ubuntu·epics
Nightwish531 分钟前
Linux随记(二十一)
linux·运维·服务器
IT成长日记3 小时前
【自动化运维神器Ansible】Ansible常用模块之File模块详解
运维·自动化·ansible·file·常用模块
獭.獭.3 小时前
Linux -- 文件【上】
linux·运维·服务器·进程·pcb
不会敲代码的XW3 小时前
高可用集群KEEPALIVED的详细部署
运维·云原生
老实巴交的麻匪3 小时前
提问的智慧,用最少的时间获得最有效的帮助
运维·团队管理
nbsaas-boot4 小时前
收银系统优惠功能架构:可扩展设计指南(含可扩展性思路与落地细节)
java·大数据·运维
未来之窗软件服务4 小时前
基于 Nginx 与未来之窗防火墙构建下一代自建动态网络防护体系—仙盟创梦IDE
网络·ide·nginx·服务器安全·仙盟创梦ide·东方仙盟
爱喝酸奶的桃酥4 小时前
解密负载均衡:如何轻松提升业务性能
运维·负载均衡
搬码临时工4 小时前
使用FRP搭建内网穿透工具,自己公网服务器独享内外网端口转发
运维·服务器