一.nginx的反向代理 nginx的反向代理就是用户在请求一个nginx的页面的时候可以将请求代理给其它服务器,让其他服务器去处理用户的请求内容。这些服务器把处理的结果教给nginx服务器,然后nginx服务器再把响应的结果发给客户端。nginx的作用主要有2个,一是作为高性能的http的服务器,第二个作用就是作为代理服务器来实现负载均衡的效果,提供更高的并发效果。 首先来看nginx的反向代理功能的配置。实验环境: 1.192.168.1.201作为nginx的代理服务器。 2.192.168.1.202装了一台apache服务器。 实验最终效果:当客户端访问192.168.1.201这台nginx服务器的时候,nginx代理给192.168.1.202这台apache服务器处理用户的请求。由于来访问apache的实际上是nginx服务器,所以apache服务器上的访问日志的客户端IP就一直是nginx服务器的IP。所以还要实现apache日志中的IP仍然是请求的客户端IP。 192.168.1.201上的配置如下: location / { proxy_pass http://192.168.1.202; proxy_set_header client-real-ip $remote_addr } 192.168.1.202上的配置如下: DocumentRoot "/html" LogFormat "%{client-real-ip}i %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined 只需要执行上面基础的配置以后,就可以完成一个简单的反向代理功能了。这里做一点说明: 1.proxy_pass上面如果没有uri的话那么会把location 后面的地址追加到proxy_pass的取值后面。 2.proxy_pass上面如果有uri的话那么会单独的定向到proxy_pass指定的路径地址下。 3.location如果使用了~模式匹配的话,一定不能在proxy_pass的值上更上uri (注意:这里的uri指的是proxy_pass后面的地址的最后面是否含有'/'来定义的,多测试几下就明白了) nginx的代理不仅仅可以代理web服务,还可以代理图片,css样式给另外一台服务器等。从而实现真正上的动静分离效果 二.nginx负载均衡的配置。实验环境: 1.192.168.1.201做我们的nginx服务器实现负载均衡 2.192.168.1.202和192.168.1.203作为两台提供apache服务的两台服务器 192.168.1.201上的配置如下: upstream agent { server 192.168.1.202; server 192.168.1.203; } location / { proxy_pass http://agent; proxy_set_header client-real-ip $remote_addr } 这样一个简单的nginx负载均衡的效果就配置出来了。在浏览器中输入192.168.1.201可以发现被轮询到不同的服务器上去了,而且nginx拥有自动脚本检测的功能。在192.168.1.202上停掉httpd服务器以后,再次刷新会看到只会显示192.168.1.203上面的页面了,重新启动httpd服务以后,又会负载均衡了。
三.给nginx装第三方模块,这里以http Redis模块为例。 # tar xf ngx_http_redis-0.3.5.tar.gz # cd /root/nginx-1.4.2 # ./configure --prefix=/usr/local/nginx/ --conf-path=/etc/nginx/nginx.conf --add-module=/root/ngx_http_redis # make # service nginx stop # cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.back # cp objs/nginx /usr/local/nginx/sbin/nginx # service nginx start 注意: 1.编译nginx的时候,一定要把以前编译时候的参数全部带上,比如指定了其它路径的话,编译出来从新启动就会报错。 2.make的时候如果成功,会在objs下生成nginx,直接把原来的/usr/local/ngin/sbin/nginx给复制掉即可,复制之前最好做下备份,即使出了问题,仍然可以换过来。 3.装第三方模块的时候不需要make install。 使用/usr/local/nginx/sbin/nginx -V 可以查看安装的模块