ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/i-scream/projects/cms/documentation/specification/configuration.txt
Revision: 1.4
Committed: Wed Jul 16 14:54:47 2008 UTC (15 years, 9 months ago) by tdb
Content type: text/plain
Branch: MAIN
CVS Tags: HEAD
Changes since 1.3: +3 -4 lines
Log Message:
Remove AJ's email address.

File Contents

# Content
1 I-Scream System Configuration - initial draft
2 =============================
3
4 ajm4, 26/11/2000
5
6 This document will address all three areas of concern
7 regarding the configuration operational parameters of the
8 i-scream system to date. These areas being:
9
10 1) Configuration Mechanisms
11 - maintenance documentation
12
13 2) Using the Configuration System
14 - developer documentation
15
16 3) Configuring the I-Scream System
17 - user documentation
18
19 Configuration Mechanisms
20 ------------------------
21
22 Configuration of the I-Scream system is predominantly
23 carried out through the ConfigurationManager component.
24 However there is another configuration option which should
25 be used to an absolute minimum, yet it is necessary to
26 explain it here as it is used!
27
28 Any configuration that should be carried out before any
29 component can initialise the ORB and obtain a reference to
30 the ConfigurationManager should be placed in a "properties"
31 file that is local to that component. At the time of
32 writing the only component to require this is the CORE. This
33 is because is requires some initialisation to get the system
34 up and running. However, it is NOT the norm to use this
35 method, and all elements of the system should make an effort
36 to attach to the orb and obtain the ConfigurationManager
37 before requiring any specific configuration. For information
38 on what is currently contained within the
39 "default.properties" file please refer to the user
40 documentation.
41
42 The main form of configuration mechanism is the afore
43 mentioned ConfigurationManager. This component acts as a
44 centralised holder for configuration for every part of the
45 system. Components get a referance to this well known
46 service either directly through the CORBA Naming Service
47 (see to-be-published conventions on Naming for the I-Scream
48 project). Or via a local proxy, in the case of a Host this
49 is through the FilterManager, a hosts first connection to
50 the system. This allows both CORBA aware and
51 non-aware components to be configured through this system.
52 The ConfigurationManager also provides support for
53 determining if a configuration has changed and thus (if the
54 component is programmed in such a way), support for dynamic
55 re-loading of configuration. For information on how to use
56 the ConfigurationManager, please see the next section on
57 "Using the Configuration System". For information on the
58 file format and structure, together with what is currently
59 contained with the standard configuraton file, please refer
60 to "Configuring the I-Scream System".
61
62
63 Using the Configuration System
64 ------------------------------
65
66 The configuration system itself has two main components.
67 The ConfigurationManager and the Configuration objects.
68 It is currently envisaged that there will only ever be one
69 instance of the ConfigurationManager registered with the ORB
70 in use at any given time. It has the well known service
71 name of "iscream.ConfigurationManager" which a component
72 can used to get a reference to it.
73
74 Once a component has reference to the ConfigurationManager
75 it should then request its configuration using the
76 getConfiguration(<name>) method. eg,
77
78 Configuration myConfig =
79 configManager.getConfiguration("FilterManager");
80
81 The above request causes the ConfigurationManager to look
82 in the system configuration file for the property:
83
84 "config.FilterManager=<config file>"
85
86 It then creates a Configuration object based on the contents
87 of <config file> using the system configuration for the
88 defaults of any values. The ConfigurationManager also has
89 support for including other configurations within a file.
90 For more information on this feature please refer to the
91 next section on "Configuring the I-Scream System".
92
93 A refernce to this Configuration object is then passed back
94 to the calling component. At which point that component can
95 interrogate the Configuration object to obtain its
96 configuration. It should be noted that the Configuration
97 object uses a java.util.Properties object to store the
98 configuration internally, so essentially Configuration acts
99 as a CORBA wrapper for a java.util.Properties object.
100
101 If the entry cannot be found, the component is returned a
102 reference to the system configuration. This allows
103 components to be configured without the need to a
104 configuration file is only a small amount is needed.
105
106 If there is an error at any stage of obtaining the
107 configuration, an appropriate entry will be made in the log,
108 but the component will be returned a NULL reference.
109
110 To obtain entries from a Configuration, a component calls
111 the getProperty(<name>) method. eg,
112
113 myConfig.getProperty("FilterManager.listenPort")
114
115 This will return the String value for that property. The
116 entry in the configuration file would appear as:
117
118 FilterManager.listenPort = <value>
119
120 The configuration system also has support for detecting that
121 a currently loaded configuration has been changed. It
122 achieves this by monitoring the date stamps of the
123 configuration files. The interface to this functionality is
124 provided in two areas. The Configuration object has two
125 further methods, getFileList() and getLastModified(). The
126 first returns a ";" separated list of filenames used to
127 obtain the configuration that was built for that instance.
128 The second returns a long (in the programming sense) number
129 of representing the date stamp of the most recently modified
130 file in the list. Using these two attributes a component
131 can ask the ConfigurationManager to see if its configuration
132 has changed. This is done by calling the isModified(<list>,
133 <last modified>) method. eg,
134
135 configManager("conf1.conf;conf2.conf", 2897938472)
136
137 The ConfigurationManager would then check the file list
138 given together with the system configuration file (as that
139 file is the root of all configurations) to see if the date
140 stamp on any of them is more recent than the given date. If
141 a change is detected this method returns "true" otherwise
142 it returns false. It is then up to the calling component to
143 act, the system does not enforce configuration changes it
144 mearly supports the facility to detect it.
145
146 (note: this next section deals with the naming conventions
147 used withing the configuration files ONLY. ie, from a
148 sys admins point of view (ie, our users).)
149
150
151 Configuring the I-Scream System
152 -------------------------------
153
154 Although there are three main configuration sections to be
155 delt with, all configuration files use the same formatting
156 conventions. These follow.
157
158 Formatting
159 ----------
160
161 Each line should be terminated by a line terminator (\n or
162 \r or \r\n). A line that contains only whitespace or whose
163 first non-whitespace character is an ASCII # or ! is ignored
164 (thus, # or ! indicate comment lines). Every line other than
165 a blank line or a comment line describes one property to be
166 added to the table (except that if a line ends with \, then
167 the following line, if it exists, is treated as a
168 continuation line, as described below). The key consists of
169 all the characters in the line starting with the first
170 non-whitespace character and up to, but not including, the
171 first ASCII =, :, or whitespace character. All of the key
172 termination characters may be included in the key by
173 preceding them with a \. Any whitespace after the key is
174 skipped; if the first non-whitespace character after the key
175 is = or :, then it is ignored and any whitespace characters
176 after it are also skipped. All remaining characters on the
177 line become part of the associated element string. Within
178 the element string, the ASCII escape sequences \t, \n, \r,
179 \\, \", \', \ (a backslash and a space), and \uxxxx are
180 recognized and converted to single characters. Moreover, if
181 the last character on the line is \, then the next line is
182 treated as a continuation of the current line; the \ and
183 line terminator are simply discarded, and any leading
184 whitespace characters on the continuation line are also
185 discarded and are not part of the element string.
186
187 As an example, each of the following four lines specifies
188 the key "Truth" and the associated element value "Beauty":
189
190
191 Truth = Beauty
192 Truth:Beauty
193 Truth :Beauty
194
195 As another example, the following three lines specify a
196 single property:
197
198 fruits apple, banana, pear, \
199 cantaloupe, watermelon, \
200 kiwi, mango
201
202 The key is "fruits" and the associated element is:
203
204 "apple, banana, pear, cantaloupe, watermelon,kiwi, mango"
205
206 Note that a space appears before each \ so that a space will
207 appear after each comma in the final result; the \, line
208 terminator, and leading whitespace on the continuation line
209 are merely discarded and are not replaced by one or more
210 other characters. As a third example, the line:
211
212 cheeses
213
214 specifies that the key is "cheeses" and the associated
215 element is the empty string.
216
217 default.properties
218 ------------------
219
220 This file is loaded by the CORE. The CORE either loads this
221 file from the working directory, or from a specific location
222 using the "-l" command line option. This file provides
223 intial bootstrapping configuration to the system to get the
224 whole thing on its feet. The requirement for entries here
225 is kept to a bare minimum, however all entries listed below
226 MUST have an option set for the system to start. Current
227 configurable options in this file are:
228
229 ----
230 org.omg.CORBA.ORBClass= jacorb.orb.ORB
231 org.omg.CORBA.ORBSingletonClass= jacorb.orb.ORBSingleton
232
233 These two options specifiy which ORB the sytem is to use.
234 By default these are set to the above values, as the JacORB
235 ORB is the one that is distributed with the system, however
236 should you wish to change ORB's to fit with your
237 organisation, it is supported.
238
239 ----
240 uk.ac.ukc.iscream.Verbosity= 5
241
242 This sets the logging verbosity to be used by the system,
243 ie, how much information will be printed to the log file,
244 where the number is:
245
246 FATAL - (0) Fatal or Critical Errors
247 ERROR - (1) All Errors
248 WARNING - (2) Warnings
249 SYSMSG - (3) System Component messages
250 SYSINIT - (4) System Component initialisation
251 DEBUG - (5) All debugging messages
252
253 ----
254 uk.ac.ukc.iscream.ConfigurationLocation=../etc
255 uk.ac.ukc.iscream.SystemConfigurationFile=system.conf
256
257 These set up the configuration component. The first entry
258 tells where the root directory of all configurations for the
259 system are to be found. The second entry specifies the name
260 of the system configuration file to be used.
261
262 ----
263 uk.ac.ukc.iscream.LoggerClass=ScreenLogger
264 uk.ac.ukc.iscream.LoggerClassParam=
265
266 These set up the logging facility. The first entry is a
267 class name of the Logger class to be used by the system.
268 The second line may or may not appear depending on the
269 logging class in use. Logging classes require different
270 configuration options to operate, please refer to their
271 documentation for details. A variety of logging classes
272 will be included with the i-scream system, again, please
273 refer to their documentation for what functionality they
274 provide.
275
276 System Configuration File
277 -------------------------
278
279 This file is used as the defaults for all configurations
280 used by the system. When a property is requested from a
281 configuration, if it can't be found in any of the other
282 files in its configuration tree, this file is checked before
283 returning null. This allows for global defaults to be
284 placed here. Another function of this file is that if no
285 individual configuration file exists for a component it is
286 returned a reference to this file alone. This means that
287 a configuration file does not HAVE to be created for every
288 component.
289
290 There are several key things to be noted for this file.
291 Individual entries for various components are not detailed
292 in this document, but are instead listed in the
293 documentation for the component in question.
294
295 config.<elementname> = <config file>
296
297 where <elementname> can be:
298
299 Host.<hostname>
300 Client.<clientname>
301 <componentname>
302
303 The <hostname> must FQDN, it should all be in lower case.
304 The <clientname> is the configured name for the particular
305 client.
306 The <componentname> the name as given in the component for
307 any particular component.
308
309 The <config file> is file name of a configuration under the
310 configurtion root directory.
311
312 An example of how this can be used:
313
314 FilterManager.listenPort=4567
315
316 This line for the <componentname> of FilterManager can
317 appear in the system configuration. Or if the following
318 line exists in the system configuration:
319
320 config.FilterManager = filterManager.conf
321
322 The file "filterManager.conf" and any included files will
323 be checked for the entry, before looking for it in the
324 system configuration.
325
326 Other Configuration Files
327 -------------------------
328
329 The main entry of other configuration files to be aware of
330 is the:
331
332 include = file1.conf;file2.conf;file3.conf
333
334 This line can be in the configuration file. Each include
335 would will be processed in turn, checking to see if they
336 have any includes. All of these would then be brought
337 together into one list.
338
339 Assuming a configuration above, and that each of the
340 includes has two includes, we would get the following list
341 of configuration files, which are checked for configuration
342 properties in the following order:
343
344 conf.conf;file1.conf;file1a.conf;file1b.conf;
345 file2.conf;file2a.conf;file2b.conf;file3.conf;
346 file3a.conf;file3b.conf;system.conf
347
348 Note the order of precedence of the includes of the included
349 files, namely that their includes take higher priority over
350 the includes of the lower down includes. Also note that
351 they system configuration appears last, allowing global
352 values to be placed there.
353
354
355 For further information on configurating other components of
356 the system, please refer to the components individual
357 documentation.
358
359
360 About
361 -----
362
363 This document was written by Alex Moore for use by the team working on
364 a 3rd year Computer Science project called "i-scream". More details
365 can be found on the project website;
366
367 http://www.i-scream.org