Category Archives: Java Pro
给JAVA初学者的建议(5)java企业级应用之中间件
前面一篇简单介绍了一下应用软件的分层
下面重点介绍一下中间件,也就是业务逻辑层的软件结构
从本系列第二篇我们知道,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初学者的建议(4)java企业级应用之软件篇
嗯,说过了硬件就该是软件了
这篇是这个系列的重中之重
首先我们来说说什么是软件,统一一下概念
所谓软件通俗地说就是一套计算机程序
实现了某些功能的计算机程序
在很早很早以前,一台计算机的软件是不分层次结构的
一台计算机只有一个系统,这个系统既是操作系统又是应用软件,与硬件紧密绑定
后来经过许多年的发展发展发展
人们把一些与硬件紧密相连的又经常用到必不可少的功能做到一套程序中去
这一套程序就被人们称做操作系统
另外一些可有可无的,不同工作适应不同环境的功能封装到另外一套程序中去
而这一系列程序被人们称作应用软件
如下图:
——————————————-
|应用软件:falshgat/IE/realplayer/winamp..|
——————————————-
|操作系统:UNIX/Windows/Linux/Solaris… |
——————————————-
前一篇我们知道,硬件分为服务器工作站与pc
其实无论哪种硬件的软件,都有操作系统与应用软件
ok,那下面我们来谈应用软件
在现在企业级应用中,我们的应用软件一般分为三层
三层分别是表示层,业务逻辑层,数据持久层
——————————
|表示层|业务逻辑层|数据持久层|
——————————
我们来说说三层中的代表软件
表示层
这一层一般在客户端pc机上,最常见的是IE浏览器,这就是表示层的软件
表示层是直接与使用者交互的软件
业务逻辑层
这一层一般在服务器端,顾名思义,所有业务逻辑处理都在这一层完成
最典型的是appserver,比如IBM的websphere,BEA的weblogic还有tomcat/jboss等
这一层也是三层中的重点,我们要说的大部分内容都是关于这一层的,这个等会再说
这一层就叫做中间层
数据持久层
这一层典型的就是数据库,一般也在服务器端
但该服务器一般与装业务逻辑层软件的服务器分开
当然你也可以用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初学者的建议(3)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初学者的建议(2)从JDK说起
在知道了java有什么优点,能做什么之后 就该说一下java该如何去学了 在说java如何去学之前,有必要把java的几个大方向做一个简单说明
早在五年前,嗯,应该说是六年前,也就是99年的时候
sun公司做出了一个决定,将java应用平台做一个划分毕竟在不同领域,语言应用特性是有区别的
针对不同领域内的应用,sun公司可以发布相关高端标准来统一规范代码这三大块就是J2SE,J2EE以及J2ME
这个举措今天看来无疑是非常了不起的正是由于这次革命性的发展,使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