Nginx笔记

第一部分  nginx基础回顾

(一)nginx介绍

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

其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、简单的配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。

Nginx是一款轻量级Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东新浪、网易、腾讯淘宝等。

来源:360百科。

(二)nginx到底是什么?

Nginx 是⼀个⾼性能的HTTP和反向代理web服务器,核⼼特点是占有内存少,并发能⼒强。

(三)nginx应用场景(具体可以做些什么)

1. http服务器(web服务器)

性能⾮常⾼,⾮常注重效率,能够经受⾼负载的考验。

⽀持50000个并发连接数,不仅如此,CPU和内存的占⽤也⾮常的低,10000个没有活动的连接才占⽤2.5M的内存。

2. 反向代理服务器

说到反向代理,我们不得不提一下正向代理。对比更容易让我们理解正向/反向代理。

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

正向代理的典型用途是为在防火墙内的局域网客户端提供访问Internet的途径。正向代理还可以使用缓冲特性(由mod_cache提供)减少网络使用率。

使用ProxyRequests指令即可激活正向代理。因为正向代理允许客户端通过它访问任意网站并且隐藏客户端自身,因此你必须采取安全措施以确保仅为经过授权的客户端提供服务。

(来源:360百科)


图(1):正向代理示意图


反向代理:浏览器客户端发送请求到反向代理服务器(⽐如Nginx),由反向代理服务器选择原始服务器提供服务获取结果响应,最终再返回给客户端浏览器。


图(2):反向代理示意图


3. 负载均衡服务器

负载均衡:就是当⼀个请求到来的时候(结合反向代理示意图),Nginx反向代理服务器根据请求去找到⼀个原始服务器来处理当前请求,那么这叫做反向代理。那么,如果⽬标服务器有多台(⽐如上图中的tomcat1,tomcat2,tomcat3...),找哪⼀个⽬标服务器来处理当前请求呢?这样⼀个寻找确定的过程就叫做负载均衡。

⽣活中也有很多这样的例⼦,⽐如,我们去银⾏,可以处理业务的窗⼝有多个,那么我们会被分配到哪个窗⼝呢?这样的⼀个过程就叫做负载均衡。

负载均衡就是为了解决⾼负载的问题。发起多个请求,nginx会根据设置的策略来实现负载均衡,比如轮询、设置权重的方式。

4. 动静分离


图(3):动静分离示意图


Nginx特点:

跨平台:Nginx可以在⼤多数类unix操作系统上编译运⾏,⽽且也有windows版本;

Nginx的上⼿⾮常容易,配置也⽐较简单;

⾼并发,性能好;

稳定性也特别好,宕机概率很低。

Nginx安装:

1.上传nginx安装包到linux服务器,nginx安装包(.tar⽂件)下载地址:http://nginx.org

2.安装Nginx依赖,pcre、openssl、gcc、zlib(推荐使⽤yum源⾃动安装)

yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel

3.解包Nginx软件包

tar -xvf nginx-1.17.8.tar

4.进⼊解压之后的⽬录 nginx-1.17.8

cd nginx-1.17.8

5.命令⾏执⾏

./confifigure

6.命令⾏执⾏

 make

7.命令⾏执⾏ make install,完毕之后在/usr/local/下会产⽣⼀个nginx⽬录。


图(4):nginx安装

8.进⼊sbin⽬录中,执⾏启动nginx命令。

cd nginx/sbin

./nginx

9.然后访问服务器的80端⼝(nginx默认监听80端⼝)


图(5):访问nginx

nginx主要命令:

./nginx   启动nginx

./nginx -s stop 终⽌nginx(当然也可以找到nginx进程号,然后使⽤kill -9 杀掉nginx进程)

./nginx -s reload (重新加载nginx.conf配置⽂件)


第二部分  Nginx核心配置文件解读

Nginx的核心配置文件conf/nginx.conf 包含三块内容:全局块、events块、http块。

(一)全局块

从配置⽂件开始到events块之间的内容,此处的配置影响nginx服务器整体的运⾏,⽐如worker进程的数量、错误⽇志的位置等。

图(6):nginx全局块

备注:worker进程数量,通常设置为与cpu数量相等。

(二)events块

events块主要影响nginx服务器与⽤户的⽹络连接,⽐如worker_connections 1024,标识每个workderprocess⽀持的最⼤连接数为1024。

图(7):nginx的events块

(三)http块

http块是配置最频繁的部分,虚拟主机的配置,监听端⼝的配置,请求转发、反向代理、负载均衡等。

图(8):nginx的http块(1)
图(9):nginx的http块(2)
图(10):nginx的http块(3)

第三部分  Nginx应用场景之反向代理

需求:两种方式实现反向代理。

图(11):nginx反向代理

需求一:实现步骤。

1 部署tomcat,保持默认监听8080端⼝。

2 修改nginx配置,并重新加载。

    2.1 修改nginx配置。

图(12):修改nginx配置

    2.2 重新加载nginx配置

   ./nginx -s reload

3 测试,访问http://111.229.248.243:9003,返回tomcat的⻚⾯。

图(13):成功访问tomcat服务器

需求二:实现步骤。

1、 再部署⼀台tomcat,保持默认监听8081端⼝。

2、 修改nginx配置,并重新加载。

图(14):修改 nginx配置2

3、 这⾥主要就是多location的使⽤,这⾥的nginx中server/location就好⽐tomcat中的Host/Context。

location 语法如下:

location [ = |~|~*|^~]  /uri/  {...}

在nginx配置⽂件中,location主要有这⼏种形式:

1)正则匹配 location ~ /lagou { }

2)不区分⼤⼩写的正则匹配 location ~* /lagou { }

3)匹配路径的前缀 location ^~ /lagou { }

4)精确匹配 location = /lagou { }

5)普通路径前缀匹配 location /lagou { }

优先级:  4 > 3 > 2 > 1 > 5


第四部分 Nginx应用场景之负载均衡

需求:实现nginx的负载均衡。

图(15): nginx负载均衡需求

Nginx负载均衡策略

1.轮询  

(默认策略,每个请求按时间顺序逐⼀分配到不同的服务器,如果某⼀个服务器下线,能⾃动剔除)。

图(16): nginx负载均衡策略之轮询设置

2.weight 权重

weight代表权重,默认每⼀个负载的服务器都为1,权重越⾼那么被分配的请求越多(⽤于服务器性能不均衡的场景)。

图(17): nginx负载均衡策略之权重设置

3. ip_hash

每个请求按照ip的hash结果分配,每⼀个客户端的请求会固定分配到同⼀个⽬标服务器处理,可以解决session问题。

图(18): nginx负载均衡策略之ip_hash设置

4. fair(第三方) 按后端服务器的响应时间来分配请求,响应时间短的优先分配。 

 upstream backserver { 

 server 111.229.248.243:8080; 

 server 111.229.248.243:8081;

 fair;

 } 

 5. url_hash(第三方) 按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。

 upstream backserver { 

 server squid1:3128; 

 server squid2:3128;

 hash $request_uri;

 hash_method crc32;

 } 

 在需要使用负载均衡的server中增加

 proxy_pass http://backserver/;

 upstream backserver{

 ip_hash;

 server 127.0.0.1:9090 down; (down 表示当前的server暂时不参与负载)  

server 127.0.0.1:8080 weight=2; (weight 默认为1.weight越大,负载的权重就越大)

 server 127.0.0.1:6060;   (不写,weight 默认为1)

 server 127.0.0.1:7070 backup; (其它所有的非backup机器down或者忙的时候,请求backup机器)

 } 

 max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误 fail_timeout:max_fails次失败后,暂停的时间。

针对负载均衡失败的场景解决方案:

方案一:使用nginx失效剔除模块。可以参考这一篇博客:https://blog.51cto.com/icenycmh/2091910

方案二:搭建一个nginx管理平台,可以动态修改nginx的配置文件并重启nginx。通过运行平台发现服务宕机,自动将upstream里面的内容去掉,然后重启。支持手动和自动修改发布。(大厂用的多)

方案三:使用nginx的收费版本,里面会提供一个管理界面进行管理。

第五部分  Nginx应用场景之动静分离

动静分离就是讲动态资源和静态资源的请求处理分配到不同的服务器上,⽐较经典的组合就是Nginx+Tomcat架构(Nginx处理静态资源请求,Tomcat处理动态资源请求),那么其实之前的讲解中,Nginx反向代理⽬标服务器Tomcat,我们能看到⽬标服务器ROOT项⽬的index.jsp,这本身就是Tomcat在处理动态资源请求了。

所以,我们只需要配置静态资源访问即可。

图(18): nginx动静分离需求

Nginx静态资源配置:

图(19): nginx静态资源配置


第六部分  Nginx底层进程机制剖析

Nginx启动后,以daemon(守护线程)多进程⽅式在后台运⾏,包括⼀个Master进程和多个Worker进程,Master进程是领导,是⽼⼤,Worker进程是⼲活的⼩弟。

图(20):查看nginx进程

master进程:

主要是管理worker进程,⽐如:

1)接收外界信号向各worker进程发送信号(./nginx -s reload)

2)监控worker进程的运⾏状态,当worker进程异常退出后Master进程会⾃动重新启动新的worker进程等

worker进程:

worker进程具体处理⽹络请求。多个worker进程之间是对等的,他们同等竞争来⾃客户端的请求,各进程互相之间是独⽴的。⼀个请求,只可能在⼀个worker进程中处理,⼀个worker进程,不可能处理其它进程的请求。worker进程的个数是可以设置的,⼀般设置与机器cpu核数⼀致。

图(21):nginx进程模型示意图

以 ./nginx -s reload 来说明nginx信号处理这部分:

1)master进程对配置⽂件进⾏语法检查

2)尝试配置(⽐如修改了监听端⼝,那就尝试分配新的监听端⼝)

3)尝试成功则使⽤新的配置,新建worker进程

4)新建成功,给旧的worker进程发送关闭消息

5)旧的worker进程收到信号会继续服务,直到把当前进程接收到的请求处理完毕后关闭

所以reload之后worker进程pid是发⽣了变化的

图(22):./nginx-s reload操作

worker进程处理请求部分的说明:

例如,我们监听9003端⼝,⼀个请求到来时,如果有多个worker进程,那么每个worker进程都有可能处理这个链接。

master进程创建之后,会建⽴好需要监听的的socket,然后从master进程再fork出多个worker进程。所以,所有worker进程的监听描述符listenfd在新连接到来时都变得可读。

nginx使⽤互斥锁来保证只有⼀个workder进程能够处理请求,拿到互斥锁的那个进程注册listenfd读事件,在读事件⾥调⽤accept接受该连接,然后解析、处理、返回客户端。

nginx多进程模型好处:

1)每个worker进程都是独⽴的,不需要加锁,节省开销。

2)每个worker进程都是独⽴的,互不影响,⼀个异常结束,其他的照样能提供服务。

3)多进程模型为reload热部署机制提供了⽀撑。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • Tomcat 系统架构与原理剖析 注意:浏览器访问服务器使⽤的是Http协议,Http是应⽤层协议,⽤于定义数据通...
    acc8226阅读 1,716评论 0 6
  • 指令上下文 nginx.conf中的配置信息,根据其逻辑上的意义,对它们进行了分类,也就是分成了多个作用域,或者称...
    三生纸书阅读 293评论 0 0
  • Nginx 常用功能 Http代理,反向代理:作为web服务器最常用的功能之一,尤其是反向代理。Nginx在做反向...
    三生纸书阅读 222评论 0 0
  • 代理一组服务器 使用upstream指令来定义一组服务器,指令放在http context里如:http { ...
    Hanze2111阅读 2,046评论 0 1
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,532评论 28 53