I am trying to run a simple java application as windows service. This is my main class file. I am trying to print time for every five seconds and stop after one minute. The Package name is samPack.
package samPack;
import java.util.Date;
public class Time {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Thread thread = new Thread()
{
public void run()
{
long start = System.currentTimeMillis();
long end = start + 60*1000;
while (System.currentTimeMillis() < end){
//System.out.println("Hello World");
Date date = new Date();
System.out.println("Ram Test ---- > "+date.toString());
try
{
Thread.sleep(5000); // 1 second
} catch (Exception e)
{
e.printStackTrace();
}
}
}
};
thread.start();
}
}
To make it a windows service I have downloaded the Tanuki Software’s Java Service Wrapper. and unzip the folder on desktop. I have created a runnable jar file for the above code and pasted it in bin folder of Java service Wrapper and also in the lib folder. The DemoApp.bat fail in bin folder I have changed it to run.bat and then in that file I have changed variable WRAPPER_CONF_DEFAULT to ../conf/wrapper.conf.
IN the Wrapper.conf file these are the changes I made
# Java Main class. This class must implement the WrapperListener interface
# or guarantee that the WrapperManager class is initialized. Helper
# classes are provided to do this for you. See the Integration section
# of the documentation for details.
wrapper.java.mainclass=samPack.Time
# Java Classpath (include wrapper.jar) Add class path elements as
wrapper.java.classpath.1=../lib/wrappertest.jar
wrapper.java.classpath.2=../lib/wrapper.jar
wrapper.java.classpath.3=../lib/sam.jar
# Name of the service
wrapper.name=samtestservice
# Display name of the service
wrapper.displayname=Sam Test Service
# Description of the service
wrapper.description=Sam Test Service Decs
# Mode in which the service is installed. AUTO_START, DELAY_START or DEMAND_START
wrapper.ntservice.starttype=AUTO_START
Now when I run the bat file run.bat it is running in the console and displaying the below result.
wrapper | Launching a JVM...
jvm 1 | Ram Test ---- > Mon May 05 18:18:59 IST 2014
jvm 1 | Ram Test ---- > Mon May 05 18:19:04 IST 2014
jvm 1 | Ram Test ---- > Mon May 05 18:19:09 IST 2014
jvm 1 | Ram Test ---- > Mon May 05 18:19:14 IST 2014
jvm 1 | Ram Test ---- > Mon May 05 18:19:19 IST 2014
jvm 1 | Ram Test ---- > Mon May 05 18:19:24 IST 2014
wrapper | Startup failed: Timed out waiting for a signal from the JVM.
wrapper |
wrapper | ------------------------------------------------------------------------
wrapper | Advice:
wrapper | The Wrapper consists of a native component as well as a set of classes
wrapper | which run within the JVM that it launches. The Java component of the
wrapper | Wrapper must be initialized promptly after the JVM is launched or the
wrapper | Wrapper will timeout, as just happened. Most likely the main class
wrapper | specified in the Wrapper configuration file is not correctly initializing
wrapper | the Wrapper classes:
wrapper | samPack.Time
wrapper | While it is possible to do so manually, the Wrapper ships with helper
wrapper | classes to make this initialization processes automatic.
wrapper | Please review the integration section of the Wrapper's documentation
wrapper | for the various methods which can be employed to launch an application
wrapper | within the Wrapper:
wrapper | http://wrapper.tanukisoftware.com/doc/english/integrate.html
wrapper | ------------------------------------------------------------------------
I have installed the service by running the bat file but unable to start the service. The service dint start. Whats going wrong ?
Modify wrapper.java.mainclass=samPack.Time
to wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperSimpleApp
and add a new line wrapper.app.parameter.1=samPack.Time
Details are on Tanuki website: http://wrapper.tanukisoftware.com/doc/english/integrate-simple-win.html