nginx负载均衡,服务器集群配置,服务器挂机自动切换

1、 首先打开nginx/conf/nginx.conf修改如下配置

http {

#在http中添加下面内容

#隐藏 Nginx 的版本号,提高安全性。
server_tokens off;
    
#指令指定允许客户端连接的最大请求实体大小,它出现在请求头部的Content-Length字段。如果请求大于指定的值,客户端将收到一个”Request Entity Too Large” (413)错误。记住,浏览器并不知道怎样显示这个错误。
client_max_body_size 5G;
#(默认8k或16k)这个指令可以指定连接请求实体的缓冲区大小。如果连接请求超过缓存区指定的值,那么这些请求实体的整体或部分将尝试写入一个临时文件
client_body_buffer_size 1m;
#开启高效文件传输模式,sendfile 指令指定 Nginx 是否调用sendfile 函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘 IO 重负载应用,可设置为 off,以平衡磁盘与网络 I/O 处理速度,降低系统的负载。
client_header_buffer_size 1024k;

## Start: Timeouts ##
client_body_timeout   10;
client_header_timeout 10;
#连接超时时间,单位是秒
keepalive_timeout     30;
send_timeout          10;
keepalive_requests    10;
## End: Timeouts ##

sendfile on;
#告诉 Nginx 在一个数据包里发送所有头文件,而不一个接一个的发送
tcp_nopush on;

#开启 gzip 压缩。
gzip  on;

proxy_connect_timeout 300; #nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout    300; #后端服务器数据回传时间(代理发送超时)
proxy_read_timeout    300; #连接成功后,后端服务器响应时间(代理接收超时)

#设置主机头和客户端真实地址,以便服务器获取客户端真实IP
proxy_set_header Host $host;
#如果没加,后端服务器会收到 Connection: close 的 Header,而不能复用连接; 清空connection的请求头,避免客户端传递短链接的请求头信息。
proxy_set_header Connection "";
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

server_names_hash_bucket_size 128;
map_hash_bucket_size 64;
  
#DENY:浏览器拒绝当前页面加载任何Frame页面
#SAMEORIGIN:frame页面的地址只能为同源域名下的页面
#ALLOW-FROM:允许frame加载的页面地址
add_header X-Frame-Options SAMEORIGIN always;
add_header X-Content-Type-Options nosniff always;

#加载虚拟主机配置
include vhost/*.conf;

}

 2、然后在nginx/conf文件夹下创建 vhost文件夹,并创建 my.conf文件

把以下内容添加到nginx/conf/vhost/my.conf中

#服务器的集群 #服务器集群名字
upstream  test {
    #least_conn; #把请求分配到连接数最少的server
    #ip_hash; #每个请求会按照访问ip的hash值分配,这样同一客户端连续的Web请求都会被分发到同一server进行处理,可以解决session的问题。
    server    127.0.0.1:3000  weight=3;
    server    127.0.0.1:3001  weight=5;
    #服务器配置   weight是权重的意思,权重越大,分配的概率越大。
}

############ 设定虚拟主机配置 ##############
server {
    #侦听端口
    listen		80;
    listen		443 ssl;
    #定义
    server_name www.dz.com;

    ssl_certificate      mycert.crt;
    ssl_certificate_key  mycert.key;

    location / {
        #设置主机头和客户端真实地址,以便服务器获取客户端真实IP
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        #禁用缓存
        #proxy_buffering off;

        #设置反向代理的地址
        proxy_pass  http://test;

        #这里就保证了自动切换服务器
        proxy_connect_timeout 1;  #连接超时 默认为60秒
        proxy_send_timeout 1;     #读取超时 默认为60秒
        proxy_read_timeout 1;     #发送超时 默认为60秒
    }
}
############ 设定虚拟主机配置 END ##############

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值