Nginx

目录

DNS域名解析

Nginx概念

 应用场景

Nginx简单安装

静态资源访问

根据域名区分项目路径

基于端口号区分项目路径

Nginx反向代理

Location正则表达式

location的作用

location的语法

Upstream Server 负载均衡

负载均衡算法

Nginx配置故障转移

nginx rewrite

Rewrite全局变量

判断IP地址来源

限制浏览器访问

lvs+keepalived+nginx实现高性能负载均衡集群

LVS作用

lvs与Nginx区别

Keepalived作用

双机主从热备

Nginx+Tomcat动静分离

动态页面与静态页面区别

什么是动静分离

为什么要用动静分离

动静分离的原理


DNS域名解析

Nginx概念

       Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好.中国大陆使用nginx网站用户有:新浪、网易、 腾讯等。

      Nginx 是一个高性能的 Web 和反向代理服务器, 它具有有很多非常优越的特性:

  • 作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢迎。能够支持高达 50,000 个并发连接数的响应,感谢 Nginx 为我们选择了 epoll and kqueue 作为开发模型

  • 作为负载均衡服务器:Nginx 既可以在内部直接支持 Rails 和 PHP,也可以支持作为 HTTP代理服务器 对外进行服务。Nginx 用 C 编写, 不论是系统资源开销还是 CPU 使用效率都比 Perlbal 要好的多

  • 作为邮件代理服务器: Nginx 同时也是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服务器),Last.fm 描述了成功并且美妙的使用经验

  • Nginx 安装非常的简单,配置文件 非常简洁(还能够支持perl语法),Bugs非常少的服务器: Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够在 不间断服务的情况下进行软件版本的升级

       Nginx一般用户七层负载均衡,其吞吐量有一定的限制。为了提高整体的吞吐量,会在DNS和Nginx之间引入LVS(软件负载均衡器)、F5(硬负载均衡器) 可以做四层负载均衡,首先DNS解析到LVS(F5),让后LVS(F5)转发给Nginx,在有Nginx转发给真实的服务器

 应用场景

  1. http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器
  2. 虚拟主机。可以实现在一台服务器虚拟出多个网站,例如个人网站使用的虚拟机
  3. 反向代理,使用反向代理隐藏真实ip访问地址
  4. 负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群。可以使用nginx做负载均衡。并且多台服务器可以平均分担负载,不会应为某台服务器负载高宕机而某台服务器闲置的情况
  5. nginz 中也可以配置安全管理、比如可以使用Nginx搭建API接口网关,对每个接口服务进行拦截

Nginx简单安装

解压:nginx-windows

双击: nginx.exe

只要是错误日志文件为空,就表明启动Nginx服务器成功。

静态资源访问

Nginx服务器默认端口号为80

首页的页面,其实就是/html目录下的index.html

根据域名区分项目路径

1、修改hosts文件

127.0.0.1   www.lun.com
127.0.0.1   bbs.lun.com

2、Nginx配置文件中增加两个服务

#添加服务
    server {
		#默认端口号
        listen       80;
		#域名
        server_name  www.lun.com;
		#项目目录地址
        location / {
            root   data/www;
            index  index.html index.htm;
        }     
    }
	server {
        listen       80;
        server_name  bbs.lun.com;

        location / {
            root   data/bbs;
            index  index.html index.htm;
        }     
    }

3、访问域名

基于端口号区分项目路径

1、修改hosts文件

127.0.0.1   www.lun.com:8080
127.0.0.1   www.lun.com:8081

2、Nginx配置文件中增加两个服务

#添加服务
    server {
		#默认端口号
        listen       8080;
		#域名
        server_name  www.lun.com;
		#项目目录地址
        location / {
            root   data/8080;
            index  index.html index.htm;
        }     
    }
	server {
        listen       8081;
        server_name  www.lun.com;

        location / {
            root   data/8081;
            index  index.html index.htm;
        }     
    }

3、访问域名

Nginx反向代理

       反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

       反向代理的好处隐藏真实内部ip地址,请求先访问nginx代理服务器(外网可以访问到),在使用nginx服务器转发到真实服务器中。

1、修改hosts文件

127.0.0.1   www.lun.com

2、Nginx配置文件中增加服务

###当客户端访问www.lun.com,监听端口号为80直接跳转到真实ip服务器地址 127.0.0.1:8080
	server {
        listen       80;
        server_name  www.lun.com;
        location / {
		 #反向代理,跳转到真实服务器中
		 proxy_pass http://127.0.0.1:8080;
            index  index.html index.htm;
        }
	}

3、启动项目(以SpingBoot为例,访问index静态页面)

Location正则表达式

location的作用

       location指令的作用是根据用户请求的URI来执行不同的应用,也就是根据用户请求的网站URL进行匹配,匹配成功即进行相关的操作。

location的语法

  • 以=开头表示精确匹配,如 A 中只匹配根目录结尾的请求,后面不能带任何字符串
  • ^~ 开头表示uri以某个常规字符串开头,不是正则匹配
  • ~ 开头表示区分大小写的正则匹配
  • ~* 开头表示不区分大小写的正则匹配
  • / 通用匹配, 如果没有其它匹配,任何请求都会匹配到

Upstream Server 负载均衡

       Upstream Server 中文翻译 上游服务器,意思就是负载均衡服务器设置,白话文表示(就是被nginx代理最后真实访问的服务器)

       负载均衡算法:配置多个上游服务器(真实业务逻辑访问的服务器)的负载均衡机制

       失败重试机制:当上游服务器(真实业务逻辑访问的服务器)出现超时或者服务器不存活,是否考虑重试机制(补偿机制)

       服务器心跳检测: 当上游服务器(真实业务逻辑访问的服务器),监控检测|心跳检测

1、修改hosts文件

127.0.0.1   www.lun.com

2、配置负载均衡

###定义上游服务器(需要被nginx真实代理访问的服务器) 默认是轮训机制
	upstream  backServer{
	    server 127.0.0.1:8080;
	    server 127.0.0.1:8081;
	}
#配置服务
	server {
        listen       80;
        server_name  www.lun.com;
        location / {
		    ### 指定上游服务器负载均衡服务器
		    proxy_pass http://backServer;
            index  index.html index.htm;
        }
    }

3、开启端口号为8080和8081的tomcat服务器

spring.mvc.view.prefix=/WEB-INF/jsp8081/
spring.mvc.view.suffix=.jsp
server.port=8081
spring.mvc.view.prefix=/WEB-INF/jsp8080/
spring.mvc.view.suffix=.jsp
server.port=8080

4、浏览器重复访问www.lun.com,就会轮训显示不同的页面

负载均衡算法

  • 轮询(默认)

       每个请求按时间顺序逐一分配到不同的后端服务,如果后端某台服务器死机,自动剔除故障系统,使用户访问不受影响。

  • weight(轮询权值)

       weight的值越大分配到的访问概率越高,主要用于后端每台服务器性能不均衡的情况下。或者仅仅为在主从的情况下设置不同的权值,达到合理有效的地利用主机资源。

upstream  backServer{
	server 127.0.0.1:8080 weight=1;
	server 127.0.0.1:8081 weight=2;
}
  • ip_hash

        每个请求按访问IP的哈希结果分配,使来自同一个IP的访客固定访问一台后端服务器,并且可以有效解决动态网页存在的session共享问题。俗称IP绑定。

upstream  backServer{
	server 127.0.0.1:8080 ;
	server 127.0.0.1:8081 ;
	ip_hash; 
}
  • fair(第三方)

        比 weight、ip_hash更加智能的负载均衡算法,fair算法可以根据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间 来分配请求,响应时间短的优先分配。Nginx本身不支持fair,如果需要这种调度算法,则必须安装upstream_fair模块。

  • url_hash(第三方)

     按访问的URL的哈希结果来分配请求,使每个URL定向到一台后端服务器,可以进一步提高后端缓存服务器的效率。Nginx本身不支持url_hash,如果需要这种调度算法,则必须安装Nginx的hash软件包。   

Nginx配置故障转移

       当上游服务器(真实访问服务器),一旦出现故障或者是没有及时相应的话,应该直接轮训到下一台服务器,保证服务器的高可用。

server {
        listen       80;
        server_name  www.itmayiedu.com;
        location / {
		    ### 指定上游服务器负载均衡服务器
		    proxy_pass http://backServer;
		    ###nginx与上游服务器(真实访问的服务器)超时时间 后端服务器连接的超时时间_发起握手等候响 
               应超时时间
			proxy_connect_timeout 1s;
			###nginx发送给上游服务器(真实访问的服务器)超时时间
            proxy_send_timeout 1s;
			### nginx接受上游服务器(真实访问的服务器)超时时间
            proxy_read_timeout 1s;
            index  index.html index.htm;
        }
}

nginx rewrite

        Nginx提供的全局变量或自己设置的变量,结合正则表达式和标志位实现url重写以及重定向。rewrite只能放在server{ },location{ },if{ }中,并且只能对域名后边的除去传递的参数外的字符串起作用。

        Rewrite主要的功能就是实现URL的重写,Nginx的Rewrite规则采用Pcre,perl兼容正则表达式的语法规则匹配,如果需要Nginx的Rewrite功能,在编译Nginx之前,需要编译安装PCRE库。

         通过Rewrite规则,可以实现规范的URL、根据变量来做URL转向及选择配置。

Rewrite全局变量

变量

含义

$args

这个变量等于请求行中的参数,同$query_string

$content length

请求头中的Content-length字段。

$content_type

请求头中的Content-Type字段。

$document_root

当前请求在root指令中指定的值。

$host

请求主机头字段,否则为服务器名称。

$http_user_agent

客户端agent信息

$http_cookie

客户端cookie信息

$limit_rate

这个变量可以限制连接速率。

$request_method

客户端请求的动作,通常为GETPOST

$remote_addr

客户端的IP地址。

$remote_port

客户端的端口。

$remote_user

已经经过Auth Basic Module验证的用户名。

$request_filename

当前请求的文件路径,由rootalias指令与URI请求生成。

$scheme

HTTP方法(如httphttps)。

$server_protocol

请求使用的协议,通常是HTTP/1.0HTTP/1.1

$server_addr

服务器地址,在完成一次系统调用后可以确定这个值。

$server_name

服务器名称。

$server_port

请求到达服务器的端口号。

$request_uri

包含请求参数的原始URI,不包含主机名,如”/foo/bar.php?arg=baz”。

$uri

不带请求参数的当前URI$uri不包含主机名,如”/foo/bar.html”。

$document_uri

$uri相同。

判断IP地址来源

## 如果访问的ip地址为127.0.0.1,则返回403
if ($remote_addr = 127.0.0.1) {  
  return 403;  
}

限制浏览器访问

## 不允许谷歌浏览器访问 如果是谷歌浏览器返回404
if ($http_user_agent ~ Chrome) {   
    return 500;  
}

lvs+keepalived+nginx实现高性能负载均衡集群

LVS作用

       LVS是一个开源的软件,可以实现传输层四层负载均衡。LVS是Linux Virtual Server的缩写,意思是Linux虚拟服务器。目前有三种IP负载均衡技术(VS/NAT、VS/TUN和VS/DR);八种调度算法(rr,wrr,lc,wlc,lblc,lblcr,dh,sh)。

lvs与Nginx区别

  • Nginx是七层负载均衡,主要针对应用层负载均衡(Http),在1.9之后开始支持对四层负载均衡的支持。
  • LVS是四层负载均衡,主要针对传输层负载均衡。
  • LVS应用场景比Nginx负载均衡应用场景更加广泛,而且LVS支持所有服务负载均衡业务功能。

Keepalived作用

        LVS可以实现负载均衡,但是不能够进行健康检查,比如一个rs出现故障,LVS 仍然会把请求转发给故障的rs服务器,这样就会导致请求的无效性。keepalive 软件可以进行健康检查,而且能同时实现 LVS 的高可用性,解决 LVS 单点故障的问题,其实 keepalive 就是为 LVS 而生的。

双机主从热备

       两台机子互为热备,平时各自负责各自的服务。在做上线更新的时候,关闭一台服务器的tomcat后,nginx自动把流量切换到另外一台服务的后备机子上,从而实现无痛更新,保持服务的持续性,提高服务的可靠性,从而保证服务器7*24小时运行。

Nginx+Tomcat动静分离

动态页面与静态页面区别

  • 静态资源: 当用户多次访问这个资源,资源的源代码永远不会改变的资源。
  • 动态资源:当用户多次访问这个资源,资源的源代码可能会发送改变。

什么是动静分离

       动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路。

动静分离简单的概括是:动态文件与静态文件的分离。

为什么要用动静分离

        在我们的软件开发中,有些请求是需要后台处理的(如:.jsp,.do等等),有些请求是不需要经过后台处理的(如:css、html、jpg、js等等文件),这些不需要经过后台处理的文件称为静态文件,否则动态文件。因此我们后台处理忽略静态文件。这会有人又说那我后台忽略静态文件不就完了吗。当然这是可以的,但是这样后台的请求次数就明显增多了。在我们对资源的响应速度有要求的时候,我们应该使用这种动静分离的策略去解决。

       动静分离将网站静态资源(HTML,JavaScript,CSS,img等文件)与后台应用分开部署,提高用户访问静态代码的速度,降低对后台应用访问。这里我们将静态资源放到nginx中,动态资源转发到tomcat服务器中。

动静分离的原理

      动静分离的原理很简单,通过location对请求url进行匹配即可,具体配置如下:

###静态资源访问
server {
   listen       80;
   server_name  static.lun.com;
   location /static/imgs {
       root F:/;
	   index  index.html index.htm;
   }
}
###动态资源访问
server {
   listen       80;
   server_name  www.lun.com;
   location / {
       proxy_pass http://127.0.0.1:8080;
	   index  index.html index.htm;
   }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值