分布式系统-性能篇
罪一:网络传输方式问题。传统的rpc框架或者是基于rmi等方式的远程服务调用采用的是同步阻塞i/o,当客户端的并发或者网络延时增大之后,同步阻塞i/o会频繁的wait导致i/o线程经常性阻塞,由于线程无法高效的工作,i/o处理能力自然下降。
采用bio通讯模型的服务端,通常是由一个独立的acceptor线程负责监听客户端的连接,接受到客户端的连接之后,为其创建一个心的线程处理请求消息,处理完成之后,返回应答消息给客户端,线程销毁,这就是典型的一个请求一应答模型。该架构最大的问题就是不具备弹性的伸缩能力,当并发访问增加之后,服务线程个数和并发访问数成线性正比,由于线程是java虚拟机非常宝贵的资源,当线程膨胀之后,系统的性能急剧下降。随着并发量的增加,可能会导致句柄溢出,线程堆栈溢出等问题,并最终导致服务器宕机。
罪二:序列化问题。java序列化存在一下几个典型的问题:
a)java序列化是其内部一个对象的编码技术,无法跨语言,例如异构系统之间的对接,java序列化的码流需要通过其它的语言反序列化成原始对象,目前很难支持。
b)相比其它的开源的序列化框架,java序列化的码流太大,无论网络传输还是持久化道磁盘,都会导致额外的资源占用。
c)序列化的性能比较的差,资源的占有率高,主要是cpu资源的占用比较高。
罪三:线程模型问题。由于采用的是同步阻塞i/o,导致每个tcp的连接都会被占用1个线程,由于线程资源是jvm虚拟机非常宝贵的资源,当i/o读写阻塞导致线程无法被释放时,会导致系统性能急剧下降,严重的甚至会导致虚拟机无法创建心的线程。
do good things。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用