• 关于Nginx


    一.nginx介绍

    1、什么是nginx

    Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。

    由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

    2、nginx能做什么

    Nginx主要就是在服务器集群的基础之上起到负载均衡的作用,让用户访问夜里平均分配到这些服务器上来,这样的话后台的处理能力明显得就提升上来了。

    那么实际上在nginx前端还有一个东西叫F5,它是一个硬件的负载均衡器,这个硬件负载均衡器能够支持非常大的并发量,互联网用户只要访问F5这一个就行了,

    那么在F5上把请求往nginx上分发,但是F5价钱不菲,几十万到几百万之间。但是不使用F5直接访问nginx也是可以的,但是有一个问题叫三点故障问题,

    即如果我们部署nginx服务器的这台机器宕机了,那么就没法访问我们的后面的三台服务器了。相当于nginx是一扇大门一样,门关了,外面的人也就没法进来了。

    可以多部署几台nginx服务器嘛,是的,在大型的互联网项目中,一般nginx都有两台,即双机模式,但是用户进来之后该访问哪台呢?

    这就要使用F5做负载均衡,去管理这两天nginx服务器,F5的负载均衡指的是对nginx的负载均衡即给nginx分配用户访问压力,这样一来一台nginx服务器出现故障了,

    F5还可以支配另一台nginx服务器应对用户访问,避免这里的三点故障即一台nginx宕机了,整个项目就无法运行了。所以使用F5对nginx做负载均衡,

    一台nginx服务器宕机了还有另一个台可以使用,这对于来访问互联网用户是没有影响的,就不会出现问题。F5是硬件负载均衡器稳定性是很高的。

    3、Nginx的应用场景:

    (1)http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。

    (2)虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。

    (3)反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。

    并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

    虚拟主机是一种特殊的软硬件技术,它可以将网络上的每一台计算机分成多个虚拟主机,每个虚拟主机可以独立对外提供www服务,

    这样就可以实现一台主机对外提供多个web服务,每个虚拟主机之间是独立的,互不影响的。

    通过nginx可以实现虚拟主机的配置,nginx支持三种类型的虚拟主机配置,a.基于ip的虚拟主机, b.基于域名的虚拟主机 c.基于端口的虚拟主机

    比如:

    一台nginx服务器绑定两个ip:192.168.101.3、192.168.101.103

    访问不同的ip请求不同的html目录,即:

    访问http://192.168.101.3将访问“html3”目录下的html网页。

    访问http://192.168.101.103将访问“html103”目录下的html网页。

    4、Web服务器分类

    (1)web服务器:Apache,Nginx,IIS;

    (2)web应用服务器:tomcat,resin,jetty;

    区分:web服务器不能解析jsp等页面,只能处理js、css、html等静态资源。

    并发:web服务器的并发能力远高于web应用服务器。

    正向代理:用户——>代理——>google

    反向代理:用户——>nginx——>tomcat

    解释:Tomcat根本不知道请求的来源,只知道所有的请求都是来源于Nginx,不知道真正的来源。

               Jetty默认采用NIO结束在处理I/O请求上更占优势,在处理静态资源时,性能较高。

               Tomcat默认采用BIO处理I/O请求,在处理静态资源时,性能较差。

    解决静态资源加载的问题:

    需要通过nginx访问静态资源,JS、CSS、Image。

    二.nginx安装

    下载:进入http://nginx.org/en/download.html 下载nginx1.8.0版本(当前最新稳定版本)。

     

    安装:

    1、nginx安装环境:

    nginx是C语言开发,建议在linux上运行,本教程使用Centos6.5作为安装环境。

    (1)gcc:安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:yum install gcc-c++

     

    (2)PCRE

    PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

    yum install -y pcre pcre-devel

    注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。

    (3)zlib

    zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

    yum install -y zlib zlib-devel

    (5)openssl

    OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

    nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

    yum install -y openssl openssl-devel

    2、编译安装:

    将nginx-1.8.0.tar.gz拷贝至linux服务器。

    解压:

    tar -zxvf nginx-1.8.0.tar.gz

    cd nginx-1.8.0

    (1)configure

    ./configure --help查询详细参数(参考本教程附录部分:nginx编译参数)

    参数设置如下:

    ./configure 
    --prefix=/usr/local/nginx 
    --pid-path=/var/run/nginx/nginx.pid 
    --lock-path=/var/lock/nginx.lock 
    --error-log-path=/var/log/nginx/error.log 
    --http-log-path=/var/log/nginx/access.log 
    --with-http_gzip_static_module 
    --http-client-body-temp-path=/var/temp/nginx/client 
    --http-proxy-temp-path=/var/temp/nginx/proxy 
    --http-fastcgi-temp-path=/var/temp/nginx/fastcgi 
    --http-uwsgi-temp-path=/var/temp/nginx/uwsgi 
    --http-scgi-temp-path=/var/temp/nginx/scgi

    注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录

    (2)编译安装

    make

    make  install

    安装成功查看安装目录 :

     

    三.启动nginx

    cd /usr/local/nginx/sbin/

    ./nginx

    查询nginx进程:

     

    15098是nginx主进程的进程id,15099是nginx工作进程的进程id。

    注意:执行./nginx启动nginx,这里可以-c指定加载的nginx配置文件,

    如下:

    ./nginx -c /usr/local/nginx/conf/nginx.conf

    如果不指定-c,nginx在启动时默认加载conf/nginx.conf文件,此文件的地址也可以在编译安装nginx时指定./configure的参数(--conf-path= 指向配置文件(nginx.conf))

    四.停止nginx

    1、方式1:快速停止:

    cd /usr/local/nginx/sbin

    ./nginx -s stop

    此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。

    2、方式2:完整停止(建议使用):

    cd /usr/local/nginx/sbin

    ./nginx -s quit

    此方式停止步骤是待nginx进程处理任务完毕进行停止。

    五.重启nginx

    1、方式1:先停止再启动(建议使用):

    对nginx进行重启相当于先停止nginx再启动nginx,即先执行停止命令再执行启动命令。

    如下:

    ./nginx -s quit

    ./nginx

    2、方式2:重新加载配置文件:

    当nginx的配置文件nginx.conf修改后,要想让配置生效需要重启nginx,

    使用-s reload不用先停止nginx再启动nginx即可将配置信息在nginx中生效,如下:

    ./nginx -s reload

    六.安装测试

    nginx安装成功,启动nginx,即可访问虚拟机上的nginx:

    到这说明nginx基本上安装成功。

    七.开发阶段中的环境

    开发环境:自己的电脑

    测试环境:提供给测试人员使用的环境

    生成环境:项目最终发布上线的环境

    预发布环境:数据是和生成环境的数据一致,运行最新的项目代码进去测试

    每个环境的访问地址是不同的,可能因为访问地址不同导致一些问题的产生,所以,为了避免该类问题的产生,可以使不同的环境访问地址完全一致,通过域名访问即可实现。

    1、需求:需要通过域名访问后台系统?

    现在:http://127.0.0.1/rest/page/index

    需要通过manage.taoao.com访问。

    2、Hosts

    用户访问淘宝:

    用户—— www.taobao.com ——本机的hosts文件中查找域名映射,如果查找到就返回 ——浏览器通过域名到DNS查找服务器ip地址 ——执行访问。

    3、实现

    (1)修改本地的hosts,将manage.taotao.com映射到127.0.0.1

    4、Nginx简介

    目前电商和互联网系统都会采用nginx + 应用服务器(tomcat).

    Web服务器分2类:

    1.web服务器

    a) Apache 服务器

    b) Nginx

    c)  IIS

    2.web应用服务器

    a)  tomcat

    b)  resin

    c)    jetty

    区分:web服务器不能解析jsp等页面,只能处理js、css、html等静态资源。

    并发:web服务器的并发能力远高于web应用服务器。

    淘宝

    京东:(也是nginx,将服务名称改为JDWS)

    5、启动nginx的注意事项

    1.其他服务占用80端口,会导致nginx启动失败,检查的方法是  cmd è nginx.exe。

    2.Nginx的路径不能包含中文。

    6、代理

    正向代理:用户 ——代理 ——google

    反向代理:用户——nginx——tomcat

    解释:

    Tomcat根本不知道请求的来源,只知道所有的请求都是来源于Nginx,不知道真正的来源。

    7、解决显示图片的问题

    之前的上传后,通过tomcat访问图片。

    没有真实的项目是通过tomcat访问静态资源。 为什么?

    Tomcat是应用服务器,作用:处理动态请求。

    Nginx、Apache是web服务器,作用:处理静态资源、反向代理功能。

    Web服务器的并发能力远高于应用服务器。

     配置nginx访问图片

    八.负载均衡的配置

    proxy_pass http://myServer;
    upstream:每个设备的状态:
    down:表示单前的server暂时不参与负载 。
    weight:默认为1.weight越大,负载的权重就越大。
    max_fails:允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误
    fail_timeout:max_fails 次失败后,暂停的时间。
    backup:其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。
    Nginx 提供轮询(round robin)、IP 哈希(client IP)和加权轮询 3 种方式,默认情况下,Nginx 采用的是轮询。

    1、轮询(默认)

    每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

    upstream backserver {

    server 192.168.1.14;

    server 192.168.1.15;

    }

    2、加权轮询

    指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

    upstream backserver {

    server 192.168.1.14 weight=1;

    server 192.168.1.15 weight=2;

    }

    3、ip_hash

    每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

    upstream backserver {

    ip_hash;

    server 192.168.0.14;

    server 192.168.0.15;

    }

    4、重试策略

    可以为每个 backserver 指定最大的重试次数,和重试时间间隔,所使用的关键字是 max_fails 和 fail_timeout。

    upstream backserver {

    server 192.168.1.14 weight=1 max_fails=2 fail_timeout=30s;

    server 192.168.1.15 weight=2 max_fails=2 fail_timeout=30s;

    }

    失败重试次数为3,且超时时间为30秒。

    5、热机策略

    upstream backserver {

    server 192.168.1.14 weight=1 max_fails=2 fail_timeout=30s;

    server 192.168.1.15 weight=2 max_fails=2 fail_timeout=30s;

    server 192.168.1.16 backup;
    }

    当所有的非备机(non-backup)都宕机(down)或者繁忙(busy)的时候,就会使用由 backup 标注的备机。必须要注意的是,backup 不能和 ip_hash 关键字一起使用。

  • 相关阅读:
    C#动态编译计算表达式的值 拓荒者
    Microsoft AJAX Library对 Error的扩展 拓荒者
    在分布式事务(MSDTC)中使用OLE DB数据库连接访问数据 拓荒者
    【转】ExtJS DateField 日期控件Format格式化 拓荒者
    自定义 Web 服务器控件 拓荒者
    Microsoft AJAX Library对 Array的扩展 拓荒者
    (转载)IE 浏览器的创新
    XUnit配置Resharper快捷键
    表现层模式MVC
    读Clean Code 数据结构和对象
  • 原文地址:https://www.cnblogs.com/ZJOE80/p/12802354.html
Copyright © 2020-2023  润新知