一个牛人给JAVA初学者的建议(上篇)
给初学者之一:浅谈java及应用
学java不知不觉也已经三年了,从不知java为何物到现在一个小小的j2ee项目经理。虽说不上此道高手,大概也算有点斤两了吧,每次上网,泡bbs逛论坛,没少去java相关的版面,总体感觉初学者多,高手少,精通的更少。由于我国高等教育制度教材陈旧,加上java自身发展不过十年左右的时间,还有一个很重要的原因就是java这门语言更适合商业应用,所以高校里大部分博士老师们对此语言的了解甚至不比本科生多。在这种环境下,很多人对java感到茫然,不知所措,不懂java能做什么,即便知道了java很有用,也不清楚该从哪里入手,所以就有了 java入门难这一说法。ok,那我们就从java到底能做什么聊起。
先说什么是java,java是一种面向对象语言,真正的面向对象,任何函数和变量都以类(class)封装起来。
至于什么是对象什么是类,我就不废话了。关于这两个概念的解释任何一本面向对象语言的教材里面都有。
知道了什么是java,那自然就会对java能干什么感兴趣。在说java能做什么之前,先说java作为一个真正面向对象语言的优点。首先第一个,既然是真正的面向对象,那就要做到彻底的封装。这是java和c++最大的不同,java所有的源码以及编译后的文件都以类的形式存在。java没有所谓的类外部定义,所有的函数(方法)以及变量(属性)都必须在类内部定义。这样就不会出现一个类被切割成这里一块那里一块的情况,c++就可以,不是么?这样做使得整个程序的结构异常清晰,明了。其次第二个,最让人欢呼雀跃的是完全屏蔽了指针,同时引入了垃圾回收机制(GC),任何一个写过c/c++代码的人,都会对内存管理深恶痛绝。因为这使得我们不能把主要精力放在我们关心的事情上,而需要考虑计算机内部的一些事情,作为一个软件工程师,我想没有一个人愿意把大量的时间花在内存管理上,毕竟我们不是电子工程师,此时java的优势体现出来了,它完全屏蔽了内存管理。也就是说,如果你用java写程序,写出来的任何一个程序内存上的开销,都不受你控制。乍一看,似乎你受到了束缚,但实际上不是这样,因为虽然你的程序无法对内存进行管理,降低了一定的速度,但你的程序会非常非常的安全,因为你无法调用一个空指针
而不像以前写c的时候那样,成天因为空指针而担惊受怕。当然,如果你深入了解这一行,就会发现java其实也无法保证程序不去调用空的指针,但是它会在最大程度上避免空指针的调用。这已经很好了,安全,这是java的最突出的优点。第三个,虚拟机跨平台,这是java最大的特点,跨平台,可能所有人都知道windows,但是不是所有人都知道unix和java一样,很多人都不知道unix这种操作系统干什么用,我不想多说unix的应用,这不是主要,但是我要说,大部分小型机,工作站,都跑在unix一族的操作系统上,比如linux/solaris,unix比起windows有一个最显著的特点,稳定,这就好比思科和华为,思科的机器慢但稳定,华为的机器快但不稳定,作为服务器这一端来说,unix在服务器端还是非常有市场的,而且很重要的windows不安全,在ms的宣传中我想所有人都很少看到安全二字,因为windows操作系统针对的是pc用户,pc死机就死机咯,大不了重启,瘟95最经常冒出来的就是蓝屏,在服务器这一端上因为ms没有自己的芯片,所以要做系统有些力不从心啊。扯远了,那么java可以做到在windows上编译
然后在unix上运行,这是c/c++做不到的。那么说到这里,java能做什么逐渐清晰起来。刚才说到了,java程序有一个的特点是安全。这个安全是针对你的系统来说得,系统在跑了java程序之后会特别地稳定,而且还能跨平台,那么很明显,java主要应用于除了windows操作系统以外所有的平台,比如手机,服务器。想想看,如果你写的程序要跑在手机上,而手机有多少款用的是windows?就算有,那如果你用c/c++,是不是要针对每一款手机写一套程序呢?累死,那跨平台的java就不用,做到编译一次,随时运行。同样,在服务器这一端,如果我想给一个网络门户站点,比如sina写一个应用程序,pc的性能肯定无法满足sina这样大站点并发数量的要求,那么它就需要买服务器,那么服务器ms没有市场,而且windows很不安全
那么十之八九会买一个sun/ibm的机器,或者hp,但不管是谁的机器,它装的操作系统也不会是windows,因为windows太不安全了,而且多核的支持太差了。这个有空再说,那么如果你要写一个程序在这样的机器上跑,难道我们就在这个机器上做开发么?当然不可能,一般程序员开发用的都是pc,windows那么该怎么办?写一个程序,然后再拿到服务器上去编译,去调试?肯定不可能,所以我们就希望找到一个语言,编译完生成程序之后,在pc上调试,然后直接移植到服务器上去,那么此时,我们就会毫不犹豫地选择java,因为在跨平台以及安全性来说,java永远是第一选择。ok,
下面说java的缺点
一慢,这其实是一种误区,这就好比goto语句一样,java也抛弃了指针,虽然看上去似乎变慢了,但是在这个两三年硬件性能就能翻番的年代,速度已经不是我们关心的问题了,而且对于企业级的应用来说,没有什么比安全稳定更重要的,换句话说,我们可以忍受慢,但是不能忍受死机和蓝屏。而且越大型的应用,这种慢的劣势体现得越模糊。因为当系统项目越做越大,任何一个环节做不好都可能影响全局的情况下,安全尤其重要,而且就像goto语句一样。这种过分追求速度的主张会给系统开发和纠错以及维护带来无可挽回甚至不可避免的损失,把内存交给计算机去管理吧,这种代价值得。我们做的不是pc游戏,没必要把内存的那一点点消耗当亲爹。
二难看,又是一个误区,很多人甚至拿出java swing控件画出的界面来说,呵呵,其实java不是不能画得好看,IDEA就是java写的IDE,挺漂亮的。但为什么难看呢,是因为swing控件它本身就是unix时代的产物,swing控件贴近unix界面,老外看unix界面其实挺顺眼的,他们就是吃unix饭长大的,而unix又是吃百家饭的,不像ms那么唯利是图,所以不怎么对中国人友好,加上我国又没有公司在做操作系统,所以看上去是不怎么顺眼,其实玩过unix的人都知道,unix对中文的支持一直不怎么好。
给初学者之二:从JDK说起
在知道了java有什么优点,能做什么之后,就该说一下java该如何去学了。在说java如何去学之前,有必要把java的几个大方向做一个简单说明,早在五年前,嗯,应该说是六年前,也就是99年的时候,sun公司做出了一个决定,将java应用平台做一个划分,毕竟在不同领域,语言应用特性是有区别的。针对不同领域内的应用,sun公司可以发布相关高端标准来统一规范代码,这三大块就是J2SE,J2EE以及J2M。这个举措今天看来无疑是非常了不起的,正是由于这次革命性的发展,使java从一种小打小闹游戏性的语言,发展成为今天企业级应用的基础。这里要特别说明一下J2SE J2EE J2ME中2的意思,其实2就是英文单词to的谐音,就是to的意思,而不是second edition,当然java 2本身版本号就是1.2,也有点2nd edition的味道。说点题外的,sun公司发布的java版本很有意思,虽然总是写是1.X但其实外界对这种版的说法也就是X.0,比如java 2,其实就是java 1.2,1.3其实就是3.0,1.4就是4.0,现在所说的5.0其实就是1.5,只是以前我们更习惯叫1.X而已。可能到了5.0以后,就全改叫X.0而不是1.X了,所以以后听到别人说java 5.0,千万别惊讶,其实就是1.5。在这三个J2*E中J2SE是基础,就是java 2的标准版(java 2 standard edition),也就是最基础的java语言部分,无论学什么java技术,J2SE都是必须掌握的,要使用J2SE就必须安装JDK(java development kit)。JDK在sun公司的主页上可以免费下载,下载后需要安装,具体安装流程看教材。JDK包含有五个部分:核心API,集成API,用户界面API,发布技术还有java虚拟机(JVM)。先说运行环境,运行环境最主要要说的就是java虚拟机(JVM)
前面我们说过java是跨平台的语言,那么如何做到跨平台呢?毕竟每种操作系统都是不同的,java的设计者们提出了一个虚拟机的概念,在操作系统之上建立一个统一的平台,这个平台必须实现某些功能以支持程序的运行。如下图:
----------------------------------------------------------------------------------------------------------
| program |
---------------------------------------------------------------------------------------------------------
| JVM |
---------------------------------------------------------------------------------------------------------
| UNIX | Windows | Linux | Solaris |..
----------------------------------------------------------------------------------------------------------
程序员所写的每一个程序都先运行在虚拟机上,所有操作都必须经过虚拟机才能和操作系统交互,这样做不仅统一了所有操作系统,同时也保证了操作系统的安全。要死机的话,死的是虚拟机(JVM)而操作系统并不会受此影响,而我们所说的java运行环境指的主要是JVM,其他的不说了,省略。下面说说JDK(java development kit)的API,其实用JDK来包括运行环境以及开发工具,个人感觉是不恰当的,因为这三个单词仅能说明开发工具,也就是几个标准的API,而没有让人感觉到有运行环境的意思在里面,这是题外。那么什么是API?简单地说就是Application Programming Interface,应用程序编程接口。在java里面,就是一些已经写好了的类打成的包,这又要解释什么是类什么是包了,简单说一下,包就是类的集合,一个包包含零个或多个类,嗯,具体的可以去看书,这些类是java的基础类,常用的类,可以简单理解成java的工具集。最后说一下JDK的发布技术,其实按我的理解,讲白了就是编译器,将.java文件转换成.class文件的一种技术。这三部分组成了JDK,有了JDK,就可以开发出J2SE应用软件了,最原始的只要用一个记事本写几行代码就可以了,但一般来说我们会使用效果比较好的开发工具,也就是IDE。在J2SE这一块,特别推荐JCreator这款IDE sun公司的产品,与JDK结合得几乎是天衣无缝,非常适合初学者使用。
教材方面中文的推荐电子工业出版社出版的《java教程》初级与高级篇各一本;还有就是《21天学通java》虽然有人说21天系列是烂书,但个人感觉对于j2se,这本书翻译得已经很不错了,基本没有什么语法错误,语句也很通顺;最后要说的就是《thinking in java》,这本书自然很经典,说得比较细,只是我觉得不太适合初学者,其实也不难,初学者直接看也不成问题,但个人感觉还是找本教材也就是前面推荐的两款来看比较好。基本概念的理解还是用教材的,毕竟thinking in java有的版本翻译得很烂,而且个人建议还是看原版比较好。当然这几本都看最好了,但如果没时间,至少精读其中一本,然后再看其他两本就可以,其实三本书内容也差不多,但看问题的角度方式以及面向的读者也都不同,嗯,怎么说呢,找适合自己的吧。最后要说的是,由于虚拟机的存在,J2SE的大多数软件的使用会比一般桌面软件慢一些,效果不尽如人意,现在大概只有swing控件还在使用吧,其它没怎么听说。J2EE&J2ME,这是java应用的重中之重,如果想拿高薪,最好把J2EE学好,记得以前在csdn上看过一个调查,月薪上万的程序员主要从事哪方面的工作,十个中有八个是做J2EE的,其他两个一个做J2ME,还有一个做嵌入式,也许有些夸张,但也从某一方面说明J2EE人才的稀缺以及应用的广泛。所以如果想学java,只精通j2se是永远不够的,至少还需要时间去了解其它两个J2*E。
给初学者之三:java企业级应用之硬件篇
总算讲到企业级应用了,内容开始逐渐有趣起来。java企业级应用分为硬件篇和软件篇,重点在软件,硬件是外延,严格地说与java没有必然联系。但是,由于java是网络语言,不了解硬件的一些基础知识,软件知道再多也没什么用,不要上了战场还不知道为什么而打仗。硬件是软件的基础,在这个前提下,有必要专门花一点点篇幅来聊一下硬件。硬件,简单地说就是我们实际生活中看得见摸得着的东西,也就是那些冰冷的机器,比如服务器,个人电脑还有网络交换机,路由器等等。那么先抛开网络设备不谈,先来说说计算机电脑的历史。在很早很早以前,人类创造了第一台电脑,那时候的电脑只是一台用来计算的机器,无比大,无比重,无比傻,除了算其它屁事不会做,没有所谓的人工智能与计算机网络。但是总算是诞生了,虽然以今天的眼光去看那时候的机器巨傻无比,只配叫做计算器而不是电脑,没有逻辑思维能力,只会死算,但千里之行,始于足下,反正是造出来了 。然后随着时间的推移,制造业发展发展发展,电脑性能逐渐得到提升,速度快了起来,成本也逐渐低了下来。于是人们造出了第二台,第三台,第四台,第五台……第n台计算机,人们就造出了无数台计算机并使其成为一种产品,逐渐应用于许多复杂计算领域,不仅仅是科研,许多生产领域也开始出现计算机的影子。然后又随着时间的推移,人们发现不可能把所有的计算机都做成一个样子,因为各行各业对计算机性能的要求各不相同,于是开始把计算机划分档次,最简单地是按照计算机的大小划分就是教科书上写的大型机,中型机,小型机//个人感觉这样分纯粹扯淡,还以为是小孩子玩球,分为大球,中球和小球。但是不管怎样,计算机不再是千篇一律一个样子了。按照性能的不同,在不同领域,出现了满足符合不同要求的计算机。几乎在同时,人们也开始考虑计算机之间通讯问题。人们开始考虑将不同的计算机连接起来,于是网线出现了,网络出现了。又随着网络的发展,出现了一下专门为了寻址而存在的机器,这就是路由器和交换机。然后又出现了一些公益性的组织或团体
他们制定了一系列的标准来规范以及管理我们的网络于是3w出现了,计算机的网络时代来临了。嗯,说到这里,计算机发展到今天的历史大概说完了。我们来详细说说网络时代的计算机以及各个硬件供应商之间的关系。前面说到了,计算机分为大型机,中型机和小型机……但是现在市场上没有人这样分,要是出去买机器,对硬件供应商说,我要买一款中型机,或者说,我要买一款小型机,硬件供应商肯定会问问题
他们会问你买机器干什么用的?科学计算啊还是居家用,是作服务器啊还是图形设计,但不管怎样,简单地说大中小型机已经没有什么意义了,我们按照使用范畴来划分。简单划分为服务器,工作站还有微机,服务器(server)。服务器涵盖了几乎所有的大型机以及大部分中型机甚至一些小型机,用通俗点话说24小时不间断运行提供服务的机器。比如卖飞机票(中航信),比如酒店预定(携程),比如提供门户站点相关服务(sina),比如电子商务(ebay,amazon,阿里巴巴),这些服务对机器都有一些特定的要求,尤其强调安全和稳定。工作站(workstation),工作站其实是图形工作站的简称,说白了,就是某种功能极其强大的计算机,用于特定领域,比如工程设计,动画制作,科学研究等。个人电脑/微机(pc)
计算机网络的最末端,这个应该不用我说太多了,网络时代的pc已经普及到千家万户。说完了分类,我们就来说说各个硬件供应商,首先是服务器还有工作站,这两类硬件供应商主要是以下三家Sun,IBM还有HP(惠普)。然后是PC,以前IBM还有PC事业部,现在被联想吞并了(蛇吞象),现在国际市场上有联想和DELL(戴尔),目前戴尔还是国际老大,还有HP康柏。然后是网络,也就是路由器和交换机,这块市场嘛,Cisco(思科)Brocade(博科)还有McDATA三足鼎立。内核(CPU),PC内核主要是AMD和Intel,前者最近与Sun公司合作,Sun也有一部分单双核服务器用的是AMD的。服务器与工作站内核,这一块与硬件厂商绑定,还是Sun,IBM,HP三家自己生产。题外,在一些大型主机应用市场,比如卖飞机票,德国的汉莎,中国的中航信,香港的国泰用的都是尤利(美国的公司,英文名我忘了),其它用的是IBM的机器,现在能做大型机的感觉似乎只有IBM可以,尤利已经快倒了,技术太落后了,现在他们的系统还是fortran写的,连c都不支持。要特别说明的是,一个超大型主机然后多个小终端/pc的结构现在越来越没市场了。将来的趋势是用一整个包含多个服务器的分布式操作系统来取代这些大型主机。因为大型主机更新换代极其困难,一旦数据量超过了主机的处理能力,那么就要换主机,这个成本是极大的,但是如果用分布式操作系统,那就只需要增加小服务器就行了。硬件就大概说到这里,与大多数人没什么关系,因为大多数人压根不可能进入这些硬件领域,除非做销售。说了这么多,只是为了给软件部分打基础而已。//做嵌入式的除外。
给初学者之四:java企业级应用之软件篇
嗯,说过了硬件就该是软件了,这篇是这个系列的重中之重。首先我们来说说什么是软件,统一一下概念。
所谓软件通俗地说就是一套计算机程序,实现了某些功能的计算机程序。
在很早很早以前,一台计算机的软件是不分层次结构的。一台计算机只有一个系统,这个系统既是操作系统又是应用软件,与硬件紧密绑定。后来经过许多年的发展发展发展,人们把一些与硬件紧密相连的又经常用到必不可少的功能做到一套程序中去,这一套程序就被人们称做操作系统。另外一些可有可无的,不同工作适应不同环境的功能封装到另外一套程序中去,而这一系列程序被人们称作应用软件。如下图:
-------------------------------------------
|应用软件:falshgat/IE/realplayer/winamp..|
-------------------------------------------
|操作系统:UNIX/Windows/Linux/Solaris... |
-------------------------------------------
前一篇我们知道,硬件分为服务器工作站与pc,其实无论哪种硬件的软件,都有操作系统与应用软件。 ok,那下面我们来谈应用软件。在现在企业级应用中,我们的应用软件一般分为三层,三层分别是表示层,业务逻辑层,数据持久层。
------------------------------
|表示层|业务逻辑层|数据持久层|
------------------------------
1.表示层
这一层一般在客户端pc机上,最常见的是IE浏览器,这就是表示层的软件。表示层是直接与使用者交互的软件。
2.业务逻辑层
这一层一般在服务器端,顾名思义,所有业务逻辑处理都在这一层完成。最典型的是App Server,比如IBM的websphere,BEA的weblogic还有tomcat/jboss等。这一层也是三层中的重点,我们要说的大部分内容都是关于这一层的,这个等会再说,这一层就叫做中间层。
3.数据持久层
这一层典型的就是数据库,一般也在服务器端。但该服务器一般与装业务逻辑层软件的服务器分开,当然你也可以用IO输入输出流往硬盘上写东西,但没人会建议你这么做,因为这样做你的数据缺乏管理,不管怎样,这一层要做的就是保存数据,业务逻辑层软件一般不负责保留数据,或者说业务逻辑层只负责暂时储存数据,一关机,业务逻辑层数据全部over了,那么数据的持久化(也就是储存数据)就必须要在这一层完成。下面放着这些概念不谈,我们来说说将来的趋势。趋势一:
瘦客户端,很早很早以前,当时C/S模式也就是client/server。客户端软件大行其道的年代,一个pc用户,是采用一个傻终端连接到服务器上。然后进行相应的操作,最典型的就是我们上bbs经常用的c-term。这就是那个时代的产物,同样还有我国现行的机票定座用的e-term。后来呢,浏览器变得非常流行,人们发现,浏览器也能传递一些数据,虽然这些数据并不像那些终端那样准确,但应付大多数日常需求足够了。于是人们就提出一个瘦客户端概念,也就是说,将来表示层所有的其他软件疾挥?我们唯一需要的就是一个网页浏览器,然后通过浏览器输入ip地址连接到服务器,然后进行相关的操作。由于网页浏览器一般每个操作系统都有自带一个。这样做就达到了给我们客户端瘦身的目的(不需要安装额外软件)。这样模式被称作B/S模式,也就是browser/server模式。但需要指出的是,虽然瘦客户端是趋势,但并不代表胖客户端没有市场。尤其是一些复杂的业务操作,还是浏览器这种简单软件无法胜任的。趋势二:
傻数据库,ok,首先,我承认,这个名词是我发明的,但我实在无法找到一个更好的表达什么是傻数据库,如果谁对数据库有所了解的话,就知道,以前的数据库,有自己的一套管理体系,甚至有自己的客户端,比如oracle,mysql,Sqlserver都有。在某个管理工具上写什么sql语句查询数据库是我们以前常做的事。那么将来我们提倡的是:将所有的业务逻辑封装到业务逻辑层去,管理的事情由软件来做,由业务逻辑层的软件来做,所谓傻数据库就是说,将来的数据库什么事都不用做,只用把数据给我保存好就行了,那些复杂的业务逻辑什么外键什么关联,都没数据库什么事了,都交给业务逻辑层软件来做,这样做的好处就是:我们就不需要这些该死难懂又复杂的数据库系列管理工具了,而且这些工具每个数据库都有自己的工具,完全不一样,乱七八糟,没有人喜欢面对他们。除了数据库维护人员,也就是DBA,我们是软件工程师,维护的事让他们去做,而且严禁数据库维护人员改动数据库的数据,他们只做备份,必要时候恢复一下就是了。了解了这两个趋势之后,是不是有种砍头去尾保中间的感觉?没错,未来的趋势就是中间件时代,中间件工程师将是未来计算机应用的主流。那再次统一一下概念,什么是中间件?记得我上学的时候,看IBM的教材,看了半天中间件定义,就看懂记住一句话,中间件是做别人不愿意去做的事情,现在想想,狗屁定义,呵呵。什么是中间件,中间件是业务逻辑层的应用软件,是处理业务数据与客户端之间业务逻辑的一种应用软件,一种提供网络服务的服务器端应用软件。举个非常简单的例子,网上银行,某个人想用IE进入工行的账户,然后转帐。在这个例子中,客户端表示层显然是IE,数据持久层显然是银行的核心数据库。那么中间件是什么?中间件就是提供这种服务的系统。这三层的划分如下
------------------------------
|表示层 |业务逻辑层 | 数据持久层 |
------------------------------
| IE | 网上银行 | 数据库 |
------------------------------
给初学者之五:企业级应用之中间件
前面一篇简单介绍了一下应用软件的分层,下面重点介绍一下中间件,也就是业务逻辑层的软件结构 。从本系列第二篇我们知道,java程序是跑在虚拟机之上的,大致结构如下:
----------------------
| grogram |
-----------------------
| 虚拟机 |
----------------------
| 操作系统 |
-----------------------
也就是说操作系统先运行一个java虚拟机,然后再在虚拟机之上运行java程序,这样做的好处前面也说过了,就是安全,一旦出现病毒或是其他什么东西,挂掉的是虚拟机,操作系统并不会受多大影响 。这时候有人可能会问,为什么非要虚拟机?把操作系统当成虚拟机为什么不行?可以,当然可以,但是这样做某一个应用软件的bug就可能造成整个操作系统的死亡。比如说我们在某个服务器上安装了一个收发电子邮件的软件和java虚拟机,那么一旦黑客通过收发电子邮件的软件入侵系统,那么操作系统就整个玩完。那么如果黑客通过java程序进行攻击的话,那么死的将会是虚拟机而不是操作系统,大不了虚拟机崩溃,而操作系统正常运行不受任何影响。 举个简单例子,比如说最常见的是将数据库(DB)与中间件放在同一台服务器上
----------------------------------------------------------------------------------------------------
| program | |
----------------------------------------------------------| DB |
| 虚拟机 | |
------------------------------------------------------------------------------------------------------
| 操作系统 |
------------------------------------------------------------------------------------------------------
那么此时如果没有虚拟机,黑客病毒攻击中间件系统,就有可能造成操作系统的死亡,那此时数据库也有可能跟着一起玩完,那损失可就大咯 。那如果此时有虚拟机,那么一旦被攻击,死的是虚拟机,操作系统与数据库不受任何影响。嗯,回顾完虚拟机,再来介绍中间件 。在很早很早以前,任何一家企业,想要搭建一个局域网系统,他需要请许多个工程师。比如说我们想搭建一个网上银行,客户端用浏览器,后台数据库比如说用oracle。那么搭建这样一个网上银行,可能需要用到多少个工程师,我们来算一算。首先,由于客户端用的是浏览器,我们需要一些了解网络通讯协议以及一些浏览器标准的网络工程师。其次,由于后台数据库用的是oracle,那我们还需要请oracle的工程师,因为数据库这一层每个数据库公司的接口什么都不一样。然后,我们还需要一些操作系统的工程师,因为我们的系统需要跟操作系统直接交互。最后,我们需要一些设计网上银行系统及其相关业务的工程师 。太多了太多了,这样一个中间件队伍实在太庞大了,制作维护成本实在太高了。不仅如此,这样一个中间件就算做出来,他们所写的代码也只能满足这一家公司使用。其它公司统统不能再用,代码重用率极低,近乎不可能重用 。毕竟这个系统中改动任何一个部分都有可能涉及到整个系统的改动 。那么如何降低成本?
我举出了四组的工程师:
网络工程师,数据库工程师,操作系统工程师以及设计网上银行系统的业务工程师
除了最后一组设计网上银行的业务工程师之外,前面三组工程师是不是每一个项目都需要的?就算不是每一个项目都需要,至少也是绝大多数项目需要的吧? 哪个项目能够脱离网络,数据库和操作系统?不可能,在这个时代已经很少很少了。好,那既然每个项目都需要,我们是不是可以用一个产品来取代这三组的工程师呢?我们的业务工程师只需要遵循这个产品所提供的接口,进行相应的开发就行了。人们提出了一种叫做App Server也就是应用服务器的东西,应用服务器是干什么的?按官方的说法,应用服务器是包括有多个容器的软件服务器。那容器是什么?容器(Container)到底是个什么东西我想多数人还是不清楚。在说这个之前,先介绍一下组件 。什么是组件,组件是什么?组件其实就是一个应用程序块 ,但是它们不是完整的应用程序,不能单独运行。 就有如一辆汽车,车门是一个组件,车灯也是一个组件 。但是光有车灯,车门没有用,它们不能跑上公路 ,在java中这些组件就叫做javabean,有点像微软以前的com组件。要特别说明的是,由于任何一个java文件编译以后都是以类的形式存在
所以javabean肯定也是一个类,这是毫无疑问的。好,那么容器里装载的是什么呢?就是这些组件。而容器之外的程序需要和这些组件交互必须通过容器 。举个例子,IE发送了一个请求给容器,容器通过调用其中的一个组件进行相关处理之后。将结果反馈给IE,这种与客户端软件交互的组件就叫做Servlet。但是组件有很多种,那么如何区分这些组件呢? 有多种管理办法,比如同是同样是SERVLET,有些是通过JSP生成的,而有些是开发人员自己写的,那么通过JSP生成的SERVLET集中放在一个地方,而开发人员自己写的则需要在XML里面配置一些基本的参数。同时,不同组件有可能还需要继承一些特定的父类或者接口,这也是容器管理的需要.还有其他的一些组件,这里就不一一说明举例了 .那么容器有很多种,按照他们装载的组件类型划分 ,比如有装ejb的ejb容器,有装Servlet与jsp还有静态页面的web容器等.//这种只含有web容器的应用服务器也被叫做web服务器.当表示层的应用软件通过网络向App Server发送一个请求的时候,App Server自动找到相应容器中的组件,执行组件中的程序块,把得到结果返还给客户.而我们要做的事就是写组件也就是javabean,然后放到App Server里面去就可以了.至于怎样与IE通讯.怎样截获网络上的请求,怎样控制对象的数量等等.这些繁琐而无味的工作我们都不管,都由App Server去做吧,把注意力集中在业务逻辑上.App Server与其他相关软件的关系如下图:
-------------------------------------------------------
| 表示层 | 业务逻辑层 |数据持久层 |
-------------------------------------------------------
| | ----------------- | |
| IE | | javabean | | |
| -> ----------------- -> DB |
| client <- App Server <- |
| |-------------------------| |
| | 虚拟机 | |
|--------------|-------------------------|------------|
| Windows | Linux/Saloris |LinuxSaloris|
|--------------|-------------------------|------------|
图上可以看出:虚拟机负责处理中间件与操作系统之间的交互 ,App Server则负责组件的管理以及与其他两层的业务交互. 要说明的是上图中还包含有应用程序客户端容器(Application client container),管理应用程序客户端组件的运行,应用程序客户端和它的容器运行在客户机.这种情况比较复杂,一般说的是两个 server之间的通讯,比如jsp/Servlet容器在一个服务器上,而ejb容器在另外一个服务器上等等。这是分布式操作系统大面积应用的基础。嗯,那么话题再回到中间件上去,什么是中间件? App Server就是所谓的中间件,但是中间件不仅有App Server,还有其他的东西,换句话说,App Server只是中间件的一种。而关于中间件有诸多规范以及遵循这些规范的模型最流行的规范无非两种,一个是j2ee还有一个是.net。但是.net几乎只有微软在用,所以很多人把.net这个规范就当成是微软的中间件产品。也不为过,毕竟没几个公司喜欢跟着微软屁股后面跑的。
- 点赞
- 收藏
- 关注作者
评论(0)