NGINX配置详解及应用

简介: 目录 NGINX    1 1.1    目录结构    1 1.2    基础配置    1 1.3    location    5 1.4    虚拟主机    5 1.5    状态模块    6 1.6    Rewrite    8 1.7    访问认证    9  目录结构 # tree /application/nginx/ 基础配置 Nginx整个配置文件是以区块的形式组织的。

目录

NGINX    1

1.1    目录结构    1

1.2    基础配置    1

1.3    location    5

1.4    虚拟主机    5

1.5    状态模块    6

1.6    Rewrite    8

1.7    访问认证    9

 

  1. 目录结构

    # tree /application/nginx/

  2. 基础配置

    Nginx整个配置文件是以区块的形式组织的。每个区块以一个大括号{}来表示,区块可分为几个层次,整个配置文件中,Main区位于最上层,在Main区下面可以有Events区、Http区等层级,在Http区中又包含一个或多个server区,每个server区中又可有一个或多个location区,主体框架如下:

    # egrep -v "^$|#" /usr/local/nginx/conf /nginx.conf.default

    核心框架如下:

     

    操作

    # /usr/local/nginx/sbin/nginx -s reload

    # 将11行localhost改成对应的网站名后,重启

    # 对应的bingbing.jpg图片存在当前目录下

    # cat /usr/local/nginx/html/index.html

    <html>

    <head>

    <title>Nginx of kazihuo</title>

    <body background="bingbing.jpg">

    My name is kazihuo!

    </body>

    </head>

    </html>

     

    多个配置文件的调用,需满足以下条件

    方框内conf.d为多出的自定义的配置文件目录,圈内aaa为自定义域名对应的根目录

    # ls /usr/local/nginx/

    aaa conf fastcgi_temp logs sbin uwsgi_temp

    client_body_temp conf.d html proxy_temp scgi_temp

    # cat /usr/local/nginx/conf/nginx.conf

    worker_processes 1;

    events {

    worker_connections 1024;

    }

    http {

    include mime.types;

    default_type application/octet-stream;

    sendfile on;

    keepalive_timeout 65;

    server {

    listen 80;

    server_name localhost;

    location / {

    root html;

    index index.html index.htm;

    }

    error_page 500 502 503 504 /50x.html;

    location = /50x.html {

    root html;

    }

    }

    include /usr/local/nginx/conf.d/*.conf;

    }

     

    自定义的配置文件只需配置server区域(个人实操:多配报错)

    # cat /usr/local/nginx/conf.d/kazihuo.conf

    server {

        listen 80;

        server_name aaa.kazihuo.com;

        location / {

            root aaa;

            index index.html index.htm;

        }

    }

  3. location

  • 作用

location指令的作用是根据用户请求的URI来执行不同的应用。

  • 语法

location[=|~|~*|^~|@]uri{

···

}

  • 说明

location

[=|~|~*|^~|@]

uri

{···}

指令

匹配标识

匹配的网站网址

匹配URI后要执行的配置段

上表中URI部分是关键,其可以是普通的字符串地址路径或者是正则表达式,当匹配成功则执行后面大括号里面的相关指令,正则表达式可有特殊字符。

  • 特殊字符

=    表示精确匹配

~   表示区分大小写的正则匹配

^~  表示以某个常规字符串开头的url即可

~*  表示不区分大消息的正则匹配

!~(*!~) 表示不区分大小写不匹配的正则

/   通配符,任何请求都能匹配到这个location,如果有任何其他location可以匹配,则会覆盖该location

  1. 虚拟主机

  • 概念

虚拟主机在WEB服务里就是一个独立的网站站点,这个站点对应独立的域名(也可能是IP或端口),具有独立的程序及资源目录,可独立对外提供服务供用户访问。

Nginx使用一个server{}标签来标记一个虚拟主机,一个WEB服务里可有多个虚拟主机标签对,即同时可支持多个虚拟主机站点。

  • 类型

基于域名的虚拟主机

应用:外部网站

基于端口的虚拟主机

应用:公司内部网站

基于IP的虚拟主机

应用:几乎不用

  1. 状态模块

    在配置文件里,添加如下配置

    # /usr/local/nginx/sbin/nginx -s reload

    # 状态查看

    第一行表示正处理的活动连接数:6个;

    第二行对应第三行,第一个server表示nginx启动到现在共处理了62个连接;

    第二个accepts表示nginx启动到现在共成功创建62次握手;请求丢失数=(握手数-连接数),可得,本次状态显示没有丢失请求;

    第四行Reading为Nginx读取到客户端的Header信息数;Writing为Nginx返回给客户端的Header信息数;Waiting为Nginx已经处理完正在等候下一次请求指令的驻留连接,在开启keep-alive的情况下,这个值等于active-(reading+writing)。

    或者

    # cat >>/usr/local/nginx/conf/extra/status.conf<< EOF

    ##status

    server{

    listen 80;

    server_name status.kazihuo.com;

    location / {

    stub_status on;

    access_log off;

    }

    }

    EOF

    配置文件里添加一行使Nginx读取指定目录下配置文件

    include extra/*.conf;

  2. Rewrite

    主要功能是实现URL地址重写。

  • 指令语法

rewrite regex replacement [flag];

  • 应用位置

server、location、if

  • 说明

rewrite 是实现URL重写的关键指令,根据regex(正则表达式)部分内容,重定向到replacement部分内容,结尾是flag标记。

  • 例子

rewrite ^/(.*) http://www.kazihuo.org/$1 permanent;

  • 解释

rewrite为固定关键字,表示开启一条rewrite匹配规则,regex为正则表达式部分^/(.*),匹配所有,成功后跳转到http://www.kazihuo.org/$1,$1是去前面regex部分()里的内容,结尾permanent表示永久301重定向标记,即跳转到后面的http://www.kazihuo.org/$1地址上。

  • 应用场景

*可调整用户浏览的URL,看起来更规范,合乎开发及产品人员的需求;

*为了让搜索引擎收录网站内容及用户体验更好,企业会将动态URL地址伪装成静态地址提供服务;

*网站换新域名后,让旧域名的访问跳转到新域名上;

*根据特殊变量、目录、客户端的信息进行URL跳转等。

  1. 访问认证

    添加用户密码访问,只需添加方框内模块;

    # yum install httpd-tools

    # mkdir -pv /application/nginx/conf

    # htpasswd -c -b /application/nginx/conf/htpasswd kazihuo 000000

    -c 指定文件;-b 明文记载;

    # /usr/local/nginx/sbin/nginx -s reload

-------------------------------------------------------------

作者: 罗穆瑞

转载请保留此段声明,且在文章页面明显位置给出原文链接,谢谢!

------------------------------------------------------------------------------

如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

------------------------------------------------------------------------------

目录
相关文章
|
6月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
355 7
|
2月前
|
应用服务中间件 nginx
Nginx进程配置指令详解
Nginx进程配置指令主要包括:`worker_processes`设置工作进程数;`worker_cpu_affinity`绑定CPU核心;`worker_rlimit_nofile`设置最大文件描述符数量;`worker_priority`设置进程优先级;`worker_connections`设置最大连接数;`daemon`控制守护进程模式;`master_process`启用主进程模式;`pid`设置PID文件路径;`user`指定用户和组;`error_log`配置错误日志。这些指令在`nginx.conf`中配置,用于优化和控制Nginx的运行行为。
118 10
|
3月前
|
存储 缓存 应用服务中间件
Nginx 响应头 Vary 的介绍与应用
`Vary` 头部字段在Web开发中扮演着重要角色,通过合理使用 `Vary`,可以优化缓存策略,提升Web应用的性能和响应速度。本文介绍了 `Vary` 头部字段的基本概念、作用、常见使用场景及其在Nginx中的配置方法。通过这些内容,希望读者能够更好地理解和应用 `Vary` 头部字段,提高Web应用的缓存效率和用户体验。
76 10
|
4月前
|
存储 应用服务中间件 Linux
nginx配置证书和私钥进行SSL通信验证
nginx配置证书和私钥进行SSL通信验证
173 4
|
6月前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
327 61
|
6月前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
373 60
|
6月前
|
安全 应用服务中间件 网络安全
配置Nginx反向代理实现SSL加密访问的步骤是什么?
我们可以成功地配置 Nginx 反向代理实现 SSL 加密访问,为用户提供更安全、可靠的网络服务。同时,在实际应用中,还需要根据具体情况进行进一步的优化和调整,以满足不同的需求。SSL 加密是网络安全的重要保障,合理配置和维护是确保系统安全稳定运行的关键。
462 60
|
6月前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
5月前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
209 5
|
5月前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
348 3