前面一篇简单介绍了一下应用软件的分层
下面重点介绍一下中间件,也就是业务逻辑层的软件结构
从本系列第二篇我们知道,java程序是跑在虚拟机之上的
大致结构如下:
------------
| grogram |
------------
| 虚拟机 |
------------
| 操作系统|
------------
也就是说操作系统先运行一个java虚拟机,然后再在虚拟机之上运行java程序
这样做的好处前面也说过了,就是安全,一旦出现病毒或是其他什么东西
挂掉的是虚拟机,操作系统并不会受多大影响
这时候有人可能会问,为什么非要虚拟机?把操作系统当成虚拟机为什么不行?
可以,当然可以,但是这样做某一个应用软件的bug就可能造成整个操作系统的死亡
比如说我们在某个服务器上安装了一个收发电子邮件的软件和java虚拟机
那么一旦黑客通过收发电子邮件的软件入侵系统,那么操作系统就整个玩完
那么如果黑客通过java程序进行攻击的话,那么死的将会是虚拟机而不是操作系统
大不了虚拟机崩溃,而操作系统正常运行不受任何影响
举个简单例子,比如说最常见的是将数据库(DB)与中间件放在同一台服务器上
------------------------
| program | |
-----------| DB |
| 虚拟机 | |
------------------------
| 操作系统 |
------------------------
那么此时如果没有虚拟机,黑客病毒攻击中间件系统,就有可能造成操作系统的死亡
那此时数据库也有可能跟着一起玩完,那损失可就大咯
那如果此时有虚拟机,那么一旦被攻击,死的是虚拟机,操作系统与数据库不受任何影响
嗯,回顾完虚拟机,再来介绍中间件
在很早很早以前,任何一家企业,想要搭建一个局域网系统,他需要请许多个工程师
比如说我们想搭建一个网上银行,客户端用浏览器,后台数据库比如说用oracle 那么搭建这样一个网上银行,可能需要用到多少个工程师,我们来算一算
首先,由于客户端用的是浏览器,我们需要一些了解网络通讯协议以及一些浏览器标准的网络工程师
其次,由于后台数据库用的是oracle,那我们还需要请oracle的工程师,因为数据库这一层每个数据库公司的接口什么都不一样
然后,我们还需要一些操作系统的工程师,因为我们的系统需要跟操作系统直接交互
最后,我们需要一些设计网上银行系统及其相关业务的工程师
太多了太多了,这样一个中间件队伍实在太庞大了,制作维护成本实在太高了
不仅如此,这样一个中间件就算做出来,他们所写的代码也只能满足这一家公司使用
其它公司统统不能再用,代码重用率极低,近乎不可能重用
毕竟这个系统中改动任何一个部分都有可能涉及到整个系统的改动
那么如何降低成本?
我举出了四组的工程师:
网络工程师,数据库工程师,操作系统工程师以及设计网上银行系统的业务工程师
除了最后一组设计网上银行的业务工程师之外,前面三组工程师是不是每一个项目都需要的?
就算不是每一个项目都需要,至少也是绝大多数项目需要的吧?
哪个项目能够脱离网络,数据库和操作系统?不可能,在这个时代已经很少很少了
好,那既然每个项目都需要,我们是不是可以用一个产品来取代这三组的工程师呢?
我们的业务工程师只需要遵循这个产品所提供的接口,进行相应的开发就行了
人们提出了一种叫做appserver也就是应用服务器的东西
应用服务器是干什么的?按官方的说法,应用服务器是包括有多个容器的软件服务器
那容器是什么?容器(Container)到底是个什么东西我想多数人还是不清楚
在说这个之前,先介绍一下组件
什么是组件,组件是什么?组件其实就是一个应用程序块
但是它们不是完整的应用程序,不能单独运行
就有如一辆汽车,车门是一个组件,车灯也是一个组件
但是光有车灯车门没有用,它们不能跑上公路
在java中这些组件就叫做javabean,有点像微软以前的com组件
要特别说明的是,由于任何一个java文件编译以后都是以类的形式存在
所以javabean肯定也是一个类,这是毫无疑问的
好,那么容器里装载的是什么呢?就是这些组件
而容器之外的程序需要和这些组件交互必须通过容器
举个例子,IE发送了一个请求给容器,容器通过调用其中的一个组件进行相关处理之后
将结果反馈给IE,这种与客户端软件交互的组件就叫做servlet 但是组件有很多种,那么如何区分这些组件呢?
有多种管理办法,比如同是同样是servlet,有些是通过jsp生成的
而有些是开发人员自己写的,那么通过jsp生成的servlet集中放在一个地方
而开发人员自己写的则需要在xml里面配置一些基本的参数
同时,不同组件有可能还需要继承一些特定的父类或者接口,这也是容器管理的需要
还有其他的一些组件,这里就不一一说明举例了
那么容器有很多种,按照他们装载的组件类型划分
比如有装ejb的ejb容器,有装servlet与jsp还有静态页面的web容器等等//这种只含有web容器的应用服务器也被叫做web服务器
当表示层的应用软件通过网络向appserver发送一个请求的时候appserver自动找到相应容器中的组件,执行组件中的程序块,把得到结果返还给客户
而我们要做的事就是写组件也就是javabean,然后放到appserver里面去就可以了
至于怎样与IE通讯,怎样截获网络上的请求,怎样控制对象的数量等等
这些繁琐而无味的工作我们都不管,都由appserver去做吧,把注意力集中在业务逻辑上appserver与其他相关软件的关系如下图:
-------------------------------------------------------
| 表示层 | 业务逻辑层 | 数据持久层 |
-------------------------------------------------------
| | ----------------- | |
| IE | | javabean | | |
| -> ----------------- -> DB |
| client <- appserver <- |
| |-------------------------| |
| | 虚拟机 | |
|--------------|-------------------------|------------|
| Windows | Linux/Saloris |LinuxSaloris|
|--------------|-------------------------|------------|
图上可以看出:虚拟机负责处理中间件与操作系统之间的交互appserver则负责组件的管理以及与其他两层的业务交互1 附图: image002.gif (76463 字节)
要说明的是上图中还包含有应用程序客户端容器(Application client container) 管理应用程序客户端组件的运行,应用程序客户端和它的容器运行在客户机
这种情况比较复杂一般说的是两个server之间的通讯
比如jsp/servlet容器在一个服务器上,而ejb容器在另外一个服务器上等等
这是分布式操作系统大面积应用的基础,这个以后再说
嗯,那么话题再回到中间件上去,什么是中间件?appserver就是所谓的中间件,但是中间件不仅有appserver,还有其他的东西
换句话说,appserver只是中间件的一种
而关于中间件有诸多规范以及遵循这些规范的模型
最流行的规范无非两种,一个是j2ee还有一个是.net 但是.net几乎只有微软在用,所以很多人把.net这个规范就当成是微软的中间件产品
也不为过,毕竟没几个公司喜欢跟着微软屁股后面跑的
下面重点介绍一下中间件,也就是业务逻辑层的软件结构
从本系列第二篇我们知道,java程序是跑在虚拟机之上的
大致结构如下:
------------
| grogram |
------------
| 虚拟机 |
------------
| 操作系统|
------------
也就是说操作系统先运行一个java虚拟机,然后再在虚拟机之上运行java程序
这样做的好处前面也说过了,就是安全,一旦出现病毒或是其他什么东西
挂掉的是虚拟机,操作系统并不会受多大影响
这时候有人可能会问,为什么非要虚拟机?把操作系统当成虚拟机为什么不行?
可以,当然可以,但是这样做某一个应用软件的bug就可能造成整个操作系统的死亡
比如说我们在某个服务器上安装了一个收发电子邮件的软件和java虚拟机
那么一旦黑客通过收发电子邮件的软件入侵系统,那么操作系统就整个玩完
那么如果黑客通过java程序进行攻击的话,那么死的将会是虚拟机而不是操作系统
大不了虚拟机崩溃,而操作系统正常运行不受任何影响
举个简单例子,比如说最常见的是将数据库(DB)与中间件放在同一台服务器上
------------------------
| program | |
-----------| DB |
| 虚拟机 | |
------------------------
| 操作系统 |
------------------------
那么此时如果没有虚拟机,黑客病毒攻击中间件系统,就有可能造成操作系统的死亡
那此时数据库也有可能跟着一起玩完,那损失可就大咯
那如果此时有虚拟机,那么一旦被攻击,死的是虚拟机,操作系统与数据库不受任何影响
嗯,回顾完虚拟机,再来介绍中间件
在很早很早以前,任何一家企业,想要搭建一个局域网系统,他需要请许多个工程师
比如说我们想搭建一个网上银行,客户端用浏览器,后台数据库比如说用oracle 那么搭建这样一个网上银行,可能需要用到多少个工程师,我们来算一算
首先,由于客户端用的是浏览器,我们需要一些了解网络通讯协议以及一些浏览器标准的网络工程师
其次,由于后台数据库用的是oracle,那我们还需要请oracle的工程师,因为数据库这一层每个数据库公司的接口什么都不一样
然后,我们还需要一些操作系统的工程师,因为我们的系统需要跟操作系统直接交互
最后,我们需要一些设计网上银行系统及其相关业务的工程师
太多了太多了,这样一个中间件队伍实在太庞大了,制作维护成本实在太高了
不仅如此,这样一个中间件就算做出来,他们所写的代码也只能满足这一家公司使用
其它公司统统不能再用,代码重用率极低,近乎不可能重用
毕竟这个系统中改动任何一个部分都有可能涉及到整个系统的改动
那么如何降低成本?
我举出了四组的工程师:
网络工程师,数据库工程师,操作系统工程师以及设计网上银行系统的业务工程师
除了最后一组设计网上银行的业务工程师之外,前面三组工程师是不是每一个项目都需要的?
就算不是每一个项目都需要,至少也是绝大多数项目需要的吧?
哪个项目能够脱离网络,数据库和操作系统?不可能,在这个时代已经很少很少了
好,那既然每个项目都需要,我们是不是可以用一个产品来取代这三组的工程师呢?
我们的业务工程师只需要遵循这个产品所提供的接口,进行相应的开发就行了
人们提出了一种叫做appserver也就是应用服务器的东西
应用服务器是干什么的?按官方的说法,应用服务器是包括有多个容器的软件服务器
那容器是什么?容器(Container)到底是个什么东西我想多数人还是不清楚
在说这个之前,先介绍一下组件
什么是组件,组件是什么?组件其实就是一个应用程序块
但是它们不是完整的应用程序,不能单独运行
就有如一辆汽车,车门是一个组件,车灯也是一个组件
但是光有车灯车门没有用,它们不能跑上公路
在java中这些组件就叫做javabean,有点像微软以前的com组件
要特别说明的是,由于任何一个java文件编译以后都是以类的形式存在
所以javabean肯定也是一个类,这是毫无疑问的
好,那么容器里装载的是什么呢?就是这些组件
而容器之外的程序需要和这些组件交互必须通过容器
举个例子,IE发送了一个请求给容器,容器通过调用其中的一个组件进行相关处理之后
将结果反馈给IE,这种与客户端软件交互的组件就叫做servlet 但是组件有很多种,那么如何区分这些组件呢?
有多种管理办法,比如同是同样是servlet,有些是通过jsp生成的
而有些是开发人员自己写的,那么通过jsp生成的servlet集中放在一个地方
而开发人员自己写的则需要在xml里面配置一些基本的参数
同时,不同组件有可能还需要继承一些特定的父类或者接口,这也是容器管理的需要
还有其他的一些组件,这里就不一一说明举例了
那么容器有很多种,按照他们装载的组件类型划分
比如有装ejb的ejb容器,有装servlet与jsp还有静态页面的web容器等等//这种只含有web容器的应用服务器也被叫做web服务器
当表示层的应用软件通过网络向appserver发送一个请求的时候appserver自动找到相应容器中的组件,执行组件中的程序块,把得到结果返还给客户
而我们要做的事就是写组件也就是javabean,然后放到appserver里面去就可以了
至于怎样与IE通讯,怎样截获网络上的请求,怎样控制对象的数量等等
这些繁琐而无味的工作我们都不管,都由appserver去做吧,把注意力集中在业务逻辑上appserver与其他相关软件的关系如下图:
-------------------------------------------------------
| 表示层 | 业务逻辑层 | 数据持久层 |
-------------------------------------------------------
| | ----------------- | |
| IE | | javabean | | |
| -> ----------------- -> DB |
| client <- appserver <- |
| |-------------------------| |
| | 虚拟机 | |
|--------------|-------------------------|------------|
| Windows | Linux/Saloris |LinuxSaloris|
|--------------|-------------------------|------------|
图上可以看出:虚拟机负责处理中间件与操作系统之间的交互appserver则负责组件的管理以及与其他两层的业务交互1 附图: image002.gif (76463 字节)
要说明的是上图中还包含有应用程序客户端容器(Application client container) 管理应用程序客户端组件的运行,应用程序客户端和它的容器运行在客户机
这种情况比较复杂一般说的是两个server之间的通讯
比如jsp/servlet容器在一个服务器上,而ejb容器在另外一个服务器上等等
这是分布式操作系统大面积应用的基础,这个以后再说
嗯,那么话题再回到中间件上去,什么是中间件?appserver就是所谓的中间件,但是中间件不仅有appserver,还有其他的东西
换句话说,appserver只是中间件的一种
而关于中间件有诸多规范以及遵循这些规范的模型
最流行的规范无非两种,一个是j2ee还有一个是.net 但是.net几乎只有微软在用,所以很多人把.net这个规范就当成是微软的中间件产品
也不为过,毕竟没几个公司喜欢跟着微软屁股后面跑的
发表评论
-
(转载)给初学者之九:收尾
2011-07-03 08:40 560最后一篇介绍几个常见 ... -
(转载)给初学者之八:java高级应用之框架篇
2011-07-03 08:16 704没错,我没敲错 之所 ... -
(转载)给初学者之七:java企业级应用之术语篇
2011-07-03 08:16 677在了解完J2ee的相关周边 ... -
(转载)给初学者之六:java企业级应用之综合篇
2011-07-03 08:14 594给初学者之六:java企业级应用之综合篇 我们知道中间件有很 ... -
(转载)给初学者之四:java企业级应用之软件篇
2011-07-03 08:11 578给初学者之四:java企业级应用之软件篇 嗯,说过了硬件就该 ... -
(转载)给初学者之三:java企业级应用之硬件篇
2011-07-03 08:10 533总算讲到企业级应用了 ... -
(转载)给初学者之二:从JDK说起
2011-07-03 08:07 686在知道了java有什么优点,能做什么之后 就该说一下java该 ... -
(转载)给初学者之一:浅谈java及应用
2011-07-03 08:00 635不厚道的前言: 呵呵, ...
相关推荐
WebSphere Application Server(WAS)是IBM提供的一款企业级的中间件产品,它主要用于构建、部署和管理基于Java EE(Java Platform, Enterprise Edition)的应用程序。这款强大的服务器平台提供了全面的集成解决方案...
中间件技术原理与应用是计算机科学领域中一个重要的主题,特别是在分布式系统、企业级软件开发以及云计算中扮演着核心角色。清华大学出版的这本教材详细地介绍了中间件的基本概念、核心技术及其实际应用,旨在帮助...
6. 应用服务器中间件:提供运行和管理企业级应用的环境,如Java EE应用服务器。 四、中间件在分布式计算环境中的角色 在分布式计算环境中,中间件扮演着至关重要的角色。它能够解决分布式系统的互操作性问题,使...
《Java中间件技术及其应用...总之,《Java中间件技术及其应用开发》的源代码涵盖了企业级Java开发的核心技术,从Web服务到分布式系统的每一个环节,无论是初学者还是资深开发者,都能从中获益,提升自己的专业技能。
Java教程中的J2EE是Java 2 Platform, Enterprise Edition的简称,主要针对企业级应用的开发,为初学者提供了丰富的工具和框架。以下是对J2EE初学者需要理解的五个关键问题的详细解释: 1. **J2EE提出的背景**: 在...
《Java中间件技术及其应用开发》是一本深入探讨Java企业级应用开发的著作,由李华飚编著。这本书的源代码包含了丰富的实例和练习,旨在帮助读者理解和掌握Java中间件的核心技术和实际运用。在4914页的源代码中,我们...
通过学习这套PPT,你可以全面理解中间件技术在实际开发中的应用,掌握JSP、Servlet和JDBC的基本操作,并了解EJB在企业级应用中的角色。这不仅对初学者来说是一份宝贵的资源,对于有经验的开发者来说,也是回顾和巩固...
3. **企业级应用**:Java在企业级应用中扮演重要角色,可以深入学习Servlet、JSP、Spring框架、Hibernate等技术,了解如何构建Web应用程序。 4. **中间件**:学习如Tomcat、Jetty等应用服务器,以及消息队列(MQ)、...
通过学习这个中间件课件,初学者将对中间件有更深入的理解,掌握如何选择和使用适合的中间件来构建高效、稳定的企业级应用。同时,对于已经在IT行业工作的人来说,进一步提升中间件知识也能增强自己在项目设计和实施...
### Java中间件之Tomcat详解 #### 一、Tomcat简介与重要性 **Tomcat** 是一个基于 **Java EE** 标准的轻量级Web服务器,它由 **Apache软件基金会** 的 **Jakarta项目** 发起并维护。由于其开放源代码的特性以及...
- **企业级应用框架的需求**:在企业级应用中,诸如数据库连接、邮件服务、事务处理等功能是常见的需求。为避免每次开发时都需要重新编写这些功能,很多公司开发了通用的服务模块,这些模块被称为中间件。 - **提出...
J2EE(Java 2 Platform, Enterprise Edition)是Sun Microsystems(后来被Oracle收购)推出的企业级应用平台,基于Java技术,旨在提供一套规范和标准,以便开发、部署和管理分布式多层企业应用程序。J2EE的主要目标...
消息中间件是分布式系统中不可或缺的组件,它在软件架构中扮演着数据传输和解耦的重要角色。...通过深入学习和实践,你可以提升自己的分布式系统设计能力,为构建高效、稳定的企业级应用打下坚实的基础。
Oracle中间件产品是企业级应用的关键组成部分,它们提供了一整套解决方案,用于构建、部署和管理复杂的分布式应用程序。Oracle的中间件产品线涵盖了多种技术领域,包括应用服务器、数据库连接池、Web服务、身份验证...
【软件平台与中间件(JavaEE)课件】是一份专为初学者设计的教育资源,旨在深入讲解JavaEE技术栈的各个方面。JavaEE,全称为Java Platform, Enterprise Edition,是Oracle公司提供的一个用于构建企业级分布式应用的...
- **Tomcat**:适合初学者和小型项目,因其轻量级、资源消耗低,广泛应用于开发和调试JSP程序,特别在并发访问用户不多的场景下。 - **WebLogic**:在需要复杂功能、高扩展性和高可用性的大型企业环境中,WebLogic...
【Tuxedo中间件培训教程】是一份专为初学者设计的编程教程,旨在帮助编程人员理解和掌握Tuxedo中间件的使用。Tuxedo中间件是由BEA Systems(现已被Oracle公司收购)开发的一种分布式计算环境的关键工具,主要用于...
J2EE(Java 2 Platform, Enterprise Edition)是一个由SUN公司推出的用于构建企业级应用的Java...理解这些核心概念是J2EE初学者的基础,随着学习的深入,还需要掌握如何使用这些工具和技术来构建实际的企业级应用程序。
分布式数据库架构在现代企业级应用中扮演着至关重要的角色,特别是在大数据、高并发场景下,传统的单体数据库已经无法满足需求。Mycat作为一个开源的分布式数据库中间件,为企业提供了有效的解决方案。本篇将深入...