您的位置:首页 > 运维架构 > 反向代理

nginx实现反向代理+健康检测

2017-11-11 21:48 417 查看
说明

tengine官方说明文档

nginx 对于后端RS的检查机制不完善
所有用Tengine进行反向代理


一、反向代理

1.定义后端real-server(在http段)

upstream static_server {
server 192.168.17.175:80 weight=5;
server 192.168.17.176:80 weight=3;
}
upstream basic_server {
server 192.168.17.175:80 weight=2;
server 192.168.17.176:80 weight=5;
}


2.location 匹配到自定义内容 代理到对应的real-server(server段)

server {
listen       80 default_server;
server_name  _;

location ~ ^/images {
index index.php index.html;
proxy_pass http://static_server; }
location ~* .(jpg|png|jpeg|gif) {
proxy_pass http://static_server; }
#匹配到/youxi  则全部代理到 http://basic_server/index.html; location ~ /youxi {
rewrite ^(.*)$ /index.html break;
proxy_pass http://basic_server/index.html; }


二、real-server健康检测

模块
nginx_upstream_check_module-master
使用
upstream块里可以用多个server选项配置多个后端服务器,同时还可配置对后端服务器的健康状态检查,
可以在server后面加上
max_fails(proxy_next_upstream指定检查策略,默认为返回超时为失败)和
fail_timeout参数实现;
也可以用health_check选项来实现
health_check可以指定的参数较多,不过需要定义在location上下文中。
另外,可以指定代理服务器自身作为备份server,当所有后端服务器都宕机时,对外提供维护提示页面。
指定负载均衡策略
主要有round_robin(加权轮询,默认)、
hash、ip_hash、least_conn(最少连接)
least_time(最少响应时间,商业版本)
策略定义在upstream上下文即可;


1.对real-server进行健康检测(upstream中)

upstream basic_server {
server 192.168.17.175:80 weight=2;
server 192.168.17.176:80 weight=5;
check interval=3000 rise=2 fall=5 timeout=2000 type=http;
check_http_expect_alive http_2xx http_3xx;
}


2.健康检测页面

server {
location /status {
check_status;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息