分布式-Java应用

article/2025/9/15 16:07:35

     分布式计算不是一门年轻的技术,早在上个世纪70年代末便已是计算机科学的一个独立分支了;它也不是一门冷僻的技术,从C/S模式到P2P模式,从集群计算到网格计算,乃至风靡当下的云计算,都是其表演的舞台。另一方面,Java作为一门应网络而生的语言,对分布式计算有着天然的友好性,同时也是当今最流行的编程语言。然而令人稍感意外的是,以“分布式Java应用”为专题的书籍并不多见,佳作则更少。至于国人所著者,请恕在下孤陋,尚未得见。不过细想之下,其实不足为奇。要开发一个高质量的分布式Java应用,以达到高性能、可伸缩、高可用、低延迟的要求,同时保证一致性、容错性、可恢复性和安全性,是何等的不易啊。它对程序开发的挑战在于:不仅需要对Java语言、类库、各种框架及相关工具极为熟悉,还需要对底层的JVM机制、各种网络协议有足够的了解;它对分析设计的挑战在于:不仅需要熟悉传统的应用架构模式,还需要掌握适用于分布式应用的架构模式和算法设计。此外,分布式应用对数据库管理员、测试分析人员等也提出了更高的要求。一本书若想涵盖这么多的内容,其难度可想而知。作者不仅需要具备起码的理论素养,更需要有丰富的实践经验。
如果仅仅是纸上谈兵,对读者是无甚裨益的。

      提起诸如“高性能”、“高可用性”、“大规模并发”、“可扩展性”这些词汇,我相信多数技术人的心情都是激动而稍有点复杂的,当然,也或许是不屑一顾。毕竟不是谁都有机会面对这些富有挑战的技术场景,也不是每个架构师在面对这些挑战之前都能做好技术上的准备。那些意外故障总是不期而至,疲于奔命地解决问题的场景回顾起来对架构师来说犹如一场噩梦。
      以下阐述当一个面向数以亿计用户的网站经过几年高速发展,技术团队不得不面临大规模、高并发、高扩展性等挑战带来的技术困境的时候,一个出色的架构师经过多年一线实践后累积的经过时间考验的解决方案以及宝贵的实战经验。在这本书里,你会看到作者在解决一些关乎Web应用问题的指导原则、实践方法、多重工具的综合运用以及作者本人的感悟。要强调的是,本书讲述的内容是一个Web应用从小到大过程中遇到的棘手问题的解决之道,并非宏观解析,亦非屠龙之技。无论您面对的站点是大是小,皆会有参考作用,毕竟大站点会越来越复杂,而小站点总有一天也将变大。

大型应用通常会拆分为多个子系统来实现,对于Java来说,这些子系统可能部署在同一台机器的多个不同的JVM中,也可能部署在不同的机器上,但这些子系统又不是完全独立的,要相互通信来共同实现业务功能,对于此类Java应用,我们称之为分布式Java应用。
Martin Fowler在《企业应用架构模式》一书中曾经说过:“能不用分布式的情况下就不要用分布式”,当应用变为分布式Java应用时,会很大程度地增加应用实现的技术复杂度,对于分布式Java应用,通常有两种典型的方法来实现。

1.基于消息方式实现系统间的通信
当系统之间要通信时,就向外发送消息,消息可以是字节流、字节数组,甚至是Java对象,其他系统接收到消息后则进行相应的业务处理。
消息方式的系统间通信,通常基于网络协议来实现,常用的实现系统间通信的协议有:TCP/IP和UDP/IP。
TCP/IP是一种可靠的网络数据传输的协议。TCP/IP要求通信双方首先建立连接,之后再进行数据的传输。TCP/IP负责保证数据传输的可靠性,包括数据的可到达、数据到达的顺序等,但由于TCP/IP需要保证连接及数据传输的可靠,因此可能会牺牲一些性能。
UDP/IP是一种不保证数据一定到达的网络数据传输协议。UDP/IP并不直接给通信的双方建立连接,而是发送到网络上进行传递。由于UDP/IP不建立连接,并且不能保证数据传输的可靠,因此性能上表现相对较好,但可能会出现数据丢失以及数据乱序的现象。
TCP/IP和UDP/IP可用于完成数据的传输,但要完成系统间通信,还需要对数据进行处理。例如读取和写入数据,按照POSIX标准分为同步IO和异步I0两种,其中同步10中最常用的是BIO(Blocking I0)和NIO(Non-Blocking IO)。

2.基于远程调用方式实现系统间的通信
当系统之间要通信时,可通过调用本地的一个Java接口的方法,透明地调用远程的Java实现。
体的细节则由Java或框架来完成,这种方式在Java中主要用来实现基于RMI和WebService的应用。
本章通过举例来介绍如何基于Java的包及开源的产品来实现以上两种方式的系统间通信,这些实现分布式Java应用的基础和必备知识,采用的例子如下。
示例程序由一个服务器端程序和一个客户端程序构成,是典型的请求-响应机制,即客户端发送求,服务端响应。客户端读取用户的输入,并将输入的字符串信息发送给服务器端,服务器端接收信息后响应,当客户端输入的是quit字符串时,则停止客户端和服务器端的程序。

基于Java自身包实现消息方式的系统间通信的方式有:TCP/IP+BIO、TCP/IP+NIO、UDP/IP+BIO以及UDP/IP+NIO4种,下面分别介绍如何实现这4种方式的系统间通信。
TCP/IP+BIO在Java中可基于Socket、ServerSocket米实现TCP/IP+BIO的系统间通信。Socket主要用于实现建立连接及网络I0的操作,ServerSocket 主要用于实现服务器端端口的监听及Socket对象的获取。基于Socket实现客户端的关键代码如下:

//创建连接,如果域名解析不了会抛出UnknownHostException,当连接不上时会抛出IOException,如果希望控制建立连接的超时,可先调用new Socket(),然后调用 socket.connect(SocketAddress类型的目标地址,以毫秒为单位的超时时间)Socket socket=new Socket(目标IP或域名,目标端口);
//创建读取服务器端返回流的BufferedReader BufferedReader in=new BufferedReader(new InputStreamReader(socket.getInputStream()));

//创建向服务器写入流的PrintWriter PrintWriter out=new PrintWriter(socket.getOutputStream(),true);
//向服务器发送字符串信息,要注意的是,此处即使写失败也不会抛出异常信息,并且一直会阻塞到写入操作系统或网络IO出现异常为止
out.println("hello");
//阻塞读取服务端的返回信息,以下代码会阻塞到服务端返回信息或网络IO出现异常为止,如果希望在超过一段时间后就不阻塞了,那么要在创建Socket对象后调用socket.setSoTimeout(以毫秒为单位的超时时间)in.readLine(); 


http://chatgpt.dhexx.cn/article/2v8rFjfa.shtml

相关文章

分布式开发简介

分布式开发简介 1 概述 分布式应用程序就是指应用程序分布在不同计算机上,通过网络来共同完成一项任务,通常为服务器/客户端模式。更广义上理解“分布”,不只是应用程序,还包括数据库等,分布在不同计算机&a…

java分布式学习

首先推荐4本书 大型分布式网站架构设计与实践 http://item.jd.com/11529266.html 大型网站技术架构:核心原理与案例分析 http://item.jd.com/11322972.html 大型网站系统与Java中间件实践 http://item.jd.com/11449803.html 分布式Java应用:基础与实践 h…

耗时十年!精心整理的Java高级开发需要的分布式技术

前言 分布式、微服务几乎是现在的技术人员必须要了解的架构方向,从理论上来讲确实解耦了很多结构,但另一方面,又会带来更多衍生的复杂度及难点。 如何保证事物的最终一致性?如何进行性能及容量预估?如何处理分布式系统…

Java分布式开发

分布式概念的引入是基于性能的提升,应用的可靠性而提出的。所谓Java分布式,即是在使用Java语言进行企业级应用开发的过程中,采用分布式技术解决业务逻辑的高并发、高可用性的一些架构设计方案。 1. RPC技术介绍 我们知道Web Servie实现了服务…

足球赛事实时大小球数据worldliveball软件搭建

worldliveball软件 worldliveball开发思路功能脑图合理的展示足球赛事如何快捷的判断赛事wordliveball下载地址与软件图片代码宏定义运用了哪些技术worldliveball流程图 worldliveball 整个足球赛事AI worldliveball 开发思路及过程。如果你想学习如何使用worldliveball, 可以…

足球走地大小球预测-分析软件开发及逻辑

足球大小球分析之大球 相比小球,热爱大球玩法的更多。走地大小球,预测进球数简单明了。无论比赛双方哪一方进球,对于您而言,都是欢喜的。只要进球数量达到了,您就妥妥的了。 走地大球玩法之挑赛事 那么有些赛事疯狂进…

足球走地大小球预测之理性分析软件开发及逻辑

足球走地大小球 前言一、足球大小球分析之小球二、走地大小球分析之看实时数据1.实时数据2.足球分析逻辑 AI足球数据 前言 足球已经开始了也快百年了,但市面上没有真正好的分析的,15年开发经验,弄个Ai分析,看看是不是这样的。 一…

足球分析大小球开发成量化交易软件

足球分析大小球量化交易软件 最近总有朋友问足球大小球的那些所谓的分析法则到底准不准,到底该如何去分析大小球究竟是大球还是小球呢,大家都知道股票有量化交易系统,能否开发足球量化交易软件,整理一些多年开发的心得总结出一套…

足球走地大小球量化分析方法软件

前阵子看了国足的比赛后突发奇想,足球的大小是否可以预测呢。于是乎翻遍了各种材料,经过数月的鏖战,结合数据采集大数据分析大小球技巧经验模型机器学习,搞出了一套可以在走地过程中自动分析比赛大小的软件,目前试水挂…

短信/语音在医疗领域(his系统)各场景的应用

短信/语音通知,可广泛应用于医疗领域的内部管理、患者服务等各种应用场景 一、预约挂号 二、远程医疗 三、系统监控 四、网络医嘱 五、体检报告 六、订单提醒 七、信息化办公 八、患者关怀

医院信息管理系统源码 HIS系统源码

系统功能简介: 一、医院门诊模块 门诊(预约)挂号系统 门诊挂号系统实现了医院门诊部挂号处所需的各种功能。 包括现场办卡,现场挂退号,临时加号,特殊加号,修改患者信息,就诊卡号打…

基层区域应用平台为目标开发的基础医疗云HIS系统源码

系统特点: JAVA语言开发,MYSQL数据库,B/S架构 基于云计算技术的低成本基层医疗信息系统,能够有效降低基层医疗单位信息化建设的投入, 减少系统的维护费用;规范医疗信息、规范业务处理流程,提高服务水平&…

his系统管理工具配置服务器,HIS系统(his管理系统)V3.0.1 官网版

HIS系统(his管理系统)是一款非常专业的his管理程序。行心HIS系统源于北美技术,经过17年HIS技术沉淀,现已拥有100多套子系统,十四项著作权,100多人技术团队。行心HIS系统已经经过300多家医院见证,成熟HIS系统采用专人驻…

云HIS源码 大型医院java云HIS系统源码 云his系统

🍓文末获取联系🍓 云HIS系统 云his系统源码 大型医院java云HIS系统源码 本套云HIS系统采用主流成熟技术开发,软件结构简洁、代码规范易阅读,SaaS应用,全浏览器访问前后端分离,多服务协同,服务可…

java项目-第37期基于springboot+layui实现的医院His系统【毕业设计】

java项目-第37期基于springbootlayui实现的医院His系统 1、项目简述 该项目是针对医院门诊和住院流程开发的一套His系统,分为不同的角色,不同的角色分管不同的模块功能,其中有个超级管理员。 包含模块有: 门诊管理:处方…

Python+Vue计算机毕业设计东软医疗HIS系统之住院入出转管理子系统7k546(源码+程序+LW+部署)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行环境配置: Python3.7.7DjangoMysql5.7pip listHBuilderX(Vscode也行)VuePychram社区版。 项目技术: Django Vue PythonMysql 等等组成,B/S模…

springboot毕设项目东软医疗HIS系统之住院入出转管理子系统7k546(java+VUE+Mybatis+Maven+Mysql)

springboot毕设项目东软医疗HIS系统之住院入出转管理子系统7k546(javaVUEMybatisMavenMysql) 项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,M…

九阵His系统总体介绍

目录 产品功能模块: 系统结构图: 门诊流程: 住院流程: 产品功能模块: 序号 模块名称 功能描述(出厂设置) 1 数据中心管理 医院各种档案管理,主要包括:往来单位、…

PHP如何接入医疗HIS系统发送短信

医疗信息系统HIS短信接口解决方案 为数字化医院系统提供可靠的短信通知服务 PHP对接验证码短信接口DEMO示例 本文为您提供了PHP语言版本的验证码短信接口对接DEMO示例 * 接口类型:触发短信接口,支持发送验证码短信、订单通知短信,节日祝福等…

ASP对接医疗HIS系统短信通知

ASP对接验证码短信接口DEMO示例 本文为您提供了ASP版本的验证码短信接口对接DEMO示例 * 接口类型:触发短信接口,支持发送验证码短信、订单通知短信,节日祝福等。 * 账户注册:请通过该地址开通账户 http://user.ihuyi.com/?exCla…