Nginx

项目刚上线的时候,并发量小,使用的用户少,所以在低并发的情况下,一个jar包启动就够了,然后内部Tomcat返回内容给用户。

conf文件 java解析nginx java中nginx_运维

但是慢慢的,使用平台的用户越来越多,并发量越来越大,这时候一台服务器满足不了我们的需求了

conf文件 java解析nginx java中nginx_nginx_02


于是我们横向扩展,又增加了服务器。这时候几个项目启动在不同的服务器上,用户需要访问,就需要增加一个代理服务器了,通过代理服务器来帮我们转发和处理请求。

conf文件 java解析nginx java中nginx_运维_03


我们希望这个代理服务器可以帮助我们接受用户的请求,然后将用户的请求按照规则帮我们转发到不同的服务器节点之上,这个过程是无感知的,用户并不知道是哪个服务器返回的结果,我们还希望他可以按照服务器的性能提供不同的权重选择。保证最佳体验。所以使用Nginx(反向代理,负载均衡)

什么是Nginx

Nginx(engin x)是一个高性能(响应和并发都特别快的)的HTTP和反向代理web服务器,同时也提供了IMAP/POP2/SMTP服务、Nginx是由伊戈尔·塞索耶夫为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4号。2011年6月1日,nginx1.0.4发布。
其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站有:百度,京东,新浪,网易,腾讯,淘宝等等。在全球活跃的网站中有12.18%的使用比率,大约为2220万个网站。
Nginx是一个安装非常简单,配置文件非常简洁(还能够支持perl语法),Bug非常少的服务。Nginx启动特别容易,并且几乎可以做到24小时不间断运行,即使运行数个月也不需要重启。你还能够不间断服务器的情况下进行软件版本的升级,Nginx代码完全用C语言写成。官方数据测试表面能够支持高达,50000个并发连接数的响应。

Nginx作用

HTTP代理,反向代理:作为web,服务器最常用的功能之一,尤其是反向代理。

正向代理:代理客户端

conf文件 java解析nginx java中nginx_运维_04


反向代理:代理服务器

conf文件 java解析nginx java中nginx_运维_05


Nginx提供的负载均衡策略有2种:内置策略和扩展策略。内置策略为轮询,加权轮询,Ip hash。扩展策略,就天马行空。

轮询:代理把客户端的请求依次分派给服务器

conf文件 java解析nginx java中nginx_java_06


加权轮询:代理根据服务器的内存大小分配不同的请求过去。

conf文件 java解析nginx java中nginx_java_07


动静分离:在我们的软件开发中,有些请求是需要后台处理的,有些请求是不需要经过后台处理的(如:css,html,jpg,js等等文件),这些不需要经过后台处理的文件称为静态文件,让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开了,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作。提高资源响应的速度。

conf文件 java解析nginx java中nginx_conf文件 java解析nginx_08


whereis nginx:查找文件所在目录(liunx系统命令)

Nginx常用命令

cd /usr/local/nginx/sbin/

./nginx

启动

./nginx -s stop

停止

./nginx -s quit

安全退出

./nginx -s reload

重新加载配置文件

ps aux

grep nginx

nginx.conf文件配置

//全局配置
events{
	//性能优化配置
	worker_connections	1024;
}
http{
	//http配置
	upstream xx{
		//负载均衡配置
		//放服务器ip地址和端口号 weight = 几次:权重
		server	127.0.0.1:8080 weight = 1;
	}
	server{
		listen	80;//端口配置
		server_name	localhost;//表示这个端口实在localhost下的
		//代理配置
		location{
			//访问80端口的根目录,请求就会到达这里面
		}
	}
}