Since 1994, the Java programming language evolved and became a
valid tool to develop reliable and performant server applications as
opposed to just applets and client applications. The major disadvantage of
the Java platform is that still today the only portable way to
start a Java application relies on a single point of entry: the
public static void
main(String[]) method.
Having a single-point of entry is a valid solution for client
applications, where interactively a user can command to the application
to quit (which can terminate the Virtual Machine process at calling the
System.exit(int)
method), but in those cases where the application is not interactive
(server applications) there is currently no portable way to notify
the Virtual Machine of its imminent shutdown.
A server application written in Java might have to perform several tasks before being able to shut down the Virtual Machine process. For example in the case of a Servlet container, before the VM process is shut down, sessions might need to be serialized to disk, and web applications need to be destroyed.
One common solution to this problem is to create (for example) a
ServerSocket and wait for a particular
message to be issued. When the message is received, all operations
required to shut down the server applications are performed and at the
end the System.exit method is called
to terminate the Virtual Machine process. This method however, has
several disadvantages and risks:
Most multi-user operating systems already have a way in which server applications are started and stopped. Under Unix based operating systems non-interactive server applications are called daemons and are controlled by the operating system with a set of specified signals. Under Windows such programs are called services and are controlled by appropriate calls to specific functions defined in the application binary, but although the ways of dealing with the problem are different, in both cases the operating system can notify a server application of its imminent shutdown, and the application has the ability to perform certain tasks before its process of execution is destroyed.
Daemon is made of 2 parts. One written in C that makes the interface to the operating system and the other in Java that provides the Daemon API.
Both Win32 and UNIX like platforms are supported. For Win32 platforms use procrun. For UNIX like platforms use jsvc.
The original Java classes came from the Jakarta Tomcat 4.0 project.
The package name for the Daemon component is
org.apache.commons.daemon.
Copyright © 2002-2025 The Apache Software Foundation. All Rights Reserved.