NGINX简单总结

特点总结

  1. nginx有一个master进程和多个worker进程,master进程是主要用来管理worker进程,管理的内容包括以下内容:接收来自外界的信号,向各个woker进程发送信号,监控worker进程的运行状态,当worker进程退出后,会自动重新启动新的worker进程。

  2. 每个worker进程是相对独立平等的,相互竞争处理一个请求,并且从始至终的处理这个请求,不会出现处理其他进程的请求;

选择NGINX的理由

  1. 底层由epoll(异步阻塞的方式)来实现,可以实现高并发;

  2. 内存消耗少,1w个非活跃的HTTP Keep-Alive连接在Nginx中仅消耗2.5MB的内存;

  3. 成本低廉,BSD协议开源免费;

  4. 配置文件简单易懂;

  5. 支持rewrite重写规则;能根据域名、URL的不同,将HTTP请求分发到不同的后端服务器群组中;

  6. 内置的健康检查功能;即使Nginx proxy后端的某台web服务器宕机了,也不会影响前端访问;

  7. 稳定性高;

  8. 支持热部署;可以长时间的运行,并且可以在不间断服务的情况下,对软件版本进行升级;

  9. 设计极具扩展性;它完全是由多个不同功能、不同层次、不同类型且耦合度极低的模块组成;

配置结构

nginx.conf的配置结构包括main全局块、events块、http块、server块、location块;不同模块的执行关系:server继承main,location继承server,upstream既不会继承指令也不会被继承,它有它自己的特殊指令;

指令上下文 解释
main 与具体业务功能无关的一些参数;比如工作进程数等;
http 与提供http服务相关的一些配置参数;
server http服务器上支持若干个虚拟主机, 每个虚拟主机对应一个server配置项,配置项中包含该虚拟主机相关的配置;
location http服务中,某些特定的URL对应的一系列配置项;
mail 实现email相关的SMTP/IMAP/POP3代理时,共享的一些配置项;

nginx.conf

# 定义Nginx运行的用户和用户组,默认是nobody
user nobody;
# 允许生成的进程数,建议设置为等于CPU总核心数
worker_processes 2;
# 指定错误日志路径,级别;这个设置可以放入全局块,http块,server块,级别依次为:debug|info|notice|warn|error|crit|alert|emerg
error_log logs/error.log info;

# 工作模式以及连接数上线
events {
   use epoll;  # 时间驱动模型,包括select, poll, epoll, kqueue等
   worker_connections 1024;  # 单个work进程允许的最大连接数目
}

# http服务器
http {
   #gzip模块设置
   gzip on; #开启gzip压缩输出
   gzip_min_length 1k; #最小压缩文件大小
   gzip_buffers 4 16k; #压缩缓冲区
   gzip_http_version 1.0; #压缩版本(默认1.1,前端如果是squid2.5请使用1.0)
   gzip_comp_level 2; #压缩等级
   gzip_types text/plain application/x-javascript text/css application/xml;
   #压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。
   gzip_vary on;
   #limit_zone crawler $binary_remote_addr 10m; #开启限制IP连接数的时候需要使用
   
   # 子配置放到/usr/local/nginx/conf/servers/*/目录下
   include /usr/local/nginx/conf/servers/\*/upstream.conf;
   include /usr/local/nginx/conf/servers/\*/site.conf;
}

site.conf

# 虚拟主机的配置
# http接口
server {  
   listen          80 default_server;  
   client_max_body_size 20m;  # 最大上传包
   server_name     www.linuxidc.com;  
   access_log     logs/linuxidc.access.log main;
   # 子配置放到/usr/local/nginx/conf/servers/test/locations/目录下
   include /usr/local/nginx/conf/servers/test/locations/\*.location;
}

# https接口
# 1. https的固定端口是443,不同于HTTP的80接口
# 2. SSL标准需要引入安全证书,所以在 conf 中你需要指定证书和它对应的 key
server {
   listen 443 ssl http2 default_server;
   root /usr/local/nginx/conf/servers/test/nginx_www/;  # 指定证书的位置
   include /usr/local/nginx/conf/servers/common/ssl_config.conf;
   include /usr/local/nginx/conf/servers/test/https/ssl_rewrite.location;
   include /usr/local/nginx/conf/servers/test/locations/\*.location;
}

upstream.conf

# 设定实际的服务器列表,几种负载均衡的方式

upstream mysvr1 {  
   server 127.0.0.1:7878;
   # 热备(其它所有的非backup机器down或者忙的时候,请求backup机器))
   server 192.168.10.121:3333 backup;
}
upstream mysvr2 {
   # weigth参数表示权值,权值越高被分配到的几率越大
   server 192.168.1.11:80 weight=5;
   server 192.168.1.12:80 weight=1;
   server 192.168.1.13:80 weight=6;
   send_timeout 90;
   proxy_connect_timeout 50;
   proxy_send_timeout 90;
   proxy_read_timeout 90;
}
upstream https-svr {
   # 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题
   ip_hash;
   server 192.168.1.11:90;
   server 192.168.1.12:90;
}

project.location

# 反向代理的路径,和upstream绑定,location后面绑定映射的路径
location /app1 {
   include uwsgi_params;
   uwsgi_pass mysvr1;
}

location /passport {
   include uwsgi_params;
   uwsgi_pass https-svr;
}

Nginx简单总结的更多相关文章

  1. Nginx 简单的负载均衡配置示例(转载)

    原文地址:Nginx 简单的负载均衡配置示例(转载) 作者:水中游于 www.s135.com 和 blog.s135.com 域名均指向 Nginx 所在的服务器IP. 用户访问http://www ...

  2. nginx简单反向代理和负载均衡(ubuntu)

    nginx简单反向代理与负载均衡 环境:三台ubuntu 12.04.5 虚拟机    均装有nginx 1.1.19 以下u1(192.168.240.129) ,u2(192.168.240.13 ...

  3. nginx简单双机热备:backup参数的使用

    nginx简单双机热备:backup参数的使用 nginx简单双机热备:backup参数的使用

  4. Nginx简单操作

    Nginx简单操作 平滑重启:读取配置文件,正确后启动新nginx,关闭旧服务进程 # kill HUP nginx.pid # /usr/sbin/nginx -c /etc/nginx/nginx ...

  5. 负载均衡介绍及Nginx简单实现

    负载均衡介绍及Nginx简单实现 负载均衡 负载均衡介绍及Nginx简单实现 1. 介绍 2. 常用的开源软件 2.1 LVS 优点 缺点 2.2 Nginx 优点 缺点 3. 常用的开源反向代理软件 ...

  6. 一篇文章带你了解轻量级Web服务器——Nginx简单入门

    一篇文章带你了解轻量级Web服务器--Nginx简单入门 Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件代理服务器 在本篇中我们会简单介绍Nginx的特点,安装,相关指令使用以及配置信 ...

  7. Nginx简单实现网站的负载均衡

    在大型网站搭建时,都会考虑如果用户量每日不断增加,大量的并发访问,会不会给网站.数据库带来崩盘的灾难.今天我们就讨论一下,现实中如何解决这些问题的一套最为容易实现的方案. 控制并发,大家都会首先考虑的 ...

  8. 使用nginx简单实现负载均衡

    只是简单使用nginx玩玩而已,知道能这么用,但是在实际项目中并没有实践过,在项目不大的时候用不到,但是对于理解负载均衡来说还是可以的. 利用虚拟机安装了三个centOS系统,然后顺便装了环境. 这里 ...

  9. Nginx 简单记录

    Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. ...

随机推荐

  1. HDU 3595 every-sg模型

    多个子游戏同时进行,每个子游戏给出两个数a,b,可以将大的数减去k倍小的数,不能操作者输. 策略就是对于一个必胜的游戏要使得步数更长,对于一个必败的游戏使得步数最短. 以下都来自贾志豪的论文.. 对于 ...

  2. ASP.NET MVC学习(二)之控制器Controller

    1.控制器 Controller接收用户请求,将Model和View匹配在一起,共同完成用户请求.它是一个分发器,通过选择不同的Model.View,可以决定完成不同的用户请求. 但Controlle ...

  3. Sublime Text 3 绿色汉化版 x64

    之前做了<Sublime Text 2 绿色汉化版 x64>,这些天抽空做了下 ST3 的汉化.. 果然我没有任何理由爱上 ST3,不仅pojie麻烦,而且汉化更麻烦,菜单字符长度做了限制 ...

  4. js调试系列: 断点与动态调试[基础篇]

    js调试系列目录: - 额,我说的不是张敬轩的 断点 这首歌,是调试用到的断点,进入正题吧. 昨天留的课后练习 1. 分析 votePost 函数是如何实现 推荐 的.其实我们已经看到了源码,只要读下 ...

  5. aps.net webform框架下页面服务器端控件和html控件用法

    (1)select 下拉框 前端: <select name="gameserverlist" id="gameserverlist" runat=&qu ...

  6. apropos找命令助手

    apropos (意即"关于")能够搜索 Linux 帮助文档来帮你找到你想要的命令.比如说,你不记得你用的发行版用的什么防火墙工具了.你可以输入 apropos "fi ...

  7. 【题解】BZOJ 1901: Zju2112 Dynamic Rankings

    题目传送门(权限题) 一道类似的非权限题 题意 N个数的序列,每次修改一个数或者询问区间里的第K小.可以离线. 简要做法 假如要求在线,可以树状数组套个线段树~ 但是这题是可以离线的,就可以乱搞整体二 ...

  8. 使用badblocks命令检测、修复硬盘坏道(待验证)

    今天我的新硬盘到了.暂时没想好怎么用它.可以把它装入光驱位硬盘架给G430用,也可以把它当成移动硬盘来用. 想起以前记录过一个badblocks的用法,用来检查坏道,这里再贴一遍备用. ####### ...

  9. springmvc上下文与springcontext上下文的关系

    内容摘自:springmvc与spring上下文的关系 原理区别 一直不清楚springmvc-servlet.xml配置与spring.xml两个配置文件出现的上下文关系.今天找到一上面的文章,倒是 ...

  10. 上传文件异常问题 | 413 Request Entity Too Large

    开发中遇到这样的问题:一个上传文件的功能,内网测试都正常了,但是发布到外网就无法上传大点的(大于1MB)文件,更奇怪的是,后台还没有任何的异常信息. 于是就用Http抓包工具(HttpDetect)看 ...