summaryrefslogtreecommitdiff
path: root/DAnCE/docs/LocalityManager-Plugins.txt
blob: 1fba66b7beedc2d29701bb42972a35fd65f5b434 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
$Id$

The LocalityManager is a deployment entity that can be easily extended
through the use of user-provided functionality plug-ins.  These
plug-ins fall into three categories:

1) Installation Handlers - These handlers add the capability to
install new instance types to the locality manager.  These plug-ins
are implementations of the InstanceDeploymentHandler interface found
in DAnCE_LocalityManager.idl.

2) Deployment Interceptors - These plug ins allow users to customize
the behavior of DAnCE and are invoked before and after most major
instance lifecycle events.  These are implementations of the
DeploymentInterceptor interface found in
DAnCE_DeploymentInterceptors.idl.

3) Locality Configurators - These are invoked when the locality
manager is launched and used to, for example, modify process
parameters of the locality manager itself.  These are implementations
of the LocalityConfiguration interface found in
DAnCE_LocalityManager.idl.

These plug-ins are loaded by the LocalityManager by using a factory
function.  This factory function must be declared as 'extern "C"',
take no arguments, and have a return value of the IDL interface type,
e.g.:

extern "C"
{
  ::DAnCE::LocalityConfiguration_ptr create_My_Plugin (void);
}

Note, however, that both symbols for this factory method and the plugin
implementation itself must be exported by the compiler.  To accomplish
this, it is suggested that you use the perl script found in
ACE_ROOT/bin/generate_export_file.pl to create an export header, e.g.:

$ACE_ROOT/bin/generate_export_file.pl MyPlugin > MyPlugin_export.h

This generated header file contains preprocessor macros that will
resolve to the platform specific export dectorators at compile time.
In this case, the factory method must be declared thusly:

extern "C"
{
  ::DAnCE::LocalityConfiguration_ptr MyPlugin_Export create_My_Plugin (void);
}

and the MPC file must have the following line:

  dynamicflags += MYPLUGIN_BUILD_DLL

The interceptor/installation handler/configuration plug-ins are loaded
in the LocalityManager by means of a configuration file that is read
at run-time.  By default,it loads a configuration from

DANCE_ROOT/bin/ciao.localityconfig

The file format should be fairly self explanatory, but for a brief
reference, it expects lines in the following format:

<plug-in instance type>  <artifact name>  <artifact entrypoint> <open_mode>

e.g.:

edu.vanderbilt.dre.DAnCE.InstanceHandler CIAO_Deployment_Handlers create_Container_Handler
edu.vanderbilt.dre.DAnCE.InstanceHandler CIAO_Deployment_Handlers create_Home_Handler
edu.vanderbilt.dre.DAnCE.InstanceHandler CIAO_Deployment_Handlers create_Component_Handler
edu.vanderbilt.dre.DAnCE.InstanceHandler CIAO_Deployment_Handlers create_Homed_Component_Handler
edu.vanderbilt.dre.DAnCE.DeploymentInterceptor CIAO_Deployment_Interceptors create_CIAO_StoreReferences
edu.vanderbilt.dre.DAnCE.DeploymentInterceptor DAnCE_Error_Interceptors create_DAnCE_Standard_Error
edu.vanderbilt.dre.DAnCE.ConfigPlugin DAnCE_LM_Config_Plugins create_Process_Name
edu.vanderbilt.dre.DAnCE.ConfigPlugin DAnCE_LM_Config_Plugins create_Process_Priority
edu.vanderbilt.dre.DAnCE.ConfigPlugin DAnCE_LM_Config_Plugins create_CPU_Affinity

This allows you to load plug-ins at runtime without having to modify
the source code of the locality manager.  Note that this configuration
ability only applies currently to the locality manager.   There are
two ways alternate configuration files can be provided to the locality
manager:  1) as a command line option specified on an explicit
locality manager instance in the deployment plan, and 2) as a command
line option to the dance_node_manager.   An example of (1) can be
found at DAnCE/tests/CIAO/Executor-Destructor (look in Component.cdp),
and an example of (2) can be found at
CIAO/examples/Hello/descriptors/run_test_shs.pl (note the additional
command line option --locality-config on the node manager).   (1) will
apply only to an individual locality instance, (2) will apply to ALL
locality instances spawned by the node manager.

The open_mode is the mode as passed to the ACE_DLL::open call. When not
specified  we default to ACE_DEFAULT_SHLIB_MODE

The dance_node_manager currently loads plug-ins by default from the
nodemanager.localityconfig file, which contains the following:
.  Locality Manager installation handler
.  Standard effort handling interceptor

Best effort deployment semantics are requested for the locality
manager by supplying the following line in the localityconfig file in
lieu of the standard error interceptor:

edu.vanderbilt.dre.DAnCE.DeploymentInterceptor DAnCE_Error_Interceptors create_DAnCE_Best_Effort