Nginx常用功能

这篇具有很好参考价值的文章主要介绍了Nginx常用功能。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、 静态资源服务

location

server {
  listen 80;
  server_name _;
  access_log /var/log/nginx/access.log json;
  location /test {
    alias /data/web/test;
    index index.html index.htm;
  }
}

二、反向代理

proxy_pass

server {
  listen 9090;
  server_name _;
  access_log /var/log/nginx/access.log json;
  location / {
  	proxy_pass http://192.168.9.10:9090;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header REMOTE-HOST $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  }
}

其中,proxy_set-header允许重新定义或者添加发往后端服务器的请求头

proxy_set_header Host $host;
#获取客户端真实IP。设置的话,nginx代理后端服务器获取到的是nginx的ip
proxy_set_header X-Real-IP $remote_addr; 
proxy_set_header REMOTE-HOST $remote_addr;
# 经过多重代理,仍能获取客户端真实IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 

三、负载均衡

proxy_pass、upstream

upstream gateway {
  server 192.168.9.30:9031;
  server 192.168.9.31:9031;
}

server {
  listen 9031;
  server_name _;
  access_log /var/log/nginx/access.log json;
  location / {
  	proxy_pass http://gateway;
  }
}

其中负载均衡有这几种常用的算法:轮询、权重、ip_hash。
其中后端服务器可以设置的常用状态有:

upstream bakend{ 
      ip_hash; 
      server 192.168.0.1:90 down; 
      server 192.168.0.1:80 weight=2; 
      server 192.168.0.2:90; 
      server 192.168.0.2:80 backup; 
}


down:表示当前的server暂时不参与负载均衡
weight:默认为1,weight越大,负载的权重越大
backup:预留的备份机器。当其他所有非backup机器出现故障或者忙碌的时候,才会请求backup机器,因为此台机器访问压力最低。

max_fails:允许请求失败的次数,默认为1,当超过最大次数时,返回proxy_next_upstream模块定义的错误
fail_timeout:请求失败超时时间。在经历了max_fails次失败后,暂停服务的时间。max_fails和fail_timeout可以一起使用

四、SSL证书

ssl

server {
    listen       443 ssl;
    server_name  test.test1.com;
    access_log  /data/nginx/logs/access.log;
    error_log /data/nginx/logs/error.log;
   
    ssl_certificate     /data/nginx/conf/crt/test.pem; 
    ssl_certificate_key /data/nginx/conf/crt/test.key;
    ssl_session_timeout 5m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
    ssl_prefer_server_ciphers on;
    
    location /{
        root /data/nginx/html/;
    }
}

解析如下:

# ssl证书的位置
ssl_certificate     /data/nginx/conf/crt/test.pem; 
# ssl私钥的位置
ssl_certificate_key /data/nginx/conf/crt/test.key;
# ssl会话超时时间
ssl_session_timeout 5m;
# nginx使用的ssl密码套件
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
# 是否在客户端和服务器之间选择服务器提供的密码套件作为首选项;设置为on,表示优先使用服务器端提供的密码套件    
ssl_prefer_server_ciphers on;

五、TCP/UDP数据流代理

stream

# 代理后端达梦数据库端口,使外部能够访问
# 可以放在文件第一行
load_module modules/ngx_stream_module.so; 
http {

}

stream {
  server {
    listen 15236;
    proxy_pass 192.168.0.23:15236;
  }
}

六、开启WebSocket代理

map $http_upgrade $connection_upgrade {
          default upgrade;
          '' close;
} 
server {
        listen       9038;
        server_name  _;
 
 
        location / {
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://192.168.0.210:9038;

        proxy_http_version 1.1;
        proxy_read_timeout 60s;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection $connection_upgrade;
        }
}

(一)配置解析

map $http_upgrade $connection_upgrade {
          default upgrade;
          '' close;
} 
server {
        listen       9038;
        server_name  _;
 
 
        location / {
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://192.168.0.210:9038;

        # 确保Nginx使用HTTP 1.1版本与后端服务器进行通信;1.1版本支持处理HTTP握手过程中的特殊头部处理
        proxy_http_version 1.1;
        # 设置代理的读取超时时间为 60 秒,即如果在 60 秒内没有从后端服务器接收到数据,代理将会中断连接。
        proxy_read_timeout 60s;
        # 将客户端的Upgrade头部传递给后端服务器。当$http_upgrade为websocket或不为空时,$connection_upgrade为upgrade;当$http_upgrade为空时,$connection_upgrade为close,根据上边的map进行映射。
        proxy_set_header Upgrade $http_upgrade;
        # 将Connection传递给后端服务器。
        proxy_set_header Connection $connection_upgrade;
        }
}

(二)简介

WebSocket是一种在单个TCP连接上进行全双工通信的协议。WebSocket使得客户端和服务器之间能够双向通信。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。

(三)原理

  1. TCP握手
  2. HTTP握手。客户端发送一个HTTP请求,其中包含了一些特殊的头部,表明它希望升级连接到WebSocket。
GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==
Sec-WebSocket-Version: 13
  1. HTTP101切换协议响应。如果服务器支持WebSocket并且验证客户端的请求合法,服务器会响应一个HTTP101状态码,表示切换协议。服务器的响应头可能如下:
HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: s3pPLMBiTxaQ9kYGzzhZRbK+xOo=
  1. WebSocket握手完成。一旦客户端收到服务器101切换协议响应,WebSocket握手就完成了。此后,客户端和服务器就可以在建立的持久连接上进行全双工通信,发送和接收WebSocket帧。

(四)配置解析

map $http_upgrade $connection_upgrade {
          default upgrade;
          '' close;
} 
server {
        listen       9038;
        server_name  _;
 
 
        location / {
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://192.168.0.210:9038;

        # 确保Nginx使用HTTP 1.1版本与后端服务器进行通信;1.1版本支持处理HTTP握手过程中的特殊头部处理
        proxy_http_version 1.1;
        # 设置代理的读取超时时间为 60 秒,即如果在 60 秒内没有从后端服务器接收到数据,代理将会中断连接。
        proxy_read_timeout 60s;
        # 将客户端的Upgrade头部传递给后端服务器。当$http_upgrade为websocket或不为空时,$connection_upgrade为upgrade;当$http_upgrade为空时,$connection_upgrade为close,根据上边的map进行映射。
        proxy_set_header Upgrade $http_upgrade;
        # 将Connection传递给后端服务器。
        proxy_set_header Connection $connection_upgrade;
        }
}

(五)问题

  1. 如何保证持久连接?
设置超时,多长时间没有活动时就认为连接已断开。且设置心跳机制,客户端定期发送特殊的帧(通常是PING帧)到服务端,确认连接的存活性。

七、跨域

server {
    listen 80;
    server_name your-domain.com;

    location / {
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        add_header 'Access-Control-Allow-Headers' 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
        index  index.html index.htm;
        root /usr/share/nginx/html;
    }
}

(一)解析

server {
    listen 80;
    server_name your-domain.com;

    location / {
        # 允许所有来源的跨域请求
        add_header 'Access-Control-Allow-Origin' '*';
        # 允许的请求方法
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        # 允许的头部信息
        add_header 'Access-Control-Allow-Headers' 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
        index  index.html index.htm;
        root /usr/share/nginx/html;
    }
}

(二)简介

跨域(Cross-Origin)是指在 Web 开发中,一个网页的资源请求来自于不同的域(域名、协议或端口),而不是当前页面所在的域。由于浏览器的同源策略(Same-Origin Policy),默认情况下,跨域请求是被禁止的,为了保障用户信息的安全性。

八、基于名称的虚拟主机

server_name文章来源地址https://www.toymoban.com/news/detail-782887.html

server {
    listen 80;
    server_name www.test1.com;
}

server {
    listen 80;
    server_name www.test2.com;
}

(一)解析

	当客户端发送请求时,Nginx会根据请求的域名和其他条件,选择匹配的 server 块来处理请求。通过设置不同的 server_name,你可以配置多个虚拟主机,每个虚拟主机处理不同的域名,从而实现域名之间的隔离。

	这种虚拟主机的隔离方式允许你在同一台服务器上托管多个域名,并为每个域名提供独立的配置和处理逻辑,而不会相互影响。这对于在一个服务器上托管多个网站或应用程序是非常常见的配置。

到了这里,关于Nginx常用功能的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • OPENWRT 使用nginx作为web服务器

    OPENWRT 使用nginx作为web服务器

    在op上大家使用nginx作为web服务器,主要是为了其强大的反向代理功能,但op上的nginx官方做了一定的修改,配置上稍显复杂,几篇文章也是比较老的,配置也是一头雾水,作业都不好抄,索性自己查了资料学了些nginx的内容,实现了如下的功能: ####默认你已经完成 域名申请,

    2024年02月04日
    浏览(13)
  • 【Web服务器】Nginx常见问题(二)

    优化内容 设置方式 隐藏版本号 server_tokens off; 设置运行用户/组 方法一:配置文件中修改 user 用户组 组名; 方法二:编译时直接设置 页面缓存时间 expires 时间; 连接保持超时 keepalive_timeout 服务器超时时间 [客户端超时时间] ; 设置工作进程数 worker_processes auto/同CPU数量 ; worker

    2024年02月08日
    浏览(12)
  • Web服务器群集:Nginx网页及安全优化

    Web服务器群集:Nginx网页及安全优化

    目录 一、理论 1.Nginx网页优化 2.Nginx安全优化 3.Nginx日志分割 二、实验 1.网页压缩 2.网页缓存 3.连接超时设置 4.并发设置 5.隐藏版本信息  6.脚本实现每月1号进行日志分割 7.防盗链 三、总结 (1)概述 在企业中,部署Nginx后只采用默认的配置参数,会引发网站很多问题,换言

    2024年02月13日
    浏览(17)
  • 【在 Ubuntu 上配置 Nginx 作为 Web 服务器】

    在 Ubuntu 上配置 Nginx 作为 Web 服务器非常常见,以下是在 Ubuntu 上配置 Nginx 的基本步骤: 安装 Nginx : 打开终端,运行以下命令来安装 Nginx: 启动 Nginx : 安装完成后,Nginx 会自动启动。你可以使用以下命令来检查 Nginx 服务状态: 配置 Nginx : Nginx 的配置文件位于 /etc/nginx/

    2024年04月23日
    浏览(17)
  • 如何在虚拟专用服务器上配置 Nginx Web 服务器

    本文档涵盖的是不再受支持的 Ubuntu 版本。如果您目前正在运行 Ubuntu 12.04 服务器,我们强烈建议升级或迁移到受支持的 Ubuntu 版本: 升级到 Ubuntu 14.04 从 Ubuntu 14.04 升级到 Ubuntu 16.04 将服务器数据迁移到受支持的版本 原因: Ubuntu 12.04 已于 2017 年 4 月 28 日到达生命周期终点(

    2024年04月27日
    浏览(15)
  • Nginx:高性能的Web服务器与反向代理

    在现代互联网应用程序的开发和部署中,选择一个可靠、高性能的Web服务器是至关重要的。Nginx是一个备受推崇的选择,它以其卓越的性能和可靠性在开发者社区中享有盛誉。本文将介绍Nginx的概念、优势,以及如何使用Nginx作为Web服务器和反向代理。 Nginx(发音为“engine X”

    2024年02月19日
    浏览(16)
  • 在 【Linux Centos】下搭建 【Nginx Web】 服务器

    系统:Linux Centos 7.9 gcc 、c++、pcre、zlib、openssl等 添加内容

    2024年01月16日
    浏览(15)
  • Nginx - ​一个高性能、灵活可靠的开源Web服务器

    Nginx - ​一个高性能、灵活可靠的开源Web服务器

    Nginx是什么?   Nginx是一个 高性能的HTTP和反向代理web服务器 ,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。2011年6月1日,nginx 1.0.4发布。   特点是 占有

    2024年02月07日
    浏览(16)
  • 【业务功能篇85】微服务-springcloud-Nginx-反向代理-网关

    【业务功能篇85】微服务-springcloud-Nginx-反向代理-网关

    Nginx域名 在c:/window/system32/drivers/etc/hosts文件,我们在这个文件中添加 注意如果是没有操作权限,那么点击该文件右击属性,去掉只读属性即可 通过这个域名访问到Nginx服务 nginx.cof是全局配置文件 /mydata/nginx/conf/nginx.cof 文件中最后配置了一个信息 include /etc/nginx/conf.d/*.conf 表示

    2024年02月10日
    浏览(22)
  • 【Nginx运维】Nginx升级打补丁

    升级nginx的过程主要需要以下步骤: 1.备份当前nginx版本及其配置文件。 2.下载新版本的nginx安装包。(如nginx-1.20.1.tar.gz) 3.解压缩安装包,并进入该目录。 4.使用configure脚本配置编译选项。 5.执行make命令进行编译。 make 6.停止旧版本的nginx服务,启动新版本nginx服务。 7.验证

    2024年02月12日
    浏览(10)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包