这篇文章主要为大家详细介绍了nginx配置七层负载的方法,文中示例代码介绍的非常详细,零基础也能参考此文章,感兴趣的小伙伴们可以参考一下。
为黄南州等地区用户提供了全套网页设计制作服务,及黄南州网站建设行业解决方案。主营业务为成都做网站、网站设计、黄南州网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
具体配置:
upstream service {
server 10.3.1.1:8913 max_fails=5 fail_timeout=10s weight=10;
server 10.3.1.2:8913 max_fails=5 fail_timeout=10s weight=10;
}
server {
listen 80;
server_name www.test.com;
location / {
proxy_set_header Host $host;
# 自定义的用于debug字段,如果不加,后端无法获取到此字段
proxy_set_header unique_id $http_unique_id;
proxy_set_header trace_id $http_trace_id;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_connect_timeout 30;
proxy_send_timeout 20;
proxy_read_timeout 20;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_pass http://service;
}
}
http中修改了如下几个配置:
include mime.types;
default_type application/octet-stream;
server_names_hash_max_size 10240;
server_names_hash_bucket_size 2048;
client_max_body_size 3m;
client_body_buffer_size 256k;
# 开启header中带下划线的配置
underscores_in_headers on;
# 修改日志记录格式,json格式方便ELK进行收集
log_format json escape=json '{"remote_addr": "$remote_addr",'
'"@timestamp": "$time_iso8601",'
'"request_uri": "$request_uri",'
'"verb": "$request_method",'
'"httpversion": "$server_protocol",'
'"response": "$status", '
'"body_bytes_sent": "$body_bytes_sent", '
'"referrer": "$http_referer", '
'"user_agent": "$http_user_agent", '
'"http_x_forwarded_for": "$http_x_forwarded_for", '
'"http_unique_id": "$http_unique_id", '
'"http_trace_id": "$http_trace_id", '
'"server_name": "$host",'
'"request_time": "$request_time",'
'"upstream_response_time": "$upstream_response_time",'
'"realpath_root": "$realpath_root",'
'"cookie": "$http_cookie",'
'"request_body": "$request_body",'
'"nginx_version": "$nginx_version",'
'"scheme": "$scheme"}';
access_log /data/log/tmp.log json;
关于nginx配置七层负载的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。