[摘抄-学习中]java-webscoekt中ngnix反向代理配置

我的服务名称为:ja-websocket-server

在nginx配置文件中(nginx.conf):
下面这项添加在


#user nobody;
worker_processes 2;

#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;

#pid logs/nginx.pid;


events {
worker_connections 1024;
}

http {
include mime.types;
default_type application/octet-stream;

charset utf-8;
server_tokens off;
server_names_hash_bucket_size 256;
client_header_buffer_size 8k;
large_client_header_buffers 4 8k;
client_max_body_size 120m;
client_body_buffer_size 128k;
client_header_timeout 1m;
client_body_timeout 1m;

send_timeout 3m;
keepalive_timeout 20;
sendfile on;
tcp_nopush on;
tcp_nodelay on;

#open_file_cache max=204800 inactive=20s;
#open_file_cache_min_uses 1;
#open_file_cache_valid 30s;

gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.0;
gzip_comp_level 2;
gzip_types text/plain application/x-javascript text/css application/xml application/javascript application/json;
gzip_vary on;

server {
listen 2080;
server_name localhost;
//重点是下面这个配置,主要是添加一个Upgrade的websocket协议解析
location /ja-websocket-server/ {
proxy_pass http://tomcats_8081/ja-websocket-server/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
}
}
upstream tomcats_8081 {
server 127.0.0.1:8081 weight=20;
}
}

此种配置,亲自试验过可行
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在生产环境,通常会使用Nginx作为反向代理服务器,并将请求转发给后端的多个Tomcat服务器,以实现负载均衡的目的。首先,我们需要进入Nginx配置文件夹,并打开nginx.conf文件进行配置。 在nginx.conf文件,我们可以添加以下代码实现反向代理配置: ``` upstream tomcats { server 127.0.0.1:9001; server 127.0.0.1:9002; } server { listen 80; server_name xxx.xxx.xxx.xxx.109; location / { proxy_pass_header Server; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Scheme $scheme; proxy_pass http://tomcats; } } ``` 这段代码,我们首先定义了一个名为`tomcats`的upstream,其列出了后端Tomcat服务器的地址和端口。然后,在server块,我们监听80端口并设置了服务器的名称。在location块,我们将请求转发给名为`tomcats`的upstream。 此外,我们还可以为每个设备设置状态值,例如: - `down`:表示该服务器暂时不参与负载。 - `weight`:表示服务器的负载权重,默认为1,权重越大,负载越重。 - `max_fails`:允许请求失败的最大次数,默认为1,超过次数后返回定义的错误。 - `fail_timeout`:在`max_fails`次失败后,暂停服务的时间。 - `backup`:当其他非备用服务器处于故障或繁忙状态时,请求会被转发至备用服务器,以减轻其负载。 例如,下面是一个具体的示例: ``` upstream tomcats { server 127.0.0.1:9001 down; server 127.0.0.1:9002 backup; server 127.0.0.1:9003 weight=2; server 127.0.0.1:9004 max_fails=2 fail_timeout=60s; } ``` 另外,还可以通过对请求的URL进行哈希来实现负载均衡。在模板,我们可以使用以下配置: ``` upstream tomcats { server ip:8080; } server { listen 80; server_name www.lianggzone.com; location / { proxy_pass http://tomcats; # Proxy Settings proxy_redirect off; 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_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; proxy_max_temp_file_size 0; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } } ``` 在这个配置,我们将请求的URL进行哈希,并将其转发给名为`tomcats`的upstream。 总结起来,Nginx反向代理配置主要通过配置upstream块和server块实现。在upstream块定义后端服务器的地址和配置状态值,而在server块设置监听的端口和服务器名称,并通过location块将请求转发给upstream。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Nginx反向代理配置](https://blog.csdn.net/weixin_42751488/article/details/124165105)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lock颠颠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值