被要求一个这样的需求:要求项目和websocket使用一个端口。经过一周激烈争论,领导终于同意可以可以开通一个端口,一个月了,端口还没有开。

正式环境已经通过此方法进行部署,没有问题。

前言

因涉及到内外网安全问题,被要求使用nginx进行代理,不能直连。即对websocket做一个反向代理即可。

项目信息:springboot(cloud等),yeauty集成的websocket(推荐使用,实现非常方便),nginx,websocket在线测试网站(百度搜有很多)

项目搭建

引入依赖

1     <dependencies>
2 <dependency>
3 <groupId>org.yeauty</groupId>
4 <artifactId>netty-websocket-spring-boot-starter</artifactId>
5 <version>0.7.5</version>
6 </dependency>
7 </dependencies>

添加代码

有两个文件,可以直接复制到项目中,如图:

Websocket.java:

 1 package com.example.springboottest.common.websocket;
2
3
4 import org.springframework.stereotype.Component;
5 import org.yeauty.annotation.*;
6 import org.yeauty.pojo.Session;
7
8 import java.util.ArrayList;
9 import java.util.List;
10
11 @Component
12 @ServerEndpoint(port = 9906,path = "/WebSocket")
13 public class WebSocket {
14
15 /**
16 * 存放所有在线的客户端
17 */
18
19
20 private static List<Session> clients = new ArrayList<>();
21
22 @OnOpen
23 public void onOpen(Session session) {
24 System.out.println("open");
25 System.out.println("remoteAddress" + session.remoteAddress());
26 //将新用户存入在线的组
27 clients.add(session);
28 sendMessage("hello Word!");
29 }
30
31 /**
32 * 客户端关闭
33 *
34 * @param session session
35 */
36
37
38 @OnClose
39 public void onClose(Session session) {
40 System.out.println(session.remoteAddress() + ":closeWebSocket");
41 }
42
43 /**
44 * 发生错误
45 *
46 * @param throwable e
47 */
48
49
50 @OnError
51 public void onError(Throwable throwable) {
52 System.out.println("websocket:error");
53 throwable.printStackTrace();
54 }
55
56 /**
57 * 收到客户端发来消息
58 *
59 * @param message 消息对象
60 */
61
62 @OnMessage
63 public void onMessage(String message, Session session) {
64 System.out.println(message);
65 sendMessage("hello Word!");
66 }
67
68 public void sendMessage(String message) {
69 try {
70 if (clients.size() > 0) {
71 for (Session session : clients) {
72 session.sendText(message);
73 }
74 }
75
76 } catch (Exception e) {
77 e.printStackTrace();
78 }
79
80 }
81 }
WebSocketConfig.java:
 1 package com.example.springboottest.common.websocket;
2
3 import org.springframework.context.annotation.Bean;
4
5 import org.springframework.context.annotation.Configuration;
6 import org.yeauty.standard.ServerEndpointExporter;
7
8
9 @Configuration
10 public class WebSocketConfig {
11 @Bean
12 public ServerEndpointExporter serverEndpointExporter() {
13 return new ServerEndpointExporter();
14 }
15 }

启动项目测试websocket

nginx代理

NGINX从1.3版本开始支持WebSocket,其可以作为一个反向代理和为WebSocket程序做负载均衡。此博客不涉及内部原理等,放个干货。

反向代理

先把我自己的nginx配置发出来:

 1 #user  nobody;
2 worker_processes 1;
3
4 #error_log logs/error.log;
5 #error_log logs/error.log notice;
6 #error_log logs/error.log info;
7
8 #pid logs/nginx.pid;
9
10
11 events {
12 worker_connections 1024;
13 }
14
15
16 http {
17 map $http_upgrade $connection_upgrade {
18 default upgrade;
19 '' close;
20 }
21
22 upstream websocket {
23 #ip_hash;
24 hash $remote_addr consistent;
25 server localhost:9907;
26 }
27
28 # 以下配置是在server上下文中添加,location指用于websocket连接的path。
29
30 server {
31 listen 9908;
32 server_name localhost;
33 #access_log /var/log/nginx/yourdomain.log;
34
35 location /WebSocket {
36 root html;
37 index index.html index.htm;
38 proxy_pass http://websocket/WebSocket;
39 proxy_connect_timeout 4s; #配置点1
40 proxy_read_timeout 60s; #配置点2,如果没效,可以考虑这个时间配置长一点
41 proxy_send_timeout 12s; #配置点3
42
43 proxy_set_header Host $host;
44 proxy_set_header X-Real-IP $remote_addr;
45 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
46
47 proxy_http_version 1.1;
48 proxy_set_header Upgrade $http_upgrade;
49 proxy_set_header Connection "upgrade";
50 }
51 }
52 }

代理端口为9908,坚挺的地址就是/WebSocket,下面测试一下:

至此反向代理已经完成。

负载均衡

如果想做负载均衡,可以在upstream websocket {}中加一个server就可以了,比如复制一下项目,将websocket端口改为9907

@ServerEndpoint(port = 9907,path = "/WebSocket")
连上之后发送信息为hello world!2
sendMessage("hello Word!2");

然后连上反向代理的链接,连接之后发现连的是9906的链接,如图:

此时我把9906断掉,再次连接时:

此时遇到问题,当负载均衡时,9906断了之后,没有自动转为9907的链接。在客户端监听此链接,如果查实连接不上则进行重新链接,即可使用9907的服务。

nginx反向代理,负载均衡和yeauty集成的websocket的使用的更多相关文章

  1. Nginx 反向代理 负载均衡 虚拟主机配置

    Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...

  2. Nginx 反向代理 负载均衡 虚拟主机

    Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...

  3. 十.nginx反向代理负载均衡服务实践部署

    期中集群架构-第十章-nginx反向代理负载均衡章节章节====================================================================== 0 ...

  4. 【转】Nginx 反向代理 负载均衡 虚拟主机配置

    原文:http://www.cnblogs.com/itdragon/p/8059000.html Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代 ...

  5. Centos7.4 Nginx反向代理+负载均衡配置

    Ningx是一款高性能的HTTP和反向代理服务器,配置起来也比较简单. 测试环境: 172.16.65.190 Nginx-反向代理 172.16.65.191 Ningx-Web 172.16.65 ...

  6. 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器

    Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...

  7. 项目实战2.2—nginx 反向代理负载均衡、动静分离和缓存的实现

    实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备注 nginx VIP:172.17.11.11 反向代理服务器 开启代理功能 设置监控,调度 rs01 RIP ...

  8. 项目实战2.1—nginx 反向代理负载均衡、动静分离和缓存的实现

    总项目流程图,详见 http://www.cnblogs.com/along21/p/8000812.html 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备 ...

  9. 项目实战02:nginx 反向代理负载均衡、动静分离和缓存的实现

    目录 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 2.下载编译安装tengine 3.设置代理服务器的配置文件 4.启动tengine服务 5.开启后端的web服务 6.测试 实验二:ng ...

  10. Centos 7.6配置nginx反向代理负载均衡集群

    一,实验介绍 利用三台centos7虚拟机搭建简单的nginx反向代理负载集群, 三台虚拟机地址及功能介绍 192.168.2.76    nginx负载均衡器 192.168.2.82    web ...

随机推荐

  1. 痞子衡嵌入式:恩智浦i.MX RT1xxx上特色外设XBAR那些事(1)- 初识

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦i.MX RT1xxx系列上的XBAR外设. 得益于 Arm Cortex-M 内核的普及,现如今 MCU 厂商遍地开花,只要能取 ...

  2. 0x00 语法知识

    目录 C++ STL Vector Pair String Queue Stack Deque Set Map Bitset Algorithm库函数 Reverse Unique Random_sh ...

  3. HTB打靶记录-Administrator

    # 信息收集 nmap -sV -sC -O 10.10.11.42 Nmap scan report for 10.10.11.42 Host is up (0.70s latency). Not ...

  4. ESP32+Arduino入门(一):开发环境搭建

    前言 作为一名硬件小白,在动手组装了一下小智AI之后,感觉还挺有意思的,也想开始学习ESP32了. ESP32介绍 ESP32 是乐鑫科技(Espressif Systems)推出的一款高性能.低功耗 ...

  5. iOS Facebook和Google登录

    前言 最近在对接完Google和Facebook登录之后准备对这部分内容做一个小小的总结,方便以后有需要的时候查看. 具体的Google账号申请和Facebook账号的申请在这里就不做介绍了,这部分内 ...

  6. 【记录】OpenAI|Python调用GPT API的开发环境及代码(2024/03/21实测)

    本文默认读者已经有API Keys,并默认读者对Python环境较为熟悉,对相关内容不予介绍. 更新时间:2024/03/21 国内安装的时候偶尔会出现各种问题, 这篇记录是记录当下可用的一个方式. ...

  7. Nacos源码—8.Nacos升级gRPC分析三

    大纲 7.服务端对服务实例进行健康检查 8.服务下线如何注销注册表和客户端等信息 9.事件驱动架构源码分析 7.服务端对服务实例进行健康检查 (1)服务端对服务实例进行健康检查的设计逻辑 (2)服务端 ...

  8. File与IO流之字节流

    FileOutputStream 创建字节输出流对象FileOutputStream fl =new FileOutputStream() 传入的参数可以是字符串路径或者File对象(实际上如果传入字 ...

  9. MySQL修改表和字段的字符集和排序规则

    摘要:通过设置表的字符集和排序规则,解决MySQL查询时不区分字母大小写.插入时不支持特殊字符的问题.   关于MySQL查询时不区分字母大小写.插入时不支持特殊字符的问题,只有修改表的字符集和排序规 ...

  10. Spring 注解之 @EnableTransactionManagement:Spring Boot 事务配置

    Spring Boot 开启声明式事务支持 所有的数据访问技术都有事务处理机制,这些技术提供了API用来开启事务.提交事务以完成数据操纵,或者在发生错误的时候回滚数据.Spring支持声明式事务,这是 ...