精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
||
---|---|---|
作者 | 正文 | |
发表时间:2008-07-07
前面发表了3篇博客,围绕的一个问题是,如何把Sun Application Server还有我们自己做的另一个Java程序发布成一个WindowsService。呵呵,不算复杂的一个问题,但是确实花了我一些时间:) 这三篇博客地址如下: Java Service Wrapper,Install Windows Service @WinServer2003,将SunAS以Windows服务方式启动
这三篇博客介绍的内容有一个共同的特点:那就是他们都是一个Wrapper。 这里对这些方案予以总结,同时给我们自己做这样一个wrapper的方法,并进行对比,从这些对比中我们可以看到C#语言确实提供了更好的抽象与封装,程序员开发应用程序要方便很多。 另外一点要说明的是,自己做的wrapper可以对服务程序进行更精细的控制,比如说shutdown,系统待机等等,对于这些接口,使用某些wrapper工具没有办法控制。调查的结果总结如下:)
1. C语言 wrapper实现方案 使用Windows API,自己想SCM注册服务,响应SCM发送过来的系统事件,不用多说,用C语言做肯定要比其他C++/C#这样的高级语言要麻烦一点,目前发现这方面最好的文章是下面这篇,中英文链接如下:
2. C++语言 wrapper实现方案 使用C++语言来做,一种方法就是把C++当C语言来用。当然如果你更习惯面向对象的思想的话,可以参照以下MSDN上面的这篇文章: Creating a Simple Win32 Service in C++ 翻译的版本如下:
他的思想是提供一个父类,对服务进行抽象,提供一个服务所应该具备的框架功能,我们要写的服务只需要继承该类并覆写相应的Start,Stop,Shutdown等方法即可。有一个问题就是,这个类没有在微软提供的库中。
3. C#语言 wrapper实现方案 C#实现方案与C/C++的比,可以说要简单了很多。C#标准库中提供了一个ServiceBase类,我们同样只需要覆写其相应的方法即可。可以看msdn里面ServiceBase的Example,代码很清晰,而且服务的安装这一块也进行了很好的封装,可以参看这两个类ServiceProcessInstaller,ServiceInstaller。visual studio中也提供了很好的支持,基本上这些东西点一点就都搞定了。
4.把Java程序包装成服务 你想用java语言实现自己的wrapper?我们当然可以,但是在开始之前,还是先看看Java Service Wrapper吧。其实完全可以不必使用JavaServiceWrapper,把java做成一个jar,或者exe,在别的wrapper里面调用,就Ok了。但是有一个问题是,我们的环境变量怎么弄,classpath怎么配,还有Log文件,如果我们要做是不是也得自己做?
所以Java service wrapper的好处就是这些问题都已经帮我们处理好了,而且还提供了更额外的支持。并以配置文件的形式出现,这样不管我们是修改,发布,还是配置都十分方便,对java程序而言,该项目还是非常友好的。
5. Windows Resource Kit 这是微软为我们提供的一个工具组合,里面有一个工具叫做srvany,可以把任何程序发布为一个服务,Readme里面所对nt内核都适用,我在2003上试验了一下没问题,虽然在拿2003的resource kit在xp上试验没有通过。猜测应该有相应的版本。
该工具的一个问题就是,这个小工具我们没有许可在我们的程序中发布,所以,对于一个网路管理员,我想该工具还是非常实用的。开发人员还是想别的办法吧。
6. 其他 比如像Sun,都提供了自己的方案,所以如果你想作为服务运行的程序恰好是别的公司的一个产品,那么还是先看该公司的文档。很多程序在安装的时候,也都自动装了相应的服务,sun application server 也是这样。在SunAS 9里面就有是否把它安装为服务程序这样的选项。只是SunAS8里面没有提供这样的功能。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
||
返回顶楼 | ||
浏览 3147 次