前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >最基础的Nginx教学

最基础的Nginx教学

作者头像
创译科技
发布2019-08-09 14:29:57
9840
发布2019-08-09 14:29:57
举报
文章被收录于专栏:Node开发

NginxApache一样都是一种WEB服务器。基于REST架构风格,以统一资源描述符URI或者统一资源定位符URL作为沟通依据,通过HTTP协议提供各种网络服务。然而,这些服务器在设计之初受到当时的用户规模,网络带宽,产品特点等局限并且各自的定位和发展都不尽相同。这也使得各个WEB服务器有着各自鲜明的特点。Apache的发展时期很长,它有着很多优点:稳定、开源、跨平台等等。所以它被设计为一个重量级的WEB服务器,但是它不支持高并发。在Apache上进行并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。这时候轻量级高并发服务器Nginx就应运而生了。

Nginx为什么会火爆互联网呢?正是由于Nginx的几大显著的特点存在:

代码语言:javascript
复制
Nginx使用基于事件驱动架构,使得其可以支持数以百万级别的TCP连接

高度的模块化和自由软件许可证是的第三方模块层出不穷(这是个开源的时代啊~)

Nginx是一个跨平台服务器,可以运行在Linux,Windows,FreeBSD,Solaris, AIX,Mac OS等操作系统上

这些优秀的设计带来的极大的稳定性

众所周知,Nginx是一款自由的、开源的、高性能的HTTP服务器和反向代理服务器;同时也是一个IMAP、POP3、SMTP代理服务器;Nginx可以作为一个HTTP服务器进行网站的发布处理,另外Nginx可以作为反向代理进行负载均衡的实现。而说到代理,又分为正向代理与反向代理。

正向代理

正向代理也是大家最常接触的到的代理模式,那究竟什么是正向代理呢?我们都知道Google在国内是无法正常访问的,但是某些时候我们由于技术问题需要去访问Google时,我们会先找到一个可以访问Google的代理服务器,我们将请求发送到代理服务器,代理服务器去访问Google,然后将访问到的数据返回给我们,这样的过程就是正向代理。

正向代理的特点

正向代理最大的特点是客户端需要明确知道要访问的服务器地址,Google服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端,正向代理可以隐藏真实客户端的具体信息。

客户端必须设置正向代理服务器,而且需要知道正向代理服务器的IP地址以及代理程序的端口。一句话来概括就是正向代理代理的是客户端,是一个位于客户端和Google服务器之间的服务器,为了从Google服务器取得数据,客户端向代理服务器发送一个请求并指定目标(Google服务器),然后代理向原始服务器转交请求并将获得的数据返回给客户端。

正向代理的使用:

代码语言:javascript
复制
访问国外无法访问的网站

做缓存,加速访问资源

对客户端访问授权,上网进行认证

代理可以记录用户访问记录(上网行为管理),对外隐藏用户信息

反向代理

说完了什么是正向代理,我们接下来看看什么叫做反向代理,如果我们网站每日访问量达到某个上限,单个服务器远远不能符合我们日常需求,这时候我们首先会想到分布式部署。通过部署多台服务器来解决访问人数限制的问题,然后我们功能其实大部分都是通过Nginx反向代理来实现的。我们可以看下图:

反向代理的特点

我们可以清楚的看到,多个客户端给服务器发送的请求,Nginx服务器接收到请求以后,按照一定的规则转发到不同的服务器进行业务逻辑处理。此时请求来源于哪个客户端是确定的,但是请求由哪台服务器处理的并不明确,Nginx扮演的就是一个反向代理角色。可以这样来理解,反向代理对外都是透明的,访问者并不知道自己访问的是一个代理。反向代理代理的是服务端,主要用于服务器集群分布式部署的情况下,反向代理隐藏了服务器的信息。

反向代理的使用:

代码语言:javascript
复制
保证内网的安全,通常将反向代理作为公网访问地址,Web服务器是内网

负载均衡,通过反向代理服务器来优化网站的负载

正向代理与反向代理区别

代码语言:javascript
复制
在正向代理中,隐藏了请求来源的客户端信息;

在反向代理中,隐藏了请求具体处理的服务端信息;

负载均衡

Nginx既然扮演了反向代理的角色,它是以依据什么样的规则进行请求分发的呢?分发的规则是否可以控制呢?负载量按照一定的规则进行分发到不同的服务器处理的规则,就是一种均衡规则。将服务器接收到的请求按照规则分发的过程,称为负载均衡。

Nginx支持的负载均衡调度算法方式如下:

weight轮询(默认):接收到的请求按照请求顺序逐一分配到不同的后端服务器,如果在使用过程中,某一台服务器宕机,Nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。这种方式下,可以给不同的后端服务器设置一个权重值,权重数据越大,服务器被分配到请求的几率越大。

ip_hash:每个请求按照发起客户端的iphash结果进行匹配,这样的算法下一个固定ip地址的客户端总会访问到同一个后端服务器。

fair:智能调整调度算法,动态的根据后端服务器的请求响应时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少。

url_hash:按照访问的urlhash结果分配请求,每个请求的url会指向后端固定的某个服务器,可以在Nginx作为静态服务器的情况下提高缓存效率。

注意:

代码语言:javascript
复制
Nginx默认不支持fair算法,如果要使用这种调度算法,需要安装upstream_fair模块。

Nginx默认不支持url_hash调度算法,要使用的话需要安装Nginx的hash软件包。

作为一个Nginx的使用者,在编写配置文件肯定出现过问题,可能经常需要将大量时间花费在配置文件编写上面。所以接下来顺便介绍一个在线快速生成Nginx配置文件的网站:

代码语言:javascript
复制
https://nginxconfig.io/

这个网站支持http,https,php,python,Node,缓存,日志等各种配置选项,可以在线生成Nginx的配置文件。而且使用方法极其简单,只需要在网站内填写对应的需求,就可以一键生成配置文件。

参数说明:

代码语言:javascript
复制
Domain:绑定的域名
Path:根目录所在
Document root:根目录下的实际项目名称
Redirect subdomains:如果访问*.niyueling.cn会重定向跳转到niyueling.cn

然后在下面就可以生成对应的nginx配置文件。我们可以下载zip包或者直接复制替换我们的配置文件:

然后替换结束服务器nginx的配置文件,使用nginx -t命令测试文件是否存在问题,若配置文件没问题,则使用 nginx -s reload命令重启服务器。替换之前为了确保不会发生意外,最好提前做好配置文件的备份。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序猿周先森 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
负载均衡
负载均衡(Cloud Load Balancer,CLB)提供安全快捷的四七层流量分发服务,访问流量经由 CLB 可以自动分配到多台后端服务器上,扩展系统的服务能力并消除单点故障。轻松应对大流量访问场景。 网关负载均衡(Gateway Load Balancer,GWLB)是运行在网络层的负载均衡。通过 GWLB 可以帮助客户部署、扩展和管理第三方虚拟设备,操作简单,安全性强。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档