首页 / 软件开发 / Delphi / DELPHI多层分布式开发(1)
DELPHI多层分布式开发(1)2010-11-23 codesky 分布式多层数据库开发简介Delphi提出的MIDAS(Multi-Tier distributed Application Services Suite多层分布式应用服务器组),是把原来Two- Tier数据连接放到了服务器端 的COM组件上,客户端只剩下了执行文件和MIDAS.DLL,前台和服务器上的COM组 件,通过DCOM机制互相沟通。这个多的一层,称为应用程序服务器(Application Server),或者称为中 间件。这种多层分布式工作机制,主要基于这样几点考虑:1) 减少客户机的维护量,因为前台程序比较简单;把企业逻辑封装在通用的中间件应用服务器中,不同的客户都可以共享同一 个中间层(包括Web),而不必每个客户都单独实现企业规则,避免了重复开发 和维护的麻烦。由于客户程序相当瘦(这就是现在流行的瘦客户机概念),无论 是开发还是发布,都变得简单了。2) 便于升级,当中间件升级的时候,客户程序可能不需要变化;3) 实现了分布式数据处理,把一个应用程序分布在几台机器上运行,可以 提高应用程序的性能,也可以把敏感部分封装在中间件,为不同的用户设置不同 的访问权限,增强了安全性。4) 减少直接连接数据库的用户数目,减少费用。在Delphi 6.0上,在原来的MIDAS基础上,发展了DataSnap技术,在很多细节 方面,它提供了原来MIDAS所没有的许多功能,使用上更加方便了。DataSnap主要提供客户端和中间件之间的通信,不但支持COM+技术也支持 TCP/IP或者CORBA,它们使用类似的界面和方法,其结果由程序自动完成,这就 大大扩充了它的应用范围。下面我们通过几个例子来说明多层数据库的设计问题。主要想解决这样几个问题:如何建立一个简单的分布式系统,如何使用SQL, 如何传递附加信息和向客户提供服务器方法,如何建立主从表结构。理解了这些 方法,我们就可以建立属于自己的性能更加高超的系统来。这些实例,我们不但要会做,更要理解。必须要提醒的是,前台机器上除了应用程序以外,还必须把一个MIDAS.DLL文 件复值到前台机器上,这个文件在服务器的WINNTSystem32目录下。服务器端程序服务器端程序实际上是个COM 工程,它本身连接数据源,再通过接口与客户 端联系,这个COM 工程必须注册在服务器上。首先建立一个空白的工程。file -> New -> Other -> Multitier -> Remote Data Module(远程数据模块)对话框: Coclass Name : COM程序的名称,前台依据这个名字查找COM程序 (Pct121) Instancing :执行模式,大部分用Multiple Instance(多重实例)Threading Model:线程模式,建议用Apartment(单元)下面我们就会对这几个选择详加说明。OK,产生一个窗口,在这个窗口里,可以放入数据控件。在Viwe -> Type Libray 中,我们可以看到这个COM 的一些特性。我们也 可以记下系统提供的GUID,以备后来使用。加入一个ADOTable,并设置其指向一个数据库。再设置一个DataSetProvider(在DataAccess页)指向ADOTable这就完成了服务器端的程序设计。保存,编译,注册(注意,只要运行就自 动在本机注册了)。