1、首先到请下载最新版本的Java Service Wrapper
wrapper 下载地址
http://sourceforge.net/projects/wrapper/files/wrapper/Wrapper_3.2.3_20061016/wrapper-windows-x86-32-3.2.3.zip/download?use_mirror=jaist
2、准备如下文件,复制到test目录,这些文件可以从下载包中找到:
wrapper.dll
wrapper.exe
wrapper.jar
3、编写wrapper.conf,也放在同一级目录下面,内容如下
wrapper.java.command=java
wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperSimpleApp
#定义程序运行的classpath
wrapper.java.classpath.1=wrapper.jar
wrapper.java.classpath.2=[jar file/path]
# Java Library Path (location of Wrapper.DLL or libwrapper.so)
wrapper.java.library.path.1=.
# Java Additional Parameters
#wrapper.java.additional.1=
# Initial Java Heap Size (in MB)
#wrapper.java.initmemory=3
# Maximum Java Heap Size (in MB)
#wrapper.java.maxmemory=64
# 运行的Main Class
wrapper.app.parameter.1=
wrapper.console.format=PM
wrapper.console.loglevel=INFO
wrapper.logfile=Beanskt.log
wrapper.logfile.format=LPTM
wrapper.logfile.loglevel=INFO
wrapper.logfile.maxsize=0
wrapper.logfile.maxfiles=0
wrapper.syslog.loglevel=NONE
#window服务配置
wrapper.console.title=samplesvr
#服务名
wrapper.ntservice.name=samplesvr
# 显示名称
wrapper.ntservice.displayname= sample Service
# 描述
wrapper.ntservice.description=sample Service
# 依赖项
wrapper.ntservice.dependency.1=
# 启动模式: AUTO_START or DEMAND_START
wrapper.ntservice.starttype=AUTO_START
# 是否交互.
wrapper.ntservice.interactive=false
4、运行测试,安装服务
》测试运行是否正常
wrapper.exe -c wrapper.conf
》安装服务
wrapper.exe -i wrapper.conf
》卸载服务
wrapper.exe -r wrapper.conf
》启动
wrapper.exe -t wrapper.conf
》停止
wrapper.exe -p wrapper.conf
出处 :http://www.blogjava.net/midea0978/archive/2008/01/17/175953.html
Java Service Wrapper提供了4种方式来Java App注册为服务运行(Integration Methods)。
- 使用 WrapperSimpleApp帮助类来启动应用。 这种方法是最简单的方法。使用这种方法需要注意的是Java Service Wrapper停止Java App的时候不会调用Java App的相应的接收方法,而是直接调用System.exit()来结束Java App。
- 使用 WrapperStartStopApp帮助类来启动应用。这种方法假设Java App有相应的启动,停止类。由ClassX负责启动Java App,ClassY负责停止Java App。当然了,具体使用的时候也可以用同一个类来启动或者停止Java App,只要初始化该类的不同启动或停止参数就可以了。
- 使用WrapperManager类来启动应用。这种方法是最灵活的启动方式,而且需要Java App的启动类必须实现 WrapperListener接口。 WrapperListener接口有start(String[] arg0)和stop(int arg0)方法,需要Java App的启动类来实现。这就就可以用WrapperManager类来管理Java App的主类了。
- 使用 WrapperJarApp 帮助类来启动应用。这种方法和WrapperSimpleApp帮助类相似,只是使用这种方法的时候,Java App要求打包为可执行的Jar文件。
我使用第二种方式启动自己的Java App。下载Java Service Wrapper后首先是copy一些文件到自己的Java App应用相应的目录下。给目录的结构类似下面这个样子:
src
|
|--bin
| |--wrapper.exe
| |--App.bat
| |--InstallApp-NT.bat
| |--UninstallApp-NT.bat
|
|--conf
| |--wrapper.conf
|
|--lib
| |--Wrapper.dll
| |--Wrapper.jar
|
|--logs
| |--wrapper.log
|
|--<Your own Source Classes here>
当然了,如果你的应用程序已经写好了,不行改变已有目录的名称,那就修改Java Service Wrapper的配置文件吧。比如conf文件目录原来的名称为configuration,那就你就可以修改bin目录下引用wrapper.conf的bat文件中相应的地方即可。
然后就是配置文件wrapper.conf的修改了。
wrapper .java .command=java : 指定要运行的Java .如果已经设定了Java的环境变量,这里可以不修改;如果没有,可以使用绝对路径指向 JDK bin 目录下的java。
wrapper .java .mainclass=org.tanukisoftware.wrapper.WrapperStartStopApp: 指定要运行的帮助类,这个类是上面说的4中方式的启动类之一。Java Service Wrapper是用自己的类来启动应用程序,并把实际要启动的Java应用程序的主类作为该类的第一个参数传进去。
wrapper .java .classpath.1=../lib/wrapper .jar :配置Java 的类路径,这里的将 wrapper .jar 也包含在内,这里可以设置参数的位置,而且这个位置必须得从 1 开始,不能跳过,必须顺序指定,指定类路径的时候还有根据依赖关系来排列 , 被依赖的排在前面,否则会出现 ClassNotFoundException 的错误,这里支持绝对路径和相对路径,也支持通配符 "*" ,比如 wrapper .java .classpath.1=../lib/wrapper * , 不过这个通配符只能用于匹配文件名,不能用于匹配文件夹名称。当然了,这里也必须添加上当前目录或者上一级目录,取决于你的主类所在的目录。
wrapper .java .library.path.1=../lib: 指定Wrapper 自带的类库文件存放文件夹,比如 Wrapper .DLL 文件等,只要指定到对应的上级目录名称就行,支持通配符。
wrapper .app.parameter.1= : 指启动类,如上面说的ClassX 。
wrapper .app.parameter.2= : 指启动类main方法需要的参数个数 。
wrapper .app.parameter.3= : 指启动类main方法的实际参数,依次列出。
wrapper .app.parameter.x= : 实际参数。
wrapper .app.parameter.y= : 指停止类,如上面说的ClassY 。当然了,也可以和启动类一样为ClassX,但是需要参数来区分相应的操作。
wrapper .console.title=Java App : 控制台窗口显示标题,
wrapper .ntservice.name=Service Name: 系统服务的名称 ,
wrapper .ntservice.displayname= Service Name : 在服务管理中显示的名称
wrapper .ntservice.description= Service Name 的介绍信息 : 在服务管理器显示服务的描述信息
wrapper .ntservice.starttype=AUTO_START: 配置服务启动方式,可以选择AUTO_START( 自动 ) 和 DEMAND_START( 手动 ) 两种方式。默认为自动。
案例:main class
public class HelloWorld implements WrapperListener{
private HelloWorld() {
}
public Integer start( String[] args ){
System.out.println( "start()" );
try{
System.out.println("HelloWorld!");
}
catch ( Exception e ){}
return null;
}
public int stop( int exitCode ){
System.out.println( "stop(" + exitCode + ")" );
return exitCode;
}
public void controlEvent( int event ){
System.out.println( "controlEvent(" + event + ")" );
}
public static void main( String[] args ){
System.out.println( "Initializing..." );
WrapperManager.start( new HelloWorld(), args );
}
}