See: Description
Interface | Description |
---|---|
LifeCycle |
The interface used to manage the lifecycle of shared, non-activatable
services started by the
service starter.
|
ServiceDescriptor |
Interface that all service description objects must implement.
|
ServiceProxyAccessor |
Provides a means to obtain a client-side proxy from a
"base" service object.
|
SharedGroup |
The service starter
supported interface for shared group objects.
|
SharedGroupBackEnd |
The
SharedGroupBackEnd interface |
Class | Description |
---|---|
ActivateWrapper |
A wrapper for activatable objects, providing separation of the import
codebase (where the server classes are loaded from by the activation
group) from the export codebase (where clients should load classes from
for stubs, etc.) as well as providing an independent security policy file
for each activatable object.
|
ActivateWrapper.ActivateDesc |
Descriptor for registering a "wrapped" activatable object.
|
ActivateWrapper.ExportClassLoader |
A simple subclass of
PreferredClassLoader that overrides
getURLs to
return the URL s of the provided export codebase. |
AggregatePolicyProvider |
Security policy provider which supports associating security sub-policies
with context class loaders.
|
AggregatePolicyProvider.AggregateSecurityContext |
Security context that produces privileged action wrappers which restore
the context class loader before delegating to the sub-policy context's
wrapped action.
|
AggregatePolicyProvider.DefaultSecurityContext |
Stand-in "default" security context for sub-policies that do not
implement SecurityContextSource.
|
ClassLoaderUtil |
This class provides useful utilities for creating and
manipulating class loaders.
|
DestroySharedGroup |
This class contains the command-line interface for
destroying an instance of a shared activation group.
|
HTTPDStatus |
Class which can be used to print a descriptive warning message
if a codebase accessibility problem is found.
|
LoaderSplitPolicyProvider |
Security policy provider which handles permission queries and grants by
delegating to different policy providers depending on the class loader
involved.
|
NonActivatableServiceDescriptor |
Class used to launch shared, non-activatable, in-process
services.
|
NonActivatableServiceDescriptor.Created |
Object returned by
NonActivatableServiceDescriptor.create()
method that returns the proxy and implementation references
for the created service. |
ProxyVerifier |
Defines a trust verifier for the smart proxies of a SharedGroup server.
|
ServiceStarter |
This class provides the main routine for starting shared groups,
non-activatable services, and activatable services.
|
ServiceStarter.Result |
Trivial class used as the return value by the
create methods. |
SharedActivatableServiceDescriptor |
Class used to launch shared, activatable services.
|
SharedActivatableServiceDescriptor.Created |
Object returned by
SharedActivatableServiceDescriptor.create()
method that returns the associated proxy, activation group
identifier, and activation identifier
for the created service. |
SharedActivationGroupDescriptor |
Class used to create a shared activation group.
|
SharedActivationPolicyPermission |
Permission class used by the
service starter
package. |
SharedActivationPolicyPermission.Collection |
Simple permission collection.
|
SharedGroupImpl |
The provided implementation
of the
SharedGroup service. |
This document covers the following service starter topics:
Operation Modes
The
service starter package supports starting
the contributed services in the following modes:
Shared activatable services are created via
SharedActivatableServiceDescriptor
entries
in service starter's configuration.
Shared non-activatable services are created via
NonActivatableServiceDescriptor
entries
in service starter's configuration.
Running the Service Starter
The Service Starter uses the following command line structure to start
one or more services:
where java_options includes such things as the security policy file and security manager, install_dir is the directory where the Apache River release is installed, and config_options includes any% java java_options -jar install_dir/lib/start.jar config_options
Configuration
provider options.
Note: More information on the java
command can be found
for:
Solaris,
Linux, and
Windows.
The command line, above, will invoke
ServiceStarter.main()
,
which obtains a
ServiceDescriptor[]
from its
Configuration
(via the com.sun.jini.start.serviceDescriptors
entry)
and invokes create()
on each array
element. The three provided implementations of ServiceDescriptor
are:
NonActivatableServiceDescriptor
SharedActivationGroupDescriptor
log
argument to
SharedActivationGroupDescriptor
's constructor. This
log directory can then be specified as the
sharedGroupLog
argument in
SharedActivatableServiceDescriptor
's
constructor in order
to associate the server with a particular activation system group.
Note:A SharedActivationGroupDescriptor
entry
(and it's associated log information)
must be created before it can be referenced by
subsequent SharedActivatableServiceDescriptor
entries.
SharedActivatableServiceDescriptor
sharedGroupLog
constructor argument.
The Service Starter uses the following command line structure to destroy one or more shared groups:
% java java_options -jar install_dir/lib/destroy.jar config_options
The command line, above, will invoke
DestroySharedGroup.main()
,
which obtains a
ServiceDescriptor[]
from its
Configuration
(via the com.sun.jini.start.serviceDestructors
entry)
and invokes create()
on each array
element. All the array elements are assumed to be
SharedActivatableServiceDescriptor
s that are configured to
run SharedGroup
implementations
(see provided implementation: SharedGroupImpl
).
Once created, each element's
destroyVM()
method will be invoked and its associated group log will be deleted.
Notes: Group destruction:
DestroyAdmin.destroy()
method on the server's Administrable
object (obtained
by invoking
Administrable.getAdmin()
on the service proxy).
Assumptions for Running the Examples
The examples below make the following assumptions:
ClassServer
class is used
for this purpose in the following examples.
com.sun.jini.phoenix
implementation for this purpose.
Throughout the examples, items in bold need to be
customized for your local environment.
Shared, non-activatable, transient configurations
To run transient versions of the contributed services, which do not
store any information persistently or use the activation system
to restart itself, using Jini extensible remote invocation (Jini ERI)
for remote communication, run the following command:
java -Djava.security.policy=config_dir/jsk-all.policy \ -jar install_dir/lib/start.jar \ config_dir/start-transient-jeri-services.config
This configuration uses the following files.
File config_dir/jsk-all.policy
Use this security policy file for starting and running all service
configurations. This file grants all permissions to local code included
in the lib
subdirectory of the Apache River release installation.
grant codebase "file:install_dir/lib/*" { permission java.security.AllPermission; };
import com.sun.jini.start.NonActivatableServiceDescriptor; import com.sun.jini.start.ServiceDescriptor; com.sun.jini.start { // // HTTPD Service // private static httpd_codebase = ""; private static httpd_policy = "config_dir/jsk-all.policy"; private static httpd_classpath = "install_dir/lib/classserver.jar"; private static httpd_impl = "com.sun.jini.tool.ClassServer"; private static httpd_service = new NonActivatableServiceDescriptor( httpd_codebase, httpd_policy, httpd_classpath, httpd_impl, new String[]{"-port", "8080", "-dir", "install_dir/lib-dl", "-verbose"}); // // Fiddler (Lookup Discovery Service) // private static fiddler_codebase = "http://your_host:http_port/fiddler-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static fiddler_policy = "config_dir/jsk-all.policy"; private static fiddler_classpath = "install_dir/lib/fiddler.jar"; private static fiddler_config = "config_dir/transient-fiddler.config"; private static fiddler_impl = "com.sun.jini.fiddler.TransientFiddlerImpl"; private static fiddler_service = new NonActivatableServiceDescriptor( fiddler_codebase, fiddler_policy, fiddler_classpath, fiddler_impl, new String[] { fiddler_config }); // // Mahalo (Transaction Service) // private static mahalo_codebase = "http://your_host:http_port/mahalo-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static mahalo_policy = "config_dir/jsk-all.policy"; private static mahalo_classpath = "install_dir/lib/mahalo.jar"; private static mahalo_config = "config_dir/transient-mahalo.config"; private static mahalo_impl = "com.sun.jini.mahalo.TransientMahaloImpl"; private static mahalo_service = new NonActivatableServiceDescriptor( mahalo_codebase, mahalo_policy, mahalo_classpath, mahalo_impl, new String[] { mahalo_config }); // // Mercury (Event Mailbox Service) // private static mercury_codebase = "http://your_host:http_port/mercury-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static mercury_policy = "config_dir/jsk-all.policy"; private static mercury_classpath = "install_dir/lib/mercury.jar"; private static mercury_config = "config_dir/transient-mercury.config"; private static mercury_impl = "com.sun.jini.mercury.TransientMercuryImpl"; private static mercury_service = new NonActivatableServiceDescriptor( mercury_codebase, mercury_policy, mercury_classpath, mercury_impl, new String[] { mercury_config }); // // Norm (Lease Renewal Service) // private static norm_codebase = "http://your_host:http_port/norm-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static norm_policy = "config_dir/jsk-all.policy"; private static norm_classpath = "install_dir/lib/norm.jar"; private static norm_config = "config_dir/transient-norm.config"; private static norm_impl = "com.sun.jini.norm.TransientNormServerImpl"; private static norm_service = new NonActivatableServiceDescriptor( norm_codebase, norm_policy, norm_classpath, norm_impl, new String[] { norm_config }); // // Outrigger (JavaSpaces Service) // private static outrigger_codebase = "http://your_host:http_port/outrigger-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static outrigger_policy = "config_dir/jsk-all.policy"; private static outrigger_classpath = "install_dir/lib/outrigger.jar"; private static outrigger_config = "config_dir/transient-outrigger.config"; private static outrigger_impl = "com.sun.jini.outrigger.TransientOutriggerImpl"; private static outrigger_service = new NonActivatableServiceDescriptor( outrigger_codebase, outrigger_policy, outrigger_classpath, outrigger_impl, new String[] { outrigger_config }); // // Reggie (Lookup Service) // private static reggie_codebase = "http://your_host:http_port/reggie-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static reggie_policy = "config_dir/jsk-all.policy"; private static reggie_classpath = "install_dir/lib/reggie.jar"; private static reggie_config = "config_dir/transient-reggie.config"; private static reggie_impl = "com.sun.jini.reggie.TransientRegistrarImpl"; private static reggie_service = new NonActivatableServiceDescriptor( reggie_codebase, reggie_policy, reggie_classpath, reggie_impl, new String[] { reggie_config }); static serviceDescriptors = new ServiceDescriptor[] { httpd_service, fiddler_service, mahalo_service, mercury_service, norm_service, outrigger_service, reggie_service }; }
com.sun.jini.fiddler { initialLookupGroups = new String[] { "your.group" }; }
com.sun.jini.mahalo { initialLookupGroups = new String[] { "your.group" }; }
com.sun.jini.mercury { initialLookupGroups = new String[] { "your.group" }; }
com.sun.jini.norm { initialLookupGroups = new String[] { "your.group" }; }
com.sun.jini.outrigger { initialLookupGroups = new String[] { "your.group" }; }
com.sun.jini.reggie { initialMemberGroups = new String[] { "your.group" }; }
java -Djava.security.policy=config_dir/jsk-all.policy \ -jar install_dir/lib/start.jar \ config_dir/start-persistent-jeri-services.config
This configuration uses the following files:
File config_dir/start-persistent-jeri-services.config
Use this configuration source file to start persistent services using
Jini ERI.
import com.sun.jini.start.NonActivatableServiceDescriptor; import com.sun.jini.start.ServiceDescriptor; com.sun.jini.start { // // HTTPD Service // private static httpd_codebase = ""; private static httpd_policy = "config_dir/jsk-all.policy"; private static httpd_classpath = "install_dir/lib/classserver.jar"; private static httpd_impl = "com.sun.jini.tool.ClassServer"; private static httpd_service = new NonActivatableServiceDescriptor( httpd_codebase, httpd_policy, httpd_classpath, httpd_impl, new String[]{"-port", "8080", "-dir", "install_dir/lib-dl", "-verbose"}); // // Fiddler (Lookup Discovery Service) // private static fiddler_codebase = "http://your_host:http_port/fiddler-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static fiddler_policy = "config_dir/jsk-all.policy"; private static fiddler_classpath = "install_dir/lib/fiddler.jar"; private static fiddler_config = "config_dir/persistent-fiddler.config"; private static fiddler_impl = "com.sun.jini.fiddler.NonActivatableFiddlerImpl"; private static fiddler_service = new NonActivatableServiceDescriptor( fiddler_codebase, fiddler_policy, fiddler_classpath, fiddler_impl, new String[] { fiddler_config }); // // Mahalo (Transaction Service) // private static mahalo_codebase = "http://your_host:http_port/mahalo-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static mahalo_policy = "config_dir/jsk-all.policy"; private static mahalo_classpath = "install_dir/lib/mahalo.jar"; private static mahalo_config = "config_dir/persistent-mahalo.config"; private static mahalo_impl = "com.sun.jini.mahalo.NonActivatableMahaloImpl"; private static mahalo_service = new NonActivatableServiceDescriptor( mahalo_codebase, mahalo_policy, mahalo_classpath, mahalo_impl, new String[] { mahalo_config }); // // Mercury (Event Mailbox Service) // private static mercury_codebase = "http://your_host:http_port/mercury-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static mercury_policy = "config_dir/jsk-all.policy"; private static mercury_classpath = "install_dir/lib/mercury.jar"; private static mercury_config = "config_dir/persistent-mercury.config"; private static mercury_impl = "com.sun.jini.mercury.NonActivatableMercuryImpl"; private static mercury_service = new NonActivatableServiceDescriptor( mercury_codebase, mercury_policy, mercury_classpath, mercury_impl, new String[] { mercury_config }); // // Norm (Lease Renewal Service) // private static norm_codebase = "http://your_host:http_port/norm-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static norm_policy = "config_dir/jsk-all.policy"; private static norm_classpath = "install_dir/lib/norm.jar"; private static norm_config = "config_dir/persistent-norm.config"; private static norm_impl = "com.sun.jini.norm.PersistentNormServerImpl"; private static norm_service = new NonActivatableServiceDescriptor( norm_codebase, norm_policy, norm_classpath, norm_impl, new String[] { norm_config }); // // Outrigger (JavaSpaces Service) // private static outrigger_codebase = "http://your_host:http_port/outrigger-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static outrigger_policy = "config_dir/jsk-all.policy"; private static outrigger_classpath = "install_dir/lib/outrigger.jar"; private static outrigger_config = "config_dir/persistent-outrigger.config"; private static outrigger_impl = "com.sun.jini.outrigger.PersistentOutriggerImpl"; private static outrigger_service = new NonActivatableServiceDescriptor( outrigger_codebase, outrigger_policy, outrigger_classpath, outrigger_impl, new String[] { outrigger_config }); // // Reggie (Lookup Service) // private static reggie_codebase = "http://your_host:http_port/reggie-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static reggie_policy = "config_dir/jsk-all.policy"; private static reggie_classpath = "install_dir/lib/reggie.jar"; private static reggie_config = "config_dir/persistent-reggie.config"; private static reggie_impl = "com.sun.jini.reggie.PersistentRegistrarImpl"; private static reggie_service = new NonActivatableServiceDescriptor( reggie_codebase, reggie_policy, reggie_classpath, reggie_impl, new String[] { reggie_config }); static serviceDescriptors = new ServiceDescriptor[] { httpd_service, fiddler_service, mahalo_service, mercury_service, norm_service, outrigger_service, reggie_service }; }
import net.jini.id.UuidFactory; import net.jini.jeri.BasicILFactory; import net.jini.jeri.BasicJeriExporter; import net.jini.jeri.tcp.TcpServerEndpoint; com.sun.jini.fiddler { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/persistent-fiddler.log"; serverExporter = new BasicJeriExporter( TcpServerEndpoint.getInstance(fiddler_obj_port), new BasicILFactory(), false, true, UuidFactory.create("fiddler_obj_UUID_string")); }
import net.jini.id.UuidFactory; import net.jini.jeri.BasicILFactory; import net.jini.jeri.BasicJeriExporter; import net.jini.jeri.tcp.TcpServerEndpoint; com.sun.jini.mahalo { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/persistent-mahalo.log"; serverExporter = new BasicJeriExporter( TcpServerEndpoint.getInstance(mahalo_obj_port), new BasicILFactory(), false, true, UuidFactory.create("mahalo_obj_UUID_string")); }
import net.jini.id.UuidFactory; import net.jini.jeri.BasicILFactory; import net.jini.jeri.BasicJeriExporter; import net.jini.jeri.tcp.TcpServerEndpoint; com.sun.jini.mercury { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/persistent-mercury.log"; serverExporter = new BasicJeriExporter( TcpServerEndpoint.getInstance(mercury_obj_port), new BasicILFactory(), false, true, UuidFactory.create("mercury_obj_UUID_string")); }
import net.jini.id.UuidFactory; import net.jini.jeri.BasicILFactory; import net.jini.jeri.BasicJeriExporter; import net.jini.jeri.tcp.TcpServerEndpoint; com.sun.jini.norm { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/persistent-norm.log"; serverExporter = new BasicJeriExporter( TcpServerEndpoint.getInstance(norm_obj_port), new BasicILFactory(), false, true, UuidFactory.create("norm_obj_UUID_string")); }
import net.jini.id.UuidFactory; import net.jini.jeri.BasicILFactory; import net.jini.jeri.BasicJeriExporter; import net.jini.jeri.tcp.TcpServerEndpoint; com.sun.jini.outrigger { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/persistent-outrigger.log"; serverExporter = new BasicJeriExporter( TcpServerEndpoint.getInstance(outrigger_obj_port), new BasicILFactory(), false, true, UuidFactory.create("outrigger_obj_UUID_string")); store = new com.sun.jini.outrigger.snaplogstore.LogStore(this); }
The *obj_port variables are the fixed TCP ports used to listen for server requests. The *obj_UUID_string variables are the universally unique IDs for the exported servers. These IDs have the form:import net.jini.id.UuidFactory; import net.jini.jeri.BasicILFactory; import net.jini.jeri.BasicJeriExporter; import net.jini.jeri.tcp.TcpServerEndpoint; com.sun.jini.reggie { initialMemberGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/persistent-reggie.log"; serverExporter = new BasicJeriExporter( TcpServerEndpoint.getInstance(reggie_obj_port), new BasicILFactory(), false, true, UuidFactory.create("reggie_obj_UUID_string")); }
"01234567-01ab-cdef-0123-456789abcdef"
.
Remember to remove the config_dir/*.log directories
before restarting persistent services if you don't want to keep the registrations
and settings made by previous service invocations.
Shared, activatable, persistent configurations
To run persistent, activatable versions of the contributed services,
which use the activation system to restart themselves, using Jini ERI
for remote communication, run the following command:
java -Djava.security.policy=config_dir/jsk-all.policy \ -jar install_dir/lib/start.jar \ config_dir/start-activatable-jeri-services.config
This configuration uses the following files:
File config_dir/start-activatable-jeri-services.config
Use this configuration source file to start persistent services using
Jini ERI.
import com.sun.jini.start.NonActivatableServiceDescriptor; import com.sun.jini.start.ServiceDescriptor; import com.sun.jini.start.SharedActivatableServiceDescriptor; import com.sun.jini.start.SharedActivationGroupDescriptor; com.sun.jini.start { // // HTTPD Service // private static httpd_codebase = ""; private static httpd_policy = "config_dir/jsk-all.policy"; private static httpd_classpath = "install_dir/lib/classserver.jar"; private static httpd_impl = "com.sun.jini.tool.ClassServer"; private static httpd_service = new NonActivatableServiceDescriptor( httpd_codebase, httpd_policy, httpd_classpath, httpd_impl, new String[]{"-port", "8080", "-dir", "install_dir/lib-dl", "-verbose"}); // // Shared Group Environment // private static sharedVM_policy = "config_dir/jsk-all.policy"; private static sharedVM_classpath = "install_dir/lib/sharedvm.jar"; private static sharedVM_log = "config_dir/sharedvm.log"; private static sharedVM_command = null; private static sharedVM_options = null; private static sharedVM_properties = null; private static sharedVM = new SharedActivationGroupDescriptor( sharedVM_policy, sharedVM_classpath, sharedVM_log, sharedVM_command, sharedVM_options, sharedVM_properties); // // Fiddler (Lookup Discovery Service) // private static fiddler_codebase = "http://your_host:http_port/fiddler-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static fiddler_policy = "config_dir/jsk-all.policy"; private static fiddler_classpath = "install_dir/lib/fiddler.jar"; private static fiddler_config = "config_dir/activatable-fiddler.config"; private static fiddler_impl = "com.sun.jini.fiddler.ActivatableFiddlerImpl"; private static fiddler_service = new SharedActivatableServiceDescriptor( fiddler_codebase, fiddler_policy, fiddler_classpath, fiddler_impl, sharedVM_log, new String[] { fiddler_config }, true); // // Mahalo (Transaction Service) // private static mahalo_codebase = "http://your_host:http_port/mahalo-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static mahalo_policy = "config_dir/jsk-all.policy"; private static mahalo_classpath = "install_dir/lib/mahalo.jar"; private static mahalo_config = "config_dir/activatable-mahalo.config"; private static mahalo_impl = "com.sun.jini.mahalo.ActivatableMahaloImpl"; private static mahalo_service = new SharedActivatableServiceDescriptor( mahalo_codebase, mahalo_policy, mahalo_classpath, mahalo_impl, sharedVM_log, new String[] { mahalo_config }, true); // // Mercury (Event Mailbox Service) // private static mercury_codebase = "http://your_host:http_port/mercury-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static mercury_policy = "config_dir/jsk-all.policy"; private static mercury_classpath = "install_dir/lib/mercury.jar"; private static mercury_config = "config_dir/activatable-mercury.config"; private static mercury_impl = "com.sun.jini.mercury.ActivatableMercuryImpl"; private static mercury_service = new SharedActivatableServiceDescriptor( mercury_codebase, mercury_policy, mercury_classpath, mercury_impl, sharedVM_log, new String[] { mercury_config }, true); // // Norm (Lease Renewal Service) // private static norm_codebase = "http://your_host:http_port/norm-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static norm_policy = "config_dir/jsk-all.policy"; private static norm_classpath = "install_dir/lib/norm.jar"; private static norm_config = "config_dir/activatable-norm.config"; private static norm_impl = "com.sun.jini.norm.ActivatableNormServerImpl"; private static norm_service = new SharedActivatableServiceDescriptor( norm_codebase, norm_policy, norm_classpath, norm_impl, sharedVM_log, new String[] { norm_config }, true); // // Outrigger (JavaSpaces Service) // private static outrigger_codebase = "http://your_host:http_port/outrigger-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static outrigger_policy = "config_dir/jsk-all.policy"; private static outrigger_classpath = "install_dir/lib/outrigger.jar"; private static outrigger_config = "config_dir/activatable-outrigger.config"; private static outrigger_impl = "com.sun.jini.outrigger.PersistentOutriggerImpl"; private static outrigger_service = new SharedActivatableServiceDescriptor( outrigger_codebase, outrigger_policy, outrigger_classpath, outrigger_impl, sharedVM_log, new String[] { outrigger_config }, true); // // Reggie (Lookup Service) // private static reggie_codebase = "http://your_host:http_port/reggie-dl.jar" + " http://your_host:http_port/jsk-dl.jar"; private static reggie_policy = "config_dir/jsk-all.policy"; private static reggie_classpath = "install_dir/lib/reggie.jar"; private static reggie_config = "config_dir/activatable-reggie.config"; private static reggie_impl = "com.sun.jini.reggie.PersistentRegistrarImpl"; private static reggie_service = new SharedActivatableServiceDescriptor( reggie_codebase, reggie_policy, reggie_classpath, reggie_impl, sharedVM_log, new String[] { reggie_config }, true); // // Services to start -- used by ServiceStarter.main() // static serviceDescriptors = new ServiceDescriptor[] { httpd_service, sharedVM, fiddler_service, mahalo_service, mercury_service, norm_service, outrigger_service, reggie_service }; // // Shared Group // private static shared_group_codebase = "http://your_host:http_port/group-dl.jar"; private static shared_group_policy = "config_dir/jsk-all.policy"; private static shared_group_classpath = "install_dir/lib/group.jar"; private static shared_group_config = "config_dir/activatable-group.config"; private static shared_group_impl = "com.sun.jini.start.SharedGroupImpl"; private static shared_group_service = new SharedActivatableServiceDescriptor( shared_group_codebase, shared_group_policy, shared_group_classpath, shared_group_impl, sharedVM_log, // Same as above new String[] { shared_group_config }, false); // // Groups to destroy -- used by DestroySharedGroup.main() // static serviceDestructors = new ServiceDescriptor[] { shared_group_service }; }
com.sun.jini.fiddler { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/activatable-fiddler.log"; }
com.sun.jini.mahalo { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/activatable-mahalo.log"; }
com.sun.jini.mercury { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/activatable-mercury.log"; }
com.sun.jini.norm { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/activatable-norm.log"; }
com.sun.jini.outrigger { initialLookupGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/activatable-outrigger.log"; store = new com.sun.jini.outrigger.snaplogstore.LogStore(this); }
com.sun.jini.reggie { initialMemberGroups = new String[] { "your.group" }; persistenceDirectory = "config_dir/activatable-reggie.log"; }
Remember to remove the config_dir/*.log directories before recreating activatable services if you want it to forget registrations and settings made by previous service invocations.com.sun.jini.start { // Use defaults }
java -Djava.security.policy=config_dir/jsk-all.policy \ -jar install_dir/lib/destroy.jar \ config_dir/start-activatable-jeri-services.config
Note: The command, above, references
config_dir/start-activatable-jeri-services.config,
which was the configuration file used to start the services. This was done
for the convenience of referencing the same sharedVM_log
value
for both group creation and destruction. The command line,
above, could also have used a separate, independent configuration file.
Activation System
There are two activation daemon implementations available: rmid
and Phoenix
. rmid
is part of the Java 2 SDK:
rmid
on Microsoft Windows
rmid
with the Solaris(TM) Operating System
and/or Linux
Phoenix
is part
of the Apache River release. Phoenix
has better support for Jini ERI, is
configurable, and supports net.jini.security, making it suitable for
a much broader range of deployments than rmid
.
Copyright 2007-2013, multiple authors.
Licensed under the Apache License, Version 2.0, see the NOTICE file for attributions.