The Glidein Frontend (or VO frontend) will match user jobs with Glidein Factory ads. It is responsible for the submission of new glideins.
The VO frontend also keeps part of the configuration of a glidein, and can also provide the glidein Factory with the pilot proxies.
Note: if you are installing only the frontend and planning to connect to the OSG Factory, please refer to this section: Connecting to OSG Factory
Note: This document refers to the tarball distribution of the Glidein Frontend. If you want to install or installed via RPM please refer to the OSG RMP Guide.
This machine needs 4 cores, preferable no more than 2 years old and a moderate amount of memory (3GB plus 2MB per running job should be enough).
The disk needed is just for binaries, config files and log files (30GB should be enough)
Hardware requirements depend on the expected load. With small loads or for test purposes one core and 1GB will suffice.
The installer requires a non-privileged user. This should be created prior to running the GlideinWMS installer.
|VO Frontend User(frontend)||The Glidein Frontend should be installed as a non-privilged user. Note: It is recommended that you install HTCondor as this user as well.|
The installer will ask for several DNs for GSI authentication. You have the option of using a service certificate or a proxy. These should be created and put in place before running the installer. The following is a list of DNs the installer will ask for:
- WMS Pool (Collector) cert/proxy DN
- User Pool (Collector) cert/proxy DN
- User Submitter cert/proxy DN
- Glidein Frontend HTCondor proxy DN (cannot use a cert here)
Note 2: The installer will ask if these are trusted HTCondor Daemons. Answer 'y'.
When installing the Glidein Frontend you will need to specify the directory location for various items. We recommend putting most of them in /var. All the directories in /var have to be created as root. Therefore, if you intend on using /var, you will have to create the directories ahead of time.
Note: The Web data must be stored in a directory served by the HTTP Server.
You will need the OSG Client (formerly VDT client). You need to install it yourself using either the RPM or the tarball provided by OSG (see here).
If you installed OSG Client using the RPM, the binaries will be in the system path. If you installed it using the tarball, then answer 'y' when asked if you want OSG_VDT_BASE defined globally. Unless you want to force your users to find and hard code the location.
By default, match authentication will be used. If you have a reason not to use it, be sure to set to False the USE_MATCH_AUTH attribute in both the Factory and Frontend configuration files.
The installer can install a local copy as the same non privileged Glidein Frontend user. The whole process is managed by a install script described below.
The Glidein Frontend needs a x509 proxy to communicate with the glidein Factory. You need to create such proxy before starting a VO
Frontend and then keep it valid for the life of the Frontend (see here). If used for glidein submission (i.e. if it is passed to the glidein Factory), this proxy must at any point in time have a validity of at least the longest expected job being run by the GlideinWMS
(and not less than 12 hours).
How you keep this proxy valid (via MyProxy, kx509, voms-proxy-init from a local certificate, scp from other nodes, or other methods), is beyond the scope of this document.
The VO Frontend can also host the x509 proxies used for glidein submission. If you do use this (recommended) method, you need to keep these proxies valid at all times, as you do for the main Frontend proxy.
The Glidein Frontend should be installed as a non privileged user. The provided installer will create the configuration file, although some manual tunning will probably be needed.
Before starting the installation of the Glidein Frontend make sure that the WMS Collector is started and running. The user collector and schedds should also be running.
And execute the following. The installation of the Frontend should be done as the Frontend user (see username below).
./manage-glideins --install vofrontend --ini glideinWMS.ini
|install_type||tarball or rpm||
If this is a VOFrontend RPM installation and you are doing a
'--configure', then rpm should be specified.
If this is a stand-alone VOFrontend install, only tarball installations are supported.
|Valid values: tarball, rpm.
|hostname||vofrontend.domain.name||hostname for VOFrontend.||.|
|username||vofrontend (non-root account)||UNIX user account that this services will run under. DO NOT use "root".||For security purposes, this value should always be a non-root user.|
|service_name||vo_frontend||Used as the 'nickname' for the GSI DN in the condor_mapfile.||This name MUST correspond to Frontend service name listed the Factory configuration for the Frontend to be able to talk to the Factory.|
|install_location||/path/to/vofrontend||HOME directory for the Frontend software.||
When the Frontend is created the following files/directories will
exist in this directory:
* frontend.sh - environment script
* frontend_[instance_name].cfg - directory containing the Frontend configuration file
* frontend_[instance_name] - directory containing the Frontend files
The install script will create this directory if it does exist.
|logs_dir||/path/to/vofrontend/logs||User settable location for all Frontend log files.||
Beneath this location there will be multiple sets of logs:
* for the Frontend as a whole
* for each group the Frontend utilizes
The install script will create this directory if it does exist.
|instance_name||v2_5||Used in naming files and directories.||.|
|condor_location||/path/to/condor-submit||Directory in which the condor software will be installed.||
Note: The Frontend never runs any HTCondor daemons.
It only uses the HTCondor client tools.
IMPORTANT: The Frontend can share the same instance of HTCondor as the User Collector and /or Submit. The condor_location must not be a subdirectory of the Frontend's install_location or logs_dir. They may share the same parent, however.
|condor_tarball||/path/to/condor/tarballs/condor-7.5.0-linux-x86-rhel3-dynamic.tar.gz||Location of the condor tarball.||The installation script will perform the installation of condor using this tarball. It must be a zipped tarball with a *.tg.tz name.|
|email@example.com||The email address to get HTCondor notifications in the event of a problem.||Used in the condor_config.local only.|
|x509_cert_dir||/path/to/certificates-location||The directory where the CA certificates are maintained.||The installer will validate for the precesence of *.0 and *.r0 files. If the CAs are installed from the VDT distribution, this will be the VDT_LOCATION/globus/TRUSTED_CA directory.|
|x509_proxy||/path-to-proxy/x509_proxyfile||The location of the proxy used to identify this service to the other GlideinWMS services.||This is the only GlideinWMS service that currently requires a proxy to communicate with the other GlideinWMS services. This is NOT the glidein pilot proxy. The x509_gsi_dn option that follows should be populated with the issuer of this proxy.|
|x509_gsi_dn||dn-issuer-of-x509_proxy-using-openssl||This is the identity used by this service to contact the other HTCondor based GlideinWMS services.||
This is the issuer of the proxy identified by the
x509_proxy option above.
openssl x509 -issuer -noout -in [x509_proxy]It is used to populate the condor_config file GSI_DAEMON_NAME and condor_mapfile entries of this and the other GlideinWMS services as needed.
|glidein_proxy_files||/path-to-proxy/proxyfile1||Identifies the proxy(s) to be used to submit the glidein pilot jobs.||
The Factory is expecting the VOFrontend to provide the glidein pilot
proxies, at least one proxy must be specified.|
When specifying multiple proxies, whitespace is the delimiter.
|glidein_proxy_dns||dn-issuer-of-glidein_proxy_files-using-openssl||Identifies the issuer(s) of each proxy specified in the glidein_proxy_files option.||
This is the issuer of the proxy.
openssl x509 -issuer -noout -in [glidein_proxy_files]Validation is performed based on the relative position of each entry in those options. This is used in the UserCollector condor_mapfile and condor_config.local so the glidein pilot can communicate with the UserCollector.
When mulitple proxies are specified, a semicolon is the delimiter.
|glexec_use||optional||Tells the Factory service if use of the glexec authorization process is to be considered in selecting entry points to submit glidein pilots for the Frontend user jobs..||Valid values:
* required - will only request glidein pilots to entry points that use glexec
* optional - will request glidein pilots regardless of glexec use
* never - will never request glidein pilots for entry points using glexec
|expose_grid_env||True||Tells the Factory service to export shell variables from the glidein pilots to the user jobs or not.||Valid values:
* True - jobs will export shell variables to the user job running.
* False - no shell variables will be exported.
|group_name||main||This defines a grouping for user jobs that you wish to monitor using a specified critera.||The criteria used is defined by the match_string and userjob_constraints options that follow.|
|userjob_constraints||,||This represents the criteria used for matching glideins to jobs.|| This is a HTCondor expression. A simple expression would be:
(JobUniverse==5)&&(GLIDEIN_Is_Monitor =!= TRUE)&&(JOB_Is_Monitor =!= TRUE)
|match_string||True||This is the selection and matching criteria used for the user jobs.||
This must be in python format so using the exact case (True and False must be capitalized) is critical. One example is:
glidein["attrs"]["GLIDEIN_Site"] in job["DESIRED_Sites"].split(",")To select all jobs, just use 'True'.
If you use other that 'True', the criteria will need to specified in your user's condor job statement.
|install_vdt_client||n||This should be set as n - so the installler will not attempt to install the OSG Client
You must pre-install OSG Client
|vdt_location||/path/to/glidein/vdt||The location of the OSG/VDT client software.||Leave this blank, since the install_vdt_client option should always be 'n'|
|glideinwms_location||/path/to/glideinWMS_code||Directory of the GlideinWMS software.||This software is used for both the installation and during the actual running of this glidein service.|
Specifies the location for the monitoring and staging data that must
be accessible by web services. The installer will create the
following directories in this location:
|Important: This should be created before installing this service as the service's username and the web server user are generally different. This script will not be able to create this directory with proper ownership.|
|web_url||http://%(hostname)s:port||Identifies the url used by the glidein pilots to download
necessary software and to record monitoring data.
In order to insure consistency, the installer will take the unix basename of the web_location and append it to the web_url value. So, for the value shown below in the web_location, the actual value used by the glidein pilots, will be web_url/factory/stage(monitor).
|Important: It may be a good idea to verify that the port specified is accessible from off-site as some sites restrict off-site access to some ports.|
For example configuration files, see here.
6.1. Starting the Glidein Frontend
Use the startup script:
cd <install dir>
The same script can be used to stop, reconfig and restart the Glidein Frontend.
Note: If you installed the Frontend via RPM some files or commands will differ. Please refer to the OSG RMP Guide.
6.2. Reconfiguring the Glidein Frontend
The files in the Frontend working directory must never be changed by hand after the directory structure has been created.
The proper procedure to update the Frontend configuration is to make a copy of the official configuration file (i.e. frontend.xml) as a backup. Then edit the config file and run
<Frontend working directory>/frontend_startup reconfig config_copy_fname
This will update the directory tree and restart the Frontend and group dameons. (If the Frontend wasn't running at the time of reconfig it will only update the directory tree.)
Please notice that if you make any errors in the new configuration file, the reconfig script will throw an error and do nothing. If you executed the reconfig command while the Frontend was running, it will revert to the last config file and restart with those settings. As long as you use this tool, you should never corrupt the installation tree.
The frontend_startup script contains a default location for the Frontend configuration and is set to the location used for the initial install. This allows you to not have to specify the config location when doing a reconfig. To change the default location in the file, run the command:
<Frontend working directory>/frontend_startup reconfig config_copy_fname update_default_cfg
NOTE: The reconfig tool does not kill the Frontend in case of errors. It is also recommended that you disable any groups that will not be used. Never remove them from the config file.
6.3 Downtime handling
The glidein Frontend supports the dynamic handling of downtimes.
You(Frontend admins) should add the following attribute for the Frontend tag in frontend.xml manually:
Downtimes are handled with
service gwms-frontend up|down|statusdown [-delay <delay>]
More advanced configuration can be done with the following script:
/usr/sbin/manageFrontendDowntimes.py -dir /var/lib/gwms-frontend/vofrontend -cmd [command] [options]
You must specify the command to run. The valid commands are:
- add - Add a scheduled downtime period
- down - Put the Frontend down now(+delay)
- up - Get the Frontend back up now(+delay)
- check - Report if the Frontend is in downtime now(+delay)
Additional options that can be given based on the command above are:
- -start [[[YYYY-]MM-]DD-]HH:MM[:SS] (start time for adding a downtime)
- -end [[[YYYY-]MM-]DD-]HH:MM[:SS] (end time for adding a downtime)
- -delay [HHh][MMm][SS[s]] (delay a downtime for down, up, and check cmds)
This script can allow you to have more control over managing downtimes.
Please note that the date format is currently very specific. You need to specify dates in the format "YYYY-MM-DD-HH:MM:SS", such as "2011-11-28:23:01:00."