日期:2014-05-17  浏览次数:21077 次

Windows Service实现方案之华山论剑 - 包装一个java程序为Windows服务

前面发表了3篇博客,围绕的一个问题是,如何把Sun Application Server还有我们自己做的另一个Java程序发布成一个WindowsService。呵呵,不算复杂的一个问题,但是确实花了我一些时间:) 这三篇博客地址如下:

Java Service WrapperInstall Windows Service @WinServer2003将SunAS以Windows服务方式启动

?

这三篇博客介绍的内容有一个共同的特点:那就是他们都是一个Wrapper。

这里对这些方案予以总结,同时给我们自己做这样一个wrapper的方法,并进行对比,从这些对比中我们可以看到C#语言确实提供了更好的抽象与封装,程序员开发应用程序要方便很多。

另外一点要说明的是,自己做的wrapper可以对服务程序进行更精细的控制,比如说shutdown,系统待机等等,对于这些接口,使用某些wrapper工具没有办法控制。调查的结果总结如下:)

?

?

1. C语言 wrapper实现方案

使用Windows API,自己想SCM注册服务,响应SCM发送过来的系统事件,不用多说,用C语言做肯定要比其他C++/C#这样的高级语言要麻烦一点,目前发现这方面最好的文章是下面这篇,中英文链接如下:

Five Steps to Writing Windows Services in C

用 C 语言编写 Windows 服务程序的五个步骤?

?

2. C++语言 wrapper实现方案

使用C++语言来做,一种方法就是把C++当C语言来用。当然如果你更习惯面向对象的思想的话,可以参照以下MSDN上面的这篇文章:

Creating a Simple Win32 Service in C++

翻译的版本如下:

用 C++ 创建简单的 Win32 服务程序

?

他的思想是提供一个父类,对服务进行抽象,提供一个服务所应该具备的框架功能,我们要写的服务只需要继承该类并覆写相应的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里面没有提供这样的功能。

1 楼 wjason 2008-07-08  
宝宝,我爱你