Difference between revisions of "Maintaining local Yaim functions"

From PDP/Grid Wiki
Jump to navigationJump to search
Line 20: Line 20:
 
  + Makefile
 
  + Makefile
 
  + template.spec
 
  + template.spec
 +
 +
The files Makefile and template.spec are required for building the package. The version information is taken from file config.version. Under directory functions/local, the modified versions of the configuration functions are defined.
  
 
== Get the latest sources from CVS ==
 
== Get the latest sources from CVS ==

Revision as of 15:18, 23 July 2009

Local Yaim functions

Yaim (http://yaim.info/) is the official configuration tool for gLite middleware. It aims to support the basic configuration for typical grid sites. That basic level of configuration may be insufficient for sites, which may use a non-standard or more complex setup. Yaim allows sites to enhance the default configuration setup with so-called "local functions".

Nikhef's grid middleware is configured using Yaim (which is in turned controlled via [Quattor]). The Nikhef site configuration differs from the default in various ways, which is facilitated by the use of local Yaim functions. For every glite-yaim-PRODUCT package that needs to be enhanced for our site-specific configuration, we maintain a corresponding package nikhef-yaim-PRODUCT. This article describes how to maintain the local packages (between parentheses their gLite counterparts):

  • nikhef-yaim-bdii (glite-yaim-bdii)
  • nikhef-yaim-clients (glite-yaim-clients)
  • nikhef-yaim-core (glite-yaim-core)
  • nikhef-yaim-dpm (glite-yaim-dpm)
  • nikhef-yaim-lcg-ce (glite-yaim-lcg-ce)
  • nikhef-yaim-lfc (glite-yaim-lfc)
  • nikhef-yaim-scas (glite-yaim-scas)
  • nikhef-yaim-wms (glite-yaim-wms)

The source code for the above packages is kept on the Subversion server under repository ndpf/nl.nikhef.ndpf.yaim; there is one directory per package. Each directory contains the same files and directories:

+ functions/local/
+ config.version
+ Makefile
+ template.spec

The files Makefile and template.spec are required for building the package. The version information is taken from file config.version. Under directory functions/local, the modified versions of the configuration functions are defined.

Get the latest sources from CVS

Do a checkout or update of the directory nl.nikhef.ndpf.yaim from the CVS repository. It will create a sub directory nikhef-yaim-local containing the sources.

The CVS repository requires the following environment:

CVSROOT=:ext:ronalds@beerput.nikhef.nl:/cvs/ndpf
CVS_RSH=ssh


Modify the sources

You should know how to do that :-)


Build the package

The file config.version contains the current version number and release number. To build the rpm while preserving the version and release number in config.version, use the command

make rpm

To build and automatically increase the release number, use

make release

To increase the version number, manually modify config.version and use 'make rpm'.

The resulting rpm package will be available in <BUILDROOT>/RPMS/noarch.


Use the freshly built rpm from Quattor profiles

Copy the rpm built in the previous step to a repository on the Quattor server stal. The current location for the package at stal is /project/quattor/www/html/mirror/nikhef. Ensure that the rpm is owned by the user ndpfmgr.

To include the new version of nikhef-yaim-local in the Quattor profiles, edit the template

$L/cfg/facility/<FACILITY>/lcg2/yaim/pro_lcg2_config_yaim.tpl where $L is the base directory of the Quattor configuration.

Search this file for the following lines:

# NIKHEF local yaim setup
"/software/packages" = pkg_repl("nikhef-yaim-local", "X.Y.Z-R", "noarch");

where X.Y.Z is the version number and R the release number. Change the version and release numbers to match those of your package.

Finally, make and deploy your quattor profile!

Note: The ncm-yaim component only executes when it detects changes in its configuration file. To manually trigger execution of the yaim configuration, execute the following command:

ncm-ncd --configure yaim

or even

/opt/lcg/yaim/scripts/configure_node /etc/lcg-quattor-site-info.def <NODE TYPE> [NODE TYPE] ...