Ngnix的反向代理,url重定向,负载均衡的实现
2014-01-26 08:11
351 查看
环境:centos-6.4-x86_64
软件:nginx-1.0.11healthcheck_nginx_upstreams-master
拓扑图:
![](http://s3.51cto.com/wyfs02/M01/11/E8/wKioL1LkUZfxMJefAABdU5oyxDU622.jpg)
Ip地址规划:
反向代理服务器连接外网的地址:192.168.1.118,连接内网的地址:192.168.29.20
Server1的地址:192.168.29.200
server2的地址:192.169.29.201
解压healthcheck_nginx_upstreams-master到tmp目录,然后安装nginx
解压nginx,然后切换到解压后的目录执行
patch -p1</tmp/healthcheck_nginx_upstreams-master/ nginx.patch为nginx打上补丁,然后执行
./configure \ --conf-path=/etc/nginx/nginx.conf \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--user=nginx \
--group=nginx \
--with-http_ssl_module \
--with-http_flv_module \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/tmp/nginx/client/ \
--http-proxy-temp-path=/var/tmp/nginx/proxy/ \
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi/\
--with-pcre
--add-module=/tmp/ healthcheck_nginx_upstreams-master/
完成之后执行make&& make install,完成后创建nginx组和nginx用户
groupadd -r nginx
useradd -r -g nginx -s /sbin/nologin -Mnginx
在/etc/init.d/目录下编写一个名为nginx的shell脚本,给以可执行权限
将nginx添加到chkconfig 管理 chkconfig --add nginx
到这里nginx的安装就完成了。
接下来先介绍nginx重定向的实现。
如果想实现访问跟站点下的图片文件时,重定向到一个页面,编辑nginx的配置文件
![](http://s3.51cto.com/wyfs02/M00/11/E9/wKiom1LkUc_xmwsoAABZ9ojDGRs683.jpg)
然后测试
![](http://s3.51cto.com/wyfs02/M02/11/E8/wKioL1LkUbey_esqAAEb6e7wFww465.jpg)
被重定向到index.html页面上了。
如果访问某台服务器上某个目录下的某个文件被重定向到另一台服务器上的想对应的目录下的文件。
在这里我们另一台服务器的ip地址为192.168.29.200 在这台服务器的跟站点目录下有abc目录和def目录,在这两个目录中都有两个jpg文件。
![](http://s3.51cto.com/wyfs02/M01/11/E9/wKiom1LkUeTz1JcnAACPWLMfa8s052.jpg)
当我们访问192.168.29.20/abc/1.jpg时会被重定向到http://192.168.29.200/abc/1.jpg
访问
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkUc3TrHWYAAAqWPsa4K0547.jpg)
访问成功后
![](http://s3.51cto.com/wyfs02/M02/11/E9/wKiom1LkUfzCCEytAAGlm9_UByM031.jpg)
接下来介绍反向代理。通过反向代理可以是内网中的服务器提供给外部用户使用。
![](http://s3.51cto.com/wyfs02/M01/11/E8/wKioL1LkUeHD1FRSAABsDC1EuCI766.jpg)
在192.168.29.200服务器的web跟站点下有一个index.html文件,在这个文件里面有“hello”
访问结果如下:
![](http://s3.51cto.com/wyfs02/M00/11/E9/wKiom1LkUg6gQLIZAACFu4h6Ies448.jpg)
从图中可以看出已经访问成功。
为反向代理增加缓
语法: proxy_cache_path path [levels=levels]keys_zone=name:size [inactive=time] [max_size=size] [loader_files=number][loader_sleep=time] [loader_threshold=time];
先用压力测试测试一下在没有缓存的情况下访问速度
![](http://s3.51cto.com/wyfs02/M02/11/E8/wKioL1LkUf6Rw4wMAACdYnBTDpE351.jpg)
接下来做缓存
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkUhKz5SKnAAERdh18ZQM794.jpg)
![](http://s3.51cto.com/wyfs02/M02/11/E9/wKiom1LkUkfQ3pGBAAD6e59qrCw898.jpg)
设置完成后,先进行一次访问,产生缓存,然后进行压力测试
![](http://s3.51cto.com/wyfs02/M01/11/E8/wKioL1LkUk6w7aL-AAG9NDsGMP0960.jpg)
接下来介绍nginx负载均衡和健康检测
在nginx的配置文件中添加如下图内容,在全局中用upstream指定服务器的地址,然后在location中引用
![](http://s3.51cto.com/wyfs02/M00/11/E9/wKiom1LkUoOAyas1AADemZb9MkM111.jpg)
![](http://s3.51cto.com/wyfs02/M02/11/E8/wKioL1LkUmCSOxi0AAA3CgfVO2Y938.jpg)
做完这些就可以实现负载均衡,但是当其中一台服务器出现故障是,前端反向代理服务器仍然会继续向故障服务器发送数据,这样会导致一些用户无法访问,因此要在反向代理服务器上实现健康检测,当服务器出现故障时不再向故障服务器发送数据,所以我们还要在nginx的配置文件中启用健康检测,并且在两个服务器的站点根目录下创建一health页面,内容随便写就可以。
![](http://s3.51cto.com/wyfs02/M01/11/E9/wKiom1LkUpDiECMRAAFF_LiNgeQ484.jpg)
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkX2vw4EkOAAA2c0e-mjE743.jpg)
那我们来测试一下,在两台服务器上分别有内容为“hello”的html页面和“helloword”的html页面
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkUoPCUkRNAACUFCpHuRw498.jpg)
![](http://s3.51cto.com/wyfs02/M02/11/E9/wKiom1LkUqfzxfO9AACc5J9-_o4153.jpg)
从图中看都可以访问到,假如我们的192.168.29.201服务器坏掉了,我们可以看到状态
![](http://s3.51cto.com/wyfs02/M01/11/E9/wKiom1Lkas7A41KBAAFdKEpmUpY826.jpg)
本文出自 “小宝_” 博客,请务必保留此出处http://mading.blog.51cto.com/8252187/1354807
软件:nginx-1.0.11healthcheck_nginx_upstreams-master
拓扑图:
![](http://s3.51cto.com/wyfs02/M01/11/E8/wKioL1LkUZfxMJefAABdU5oyxDU622.jpg)
Ip地址规划:
反向代理服务器连接外网的地址:192.168.1.118,连接内网的地址:192.168.29.20
Server1的地址:192.168.29.200
server2的地址:192.169.29.201
解压healthcheck_nginx_upstreams-master到tmp目录,然后安装nginx
解压nginx,然后切换到解压后的目录执行
patch -p1</tmp/healthcheck_nginx_upstreams-master/ nginx.patch为nginx打上补丁,然后执行
./configure \ --conf-path=/etc/nginx/nginx.conf \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--user=nginx \
--group=nginx \
--with-http_ssl_module \
--with-http_flv_module \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/tmp/nginx/client/ \
--http-proxy-temp-path=/var/tmp/nginx/proxy/ \
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi/\
--with-pcre
--add-module=/tmp/ healthcheck_nginx_upstreams-master/
完成之后执行make&& make install,完成后创建nginx组和nginx用户
groupadd -r nginx
useradd -r -g nginx -s /sbin/nologin -Mnginx
在/etc/init.d/目录下编写一个名为nginx的shell脚本,给以可执行权限
将nginx添加到chkconfig 管理 chkconfig --add nginx
到这里nginx的安装就完成了。
接下来先介绍nginx重定向的实现。
如果想实现访问跟站点下的图片文件时,重定向到一个页面,编辑nginx的配置文件
![](http://s3.51cto.com/wyfs02/M00/11/E9/wKiom1LkUc_xmwsoAABZ9ojDGRs683.jpg)
然后测试
![](http://s3.51cto.com/wyfs02/M02/11/E8/wKioL1LkUbey_esqAAEb6e7wFww465.jpg)
被重定向到index.html页面上了。
如果访问某台服务器上某个目录下的某个文件被重定向到另一台服务器上的想对应的目录下的文件。
在这里我们另一台服务器的ip地址为192.168.29.200 在这台服务器的跟站点目录下有abc目录和def目录,在这两个目录中都有两个jpg文件。
![](http://s3.51cto.com/wyfs02/M01/11/E9/wKiom1LkUeTz1JcnAACPWLMfa8s052.jpg)
当我们访问192.168.29.20/abc/1.jpg时会被重定向到http://192.168.29.200/abc/1.jpg
访问
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkUc3TrHWYAAAqWPsa4K0547.jpg)
访问成功后
![](http://s3.51cto.com/wyfs02/M02/11/E9/wKiom1LkUfzCCEytAAGlm9_UByM031.jpg)
接下来介绍反向代理。通过反向代理可以是内网中的服务器提供给外部用户使用。
![](http://s3.51cto.com/wyfs02/M01/11/E8/wKioL1LkUeHD1FRSAABsDC1EuCI766.jpg)
在192.168.29.200服务器的web跟站点下有一个index.html文件,在这个文件里面有“hello”
访问结果如下:
![](http://s3.51cto.com/wyfs02/M00/11/E9/wKiom1LkUg6gQLIZAACFu4h6Ies448.jpg)
从图中可以看出已经访问成功。
为反向代理增加缓
语法: proxy_cache_path path [levels=levels]keys_zone=name:size [inactive=time] [max_size=size] [loader_files=number][loader_sleep=time] [loader_threshold=time];
先用压力测试测试一下在没有缓存的情况下访问速度
![](http://s3.51cto.com/wyfs02/M02/11/E8/wKioL1LkUf6Rw4wMAACdYnBTDpE351.jpg)
接下来做缓存
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkUhKz5SKnAAERdh18ZQM794.jpg)
![](http://s3.51cto.com/wyfs02/M02/11/E9/wKiom1LkUkfQ3pGBAAD6e59qrCw898.jpg)
设置完成后,先进行一次访问,产生缓存,然后进行压力测试
![](http://s3.51cto.com/wyfs02/M01/11/E8/wKioL1LkUk6w7aL-AAG9NDsGMP0960.jpg)
接下来介绍nginx负载均衡和健康检测
在nginx的配置文件中添加如下图内容,在全局中用upstream指定服务器的地址,然后在location中引用
![](http://s3.51cto.com/wyfs02/M00/11/E9/wKiom1LkUoOAyas1AADemZb9MkM111.jpg)
![](http://s3.51cto.com/wyfs02/M02/11/E8/wKioL1LkUmCSOxi0AAA3CgfVO2Y938.jpg)
做完这些就可以实现负载均衡,但是当其中一台服务器出现故障是,前端反向代理服务器仍然会继续向故障服务器发送数据,这样会导致一些用户无法访问,因此要在反向代理服务器上实现健康检测,当服务器出现故障时不再向故障服务器发送数据,所以我们还要在nginx的配置文件中启用健康检测,并且在两个服务器的站点根目录下创建一health页面,内容随便写就可以。
![](http://s3.51cto.com/wyfs02/M01/11/E9/wKiom1LkUpDiECMRAAFF_LiNgeQ484.jpg)
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkX2vw4EkOAAA2c0e-mjE743.jpg)
那我们来测试一下,在两台服务器上分别有内容为“hello”的html页面和“helloword”的html页面
![](http://s3.51cto.com/wyfs02/M00/11/E8/wKioL1LkUoPCUkRNAACUFCpHuRw498.jpg)
![](http://s3.51cto.com/wyfs02/M02/11/E9/wKiom1LkUqfzxfO9AACc5J9-_o4153.jpg)
从图中看都可以访问到,假如我们的192.168.29.201服务器坏掉了,我们可以看到状态
![](http://s3.51cto.com/wyfs02/M01/11/E9/wKiom1Lkas7A41KBAAFdKEpmUpY826.jpg)
本文出自 “小宝_” 博客,请务必保留此出处http://mading.blog.51cto.com/8252187/1354807
相关文章推荐
- Tomcat(三):Apache反向代理实现Tomcat负载均衡
- haproxy实现反向代理和负载均衡
- windows2008 使用nginx 反向代理实现负载均衡解决HTTPS 证书问题
- 通过Nginx+tomcat+redis实现反向代理 、负载均衡及session同步
- nginx反向代理实现http负载均衡
- Nginx实现反向代理和负载均衡
- Nginx实现反向代理,负载均衡,url重写以及健康检测
- Nginx实现反向代理和负载均衡
- nginx 实现反向代理和负载均衡
- Apache反向代理结合Tomcat集群来实现负载均衡(四)、Apache反向代理
- nginx结合tomcat实现反向代理和负载均衡的部署
- CentOS 6.5 下 Nginx的反向代理和负载均衡的实现
- 编译安装nginx实现反向代理、负载均衡、缓存功能
- nginx和tomcat实现反向代理、负载均衡和session共享
- CentOS系统中配置Nginx服务器实现反向代理和负载均衡
- Apache实现反向代理和负载均衡
- Centos6.5系统下nginx反向代理实现tomcat负载均衡
- Nginx简单实现反向代理和负载均衡
- HAproxy实现反向代理、负载均衡集群以及web动静分离
- nginx和tomcat实现反向代理、负载均衡和session共享