ng 负载均衡
网站的访问量越来越大,服务器的服务模式也得进行相应的升级,如分离出数据库服务器、分离出文件或图片作为单独服务,这些是简单的数据的负载均衡,将压力分散到不同的机器上。有时候来自 web 前端的压力,也能让人十分头痛。怎样将同一个域名的访问分散到两台或更多的机器上呢?这其实就是另一种负载均衡了,nginx 自身就可以做到,只需要做个简单的配置就行。
nginx 不单可以作为强大的web服务器,也可以作为一个反向代理服务器,而且nginx还可以按照调度规则实现动态、静态页面的分离,可以按照轮询、ip哈希、URL哈希、权重等多种方式对后端服务器做负载均衡,同时还支持后端服务器的健康检查。
ng 的 upstream 目前支持 4 种方式的分配
- 轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
- weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
- ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
- fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
- url_hash(第三方)
nginx 负载均衡配置
主要是 proxy_pass , upstream 的使用,在http段做如下配置,即可实现两个域名
upstream test.ng.com
{
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
upstream go.ng.com
{
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
server
{
listen 80;
server_name test.ng.com;
location / {
proxy_pass http://test.ng.com;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
server
{
listen 80;
server_name go.ng.com;
location / {
proxy_pass http://go.ng.com;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
注意事项
- 多台机器间 session 共享的问题
- 后端服务器自动加上端口的问题