nginx的配置详解

本文详细介绍了nginx的配置,包括配置文件语法高亮显示、热部署(平滑部署)、systemd启动脚本编写、截取ip、反向代理查看真实物理机ip、图片缩小模块的使用以及重定向设置。内容涵盖了nginx的多个核心功能及其应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、nginx配置文件语法高亮显示

首先安装nginx,在官网下载nginx安装包,解压

[root@server1 ~]# tar zxf nginx-1.14.2.tar.gz 

安装nginx编译需要的依赖

[root@server1 ~]# yum install -y gcc pcre-devel zlib-devel

隐藏版本号,关闭debug日志

编译安装

[root@server1 nginx-1.14.2]# ./configure  --prefix=/usr/local/nginx
[root@server1 nginx-1.14.2]# make
[root@server1 nginx-1.14.2]# cd objs/
[root@server1 objs]# ls
autoconf.err  nginx    ngx_auto_config.h   ngx_modules.c  src
Makefile      nginx.8  ngx_auto_headers.h  ngx_modules.o
[root@server1 objs]# ll nginx
-rwxr-xr-x 1 root root 803880 Feb 21 14:16 nginx
[root@server1 objs]# cd ..
[root@server1 nginx-1.14.2]# make install

启动nginx并查看

配置

 查看nginx的配置文件 高量显示

二、nginx的热部署(平滑部署)

在不停止服务的情况下进行升级

首先解压要升级的安装包

[root@server1 ~]# tar zxf nginx-1.15.8.tar.gz

隐藏版本号,关闭debug日志

[root@server1 ~]# cd nginx-1.15.8
[root@server1 nginx-1.15.8]# vim auto/cc/gcc 	##关闭debug

源码编译(这里注意编译时的参数和上个版本编译时的参数要保持一致,否则升级时不匹配)

[root@server1 nginx-1.15.8]# ./configure --prefix=/usr/local/nginx 	##编译的参数和上个版本的参数必须相同

 这里编译完成后 进行安装时只执行make 因为升级时只需要新版被编译安装的nginx二进制程序。

[root@server1 nginx-1.15.8]# make	##make完之后不能进行make install

备份旧版本的二进制文件,以免新版本的nginx出错后无法还原旧版本

将新版本的二进制文件覆盖旧版本的二进制文件,告诉旧服务不要再接收新的用户请求(下线),新服务启动子进程接收用户请求(上线)

旧服务关闭子进程,查看服务版本

当新版本故障,退回原来的服务

首先将旧版本的二进制程序恢复

执行命令[root@server1 sbin]# kill -HUP 3591  拉起旧的服务(重载)

告诉旧服务不要再接收新的用户请求(下线),新服务启动子进程接收用户请求(上线),旧服务关闭子进程,查看服务版本

恢复成功。。。

三、编写systemd的nginx的启动脚本

首先安装httpd

[root@server1 ~]# cd /usr/lib/systemd/system
[root@server1 system]# yum install -y httpd

查看httpd的启动脚本

 cp httpd.service /etc/systemd/system/nginx.service 拷贝,编写nginx的启动脚本,完成后刷新策略

查看nginx的systemd没有起来

因为之前的nginx是开启的并且有进程,所以要杀死之前nginx的进程并重新加载启动。

重新加载,用systemd脚本启动,并查看nginx开启

四、nginx截取ip

对nginx做软链接,方便后期运用命令。

[root@server1 sbin]# ln -s /usr/local/nginx/sbin/nginx /sbin/  做软连接

查看nginx的版本,因为要截取ip,需要--with-http_realip_module模块,因此要重新编译,安装。

[root@server1 ~]# nginx -v
nginx version: nginx/1.14.2
[root@server1 ~]# cd nginx-1.14.2
[root@server1 nginx-1.14.2]# make clean  


[root@server1 nginx-1.14.2]# ./configure  --prefix=/usr/local/nginx/ --with-http_realip_module   重新编译
[root@server1 nginx-1.14.2]# make

拷贝新的二进制文件,覆盖原来的二进制文件。

编辑配置文件

[root@server1 ~]# cd /usr/local/nginx/conf/
[root@server1 conf]# vim nginx.conf     在文件最后写入该模块
server {
       listen 80;
       server_name server1.westos.org; 

       location / {
                return 200 "client real ip: $remote_addr\n";返回一个ip,将该ip取出
       }
}
[root@server1 conf]# nginx -s reload  重新加载配置

测试:

测试前先给本机做解析。

再次编辑配置文件

[root@server1 conf]# vim nginx.conf
server {
       listen 80;
       server_name server1.westos.org;
       set_real_ip_from 172.25.254.1;   nginx的上层ip(真实ip)
       real_ip_header X-Forwarded-For; 该参数会一直累加ip
       real_ip_recursive off;  默认为off取ip的最后一个

       location / {
                return 200 "client real ip: $remote_addr\n";
       }
}
[root@server1 conf]# nginx -s reload

测试:

再次编辑配置文件,将off改为on

[root@server1 conf]# vim nginx.conf
server {
       listen 80;
       server_name server1.westos.org;
       set_real_ip_from 172.25.254.1;
       real_ip_header X-Forwarded-For;
       real_ip_recursive on;  当为on时,取ip最后一个的前一个

       location / {
                return 200 "client real ip: $remote_addr\n";
       }
}
[root@server1 conf]# nginx -s reload

测试:

五、nginx的反向代理实现查看真实物理机ip

打开两台虚拟机,server1做后端来发现真实物理机ip,server2做nginx的反向代理

配置server1

首先将server1编译安装好的nginx发送给server2主机

[root@server1 ~]# cd /usr/local/
[root@server1 local]# scp  -r nginx root@172.25.254.2:/usr/local/

编辑server1的配置文件(注释之前写入的)

[root@server1 conf]# vim nginx.conf

[root@server1 conf]# nginx -s reload  加载配置

编辑server1的发布目录

[root@server1 nginx]# cd html/
[root@server1 html]# ls
50x.html  index.html
[root@server1 html]# vim test.html
test
[root@server1 html]# ls
50x.html  index.html  test.html

配置server2

编辑配置文件

[root@server2 conf]# vim nginx.conf

     upstream westos {         在http模块下写
     server 172.25.254.1:80;
}


server {
       listen 80;
       server_name www.westos.org;

       location / {
           proxy_pass http://westos;   
           #proxy_set_header X-Real-IP $remote_addr;
           proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
       }
}
[root@server2 ~]# /usr/local/nginx/sbin/nginx
[root@server2 ~]# /usr/local/nginx/sbin/nginx -s reload

测试:真机写入解析,测试

测试后在后端server1查看日志

发现真实物理机的ip

六、nginx图片缩小模块

首先需要重新编译,添加图片缩小的模块

[root@server1 nginx-1.14.2]# make clean  清除上次编译的数据

[root@server1 ~]# ls  导入gd包,该包是图片缩小模块的依赖
gd-devel-2.0.35-26.el7.x86_64.rpm  nginx-1.14.2.tar.gz  nginx-1.15.8.tar.gz
nginx-1.14.2                       nginx-1.15.8
[root@server1 ~]# yum install -y gd-devel-2.0.35-26.el7.x86_64.rpm 

[root@server1 nginx-1.14.2]# ./configure  --prefix=/usr/local/nginx/ --with-http_realip_module --with-http_image_filter_module=dynamic 编译

[root@server1 nginx-1.14.2]# make 安装

配置server1

查看进程,关闭nginx

[root@server1 nginx-1.14.2]# ps ax   查看进程,当nginx进程运行时,关闭nginx
[root@server1 nginx-1.14.2]# nginx -s stop

将新编译的nginx二进制文件拷贝到nginx的启动目录下,并将图片缩小模块移动到/usr/local/nginx/modules/在配置文件里写入,方可生效

[root@server1 nginx-1.14.2]# cd objs/
[root@server1 objs]# cp nginx /usr/local/nginx/sbin/
cp: overwrite ‘/usr/local/nginx/sbin/nginx’? y
[root@server1 objs]# mkdir /usr/local/nginx/modules
[root@server1 objs]# cp ngx_http_image_filter_module.so /usr/local/nginx/modules/

编辑配置文件

[root@server1 objs]# cd /usr/local/nginx/conf/
[root@server1 conf]# vim nginx.conf

写入图片缩小模块

编辑默认发布目录,在download目录里导入图片

[root@server1 conf]# cd ../html/
[root@server1 html]# ls
50x.html  index.html  test.html
[root@server1 html]# mkdir download
[root@server1 html]# ls
50x.html  download  index.html  test.html
[root@server1 html]# cd download/
[root@server1 download]# ls
vim.jpg

该图片从真实物理机导入

nginx -t 测试

[root@server1 modules]# nginx -t
nginx: the configuration file /usr/local/nginx//conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx//conf/nginx.conf test is successful

启动nginx

[root@server1 modules]# nginx
[root@server1 modules]# nginx -s reload

在浏览器测试
输入:172.25.254.1/download/vim.jpg,出现图片,缩小版。

七、nginx的重定向

编写配置

[root@server1 conf]# vim /etc/hosts  写入解析
www.westos.org
[root@server1 conf]# ping www.westos.org
[root@server1 conf]# mkdir /web
[root@server1 conf]# cd /web/
[root@server1 web]# ls
[root@server1 web]# vim index.html
www.westos.org

编辑配置文件

[root@server1 conf]# vim nginx.conf
    # HTTPS server
    #
    server {
        listen       443 ssl;
        server_name  www.westos.org;

        ssl_certificate      cert.pem;  认证
        ssl_certificate_key  cert.pem;

        ssl_session_cache    shared:SSL:1m;
        ssl_session_timeout  5m;

        ssl_ciphers  HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers  on;

        location / {
            root   /web;
            index  index.html index.htm;
        }
    }

server {
       listen 80;
       server_name www.westos.org;
       

       location / {
       root /web;
       index index.html;
       }
}

}

重新编译安装

[root@server1 nginx-1.14.2]# make clean
[root@server1 nginx-1.14.2]# yum install -y openssl-devel
[root@server1 nginx-1.14.2]# ./configure  --prefix=/usr/local/nginx/ --with-http_realip_module --with-http_image_filter_module=dynamic --with-http_ssl_module
[root@server1 nginx-1.14.2]# make

查看进程,杀死nginx在运行的所有进程

将新编译的nginx二进制文件拷贝到nginx的启动目录下并拷贝ngx_http_image_filter_module.so

[root@server1 objs]# cp nginx /usr/local/nginx/sbin/
cp: overwrite ‘/usr/local/nginx/sbin/nginx’? y
[root@server1 objs]# cp ngx_http_image_filter_module.so /usr/local/nginx/modules/
cp: overwrite ‘/usr/local/nginx/modules/ngx_http_image_filter_module.so’? y

启动nginx,出现认证错误,自己添加认证

将证书拷贝到/usr/local/nginx/conf/

[root@server1 certs]# cp cert.pem /usr/local/nginx/conf/

开启nginx,并查看端口

浏览器输入www.westos.org

输入https://www.westos.org

真实物理机测试

编辑配置文件,使其重定向到302

[root@server1 conf]# vim nginx.conf

当访问www.westos.org的时候跳转到https://www.westos.org

重启动服务测试

Nginx 是一个高性能的开源 Web 服务器和反向代理服务器。它的配置文件是一个重要的部分,影响着服务器的行为和性能。下面是对 Nginx 配置文件的详细解释: 1. 配置文件位置: Nginx配置文件通常位于 /etc/nginx/nginx.conf。此外,可以通过 include 语句包含其他配置文件,使配置更加模块化。 2. 基本结构: Nginx配置文件由多个指令和块组成。指令是配置文件的最小单位,而块是由一对花括号括起来的指令集合。配置文件从上到下按顺序解析,遇到块会进一步解析块内的指令。 3. 主要指令: - worker_processes:指定 Nginx 创建的进程数。通常设置为 CPU 核心数的倍数。 - events:配置 Nginx 处理连接和请求的事件模型。 - http:定义 HTTP 服务器的全局配置。 - server:定义一个虚拟主机(或称为 server block),可以包含多个 location 块。 - location:根据请求的 URI 匹配规则,定义不同的请求处理方式。 4. 常用配置选项: - listen:指定监听的 IP 地址和端口。 - server_name:指定虚拟主机的域名。 - root:指定网站根目录。 - index:指定默认的索引文件。 - location:根据匹配规则指定不同的处理方式,如代理、重定向、静态文件处理等。 5. 变量和指令: Nginx 支持一些内置变量和指令,用于实现动态的配置和请求处理。常见的变量包括 $uri、$args 和 $http_user_agent,常见的指令包括 if、rewrite 和 return。 6. 配置文件的重载: 在修改配置文件后,可以通过发送信号给 Nginx 进程来重新加载配置,而无需停止服务器。常用的信号有 HUP(重新加载配置)和 TERM(停止服务器)。 这些是 Nginx 配置文件的一些基本概念和常用指令。具体的配置方式和使用方法可以根据实际需求进行深入学习和探索。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值