Nginx简明教程

目录

什么是Nginx

Nginx官网的定义如下

nginx [engine x] is an HTTP and reverse proxy server, a mail proxy server, and a generic TCP/UDP proxy server

为什么是Nginx

除了Nginx, Web Server的老大哥应该是Apache HTTP Server(httpd, 下文简称Apache), Apache和Nginx一起支撑了互联网上超过50%的流量

那为什么我们要重点介绍Nginx呢

Nginx相比Apache的优点

  • 轻量级

  • 配置简洁

  • 高并发(实现基于异步非阻塞)

  • 高静态处理能力

Apache相比Nginx的优点

  • PHP支持更好

  • 插件多, 而Nginx部分插件需要收费或自己编译

  • 高动态处理能力

综上所述, 通常

  • Nginx用作静态和反向代理服务器, 处理前端静态请求

  • Apache用作动态代理服务器, 处理后端动态请求

示例代码

为了验证nginx配置, 写了一个简单的服务器程序, 完成的Demo代码可以参考这里的StudyNginx, 其中

  • url显示的内容如下
/                                Welcome to Express
/users                       users
/proxy                       proxy
/proxy/users             proxy/users
  • 运行的端口号为3000

反向代理

反向代理是Nginx最常用的功能之一, 配置如下

server {
    location / {                             
            proxy_pass http://127.0.0.1:3000;
    }
}

执行

sudo service nginx restart

重启nginx后, 使用服务器ip访问各url效果如下

server-ip/                         Welcome to Express
server-ip/users                users
server-ip/proxy                proxy
server-ip/proxy/users   proxy/users

url的/问题

在设置反向代理proxy_pass时, 在url后面加不加"/"有区别么? 我们来实际看下效果

  • 不加/
server {
    location / {                              
    }                                         
                                              
    location /proxy/ {                         
            proxy_pass http://127.0.0.1:3000; 
    }
}

重启nginx后, 使用服务器ip访问各url效果如下

server-ip/                        Welcome to Nginx <-- 发生改变
server-ip/users                Page Not Found <-- 发生改变
server-ip/proxy                proxy
server-ip/proxy/users   proxy/users
  • 加上/
server {
    location / {                              
    }                                         
                                              
    location /proxy/ {                         
            proxy_pass http://127.0.0.1:3000/; 
    }
}

重启nginx后, 使用服务器ip访问各url效果如下

server-ip/              Welcome to Nginx <-- 发生改变
server-ip/user                  Page Not Found <-- 发生改变
server-ip/proxy                Welcome to Express <-- 发生改变
server-ip/proxy/users   users <-- 发生改变

从上面的例子可以看出

如果proxy_pass的url中加上"/", 那么反向代理会去掉location部分

负载均衡

当服务器压力越来越大, 就需要考虑用多台服务器提供服务, 这样Nginx就又可以"变身"负载均衡服务器

配置方法如下

upstream server-name  {
    server server-ip-01;
    server server-ip-02;
}

server{ 
    server_name 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; 
    } 
}

负载均衡需要多台设备, 所以这里没有提供实例

页面缓存

开启页面缓存的方式就是在nginx.conf中添加如下

proxy_cache_path /data/nginx/cache levels=1:2 keys_zone=STATIC:200m inactive=24h max_size=1g;

其中需要解释下的是keys_zone选项

keys_zone=STATIC:200m, 表示这个zone名称为STATIC, 分配的内存大小为200MB

接着, 在server中使用该缓存

server {
    proxy_cache STATIC; 
    proxy_cache_key $host$uri$is_args$args; 
    proxy_cache_valid 200 304 10m;
}

这样, 我们的页面缓存就开启啦

验证配置

反向代理, 负载均衡, 页面缓存的配置虽然简单, 但是都是纯文本, 所以难免会出现一些拼写错误, 有什么办法可以验证Nginx配置是否有效么?

使用的命令和输出如下

~ sudo nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

想要了解更多Nginx命令的使用可以查看手册"man nginx"

小结

从上面的介绍已经可以看出, Nginx还是非常小巧强大的

当然还有诸如: URL重写及读写分离等功能没有涉及, 更多讨论在实际开发中摸索后, 再和大家继续讨论分享

参考

更多文章, 请支持我的个人博客

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 上一篇《WEB请求处理一:浏览器请求发起处理》,我们讲述了浏览器端请求发起过程,通过DNS域名解析服务器IP,并建...
    七寸知架构阅读 80,944评论 21 356
  • 第一章 Nginx简介 Nginx是什么 没有听过Nginx?那么一定听过它的“同行”Apache吧!Ngi...
    JokerW阅读 32,650评论 24 1,002
  • Nginx简介 解决基于进程模型产生的C10K问题,请求时即使无状态连接如web服务都无法达到并发响应量级一万的现...
    魏镇坪阅读 1,994评论 0 9
  • 这两章一章是讲良好的自尊是怎么样的,一章是讲自尊受伤了又有什么表现。看到某几条时能看到自己的影子,而且更容易在负面...
    希可人儿阅读 134评论 0 0