基于Netty的WEB聊天服务端开发|Java 开发实战

简介: 基于Netty的WEB聊天服务端开发|Java 开发实战

1.主要采用了Netty的什么功能



webSocket的wss    
复制代码


//wss配置
@Override
public void initChannel(SocketChannel ch) throws Exception {
  ChannelPipeline pipeline = ch.pipeline();
  pipeline.addLast(new IdleStateHandler(10, 0, 0, TimeUnit.SECONDS));
  pipeline.addLast(new HttpServerCodec());
  pipeline.addLast(new HttpObjectAggregator(1024 * 1024));
  pipeline.addLast(new ChunkedWriteHandler());
  // pipeline.addLast(new HttpRequestHandler("/ws"));
  pipeline.addLast(new WebSocketServerProtocolHandler("/ws", null, true, 1024 * 512));
  // pipeline.addLast(new HeartbeatServerHandler());
  pipeline.addLast(new TextWebSocketFrameHandler());
  // 配置ssl访问的
  logger.info(WebsocketChatServerInitializer.class.getResource("/").toString());
  URL xmlpath = this.getClass().getClassLoader().getResource("");
  logger.info(xmlpath.toString());
  // File f = new File(this.getClass().getResource("/").getPath());
  File f = new File(WebsocketChatServerInitializer.class.getResource("").toString());
  logger.info(f.getAbsolutePath());
  SSLContext sslContext = SslUtil.createSSLContext("PKCS12",
        this.getClass().getClassLoader().getResourceAsStream("keystore.p12"), "changeit"); 
       SSLEngine engine =sslContext.createSSLEngine();
  SSLEngine sslEngine = sslContext.createSSLEngine();
  sslEngine.setNeedClientAuth(false);
  sslEngine.setUseClientMode(false);
  pipeline.addFirst(new SslHandler(sslEngine));
    }
复制代码


2.WEB聊天的基本流程和一些限制



2.1消息采用wss发送
  2.2首先前端用户先在服务端登录,获取token,然后连接websocket绑定服务端.
     为了防止恶意连接保存token的时候时候key为:前缀_用户名
  2.3服务端校验token后会保存一个键值对,用户名:Channel
     为了防止恶意信息的发送,在发送消息的时候会根据用户名获取Channel,然后当前的Channel和获取到的Channel可以做个比对,这样用户就是正常用户了
  2.4web端绑定了服务端后可以进行消息的收发,消息格式为JSON
     Netty服务端主要通过保存的Channel获取连接,然后做信息转发推送
  2.5配置个后台管理的模块,对用户进行强制管理,后消息广播
复制代码


3.消息格式



整体格式
{
    "cmd":null,
    "mdChild":ull,
    "from":null,
    "accept":null,
    "group":null,
    "msg":null,
    "status":null,
    "id":null,
    "createDate":"2021-01-09 22:26:14",
    "chatSet":null,
    "groupSet":null,
    "oldMsg":null
}
单聊
{
    "cmd":"3",
    "from":{
        "userCode":"dnmt"
    },
    "accept":{
        "userCode":"fhx"
    },
    "msg":"单聊测试"
}
群聊
{
    "cmd":"4",
    "from":{
        "userCode":"dnmt"
    },
    "group":{
        "groupCode":"g003"
    },
    "msg":"群聊测试"
}
复制代码


4服务端的扩展



3.1因为当用户量变大,服务端可能处理有些跟不上。
     这里可以采用的是服务端集群部署。
  3.2集群部署问题
     消息的转发可能会跨服务器进行推送?
     用户的跨服务器绑定?
  3.3netty集群解决跨服务器消息推送思路
     采用redis的发布和订阅进行消息的转发,当前获取订阅消息判断用户是否存在,如果存在就进行消息处理。
 3.4用户的跨服务器绑定。
     这里用到了zookeeper
     当服务器启动的时候,会把服务器的连接信息发送到zookeeper上
     当用户登录的时候,可以根据一个简单的负载均衡算法(随机、或者最小)获取netty服务器的绑定信息,然后绑定到后端服务器。
 3.5进一步性能提升
    服务端在处理转发消息的时候,采用线程池处理。
复制代码


5.以玩转的地方



1.支持了WEB的语音、和视频聊天
    刚开始的时候是采用了peerjs的WEBRTC方式,进行的视频聊天,但是对node不了解和感觉这样不可控,采用了下面的方式。
  2.通过WEBRTC的浏览器音频,视频录制功能,定时获取到数据,然后进行base64编码进行数据传输,转发到web端解码进行音视频聊天。
  3.在视频聊天的时候,可以借助opencv进行一些对视频的操作(这里是我开始学习opencv的地方)
    简单的例子:视频中人脸识别的思路,首先提取视频文件的音频(ffmpeg),然后对视频跳帧(主要想提高点速度)的处理获取每帧的图片,处理完毕后提取的音频和新的视频文件合并,然后编码进行视频流转发
复制代码


6.项目地址欢迎star

相关文章
|
8天前
|
网络协议 Java Shell
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
40 7
|
1月前
|
Kubernetes Java 持续交付
小团队 CI/CD 实践:无需运维,Java Web应用的自动化部署
本文介绍如何使用GitHub Actions和阿里云Kubernetes(ACK)实现Java Web应用的自动化部署。通过CI/CD流程,开发人员无需手动处理复杂的运维任务,从而提高效率并减少错误。文中详细讲解了Docker与Kubernetes的概念,并演示了从创建Kubernetes集群、配置容器镜像服务到设置GitHub仓库Secrets及编写GitHub Actions工作流的具体步骤。最终实现了代码提交后自动构建、推送镜像并部署到Kubernetes集群的功能。整个过程不仅简化了部署流程,还确保了应用在不同环境中的稳定运行。
75 9
|
2月前
|
前端开发 安全 JavaScript
2025年,Web3开发学习路线全指南
本文提供了一条针对Dapp应用开发的学习路线,涵盖了Web3领域的重要技术栈,如区块链基础、以太坊技术、Solidity编程、智能合约开发及安全、web3.js和ethers.js库的使用、Truffle框架等。文章首先分析了国内区块链企业的技术需求,随后详细介绍了每个技术点的学习资源和方法,旨在帮助初学者系统地掌握Dapp开发所需的知识和技能。
2025年,Web3开发学习路线全指南
|
2月前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
103 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
3月前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
55 7
|
3月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
66 2
|
3月前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
159 62
|
3月前
|
Java Maven Spring
Java Web 应用中,资源文件的位置和加载方式
在Java Web应用中,资源文件如配置文件、静态文件等通常放置在特定目录下,如WEB-INF或classes。通过类加载器或Servlet上下文路径可实现资源的加载与访问。正确管理资源位置与加载方式对应用的稳定性和可维护性至关重要。
87 7
|
3月前
|
Java 持续交付 项目管理
使用Maven进行项目管理:提高Java Web开发的效率
Maven 是一款强大的项目管理和构建自动化工具,广泛应用于Java社区。它通过依赖管理、构建生命周期管理、插件机制和多模块项目支持等功能,简化了项目的构建过程,提高了开发效率。本文将介绍Maven的核心功能及其在Java Web开发中的应用。
90 0
|
3月前
|
消息中间件 缓存 Java
java nio,netty,kafka 中经常提到“零拷贝”到底是什么?
零拷贝技术 Zero-Copy 是指计算机执行操作时,可以直接从源(如文件或网络套接字)将数据传输到目标缓冲区, 而不需要 CPU 先将数据从某处内存复制到另一个特定区域,从而减少上下文切换以及 CPU 的拷贝时间。
java nio,netty,kafka 中经常提到“零拷贝”到底是什么?

热门文章

最新文章