出身名门的 Mina 通信框架,可靠且省时
ccwgpt 2024-10-08 01:29 43 浏览 0 评论
随着网络通信技术的发展速度加快,互联网应用对高并发、高可用的要求越来越高,分布式、弹性伸缩的架构逐渐成为开发人员常用的技术了。
在Java NIO通信框架中,出身于开源界的大牛Apache组织的Mina通信框架为开发者们提供了很大的便利。
那Mina框架的执行流程是怎么样的呢?异步君带大家来了解一下Mina设计架构吧!
Mina设计架构
Mina 框架是 Apache 开源的一款网络通信应用框架。使用 Mina 框架可以帮助用户开发高性能和高伸缩性的网络应用框架。
Mina 提供了一个抽象的事件驱动,开发者既可以通过 Java NIO 实现 TCP/IP 和 UDP/IP 等协议的数据传输,也可以在 VM 内管道通信。Mina 对于传输不同类型数据,提供了一整套的 API,极大地减少了开发者的开发时间。
在客户端与服务器端连接成功之后,可以抽象地认为客户端与服务器端建立了一个通信管道, IoSession 就是负责在管道中传输数据和接收数据的管理者,同时 Mina 提供了过滤器,能够增强开发者对管道的管理。在 IoHandler 作为 Mina 执行流程的末端,需要开发者在 IoHandler 中实现业务逻辑的编码。
对于在互联网 TCP 协议传输数据包的时候,Mina 提供了编码解码过滤器,帮助开发者解决粘包和断包问题处理,同时 Mina 也支持开发者自定义数据包的编码和解码操作。
Mina整体架构
在 Mina 运行架构中,开发者只需要关注应用程序开发即可。Mina 会自动把开发者的应用程序和底层网络层之间黏合起来,开发者不需要考虑网络通信中底层的实现。
也就是说,Mina 起到的是黏合剂的作用。这里说的应用程序是指 Mina 建立的客户端应用程序或者 Mina 建立的一个后端应用程序,如图所示。
Mina存在于中间层,开发者只需要关注于Mina顶部的设计,即应用程序设计。也就是说,开发者根据业务需求开发出对应的应用程序即可。
至于 Mina 底层网络数据的传输,不需要开发者去关心。对于Mina黏合底层网络层,可以基于TCP 协议、UDP 协议或者 VM 通信。
Mina 负责接收底层网络数据 之后,并且通过过滤器编码或者解码,把数据转化成开发者需要的数据包,返回到开发者的应用程序中。
Mina执行流程
Mina 整体执行流程分为服务器端执行流程和客户端执行流程。无论是服务器端执行流程,还是客户端执行流程两者都具有很大的共性:需要在应用程序中新建 IoService 服务。
IoService服务分为两种,一种是包括开启Mina服务器端接收器 IoAcceptor,另一种是Mina客户端连接服务器端的IoConnector连接器。接着在IoFilterChain 中创建过滤链。
在创建过滤链的时候,开发者根据项目需求的选择 Mina 自带的过滤 器,增强对应用程序的控制。最后在 IoHandler 中实现开发者业务逻辑处理。
Mina服务器端执行流程
对于 Mina 服务器端执行流程主要分为3步:首先 IoAcceptor 接收器监听端口号,或者监听IP地址和端口号,实现接收客户端新建连接或者接收客户端发送来服务器端的数据包。
接着开始遍历在开启Mina接收器时,加入的过滤链中的过滤器,在加载完过滤器之后,数据就会传输到 IoHandler 中,在 IoHandler 中开发者需要根据需求实现业务逻辑代码。接收器执行流程如图所示。
当接收器IoAcceptor接收到有新客户端连接的时候,就会为这位客户端创建对应新的会话IoSession,服务器端通过操作这个会话IoSession实现对客户端发送数据、接收数据或者接收客户端的请求等操作。
IoFilter过滤器可以用来解析数据包的内容或者增强对应用程序流程的控制等操作,例如,当开发者使用自定义编码和解码器的时候,需要判断此刻服务器端接收的数据包是否完整,是否出现粘包或者断包现象;当发现非法IP地址连接的时候,直接拒绝非法客户端的连接。
在IoFilter中,开发者根据需要实现项目中自定义的编码解码。执行完IoFilter 过滤链之后,后端通过 IoSession 发送数据包到客户端。
Mina客户端执行流程
Mina 客户端执行流程也是分为 3 个部分,客户端通过 IoHandler 从服务器端接收所有响应请求和消息之后,通过开发者在 IoConnector 连接服务器时,遍历加入过滤链的过滤器,接着通过 IoConnector 发送数 据到服务器端。Mina 客户端执行流程如图 所示。
在客户端中负责连接后端的 IoConnector 连接器,客户端在新建连接的时候,指定服务器端的 IP 地址和端口号进行连接,在客户端连接成功之后,就会创建与服务器端关联的会话 IoSession,客户端通过这个会话 IoSession,向服务器端发送消息,在发送消息之前,连接器会遍历过滤链中开发者在客户端加入的编码模式,在对数据包进行编码完成之后,向后端发送数据包。
Mina 执行流程无论是客户端,还是服务器端都需要经过过滤链,遍历开发者加入过滤链中的过滤器,过 滤器在其中的作用至关重要,在加入过滤器的时候,可以加入日志过滤器、开发者自定义的编码解码过 滤工厂等。
在 IoService 中会把 NIO 烦琐的部分进行封装,提供简洁的接口给开发者使用。IoService 分为 Mina 服务器端接收器 IoAcceptor 和 Mina 客户端连接器 IoConnector。
在 Mina 客户端连接器 IoConnector 连接成功之后,就生成一个与服务器端关联是 IoSession,开发者根据获得的 IoSession 向后端 发送数据包,同样的,对服务器而言,接收器成功接收客户端连接器连接之后,也会与成功连接的每一 个客户端连接器生成一个关联的 IoSession,服务器端通过操作 IoSession,可以向每一个连接成功客户端 发送数据包。
相关推荐
- 谷歌正在为Play商店进行Material Design改造
-
谷歌最近一直忙于在其应用程序中完成MaterialDesign风格的改造,而Play商店似乎是接下来的一个。9to5Google网站报道,有用户在Play商店的最新版本中发现了新界面,暗示该应用和网...
- 企业网站免费搭建,定制化建站CMS系统
-
科腾软件企业网站CMS管理系统已完成开发工作,首次开源(全部源码)发布。开发工具:VisualStudioEnterprise2022数据库:SQLite(零配置,跨平台,嵌入式)开发...
- 您需要的 11 个免费 Chrome 扩展程序
-
来源:SEO_SEM营销顾问大师Chrome扩展程序是SEO的无名英雄,他们在幕后默默工作,使您的策略脱颖而出并提高您的努力效率。从竞争对手研究到审核您的网站,速度比您说“元描述”还快,这些小工具发...
- 户外便携设备抗干扰困境如何破局?CMS-160925-078S-67给出答案
-
在户外复杂的电磁环境中,便携式设备中的扬声器需具备出色抗干扰能力,CUID的CMS-160925-078S-67在这方面表现突出。 从其结构设计来看,矩形框架虽主要为适配紧凑空...
- 一个基于NetCore开发的前后端分离CMS系统
-
今天给大家推荐一个开源的前后端分离架构的CMS建站系统。项目简介这是一个基于.Net3构建的简单、跨平台、模块化建站系统。系统业务简单、代码清晰、层级分明、全新架构便于二次扩展开发。支持多种数据库,...
- 本地Docker部署ZFile网盘打造个人云存储
-
前言本文主要介绍如何在LinuxUbuntu系统使用Docker本地部署ZFile文件管理系统,并结合cpolar内网穿透工具实现远程访问本地服务器上的ZFile传输与备份文件,轻松搭建个人网盘,无...
- pcfcms企业建站系统 免费+开源的企业内容管理系统
-
项目介绍pcfcms是基于TP6.0框架为核心开发的免费+开源的企业内容管理系统,专注企业建站用户需求提供海量各行业模板,降低中小企业网站建设、网络营销成本,致力于打造用户舒适的建站体验。演示站...
- 【推荐】一个高颜值且功能强大的 Vue3 后台管理系统框架
-
如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍SnowAdmin是一款基于Vue3、TypeScript、Vite5、Pinia、Arco-Desi...
- java开源cms管理系统框架PublicCMS后台管理系统
-
一款使用Java语言开发的CMS,提供文章发布,图片展示,文件下载,用户权限、站点模块,内容管理、分类等功能。可免费用于商业用途maven工程数据库脚本在工程中database文件夹下代码结构:效果...
- 一定要大量读书:当我问Deepseek,它给出的高效阅读方法厉害了!
-
一年一度的世界读书日,总该写点什么。于是,我去问Deepseek给我推荐人生破局必读的10本书,结果它给了我回复,竟然10本推荐的书籍里,我都曾经浏览过,同时还给出破局关键。而说浏览过,不是读过,是因...
- 《搜神札记》:不应磨灭的惊奇(小说《搜神记》)
-
□黄勃志怪传说的书写一直是文人墨客的后花园,晚近尤盛,从张岱到袁枚到纪昀,收集那些或阴森或吊诡的行状故事,遂成一类,到民国年间,周作人挟此遗传,捋袖子拿希腊神话动刀,乃兄鲁迅不甘其后,《故事新编》虎...
- 《如何构建金字塔》之第三章总结(构建金字塔结构的方法有)
-
“没有什么比一套好理论更有用了。”——库尔特.勒温这篇读后感依然引用了这句库尔特.勒温名言,这句话也是我读芭芭拉.明托这本书的初衷。今天就“如何构建金字塔”,我来谈谈我的读后心得。我热爱写作,但是写...
- 《助人技术》第一章助人引论内容框架
-
第一章内容基本呈现如何成为助人者(心理咨询师)以及一些相关基础知识,对于进入这个行业有兴趣以及希望通过心理咨询寻求帮助但存有疑虑的当事人,都值得一读。心理咨询的三个阶段(不是说严格的三个阶段,而是广义...
- AI助手重构读后感写作流程:从提纲到完整性思考的转换
-
大家好!你有没有遇到过读完一本书,想要写读后感,却不知道从何下手的情况呢?今天我们要来探讨一下如何利用稿见AI助手来重构读后感写作流程,从提纲到完整性思考的转换。让我们一起来看看这个全新而又实用的方法...
- 图解用思维导图做读书笔记技巧(图解用思维导图做读书笔记技巧视频)
-
做阅读笔记非常有利于读后进行有效的深入思考,而思维导图这一强大的工具其最大的特点就是架构清晰,在阅读过程中对文章的分析、总结、分类起着很大的辅助作用。思维导图读书笔记步骤:1、阅读大纲。首先要快速浏览...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- JAVA集合框架 (47)
- mfc框架 (52)
- abb框架断路器 (48)
- grpc框架 (55)
- ppt框架 (48)
- 内联框架 (52)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)