加入收藏 | 设为首页 | 会员中心 | 我要投稿 好传媒网 (https://www.haochuanmei.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

前端开发者必备的Nginx知识

发布时间:2019-03-17 23:52:39 所属栏目:优化 来源:精致的前端
导读:nginx在应用程序中的作用 解决跨域 请求过滤 配置gzip 负载均衡 静态资源服务器 nginx是一个高性能的HTTP和反向代理服务器,也是一个通用的TCP/UDP代理服务器,最初由俄罗斯人Igor Sysoev编写。 nginx现在几乎是众多大型网站的必用技术,大多数情况下,我
副标题[/!--empirenews.page--]

nginx在应用程序中的作用

  •  解决跨域
  •  请求过滤
  •  配置gzip
  •  负载均衡
  •  静态资源服务器

nginx是一个高性能的HTTP和反向代理服务器,也是一个通用的TCP/UDP代理服务器,最初由俄罗斯人Igor Sysoev编写。

nginx现在几乎是众多大型网站的必用技术,大多数情况下,我们不需要亲自去配置它,但是了解它在应用程序中所担任的角色,以及如何解决这些问题是非常必要的。

下面我将从nginx在企业中的真实应用来解释nginx在应用程序中起到的作用。

为了便于理解,首先先来了解一下一些基础知识,nginx是一个高性能的反向代理服务器那么什么是反向代理呢?

正向代理与反向代理

代理是在服务器和客户端之间假设的一层服务器,代理将接收客户端的请求并将它转发给服务器,然后将服务端的响应转发给客户端。

不管是正向代理还是反向代理,实现的都是上面的功能。

前端开发者必备的Nginx知识

正向代理

正向代理,意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。

正向代理是为我们服务的,即为客户端服务的,客户端可以根据正向代理访问到它本身无法访问到的服务器资源。

正向代理对我们是透明的,对服务端是非透明的,即服务端并不知道自己收到的是来自代理的访问还是来自真实客户端的访问。

反向代理

反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

反向代理是为服务端服务的,反向代理可以帮助服务器接收来自客户端的请求,帮助服务器做请求转发,负载均衡等。

反向代理对服务端是透明的,对我们是非透明的,即我们并不知道自己访问的是代理服务器,而服务器知道反向代理在为他服务。

基本配置

配置结构

下面是一个nginx配置文件的基本结构:

  1. events {   
  2. }  
  3. http   
  4. {  
  5.     server  
  6.     {   
  7.         location path  
  8.         {  
  9.             ...  
  10.         }  
  11.         location path  
  12.         {  
  13.             ...  
  14.         }  
  15.      }  
  16.     server  
  17.     {  
  18.         ...  
  19.     }  
  •  main:nginx的全局配置,对全局生效。
  •  events:配置影响nginx服务器或与用户的网络连接。
  •  http:可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。
  •  server:配置虚拟主机的相关参数,一个http中可以有多个server。
  •  location:配置请求的路由,以及各种页面的处理情况。
  •  upstream:配置后端服务器具体地址,负载均衡配置不可或缺的部分。

内置变量

下面是nginx一些配置中常用的内置全局变量,你可以在配置的任何位置使用它们。

  1. | 变量名 | 功能 | 
  2.  
  3. | ------ | ------ | 
  4.  
  5. | $host| 请求信息中的Host,如果请求中没有Host行,则等于设置的服务器名 | 
  6.  
  7. | $request_method | 客户端请求类型,如GET、POST 
  8.  
  9. | $remote_addr | 客户端的IP地址 | 
  10.  
  11. |$args | 请求中的参数 | 
  12.  
  13. |$content_length| 请求头中的Content-length字段 | 
  14.  
  15. |$http_user_agent | 客户端agent信息 | 
  16.  
  17. |$http_cookie | 客户端cookie信息 | 
  18.  
  19. |$remote_addr | 客户端的IP地址 | 
  20.  
  21. |$remote_port | 客户端的端口 | 
  22.  
  23. |$server_protocol | 请求使用的协议,如HTTP/1.0、·HTTP/1.1` | 
  24.  
  25. |$server_addr | 服务器地址 | 
  26.  
  27. |$server_name| 服务器名称| 
  28.  
  29. |$server_port|服务器的端口号| 

解决跨域

先追本溯源以下,跨域究竟是怎么回事。

跨域的定义

同源策略限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的重要安全机制。通常不允许不同源间的读操作。

同源的定义

(编辑:好传媒网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读