Nginx 学习

  • A+
所属分类:linux技术
摘要

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,占有内存少,并发能力强,能接受高负载。


一、什么是nginx

1、nginx基本概念

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,占有内存少,并发能力强,能接受高负载。

2、反向代理

(1)、正向代理

用户无法访问某网站,但是可以访问代理服务器,代理服务器可以访问目标网站,用户配置代理服务器让
代理服务器对目标网站进行访问,并把结果返回给用户 (老打工人了)

Nginx 学习

(2)、反向代理

用户访问代理服务器,代理服务器去访问目标资源,处理返回结果给用户,从外部看用户不知道是否有代理服务器以为是一个服务器,暴漏的是代理服务器,隐藏了访问的资源服务器

Nginx 学习

3、负载均衡

负载均衡(Load Balance),意思是将负载(工作任务,访问请求)进行平衡、分摊到多个操作单元(服务器,组件)上进行执行。是解决高性能,单点故障(高可用),扩展性(水平伸缩)的终极解决方案。

Nginx 学习

4、动静分离

有专门的服务器放静态资源。用户请求静态资源时nginx就去静态资源服务器查找。加快了网站的解析速度,降低单个服务器的压力

Nginx 学习

二、Nginx安装、常用命令、配置文件

1、Nginx安装

1、下载nginx 2、解压nginx 3、$sudo apt-get install libpcre3 libpcre3-dev zlib1g-dev //安装依赖库 4、./configure 5、make && make install	//编译并且安装 *安装成功后 usr/local 会多出一个nginx文件 nginx里有sbin,sbin里面有启动脚本 相关命令: 	ps -e | grep nginx	//查看是否启动nginx 	netstat -ltunp		//查看占用的端口号等详细信息 ----防火墙默认无法访问,添加规则开放端口即可 

2、Nginx常用命令

*使用ngin常用密令要在	/usr/local/nginx/sbin 中使用 	./nginx -v		//查看nginx版本号 	./nginx			//启动 	./nginx -s stop		//关闭 	./nginx -s reload	//重新加载(比如conf的配置文件) 

3、Nginx配置文件

*nginx配置文件在 /usr/local/nginx/conf	中 nginx配置文件分为三块 	1、全局块 		全局开始到events结束为全局快,主要设置一些影响nginx服务器整体运行的配置指令 例:worker_processes  1; 是 	nginx处理并发的数量,值越大处理的并发也越多(会受到硬件影响)  	2、events块 		影响nginx服务器与用户的网络连接 例:worker_connections  1024; 表示nginx用户最大连接数量  	3、http块 		又包括 http全局块 和 server块 是配置最频繁的部分(高可用,负载均衡,动静分离都要在这配置)可以嵌套多个 	server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使 	用sendfile传输文件,连接超时时间,单连接请求数等。  		server全局块:配置虚拟主机的相关参数,一个http中可以有多个server。 		 		location块:配置请求的路由,以及各种页面的处理情况。 

三、Nginx配置示例-反向代理

实例一、反向代理 	1、修改配置文件 		server { 			listen       80; 			server_name  localhost     //nginx地址; 		 			location / { 			    root   html; 				//添加proxy_pass +http://项目地址 			    proxy_pass http://localhost:428; 			    index  index.html index.htm; 			} 		} 		 		   实例二、反向代理(根据访问路径跳转不同端口) 	1、部署两个tomcat,tom1的dev放a.html,tom2的vod放b.html,并开放端口 	 	2、修改配置文件 		server { 			listen       80; 			server_name  localhost     //nginx地址; 		 			location ~ /edu/ { 			    proxy_pass http://localhost:8080 			}  			location ~ /vod/ { 			    proxy_pass http://localhost:8081 			} 		}  location使用正则表达式 location   =   /uri       =开头表示精确前缀匹配,只有完全匹配才能生效。  location   ^~   /uri       ^~开头表示普通字符串匹配上以后不再进行正则匹配。  location   ~   pattern     ~开头表示区分大小写的正则匹配。  location   ~*   pattern     ~*开头表示不区分大小写的正则匹配。  location   /uri           不带任何修饰符,表示前缀匹配。  location   /             通用匹配,任何未匹配到其他location的请求都会匹配到。  注意: 正则匹配会根据匹配顺序,找到第一个匹配的正则表达式后将停止搜索。普通字符串匹配则无视顺序,只会选择最精确的匹配。 

四、Nginx配置实例-负载均衡(增加服务器,平摊访问)

1、修改文件 	http下添加: 		upstream 服务名字{ 			server 192.168.1.1:8080; 			server 192.169.1.1:8080; 		} 	配置server { 		listen       80; 		server_name  192.168.1.1     //nginx地址; 			 		location / { 		    proxy_pass http://服务名字; 		} 	}  2、负载均衡策略 	·轮询(默认) 		按照时间顺序进行分配,服务器宕机自动剔除。  	·weight 		默认为1,权重越高被分配的客户端越多,就是按比例分配 		例: 			upstream 服务名字{ 				server 192.168.1.1:8080 weight=5; 				server 192.169.1.1:8080 weight=10; 			}  	·ip_hash 		大白话就是,按照你的ip地址来,你的ip分到服务器1以后你访问都是服务器1可解决session问题 		例: 			upstream 服务名字{ 				ip_hash 				server 192.168.1.1:8080; 				server 192.169.1.1:8080; 			}  	·fair(第三方)按照后端访问时间,那个服务器相应快那个先给用户访问 		例: 			upstream 服务名字{ 				server 192.168.1.1:8080; 				server 192.169.1.1:8080; 				fair 			} 

五、Nginx配置示例-动静分离

*常用方式单独域名存放静态资源。 			location /www/ { 			    root /data/; 			}  			location /image/ { 			    root /data/; 			    autoindex on; //显示文件列表 			}  

六、Nginx配置高可用集群

((主从模式))解决nginx宕机就是高可用。。。。
需要2台nginx服务器
需要keeplived
需要虚拟ip地址

Nginx 学习

1、两台服务器都装上nginx服务器  2、两台服务器安装keeplived 	安装后 etc 下会生成keeplived目录,里面包含keeplived配置文件keeplived.conf 	配置keeplived,并且配置脚本 	  3、然后就高可用了