[Top] | [Contents] | [Index] | [ ? ] |
STORE is a system for installing and maintaining third party software on UNIX computers. The setup of STORE makes it easier to maintain and keep updated the same versions of software on all architectures in a network consisting of UNIX machines of more that one type.
If you are just curious about what STORE is, as a user of a UNIX system or as a system manager considering using STORE on your system, then you should read 3. Introduction to STORE. You should also see 6.4 Handling documentation which tells you where information about software packages may be found.
If you are going to install STORE on your system you should read 5. Installing STORE, which attempts to give you a step by step instruction of how to install and configure STORE itself.
If you are installing third party software under STORE, Installing Software under STORE, gives you examples of installing common types of software packages from the internet.
This is edition 2.3 of the STORE documentation, covering perl-internal version 1.75.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
We want STORE to be used by people and to be of use for them. We want improvements and changes to be merged back into the main STORE distribution. The GNU General Public License seems to work well for the GNU suite of programs so we have deceided to release the STORE distribution under the terms of this license.
The STORE system free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version.
STORE is distributed in the hope that it will be useful, but without any warranty; without even the implied warranty of merchantability or fitness for a particular purpose. See the GNU General Public License for more details.
Copyright 1992, 1993, 1994 by Stig Sæther Bakken, Anders Christensen, Tor Egge, Arne Henrik Juul.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
STORE is a concept for handling third-party programs under Unix.
The goal of STORE is to give administrators and users a framework that:
To provide these features, STORE is a set of programs, supporting a central concept on how to organize software installation. The central concept is:
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
As described in the brief introduction, STORE is mostly a set of concepts and conventions on how to organize and install program packages. The visible parts of STORE itself consists of:
We will start by describing the directory tree structure.
3.1 The /store directory tree The STORE directory tree 3.2 The main utility programs. The set of utility programs
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The `/store' directory tree looks much like a typical `/local' or `/usr' directory tree on a UNIX system (i.e. there is a `/store/bin' directory, a `/store/lib' directory, and so on).
/store | +----+----+----+-- ... --+---------+-------------------+ | | | | | | bin lib man etc doc store | +-------+-------------+ man1 | | khym Adm +-----+-----+-----+-- ... --+ | | | | | fbm emacs gcc tex zoo |
No files reside in the immediate subdirectories of `/store'. Instead we find cryptic soft links, like (if we are on a Sun Sparc machine):
/store/bin/gcc -> /store/store/khym/gcc/ver-2.3.3/bin/gcc@sun4os4 |
Alternatively, if we are on a DecStation running Ultrix 4.x (1):
/store/bin/gcc -> /store/store/khym/gcc/ver-2.3.3/bin/gcc@dsult4 |
The observant reader may have noticed the system in the files pointed to by the two softlinks, and (correctly) concluded that the directory tree under `/store/store/khym/gcc' may contain some interesting material. So let us take a look at this directory tree:
/store | store/ | ...--+----------+---------+---------+---... | | | | lise1/ khym/ ild/ storlind/ | gcc/ | +------------+---------+-+-----------+-------------------+ | | | | | registration ver-2.3.3/ src-2.3.3/ src-2.3.3-sun4os4/ src-2.3.3-dsult4/ | | +--------+---+------------+ | | | bin/ lib/ emacs/ | | gcc@sun4os4 info/ gcc@dsult4 | gcc.info ... |
What this directory shows us is that no actual files "live" in the `/store' sub-directories. Instead we have soft links pointing to files collected in applications. The name of the `/store' tree used in the STORE documentation is linktree or server linktree, and conceptually, the macro view. The directory tree where the files actually reside is called a package's version tree or the micro view.
The scheme gives us some advantages: First, we don't get any leftover files on deinstallation(2), always a problem when upgrading packages.
Another advantage is that we can have several versions of a package compiled at any given time and install/deinstall different versions with a few simple commands. We can also have softlinks pointing to packages on remote systems, saving space on our local system (but decreasing performance and reliability). By looking at the softlinks, it is immediately apparent to an experienced STORE user what application files belongs to, what version of the application, and where to go to find all the files belonging to the application. Even better, this procudure may be automated, so less sophisticated users may find their way around. (NOTE: I have planned to write this automated script, but I haven't gotten around to it yet).
An application (or package) is a directory containing:
patch
program), and softlinks pointing
to files in the original source tree. This allows us to record and
extract changes necessary to make a program (or set of programs) run on
a particular platform. It also allows us to keep compilation-ready
source trees for a particular package in a space-efficient manner.
In the level above khym
in the figure, the other STORE file
servers are mounted on the machine khym
(with khym
appearing on the same level in their STORE directory trees).
STORE also supports shadowing of applications. If we take a look at a typical application (in this case gcc, the GNU C compiler):
/store | store/ | ...--+----------+---------+-+--------------------------+---... | | | | lise1/ khym/ ild/ storlind/ | | gcc/ .gcc/ | | +----------+-+------------+-... +------+-----+ | | | | | registration ver-2.3.3/ src-2.3.3/ registration ver-2.3.3/ | | | | +--------+-... +--------+-... | | bin/ bin/ | | gcc@sun4os4 gcc@sun4os4 gcc@sun3os4 gcc@sun3os4 gcc@dsult4 ... ... |
The file server khym
holds the master installation of the
application gcc. Any changes to the current version, or installation of
new versions of the package should take place here.
The file server storlind
holds a slave of the gcc package.
The slave copy consists of the `registration' file and a copy of
the `ver-<version>' directory tree holding the installed files of
the package.
Because khym
holds the master installation it needs to hold files
for all architectures using this particular system. In this example,
storlind
is a file server for a site using Sun 4 and Sun 3
machines, which means that only files for these arhictectures, as well
as those common for all architectures (e.g. emacs info files) are copied
over.
The updating of slave installation of packages is done nightly. The reason for using slave packages is to reduce cross-system NFS access (a STORE system may use a wide area network).
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The main utility programs are those that do batch processing or the STORE trees, checking consistency, propagating changes, and updating linktrees. The basic functionality of these has been unchanged since the first versions. See section 8. Understanding STORE output.
3.2.1 cmaster utility The cmaster utility 3.2.2 cslave utility The cslave utility 3.2.3 cclient utility The cclient utility 3.2.4 report utility The report utility 3.2.5 status utility (planned) The status utility (planned) 3.2.6 autocomp utility The autocomp utility
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
cmaster runs on each machine having a repository. It checks all the locally defined repositories and finds master applications. It reads their registration files, checks the application for consistency (potentially producing warnings that need to be dealt with), and writes back the registration file. Any output from cmaster probably indicates a real problem with the application.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
cslave finds all slave applications on the local STORE server, and fetches changes or new versions from the master servers. Since the master copies of applications will change with time (if the master copy is properly maintained and bugs are fixed!), some output is inevitable. Also, spurious errors may indicate NFS problems or incorrect mounting of filesystems. It is hard at first to recognize which warnings from cslave need manual intervention, but running it manually a couple of times should give some clues. Since it fixes most of the transient problems on the first run, any warnings or errors on the second run may indicate a "permanent" problem, especially if you also make sure that all the repositories involved have been checked with cmaster first.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
cclient first processes the linktree to find links that are obviously wrong (like pointing at nonexistant files), or extra non-symlinks. Then, it finds all available applications for the linktree and makes the right symlinks in the linktree, optionally running any "nightly commands" defined by the applications.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The report utility finds all applications and makes a nice report on them, including a graphic presentation of architectures supported and special files. Most of the information reported is extracted from the registration file directly.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The status utility is even more administrator-oriented than the report utility. It will show the amount of disk space occupied by different applications, what types of documentation is available, what source code and build trees are left around, etc. It is intended to help prevent "bit rot" in the STORE system.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Autocomp is a tool designed to make things easier for people updating applications. It will compile and install applications for different architectures automatically(and simultaneously). Of course, if compiling or installing errors occur, autocomp will fail. (A mail will be sent to notify the one who started it.) Autocomp tries to pick the least loaded host for compilation, and makes sure only one autocomp process is installing in a linktree at a time. It depends on rsh/rcp access from the host autocomp is started to all the hosts that will be used for the actual compilation.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
When discussing STORE, there are many new terms and concepts. We have tried to define the most important concepts here.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A repository is a directory containing application packages
suitable for STORE. It must be available as /store/store/<name>
.
You may have several repositories on a single repository server. The naming
conventions we use is that repositories are named after the machines.
In the config files, the programs and earlier versions of this documentation the term that was and is used is just "store". This may lead to unfortunate confusion between the term when used for the STORE system itself, or when used for the repository concept.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The linktree, also called /store
, also called the macro view,
is what the users see available under the /store
directory,
not including anything under /store/store
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A STORE server is any machine having a repository or a linktree. In most cases, you would have just one repository and one linktree. If you get short on disk space, and add another disk, using it as an extra repository mostly for compiling is easy. You would only want extra linktrees in a heterogenous environment.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
An application, or package, or software, or a program, is
whatever is packaged under a /store/store/<master>/<app>
directory. It is wise to keep a single program released as one
package as a STORE application. It is generally a very bad
idea to have several masters for the same application.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
You may have several versions of an application in the master repository, with different maturity levels. Different version can have different architecture support, so you can compile new versions for just some architectures at first. All slave copies will mimic the master, copying any old or new versions, and deleting versions when they are deleted on the master. Link trees will choose the best version according to their level profile and what support the differing versions have. Keeping old versions around may also provide backup, or be useful references when compiling new versions.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A master repository is a repository containing some masters for applications. In principle, any repository will be checked for masters, but in practice, it is wise to limit the number of master repositories. Master repositories should be on trusted, stable machines, and mounted on most other repository servers to ensure correct copying to slaves.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A slave repository is a repository with no master versions, only slave
copies of applications. You would probably have several slave
repositories for each master repository, but as always, this depends on
available disk space. Slave copies only hold the version trees
for an application, not source code or build trees, and you may
limit the amount of files copied by limiting the number of
architectures. You only need to make the slave directory
/store/store/<slave>/.<app>
to make the next nightly run
slave down the application, but you may prefer to use
slaveapp
and linkup
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A compile server is a machine used for compiling applications in STORE for some architecture. It would probably have a local master or slave repository, but it only needs read-write access to a repository to use for compile trees, and read access to the master servers for the applications it should compile.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A new concept recently introduced in STORE that wasn't originally in the design is the compile tree. This is a bit of a kludge, with some hackery in the tools to support it. But it's very useful.
A master server for an application holds the master registration file, the source code, additional files (doit scripts etc), and probably some shadow trees created with shadow. In the original design, the master should hold shadow trees for all architectures the compilation was compiled for, e.g. sun3, sun4os4, and sgi. The compile server would just mount the repository containing the application read-write, and compile there.
In practice, this isn't feasible. The master server would need to export its repository read-write to a large (and variable) group of compile servers, and compiling on a disk mounted remotely may be nearly impossible. Instead, the compile server creates a pseudo-application for the exact purpose of compiling. If the master is `mast', the compile server `compi', and the application is `someapp' version `1.23', the compile tree would be the pseudo-application `/store/store/compi/someapp-c'.
The -c
suffix denotes that this is indeed a compile tree.
The shadow utility recognizes this, and looks around in
`/store/store/*/someapp' for original source code (in this
case, `/store/store/mast/someapp/src-1.23'). The shadow
utility makes a shadow tree on the compile server, with links to
the NFS-mounted original source. After compilation and successful
installation into `/store/store/compi/someapp-c/ver-1.23',
the files which differ between the compile server and the master
server's version trees should be exactly the
architecture-dependant files. These can be tar
'ed together
and transferred to the master server to complete the installation
for this specific architecture. (Postinst will try to do this
tar
automatically).
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
In STORE, an architecture is a description of a set of computers. It may range from any machine to one very specific machine. The name "architecture" should indicate the common meaning, but the concept is deeper than this. For example, "sparc" and "sgi" is two different architectures, but "sparc" may be further subdivided into "sun4os4" or even into "sun4mos413p", indicating a SparcStation 10 series running SunOS 4.1.3 with patches.
For files, architectures are denoted by suffixes using an @ as a special separator. Mostly, we are only interested in binary files having support for a special hardware/software platform. However, it is sometimes necessary to have configuration files that depend on other attributes of machines, for example mail programs that need to know the local address. The architecture concept, therefore, has been expanded to include other attribute-value pairs. The currently defined attributes are:
arch:<value>
or only <value>
domain:<value>
or d:<value>
So a file for SparcStations running SunOS 4 could be `file@sun4os4', while a file for machines at the mathematics department could be `file@domain:imf.unit.no'. In the pathological case of a file with compiled-in configuration, one would need `file@arch:sun4os4,domain:imf.unit.no'. This general syntax would also permit additional attributes to be defined, but then some of the internals of the STORE scripts would have to be changed, too.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The home area for the "store" user contains configuration files for STORE, logs, reports, and may also have special programs to avoid peculiar troubles on special systems.
It is probably a good idea to share the administrative area between all machines running STORE in an administrative domain. This may be done by making `/store/store/Adm' a symlink to `/store/store/<primary>/Adm', where `<primary>' is the main repository server in the administrative domain. The problem is, of course, that if the primary server is down, the directory is unavailable, and you cannot run the STORE scripts, not even manually. However, it makes for much easier administration, as you otherwise would have to keep configuration files up-to-date on several servers.
Dot files: As all users, the "store" user should have a good setup for the shell in use, such as .cshrc/.login or .bashrc/.bash_profile files which are distributed in the inistore package. The most important thing about these files is setting the PATH variable properly. This must be done individually on different systems, since machines, OSes and sites differ substantially in their proper setup. The distributed set will try to source files in a common area, as this is the most widespread method (and also one of the best) for the setup of the shell. In addition, the distributed files will source files provided as part of the STORE scripts, to make STORE support commands available. These are implemented as perl scripts, and directly available as aliases in the shell. (See `/store/etc/internal/aliases.{csh,bash}' for details).
Configuration files are contained in the `etc/' directory. The main configuration file is just the `config' file. See section 7.2 Configuration file.
The `initials' is part of the perl-internal
application, and is a site-wide file contains initials for the
persons installing and maintaining applications in STORE,
with mail address, organization, etc. The primary repository
maintainers should update this in the same way as the
`genarchs' file whenever new staff is hired. See section 7.3 The genarchs configuration file.
There are also descriptions of the different licensing terms that applies to the programs you put into STORE, and the classifications of programs that you use. These will also be maintained in the same way as the `initials' file.
The `logs/' directory contains logs from the nightly runs of the STORE programs, and may also be used for other jobs that are run via the nightly commands feature.
The `bin/' directory is used mainly for holding the nightly
script `night.sh' that runs the STORE updates. This
needs to be modified to be able to: Have a correct PATH
,
start the STORE updates (commonly via rsh
or
remsh
), and send mail about the result. If you need to
make script versions of common programs to avoid errors or
deficiencies in your operating system, this is also the place to
put such scripts, so they will be found by the STORE
programs.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
An administrative domain is a set of repository servers administrated together, with a single configuration file. They would probably be located nearby each other net-wise, so it is possible to use any repository from any linktree inside the administrative domain. One could define the administrative domain as the set of machines running the STORE scripts on the same nightly run.
The set of administrative domains NFS-mounting directories and
slaving applications from each other is a STORE
site. The site's primary repository is the master
for the perl-internal
application. You don't need to
mount every other repository directly - you can slave applications
indirectly.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The STORE nightly job is run on the primary server for an
administrative domain. It will start the cmaster and cslave
scripts on all repository servers in the domain, and the cclient
script on all machines hosting a link tree, by using the
`rsh' command. In addition, it will run the report script on
the primary server, to make a report on all available programs.
Any nightly jobs specified in the registration files will be run
(by cclient
) for each linktree, with the TOPDIR
environment variable set to the top of the linktree.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
To make the reports produced by STORE more readable, initials should be registered in the registration files. The standard report script will work well with two- to four-letter acronyms, while longer names will be truncated to four letters.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This chapter has instructions on how to set up a STORE system. It mostly assumes you are setting up a brand new STORE system on a site where STORE hasn't been used before, but is also useful if you're setting up a new STORE administrative domain, and are going to cooperate with other administrators in your organization. In this case, you should probably get some of the other administrators to help you out. In particular, if you're installing STORE somewhere at the University of Trondheim, please contact us first!
5.1 Requirements for installing STORE 5.2 Description of preliminary actions 5.3 The 'inistore' setup script 5.4 Completing the setup
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Short checklist of preliminaries:
If you are in doubt on these, read the next section carefully!
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This is a quite long description of the preliminary actions to take before you can really start installing STORE, explaining in detail the 'Needed Items' list of requirements .
The STORE program system has some special requirements that must be dealt with before installing the STORE system itself. The most troublesome requirement is that STORE really needs a decent bit of disk space. If you are installing STORE on a large installation with lots of old applications, you will probably want to keep the old applications running while you install STORE and alternative versions of your applications there. If you don't already have some space free, the advised course is buying a disk before installing STORE. A 300MB partition is good for trying out STORE, while a full installation with some architectures would call for at least 1GB on the main server.
After getting some disk space, you need to make it available under `/store' on all the machines that should run STORE. First, let's look at a standalone system. In this case, make a big partition and mount it as `/store'. (Or alternately, make a symlink from `/store' to another partition - say `/usr/local/store' - that has some free space).
You also need to decide which user should own `/store' and run the STORE scripts. The recommended way is to make a specific "store" user and a "store" group. Currently at the University of Trondheim, this user is uid 52 and the group gid 52, and the "store" user should run "bash" or "tcsh" as shell. Using csh or ksh as equivalents for these should also work, and if you're starting a new, separate STORE installation, you can choose other id's if necessary.
The home directory for the "store" user should be taken to be the location of the administrative area for STORE, the `/store/store/Adm' directory. See section 4.11 The administrative area.
At this point, you are ready for running the initial STORE setup script (as the "store" user).
Extra requirements when setting up a differing cases of repository servers: In the common case, you need to export the `/store' directory and possibly any `/store/store/<server>' directories. STORE is written to permit readonly mounting everywhere, since exporting readonly to the world is both simple and secure.
The clients need to mount the server's `/store' on `/store'. If you have a heterogenous setup, for example you have Sun clients running from an SGI server (or conversely), you need an extra linktree for the clients. See section 7.2.6 A configuration file with foreign linktrees. You should also propagate the "store" user to the clients.
With all the different setups for mounting and exporting disks, and distribution password information, it is impossible to specify exactly what actions you need to take to export the filesystems from the server, mount them on the clients, and make a common "store" user. If you don't know how to do this on your machines already, you probably need to find out anyway, or hire someone who knows how. Giving specific examples here would be of doubtable use, seeing as there are different export file formats (and names), fstab formats (and names), two different automounters with differing setups, and a couple of NIS/YP versions here already.
(NOTE: I will try to include some amd
examples, at least. -arnej)
In addition to all of this, you need the perl scripting language. Decent vendors actually ship perl as part of the operating system these days, and most sites quickly install it otherwise. If you haven't got it already, you need to compile and install it yourself, or get a binary version from somewhere. Perl is also needed for running many other system administration tools, so the sooner you get it, the better!
If you find you need perl, we have a package with perl for
various platforms available from ftp.unit.no
in
`/local/store/perl-4.036.tar.Z'. This is also a good
example of a STORE application.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The STORE setup script is named 'inistore' and is available
together with the STORE scripts themselves from
ftp.ntnu.no
in `/local/store/inistore-1.80.tar.Z'.
This script will do some sanity checks, and ask you one (possibly two) questions: Are you installing a new primary repository, and if not, what is the nearby primary repository named. See section 4.12 Cooperating administrative domains.
First, the inistore setup script will check that it's running as the "repository" user, using the 'id' command. If this command is missing, or the output is not recognized as correct, the script will give a warning, and ask if you want to continue.
Then, the script checks that the `/store' directory exists and is owned by the user. If this fails, the script will abort with a fatal error.
The script needs either uname -n
or hostname
to
work, and will use the short form of the hostname as the name for
the repository. If only uname
is found, the script will create
a hostname
script in the administrative area.
If you already have the `/store/store/<host>/Adm/' directory, the script will ask you if you want it removed and reinstalled.
The administrative area with initial files is unpacked into
/store/store/<host>/Adm
for sharing in your admistrative domain. Additionally,
/store/store/Adm
is made a symlink to
/store/store/<primary>/Adm
.
The script will copy the perl scripts used by STORE into
/store/store/<primary>/perl-internal
and set this up as a
STORE application. The `/store/etc/internal' directory
will be made, with softlinks pointing to the perl-internal
application. You should not need to change the scripts in the
perl-internal application. (The internal nature of the scripts
are still changing fast, and isn't documented at all, so you
would need to know a lot about both STORE and perl to do real
modifications). However, on the primary repository you need to
maintain the files under `perl-internal/src/cf'
(See section 7.3 The genarchs configuration file).
The script will try to determine a list of directories to use as a PATH when running scripts. It will try some well-known directories, and will also try using the common files given at the previous questions if possible. This is used in an initial version of the 'nightly' shell script in the bin directory.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
After running the setup script, you still do not have a complete setup. These are the things you may want to do:
5.4.1 Fixing the nightly script 5.4.2 Changes to user setup to accomodate STORE.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
One of the most important things if you want a stable STORE system is to ensure that the nightly script (named `night.sh' or `nightly') runs regularly, and that the output is taken into consideration by the person(s) maintaining your STORE.
The nightly script should run the `batch' update scripts cmaster.pl, cslave.pl, cclient.pl on all machines in your administrative domain, and report.pl and status.pl once for the whole administrative domain.
If your machine is running standalone (your administrative domain is
just this machine), the scripts can be started directly. In all other
cases, some sort of remote job must be started. The normal case is to
run the scripts via the rsh
or remsh
commands. This may
provoke a need for `.rhosts' files in the STORE administrative
area, and may also need other customization.
Also, the nightly script needs to have a sensible default PATH variable. The setup script will guess a value, but you probably want to change it.
Lastly, the nightly script needs to send its results via mail to the STORE maintainers. This must be customized manually - both the list of recipients and the way to invoke the mail program probably needs changing.
One problem with the current nightly script is that installation of new versions of programs produces many warnings about links being changed and files being copied. The simplest way of dealing with this is just by running the nightly script twice and only collecting warnings on the second go, thus getting just the persistent output -- presumably errors that need manual fixing. This may be done by running "nomail.sh" first, then "night.sh" afterwards. "nomail.sh" is exactly like "night.sh", but all output comes directly on stdout. Note that if you run it from cron, the output is not saved.
For further help, there are some examples (See section 7.4 night.sh script examples).
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The standard user login should be changed to make users find the software installed under STORE. In addition, certain environment variables may need to be set to make programs work correctly when installed in STORE.
Changing the PATH to include `/store/bin' and `/store/gnu/bin' in appropriate places should be self-evident. However, you will probably also need to change the `XFILESEARCHPATH' environment variable, since you now have some application-default files in STORE, and some in your 'normal' old location. (Here, we have app-defaults directories under `/usr/lib/X11', `/store/lib/X11', `/local/lib/X11', and `/local/X11/lib/X11' !)
Some other environment variables that may need proper setting are `INFOPATH', `MANPATH', `EMACSLOADPATH', `PAGER' and `LD_LIBRARY_PATH'.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Ordinary users of the computer systems running STORE should not notice STORE at all in any way, other than new versions of popular program packages becoming available to everybody.
The main "users" of STORE are the people who install and maintain applications. They need to learn handling the peculiarities of installing programs in STORE. The overview of STORE provides an understanding of the goals of the installation, while this part of the documentation is concerned with the details of how to do it.
When you learn to use the tools provided with STORE, installation in STORE may actually become easier than "normal" installation.
The most useful sections may be the examples, especially if you have little experience with STORE. Looking at the examples (See section 6.5 Example installation: Gopher), you should be able to install most programs.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
You need to compile the application so it will search under
`/store' for all its data files. Most programs using GNU configure,
for example, can be configured correctly, by simply using
configure --prefix=/store
. Alternatively, you may need to modify
the Makefile, or a configuration file.
The program should ideally be as self-contained as possible, and should not refer to any nonstandard files outside of STORE. In some cases, programs may be set up to look for configuration files under `/etc' or `/local' as well as under `/store', but this should be noted in the registration file. If the program needs to have another STORE application in order to work at all, this should be noted in the 'dependant on' field in the registration file -- then the STORE scripts will check that this other application is available before slaving or linking up the application (NOTE: this is not implemented yet!)
A binary program would be available as /store/bin/<program>
, but
the goal is then to install it on the master repository as
/store/store/<master>/<app>/ver-<ver>/bin/<program>@<arch> |
/store/lib
or /store/lib/<app>
directory, and you need to consider whether the data files are
architecture-dependant or not.
Manual pages goes into, for example,
/store/man/man1/<program>.1
.
See section 6.4 Handling documentation.
Of course, all these are only our local convention, and it is possible to modify them to suit other environments. However, they seem to work pretty well here.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
These are the steps to follow when installing an application:
src-<version>
directory under
the application's directory.
src-<version>-<architecture>
tree.
Read any installation instructions for the application.
ver-<version>
tree, or
ver-<version>
tree.
ver-<version>
directory. Check that all
files have a correct architecture prefix.
chkapp -a <app>
.
Furthermore, you should follow these steps when compiling for additional architectures:
/store/store/<compi>/<application>-c
.
src-<version>-<arch>
directory.
ver-<version>
subtree in the
compilation tree, possibly by make install
and
postinst
.
register
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
When using STORE, we have found that a need for some tools for effective installation of application. It is also possible to make more such tools.
All these tools are currently implemented as aliases or functions
in the shell, mostly just starting a perl script. They could also
be implemented as shell scripts installed in the administrative
area, in the bin/
directory, if you use a shell without
aliases or equivalent functionality. For example, the "shadow"
command is just an alias for "perl /store/etc/internal/shadow.pl".
These are the tools currently available:
Common for most of these tools are that they ask cryptic questions with
(normally correct) default values, like for example shadow
:
Which compile repository? [khym] ? Which application? [gopher] ? What version? [1.03] ? what architechture [sun4os4] ? |
The default values are based on the current directory and what repository server you are currently logged onto. If you run the commands from the "correct" place the defaults are correct. You can also give the answers as parameters to the program; the example above is equivalent to:
shadow -s khym -a gopher -v 1.03 -A sun4os4 |
A short overview of the current behaviour of the different programs are:
6.3.1 "shadow" shadow source code 6.3.2 "unshadow" and "fix" unshadow and fix files 6.3.3 "postinst" post-installation tool 6.3.4 "register" registration file handling 6.3.5 "slaveapp" slave application 6.3.6 "linkup" make links to application 6.3.7 "linkdown" delete links to applications
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
/store/store/<master>/<application>/src-<version>
. For compile
trees, you also need to have created the directory
/store/store/<compilerepository>/<application>-c
.
Asks for:
src-<version
directory),
shadow
tries to locate a master repository with source code, and
asks you to confirm that it guessed right. If it can't find anything,
you may need to NFS-mount the repository.
In addition to creating the source shadow tree, shadow
protects the original source code. This is so diffs can be
made more easily (if needed, automatically).
Sometimes you want to make a set of patches to be used for all
compilations regardless of architectures. In this case, run
shadow
with an architecture of "local", and make your
modification in the src-<local>
shadow tree. On later runs,
shadow
will make links to this new tree instead of the
real original, so you get a two-tier system of links.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
unshadow
replaces a softlink with a copy of the file it points
to, and ensures that the file copy is writable by the owner (repository).
It is just a small shell function, and takes the name of the
link as parameter.
fix
is exactly like unshadow
, but in addition invokes
the "vi" editor on the file, for small modifications.
Note that "unshadow" is not the inverse of "shadow".
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
postinst
is quite a 'dirty' tool. It assumes that you are
installing a complex application, and do not want to unneccessarily
modify the Makefiles etc. In this case, it is convenient to do 'make
install' into the `/store' directory directly. Normally, this would
be dead wrong, and the next run of the nightly job with cclient
would notice all the extra files and delete them.
postinst
is used right after installing directly into `/store', and
searches the `/store' linktree for extra files, assumes they really
belonged to the application you are installing, and moves them into the
version tree.
To alleviate some of the worst problems with postinst, it has a built-in
time limit: It assumes that files older than 10 minutes doesn't belong
with this installation, and leaves them alone. To modify this time
limit, use the -t minutes
option.
In addition, if the application only installs files into a specific
directory, you may optimize postinst
by using the -p
prefix
option. For example, use -p /store/gnu
when installing
GNU programs configured with configure --prefix=/store/gnu
.
Postinst asks the following extra questions:
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
perl
regular expression identifying files in the link
tree that are not softlinks to files in the version tree. This
can be temporary files or automatically generated configuration files (e.g.
generated by the Nightly command). Should normally be left
empty.
You may also edit the registration file manually, if you are just updating some fields. Note that if the registration file syntax is wrong, important information may be lost. See section 7.1 Example registration file.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
cslave
. It asks for slave repository, application, and
master repository. These may also be specified using the -s
,
-a
and -m
options.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
cclient
. The program reads the `registration' file to get
most of its information, like what version to link up. It asks for three
things:
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
To make it easy for users to find documentation, as much as possible
should be installed under the /store/doc/<app>
directory. This
means user guides, reference cards, background information etc.
If possible, such documentation should be available as ascii text, dvi files, and postscript files.
Most programs will have at least some manual pages, to be made available
under the /store/man
directory. The directories are divided
as follows:
Note that this follows the traditional BSD layout. In most cases,
installing the nroff
source files will be sufficient. In some
cases, it may be desirable to process the manual pages into postscript
and put them with other documentation under /store/doc/<app>
as
above.
Most applications from FSF (the Free Software Foundation), like gcc and bison, come with their documentation in the TeXinfo format. The TeXinfo format can be used to create printable documentation (using Don Knuth's TeX typesetting program) and to create info files. Info files are hypertext documents that can be read by Emacs, and by standalone info readers like info, xinfo, and ivinfo.
To process a texinfo file, use the makeinfo
and texi2dvi
programs (these are in the texinfo application). In addition, you need
to create a one line description to be merged into the top level menu
(`/store/emacs/info/dir'). The STORE convention for this is to
put the description into a file named `programname.dir.type'
where `type' is one of the following:
calc
gcc
, gdb
and so on
tar
The division into types is controlled by the file `/store/emacs/info/dir.pre'. To get a correct syntax for the short-description file, just copy one of the preexisting files -- it will be merged into an emacs-info menu.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Gopher is a protocol for simple exhange of information. The Gopher package contains several programs (e.g. a server program and a client program). As an example of installation of an ordinary (text oriented) UNIX program we install the Gopher client(3).
We start by installing the source code on the file server khym
.:
khym:/store/store/khym$ mkdir gopher khym:/store/store/khym$ cd gopher khym:/store/store/khym/gopher$ ftp ftp.ntnu.no |
Fetch the source code, then check that it is OK to unpack here:
khym:/store/store/khym/gopher$ zcat gopher1.03.tar.Z | tar tvf - rwxr-xr-x1147/10 0 Aug 31 23:47 1992 gopher1.03/ rw-r--r--1147/10 1876 Jun 25 02:14 1992 gopher1.03/README rwxr-xr-x1147/10 0 Sep 2 23:07 1992 gopher1.03/gopherd/ ... |
This looks good, so we do an actual unpack:
khym:/store/store/khym/gopher$ zcat gopher1.03.tar.Z | tar xvf - ... (lots of output) |
Change the name of the top level directory:
khym:/store/store/khym/gopher$ mv gopher1.03 src-1.03 |
Trash the tar-file, which we don't need any longer:
khym:/store/store/khym/gopher$ rm gopher1.03.tar.Z |
Then we create the build tree for Sun Sparc machines on the file server
khym
. The tool shadow
should be smart enough that we can
accept the default values it presents:
khym:/store/store/khym/gopher$ shadow Which machine? [khym] ? Which application? [gopher] ? What version? [1.03] ? What architechture(s) [sparc] ? Protecting original source in src-1.03 Shadowing from ../src-1.03 to src-1.03-sparc /store/store/khym/gopher/src-1.03/gopherd: /store/store/khym/gopher/src-1.03/gopher: [...] /store/store/khym/gopher/src-1.03/examples/Sample Directory: /store/store/khym/gopher/src-1.03/examples/Sample Directory/.cap: /store/store/khym/gopher/src-1.03/examples/Sample Directory/wais-index: Making version tree ver-1.03 |
Then we come to the tricky part of the installation: You have to read the `README' and the `INSTALL' files of the source code and configure the application approprately. It is difficult to give any general guidelines here, since almost every program has its own unique configuration scheme.
In this example we have to edit `Makefile.config' (the simplest way to do it is by issuing the command `fix Makefile.config') and then issue the command `make client'. In `Makefile.config' we had to change the directories `/store/bin' and `/store/lib' instead of `/usr/local/bin' and `/usr/local/lib'. In addition we will have to add the location of the local gopher-server.
On Sun machines we need to make sure that all networking applications
are loaded with the argument -lresolv
. This ensures that the
applications use DNS to look up machines.
Following these modification the compilation should be straightforward. This brings us to the next stage in the "storification process": the Installation.
This program consists of so few files that it is simplest to do the
intallation by hand. The first thing we do is to issue a make -n
command(4):
khym:/store/store/khym/gopher/src-1.03-sparc/gopher$ make -n install install -c gopher /store/bin install -c gopher.hlp /store/lib |
This looks OK, so we do:
khym:/store/store/khym/gopher/src-1.03-sparc/gopher$ mkdir ../../ver-1.03/bin khym:/store/store/khym/gopher/src-1.03-sparc/gopher$ mkdir ../../ver-1.03/lib khym:/store/store/khym/gopher/src-1.03-sparc/gopher$ cp gopher ../../ver-1.03/bin/gopher@sparc khym:/store/store/khym/gopher/src-1.03-sparc/gopher$ cp gopher.hlp ../../ver-1.03/lib/gopher.hlp |
The manual page can be found in the `doc/' catalogue of the source code. We install that as well:
khym:/store/store/khym/gopher/src-1.03-sparc/doc$ mkdir ../../ver-1.03/man khym:/store/store/khym/gopher/src-1.03-sparc/doc$ mkdir ../../ver-1.03/man/man1 khym:/store/store/khym/gopher/src-1.03-sparc/doc$ cp gopher.1 ../../ver-1.03/man/man1/gopher.1 |
The Sun Sparc installation of the gopher program is complete. However, we wish to install this application for the SGI platform as well. Since most servers are exported read only to other machines we can't normally write to the `/store/store/khym/gopher' directory when compiling on another machine. Therefore, the STORE system supports shadow directories on other machines than the main installation server for a particular package:
flory:/store/store/flory (405)$ mkdir gopher-c flory:/store/store/flory (406)$ cd gopher-c flory:/store/store/flory/gopher-c (407)$ shadow Which machine? [flory] ? Which application? [gopher-c] ? What version? [1.03] ? Using server on khym, app name gopher What architechture(s) [sgi] ? Shadowing from /store/store/khym/gopher/src-1.03 to src-1.03-sgi /store/store/khym/gopher/src-1.03/gopherd: /store/store/khym/gopher/src-1.03/gopher: /store/store/khym/gopher/src-1.03/object: [...] /store/store/khym/gopher/src-1.03/examples/Sample Directory/.cap: /store/store/khym/gopher/src-1.03/examples/Sample Directory/wais-index: Making version tree ver-1.03 flory:/store/store/flory/gopher-c (408)$ cd src-1.03-sgi/ flory:/store/store/flory/gopher-c/src-1.03-sgi (409)$ fix Makefile.config |
From here on, the going is easy. We can start out with the changes we did to make the application compile on the Sun architecture, and, if necessary, add flags for the SGI platform. Then we compile the application.
After completing the compile,
log in on the machine khym
again and copy the gopher
application compiled for SGI:
khym:/store/store/khym/gopher/ver-1.03/bin$ cp /store/store/flory/gopher-c/src-1.03-sgi/gopher/gopher gopher@sgi |
The only thing left is updating the registration of the newly installed
package. Here, to illustrate, only thing actually entered by the user is
a lot of <return>
s to accept the default, and a log entry.
khym:/store/store/khym/gopher$ register What repository [khym] ? What application [gopher] ? (Info) (register) <gopher@khym> Updating registration. (Info) (register) <gopher@khym> Consistency check - be patient. Full name . ... ... [Gopher] ? Available versions are: 1.03 2.012 - choose primary: Primary Version ... [1.03] ? Program Type .. ... (? for list) [FO] ? License Type .. ... (? for list) [Fri] ? You need to decide what release levels the different versions are. The different versions support: 1.03 / dsult4/sgi/sun4os4 2.012 / sun4os4 Possible release levels include alpha, beta, gamma, stable, old, obsolete. 'prealpha' is always last chosen. Release level for version 1.03 [release] ? Release level for version 2.012 [alpha] ? OK, releaselevels are: 1.03/release 2.012/alpha Signature . ... ... [AHJ] ? Short Description . (max 30 chars) [Gopher information service] ? ==> <== Online Help ... ... [some, in /store/lib/gopher.hlp] ? Importance ... ... [3] ? Source ... ... ... [boombox.micro.umn.edu] ? Nightly Command ... [] ? Not Links . ... ... [] ? Dependencies .. ... [] ? Compile Info .. ... [] ? Current description is: : Used to access gopher information servers. May also be used as : an interface to X.500, archie, anon.ftp, etc. You need good local servers : with well-structured, up-to-date information to fully realize : gopher's potential. Do you want to edit the description [N]? Enter text to be appended (terminate with '.') Compiled 2.012 for sun4os4. Still the same type configuration. . |
We can wait until the nightly commands are run for the links to be
created, or if we are impatient to test the installation we can use
linkup
:
khym:/store/store/khym/gopher$ linkup Which linktree? [khym] ? Which server? [khym] ? Which application? [gopher] ? Missing link to ++/khym/gopher/ver-1.03/bin/gopher@sparc Missing link to ++/khym/gopher/ver-1.03/lib/gopher.hlp Missing link to ++/khym/gopher/ver-1.03/man/man1/gopher.1 done |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Xgopher is another gopher client. It is used as an example of how to
install a typical X11 application (using imake
for configuration.
We start by installing the source code (fetching, checking directories and finally unpacking the software):
khym:/store/store/khym$ mkdir xgopher khym:/store/store/khym$ cd xgopher khym:/store/store/khym/xgopher$ ftp ftp.ntnu.no ... khym:/store/store/khym/gopher$ zcat xgopher.1.2.tar.Z _ tar tvf - [...] khym:/store/store/khym/gopher$ zcat xgopher.1.2.tar.Z _ tar xvf - [...] khym:/store/store/khym/gopher$ mv xgopher.1.2 src-1.2 khym:/store/store/khym/gopher$ rm xgopher.1.2.tar.Z |
We then create the build tree:
khym:/store/store/khym/xgopher$ shadow Which machine? [khym] ? Which application? [xgopher] ? What version? [1.2] ? What architechture(s) [sparc] ? Protecting original source in src-1.2 Shadowing from ../src-1.2 to src-1.2-sparc ../src-1.2/bitmaps: Making version tree ver-1.2 |
We now have to do the necessary changes to make the application compile on a Sparc platform. It this case we see from the installation documentation that we need to do some changes in the `Imakefile' and the file `conf.h'.
We also need to change the applications defaults file and the help file to use Store. Many X applications have an `app-defaults' file so it is worth noting that this file must but put into the `/store/lib/X11/app-defaults' directory, so that the application will be able to find it. If you wish to change the default choices of colors, fonts and so on, you can do modifications to the effect in the installed application defaults file
/store/store/khym/xgopher/ver-1.2/lib/X11/app-defaults/Xgopher |
For the X libraries to be able to find it at this location (rather than in the default hardwired directory), we need to set the environment variable XFILESEARCHPATH correctly (this is done in the default X setup for the site). The location of the help-file is hardwired into the xgopher application, so this just needs to be set correctly in the `Imakefile'.
The changes in the `conf.h' file are mainly gopher setup information which we will not touch in this example.
After changing `Imakefile' and `conf.h' the commend sequence
xmkmf; make
will do most of the work.
In this example as well we will do most of the installation manually (from the directory `/store/store/khym/xgopher/src-1.2-sparc':
$ make -n install if [ -d /local/X11/bin ]; then set +x; else (set -x; /bin/sh /local/X11/bin/mkdirhier /local/X11/bin); fi install -c xgopher /local/X11/bin if [ -d /store/lib ]; then set +x; else (set -x; /bin/sh /local/X11/bin/mkdirhier /store/lib); fi install -c -m 0444 xgopher.help /store/lib if [ -d /store/lib/X11/app-defaults ]; then set +x; else (set -x; /bin/sh /local/X11/bin/mkdirhier /store/lib/X11/app-defaults); fi install -c -m 0444 Xgopher.ad /store/lib/X11/app-defaults/Xgopher if [ -d /store/lib/X11/app-defaults ]; then set +x; else (set -x; /bin/sh /local/X11/bin/mkdirhier /store/lib/X11/app-defaults); fi install -c -m 0444 Xgopher-color.ad /store/lib/X11/app-defaults/Xgopher-color echo "install in . done" $ make -n install.man make -n install.man if [ -d /local/X11/man/man1 ]; then set +x; else (set -x; /bin/sh /local/X11/bin/mkdirhier /local/X11/man/man1); fi install -c -m 0444 xgopher.man /local/X11/man/man1/xgopher.1 echo "install.man in . done" $ mkdir ../ver-1.2/bin $ mkdir ../ver-1.2/lib $ mkdir ../ver-1.2/lib/X11 $ mkdir ../ver-1.2/lib/X11/app-defaults $ mkdir ../ver-1.2/man $ mkdir ../ver-1.2/man/man1 $ cp xgopher ../ver-1.2/bin/xgopher@sparc $ cp Xgopher.ad ../ver-1.2/lib/X11/app-defaults/Xgopher $ cp xgopher.man ../ver-1.2/man/man1/xgopher.1 |
In the same way as for the text based gopher client example, xgopher can
be compiled for an SGI architecture on the file server flory
.
This examples shows the commands only (output removed in the interest of
brevity):
/store/store/flory$ mkdir xgopher-c /store/store/flory$ cd xgopher-c /store/store/flory/xgopher-c$ shadow /store/store/flory/xgopher-c$ cd src-1.2-sgi /store/store/flory/xgopher-c/src-1.2-sgi$ rm Imakefile conf.h /store/store/flory/xgopher-c/src-1.2-sgi$ cp /store/store/khym/xgopher/src-1.2-sparc/Imakefile . /store/store/flory/xgopher-c/src-1.2-sgi$ cp /store/store/khym/xgopher/src-1.2-sparc/conf.h . /store/store/flory/xgopher-c/src-1.2-sgi$ vi Imakefile /store/store/flory/xgopher-c/src-1.2-sgi$ xmkmf /store/store/flory/xgopher-c/src-1.2-sgi$ make |
We then skip back to khym
and do the installation of the
executable by hand (that is: copy the file
`/store/store/flory/xgopher-c/src-1.2-sgi/xgopher'
over to
`/store/store/khym/xgopher/ver-1.2/bin/xgopher@sgi'.
We then register xgopher:
What repository [khym] ? What application [xgopher] ? (Info) (register) <xgopher@khym> Updating registration. (Info) (register) <xgopher@khym> Consistency check - be patient. Full name . ... ... [X gopher grensesnitt] ? Available versions are: 1.2 1.3 1.3.1 - choose primary: Primary Version ... [1.3.1] ? Program Type .. ... (? for list) [FO] ? License Type .. ... (? for list) [Fri] ? You need to decide what release levels the different versions are. The different versions support: 1.2 / dsult4/sgi/sun3/sun4os4 1.3 / dsult4/m68k/m88k/sgi/sun4os4 1.3.1 / dsult4/hp700ux9/m68k/m88k/rs6aix32/sgi/sparc Possible release levels include alpha, beta, gamma, stable, old, obsolete. 'prealpha' is always last chosen. Release level for version 1.2 [obsolete] ? Release level for version 1.3 [old] ? Release level for version 1.3.1 [release] ? OK, releaselevels are: 1.2/obsolete 1.3/old 1.3.1/release Signature . ... ... [TIW] ? Short Description . (max 30 chars) [X-klient mot informasjonstj.] ? ==> <== Online Help ... ... [litt, trykk '?'] ? Importance ... ... [4] ? Source ... ... ... [ftp.cso.uiuc.edu:uiuc/src/xgopher.${version}.tar.Z] ? Nightly Command ... [] ? Not Links . ... ... [] ? Dependencies .. ... [] ? Compile Info .. ... [conf=info,inst=info,make=info] ? Current description is: : Nice-looking interface to the gopher services. Quite unusable. : Actually much better, almost usable, in version 1.2! : And even more elegant in 1.3 !! Do you want to edit the description [N]? Enter text to be appended (terminate with '.') . |
Note that in this example version 1.1 had already been installed. The description partially refers to the previous version.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Emacs is a large program with lots of possibilities. For Emacs to be able to use STORE, we have to make some changes to Emacs. Most of the changes are done when installing Emacs, seeing to that it is compiled with the correct load-path, options and X libraries. We must also make sure that the DOC-file is identical on all architecture (or that we use DOC-files with an unique suffix for each type of architecture.
You also need special conventions to handle the installation of emacs-lisp packages. Emacs should be compiled with the following load-path: `/store/elisp /store/emacs/elisp'. This enusres that we have at least two alternative directories in which to place emacs-lisp code. This gives us the possibility of overriding emacs-defaults by installing files with the same name in `/store/elisp'. Usually we are installing completely new packages. In which case we usually install them in `/store/emacs/lisp'.
For new packages to be accessible to Emacs, we need to insert code which will be run by Emacs on startup. There are two ways of handling this: the first one is to let users install code in their personal `~/.emacs' file. The second is to make code being included in the `/store/emacs/lisp/default.el' file.
For an application like e.g. auc-tex, which radically changes the the behaviour from the standard TeX-mode, it's probably best to let individual users install the start-up code themselves. How to do this is well documented in the auc-tex emacs info file. In this sample installation we only install the lisp files under `.../auc-tex/ver-6.1/emacs/lisp' and leave it up to the user whether or not to use them.
For other packages it may be more suitable to make the installation common to all users. Since each package needs to have a few lines inserted into `default.el', this file is generated automatically from the different emacs-lisp applications' pieces of code. The STORE convention is to make each application have a file `.../app/ver-ver/emacs/lisp/default.el-app'. These files are then concatednated to create the final `default.el' file.
An example: The application "term-lock" is very simple. It consists of a
simple emacs lisp file, which let you lock your emacs (on a terminal)
using a simple password. The file defines the function M-x
term-lock
. To make it publically available we create the file
`.../ver-90/emacs/lisp/default.el-term-lock' containing the line:
(autoload 'term-lock "term-lock" "Lock the terminal" t) |
A somewhat more advanced example is the USENET newsreader "GNUS". This newsreader has a lot of files we install in the `.../ver-3.13/emacs/lisp' directory. Also GNUS has a couple of functions we wish to publicise by inserting autoload lines as above. We create a `default.el-gnus' file with the following contents:
(autoload 'gnus "gnus" "" Read network news." t) (autoload 'gnus-post-news "gnuspost" "" Post a news article." t) (defvar gnus-use-generic-from t) (defvar gnus-nntp-server "news.ntnu.no") (defvar gnus-use-generic-path "imf.unit.no") (defvar gnus-your-domain "imf.unit.no") (defvar gnus-your-organization "Norwegian Institute of Technology") |
As you can see from the contents, having the same version of this file for all sites using the same STORE system will create undesirable effects. We threfore split the file on the basis of the link tree name, making it specific for each organization using ut. Strictly speaking this gives us an overhead since separate machines in the same orgranization may need separate files. This files will be residing in the same master directory and can thus be easiliy maintained.
The contents of the directory `/store/store/khym/gnus/ver-3.13/emacs/lisp' will look like this:
default.el-gnus@chanur gnus-user-sxa.el gnuspost.elc default.el-gnus@flory gnus-user-tale.el mhspool.el default.el-gnus@hitra gnus.el mhspool.elc default.el-gnus@hufsa gnus.elc nnspool.el default.el-gnus@ild gnusmail.el nnspool.elc default.el-gnus@kari gnusmail.elc nntp.el default.el-gnus@khym gnusmisc.el nntp.elc default.el-gnus@lise1 gnusmisc.elc tcp-not-needed.el default.el-gnus@tootikki gnuspost.el tcp-not-needed.elc |
Luckily GNUS use a simple ASCII file for the configuration. Applications with the domain name compiled into them are much more difficult to handle.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
In this case, the source code consists of just two files: The emacs lisp 'source code', and the texinfo documentation source code. A step-by-step installation goes like this:
* Ange-FTP (ange-ftp.info): Transparent FTP support for GNU Emacs |
Now, users will have to put the following line in their .emacs
files to use ange-ftp: (require 'ange-ftp)
- if ange-ftp is
always wanted for all users, this line may be put into a
file named default.el-ange-ftp in the ver-X.XX/emacs/lisp
directory.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
STORE really shines with a lot of small applications. These are really hopeless to keep track of with a usual installation, but easily installed and maintained with STORE. However, STORE can also manage more complicated programs, like gcc. This means the installer of the programs must be more experienced, but also that others can use a complex program without great pain in installing it.
As of the current version, gcc is quite easy to install on the 'supported' architectures: configure with the prefix you wish, in this case /store, and say 'make bootstrap ; make install'. This takes a lot of disk space but is otherwise mostly painless.
The problem with gcc in STORE stems from two facts:
Instead of marking all these files with their specific architectures, they are all put in an architecture-dependant directory. The current semantics of such a directory implies that these files are all optional, and that they all are implicitly tagged with the directory's tag. This simplifies the master version tree significantly, but means some extra pain in the installation process. The installation process may, however, be largely automated as long as everything works.
The binary files under the arch-dep directory need not have their own tags, but using postinst during installation, they usually will have their own tags.
The resulting layout of the version tree will then look like this:
ver-2.4.5 +-> bin +-> man +-> man1 +-> doc +-> gcc +-> emacs +-> info +-> lib +-> gcc-lib@alpha +-> alpha-dec-osf +-> 2.4.5 | +-> gcc-lib@dsosf1 +-> mips-dec-osf1 +-> 2.4.5 | +-> gcc-lib@dsult4 +-> mips-dec-ultrix +-> 2.4.5 | +-> gcc-lib@m88k +-> m88k-dolphin-svr3 +-> 2.4.5 | +-> gcc-lib@sgi3i4 +-> mips-sgi-irix4 +-> 2.4.5 | +-> gcc-lib@sun4os4 +-> sparc-sun-sunos41 +-> 2.4.5 | \-> gcc-lib@sun4os5 +-> gcc-lib +-> sparc-sun-solaris2 | \-> sparc-sun-solaris2 +-> 2.4.5 | +-> alpha-dec-osf@alpha +-> include +-> m88k-dolphin-svr3@m88k +-> include +-> mips-dec-osf1@dsosf1 +-> include +-> mips-dec-ultrix@dsult4 +-> include +-> mips-sgi-irix4@sgi3i4 +-> include +-> sparc-sun-solaris2@sun4os5 +-> include \-> sparc-sun-sunos41@sun4os4 +-> include |
The compilation sequence would look like this, showing '$' only as the prompt:
$ mkdir /store/store/khym/gcc $ cd !$ $ ftp prep.ai.mit.edu [... get gcc-2.4.5.tar.gz...] $ zcat gcc-2.4.5.tar.gz | tar xvf - $ rm gcc-2.4.5.tar.gz $ mv gcc-2.4.5 src-2.4.5 $ shadow -a gcc -m khym -s khym -A sun4os4 $ cd src-2.4.5-sun4os4 $ ./configure --prefix=/store sparc-sun-sunos41 $ make bootstrap $ make install $ cd ../ver-2.4.5 $ postinst -a gcc -s khym -A sun4os4 -v 2.4.5 $ postinst -t 300 -p /store/lib/gcc-lib $ rm bin/sparc-sun-sunos41-gcc@sun4os4 $ mv lib/gcc-lib lib/gcc-lib@sun4os4 $ strip lib/gcc-lib@sun4os4/sparc-sun-sunos41/$version/cc1* $ strip lib/gcc-lib@sun4os4/sparc-sun-sunos41/$version/cpp* $ mv sparc-sun-sunos41 sparc-sun-sunos41@sun4os4 |
The extra run of postinst is necessary because gcc possibly installs include files with old modification times. This procedure has been evolved through time, and will need changes as new versions of gcc becomes available. The overall concepts remain, however, the same as for simple applications.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This chapter has some example configuration files for repositories, and a detailed explanation of the features available.
7.1 Example registration file 7.2 Configuration file Examples and explanations 7.3 The genarchs configuration file The generic architectures file 7.4 night.sh script examples Nightly script file 7.5 Nightly Command examples More examples 7.6 List of core applications
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
To provide a full example of a complex registration file the GCC application was chosen. Note that there are many fields in addition to the one manually entered with the "register" utility - these are internal to STORE, and updated automatically.
Full name . ... ... : GNU C kompilator Primary Version ... : 2.5.8 Release Levels ... : 2.4.5/dated 2.5.8/release Program Type .. ... : PL - Programming languages License Type .. ... : GPL - General Public License Signature . ... ... : AHJ Short Description . : C, C++ and ObjC compiler Manual Pages .. ... : 3 files - 138 KB Other Documentation : 1 files - 1716 KB Emacs Info ... ... : 30 files - 1194 KB Online Help ... ... : none Examples .. ... ... : none Init Files ... ... : none Importance ... ... : 9 Source Code ... ... : 795-files 23580-kb Source ... ... ... : prep.ai.mit.edu Nightly Command ... : Not Links . ... ... : Master pathname ... : /store/store/ludvig/gcc Master repository .. ... : ludvig Path to slave . ... : ludvig Versions .. ... ... : 2.4.5 2.5.8 Locks . ... ... ... : Compile Info .. ... : Dependencies .. ... : Begin(Versionlines) : 2.4.5 / alpha/m88k/pmax/rs6aix32/sgi3i4/sparc : 2.5.8 / alpha/linux/m88k/pmax/rs6aix32/sgi3i4/sgi4i5/... End(Versionlines) Begin(MasterVlines) : 2.4.5 / alpha/m88k/pmax/rs6aix32/sgi3i4/sparc : 2.5.8 / alpha/linux/m88k/pmax/rs6aix32/sgi3i4/sgi4i5/... End(MasterVlines) Begin(Description) : The Free Software Foundation's GNU C compiler is regarded as the best : general C-compiler around. It produces code for many different : processors and all major Unix platforms. The C++ part is more buggy : and has many known problems. End(Description) Begin(Log) : getlogin=arnej, uid=store, Sun Nov 7 02:42:08 MET 1993 : Name mangling has changed again, so people using C++ libraries : compiled with 2.4 must use 2.4.5. End(Log) |
7.1.1 Manually entered information 7.1.2 Computed information
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
As seen in the examples for the register utility, these fields are entered by the installer:
noupdate
, which
means slave repositories should not update from the master automatically. Also
note that you cannot enter this field with register
, but must
manually edit the configuration file. This is a deliberate restriction.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Some of the computed information is only updated when you run
register
- the fields tallying different types of files:
Manual Pages,
Other Documentation,
Emacs Info,
Source Code,
Examples,
and Init Files.
The remaining fields are updated each time you run cmaster
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The main STORE configuration file is the administrative area's `etc/config' file. There will be one such configuration file for each administrative domain.
7.2.1 Quick guide to etc/config features 7.2.3 Full walkthrough of the etc/config syntax 7.2.2 Metrics Modifying preferences for slaving and symlinks 7.2.4 Simple config example Simple configuration example 7.2.5 Complex config example Complex configuration example 7.2.6 A configuration file with foreign linktrees Configuring for a foreign linktree
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Blank lines are ignored. Lines may be continued using backslash-newline. Keywords must be at start of lines.
Keywords:
host=<host>
(must match the value
of `uname -n`
) and archs=<arch list>
declaring
architectures to slave down.
host=<host> arch=<arch> domain=<domain>
attributes, where the architecture is the most specific
name of the host's architecture, and the domain is the
most-specific mail or organization domain the host belongs to.
Also common is the unwantedfile=<file>
to exclude applications
from consideration.
shadow
and postinst
. Like,
compile <arch> on=<host>
.
report
to
include in the report.out file.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
There are two types of metrics in the STORE system: From linktrees to repositories, and between different repositories.
Linktree to repository metrics Symlink preferences Store to store metrics Slaving preferences Metric syntax Exact syntax Default metrics The defaults Metric evaluation and priority How the metrics are evaluated
The linktree-to-store metrics control what repositories a particular linktree may get symlinks to and the preference between these repositories.
For example, if the linktree "flipper" has metrics to the following repositories:
- store "flipper"
- metric 1
- store "flipper-b"
- metric 2
- store "nova"
- metric 5
- store "ernie"
- metric 150
- all other repositories
- metric 10000
The limit where symlinks will be created is 100, so this means that the "flipper" linktree wil get symlinks to applications in repositories "flipper", "flipper-b" and "nova" in this prefered order, but never to any other repositories.
Manual linkup will not check metrics or the linkup metric limit (See section 6.3.6 "linkup").
The store-to-store metrics control from where a slave store will get its applications. At the present time there is a limit of 100000 for slaving, so one may be aware of remote repositories without actually copying from them.
For example, if the store "flipper" has metrics
This means that, for a slave application in store "flipper", it will first try to slave from the store "nova", then "ernie", then others. Slaving manually can override the metrics and the metric limit (See section 6.3.5 "slaveapp").
- store "nova"
- metric 5
- store "ernie"
- metric 150
- all other repositories
- metric 10000
metric <n> symlink <lkts> to-store <sts>
metric <n> slave <sts> from-store <sts>
where <lkts> is a list of linktrees or possibly the keyword "internal", meaning all linktrees specified in this configuration file, and <sts> is a list of repositories, or "internal", meaning the list of repositories defined as "internal" in the top of the config file, or "external", similarly meaning the list of repositories defined as "external" in the config file.
If you don't specify any metrics the following defaults apply:
Any linktree <l> will get metric 1 to a store <l> with the same name if such a store exists. Any linktree on host <h> will get metric 2 to any repositories that are also on host <h> except where the previous rule applies. All internal linktrees will get metric 5 to all internal repositories except where the previous two rules apply. All internal linktrees will get metric 10000 to all external repositories.
All internal repositories will get metric 5 to all other internal repositories. All internal repositories will get metric 10000 to all external repositories.
The default metrics are designed to fulfill the normal expectations. Unless you're really sure you want to modify them, you should leave the configuration file without any metric specification, so you'll get the defaults.
Metrics in the configuration file are evaluated in the order they appear. Earlier specifications in the configuration file will have priority; later specifications of the same metric will be silently ignored.
This means that the general forms with "internal" and "external" will not override any metric that has already been determined, but they will override any metric (even a completely specific one) appearing later in the file.
The defaults are applied after evaluating the entire configuration file, using the same rules. So they will not override any user-specified metrics.
This means that, for example, with this config-file extract:
metric 5 symlink flipper to-store flipper metric 7 symlink flipper to-store flipper-b metric 15 symlink nova to-store flipper metric 10 symlink internal from-store internal metric 20 slave internal from-store internal metric 30 slave internal from-store ernie vier ild metric 50 slave internal from-store external |
The only default metric with any effect applied after this is the one (in effect) specifying
metric 10000 symlink internal to-store external |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
If in doubt, consult the source (`/store/etc/internal/conffile.pl').
The configuration file is parsed line-by-line, with backslash-newline deleted first. Keywords are only recognized at start of lines, and anything else is ignored. There is no comment possibility. Attribute=value pairs are whitespace-separated, while lists are comma-separated.
The top
keyword and the logdir
attribute are part of a
scheme to allow a repository-like system using different names as a separate
universe, but using the same scripts. It is not documented at all, and
you should not use it. It is only mentioned here for completeness.
Host specifications (with on=<host>
, from=<host>
or host=<host>
)
should preferrably match exactly the value returned by the shell
command hostname
, and we recommend that you use the full
name. However, only the first component will
be compared, because we have found that various OS'es have real
problems getting this consistently right.
compile <arch> on=<host> [on=<host> ...] |
run <what> on=<host> pass=<number> [ from=<host> via=<method> ] |
internal <repositoryname> [<repositoryname> ...] |
external <repositoryname> [<repositoryname> ...] |
top <dir> <dir> |
report <arch> <archs> [ <arch> ... ] |
store <repositoryname> host=<host> archs=<arch list> \ [ dir=<dir> ] \ [ logdir=<dir> ] \ [ domains=<domain list> ] \ [ levels=<level list> ] \ [ autoadd=<repository list> ] \ [ unwantedfile=<file> ] |
linktree <linktreename> host=<host> arch=<arch> domain=<domain> \ [ level=<level> ] \ [ dir=<dir> ] \ [ logdir=<dir> ] \ [ unwantedfile=<file> ] |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Here is the simplest configuration file in actual use at our site today, for the standalone server ludvig.solan.unit.no (our primary repository server). It has two disks with repositories, ludvig and ludvig2, for a total of 4GB. It has mostly masters for core application like perl, emacs, X11, etc.
internal ludvig ludvig2 external khym ild nova vier lastebil store ludvig host=ludvig archs=sun4os4 store ludvig2 host=ludvig archs=sun4os4 linktree ludvig host=ludvig \ arch=sun4os412 domain=solan.unit.no \ unwantedfile=/store/store/Adm/etc/uwfile.ludvig compile sun4os4 on=ludvig report sun4os4 none allarchs |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Here is the most complex configuration file in actual use at our site today, for the administrative domain at pvv.unit.no. PVV is the most heterogenous site, having just two Sparc/SunOS machines, one Sparc/Solaris machine, one HP-700, one IBM workstation, one DECstation running DecOSF, a Dolphin m88k server, and a PC running Linux. Each machine has its own repository and its own linktree. The main repository server (nova) has a 2GB repository disk.
internal nova dekk bigblue bob datter flipper supernova external khym ild vier ludvig ludvig2 lastebil \ flory hani smola grip mari1 kari iptibm3 \ petra1 taiyang storlind store nova host=nova archs=sun4os4,rs6aix32,m88k,hp700ux9,linux,sun4os5 \ autoadd=khym,ild,ludvig,ludvig2,vier,lastebil \ unwantedfile=/store/store/Adm/uw.pvv store dekk host=dekk archs=dsosf1 store bigblue host=bigblue archs=rs6aix32 store bob host=bob archs=hp700ux9 store datter host=datter archs=sun4os5 store flipper host=flipper.pvv.unit.no archs=m88k store supernova host=supernova archs=sun4os4 linktree nova host=nova level=newer arch=sun4os413 domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv level=newer linktree supernova \ host=supernova \ arch=sun4os41B \ domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv \ level=newer linktree bigblue host=bigblue level=newer arch=rs6aix32 domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv linktree bob host=bob level=newer arch=hp700ux9 domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv linktree datter host=datter level=newer arch=sun4os5 domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv linktree dekk host=dekk level=newer arch=dsosf1 domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv linktree flipper host=flipper.pvv.unit.no \ level=newer arch=m88k domain=pvv.unit.no \ unwantedfile=/store/store/Adm/uw.pvv run cmaster on=nova pass=1 run cslave on=nova pass=2 run cclient on=nova pass=3 run cslave on=flipper.pvv.unit.no pass=3 from=nova via=rsh run cslave on=bigblue pass=3 from=nova via=rsh run cslave on=datter pass=3 from=nova via=rsh run cslave on=dekk pass=3 from=nova via=rsh run cslave on=bob pass=3 from=nova via=rsh run cslave on=supernova pass=3 from=nova via=rsh run cclient on=flipper.pvv.unit.no pass=4 from=nova via=rsh run cclient on=bigblue pass=4 from=nova via=rsh run cclient on=datter pass=4 from=nova via=rsh run cclient on=dekk pass=4 from=nova via=rsh run cclient on=bob pass=4 from=nova via=rsh run cclient on=supernova pass=4 from=nova via=rsh run report on=nova pass=4 compile m88k on=flipper.pvv.unit.no compile dsosf1 on=dekk compile rs6aix32 on=bigblue compile sun4os5 on=datter compile hp700ux9 on=bob compile sun4os4 on=nova on=supernova report sun4os4 sun4os5 dsosf1 m88k rs6aix32 \ hp700ux9 linux 386netbsd sgi4i5 sgi3i4 |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Now say you have a large disk server with several different types of clients, and you want to make linktrees for the clients on the server, as well as a linktree for the server itself. Now `/store' will hold the server's own linktree, `/store/store/large' is the actual repository with lots of packages, and you allocate the directories `/linktrees/sun3', `/linktrees/linux' and `/linktrees/sun4os5' to hold linktrees. The names here doesn't really matter, as long as the server exports the directories, and the clients mount the correct linktree directory on their private `/store', as well as `/store/store/large'.
Let us further assume that some of the sun3 clients really belongs in a maildomain different from the server; they could be at a student lab named studlab.somewhere while the rest of the hosts are in the host.somewhere domain.
The configuration file could look something like this:
internal large external foo bar baz store large host=large.host.somewhere archs=sun3,sun4os4,sun4os5,linux linktree large host=large.host.somewhere \ arch=sun4os413 domain=host.somewhere \ dir=/store linktree largesun3 host=large.host.somewhere \ arch=sun3 domain=host.somewhere \ dir=/linktrees/sun3 linktree largestudlab host=large.host.somewhere \ arch=sun3 domain=studlab.somewhere \ dir=/linktrees/studlab linktree largesun4os5 host=large.host.somewhere \ arch=sun4os53 domain=host.somewhere \ dir=/linktrees/sun4os5 linktree largelinux host=large.host.somewhere \ arch=linux domain=host.somewhere \ dir=/linktrees/linux compile sun4os4 on=large.host.somewhere compile sun3 on=small.host.somewhere compile linux on=pc.host.somewhere compile sun4os5 on=sol.host.somewhere report sun4os4 sun4os5 sun3 linux |
The server's `/etc/exports' file could look like:
/linktrees/sun3 -access=sun3hosts /linktrees/sun4os5 -access=sun4os5hosts /linktrees/linux -access=linuxhosts /linktrees/studlab -access=studlabhosts /store/store/large -ro |
The sun3 clients' `/etc/fstab' could look like this:
large.host.somewhere:/linktrees/sun3 /store nfs hard,ro,intr large.host.somewhere:/store/store/large /store/store/large nfs hard,ro,intr |
Now this is a hypothetical example, but it should hopefully give some good guidelines on how to configure disk servers with foreign linktrees.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The genarchs configuration file defines architectures and domains recognized by STORE. You will need to define your site's domains in this file to be able to use domain-specific files. Also, if you have architectures on your site that we don't have here, you need to add them alongside those already defined.
You should only need to edit the genarchs file on your site's primary repository, so this section is really only relevant to the first STORE installation on a site. If someone else is maintaining the primary repository, ask them to add architectures or domains that you need.
The machine with the primary repository will (with the default installation) have a directory with the name `/store/store/<primary>/perl-internal' where <primary> is the name of the primary repository. To edit the genarchs file, follow this checklist:
co -l genarchs
emacs genarchs
or whatever
ci -u genarchs
cd ..
make install
You may want to change the version number in the Makefile first, so you have both the old and the new version running in parallel first.
7.3.1 Adding architectures How to add extra architectures 7.3.2 Adding and changing domains How to add domains
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Adding an extra architecture should be relatively straight-forward. The relevant part of the configuration file looks like this:
# Normal architectures - add architectures as needed: expand arch allarchs bigend litend expand arch bigend sun sgi apollo hp ibm m88k expand arch litend pmax i386 vax alpha expand arch sun sun3 sparc expand arch sun3 sun3os4 expand arch sun3os4 sun3os40 sun3os41 sun3os411 expand arch sparc sun4os4 sun4os5 expand arch sun4os4 sun4os40 sun4os41 sun4os41B expand arch sun4os41 sun4os411 sun4os412 sun4os413 expand arch sun4os5 sun4os50 sun4os51 sun4os52 sun4os53 ... |
To add SunOS 4.1.4 for the sparc platform (fat chance), just change the sun4os41 line to:
expand arch sun4os41 sun4os411 sun4os412 sun4os413 sun4os414 |
For a more drastic example, let's say you start running repository on your Cray machines running UNICOS 6.0, 6.1, and 7.0. Then we need to add another family altogether. The Cray is big-endian, so change the bigend line and add like this:
expand arch bigend sun sgi apollo hp ibm m88k cray expand arch cray unicos6 unicos7 expand arch unicos6 unicos60 unicos61 |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The domain part of the genarchs file will probably be more interesting to change, as you will probably want to rip out the part pertaining to the University of Trondheim and substitute your own site. Whether you follow strict mail-domain lines or use some other administrative boundaries as your guide is entirely up to you - do as you feel is most natural. We have found the greatest benefit of domain-specific files to be setup files for mail and news programs, so we follow mail-domains very closely.
The relevant part of the genarchs file looks like this:
# Mail/administration domains - add your own domains as needed. expand domain alldomains unit.no sintef.no expand domain unit.no idt.unit.no fm.unit.no pvv.unit.no \ stud.unit.no kjemi.unit.no ipt.unit.no \ dsl.unit.no ifi.unit.no elkraft.unit.no expand domain fm.unit.no imf.unit.no phys.unit.no expand domain phys.unit.no nobipol.unit.no expand domain stud.unit.no lise.unit.no solan.unit.no siri.unit.no \ marin.unit.no alkymi.unit.no petra.unit.no expand domain sintef.no sima.sintef.no runit.sintef.no |
If we wanted to have a global STORE installation, it would probably have to look something like this:
expand domain alldomains edu com gov mil net org countries expand domain edu mit.edu berkeley.edu toronto.edu \ 22cf.edu aa.edu ac.edu accd.edu \ ... expand domain com sun.com sgi.com dec.com cray.com \ 10a.com 1776.com 23kgroup.com 24hour.com \ 24stex.com 2600.com 35sys.com 3com.com \ ... expand domain countries no se fi dk is us ca de nl ae ag al an \ aq ar arpa at au bb be bf bg bh bm bo \ ... expand domain no unit.no uio.no uit.no uib.no sintef.no \ ... expand domain unit.no idt.unit.no fm.unit.no pvv.unit.no \ stud.unit.no kjemi.unit.no ipt.unit.no \ dsl.unit.no ifi.unit.no elkraft.unit.no ... |
The syntax and semantics should be quite simple, but if you get problems, send a mail and we'll try to help you.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The nightly script must take care of running the nigthly
perl jobs cmaster
and cslave
on all hosts having
repositories, and cclient
wherever there is a linktree.
In addition it should run report
.
The night.sh script itself is most commonly started from cron. Therefore it may need to set the PATH variable, although the STORE scripts themselves use very few shell commands.
Also, the errors and warnings from the scripts should be logged and (preferably) mailed to the local STORE administrators.
One simple situation is with a standalone machine, where a typical repository script could look like this:
PATH=$HOME/bin:/store/bin:/store/gnu/bin:/local/bin:/usr/bin export PATH ADM=/store/store/Adm OUT=$ADM/output LOG=$ADM/logs/nightly.log MAIL=mail PERSONS=root SCRIPTS=/store/etc/internal exec >$OUT 2>&1 echo "(Info) Store nightly job start `date`" perl $SCRIPTS/cmaster.pl perl $SCRIPTS/cslave.pl perl $SCRIPTS/cclient.pl perl $SCRIPTS/report.pl echo "(Info) Store nightly job stop `date`" $MAIL -s "Nightly Store problems" $PERSONS < $OUT cat $OUT >> $LOG exit 0 |
Using the run
keyword in your configuration file properly, you
can use the nightly.pl
perl script to actually start the
perl scripts remote. Here's a real world example for the same
host that has the complex configuration file detailed in this
documentation (See section 7.2.5 Complex config example):
#! /bin/sh # nightly script, to be run from crontab # checks vital and trivial ting about the Store system ADM=/store/store/Adm OUT=$ADM/output MAIL=/usr/ucb/mail PERSONS="arnej stigb tegge" SCRIPTS=/store/etc/internal PATH=$HOME/bin:/store/bin:/store/gnu/bin:/local/bin:\ /local/gnu/bin:/local/X11/bin:/usr/lang:/usr/ucb:/bin:\ /usr/bin:/local/etc:/etc:/usr/etc:/etc/bin:/local/games:/usr/games export PATH exec >$OUT 2>&1 perl $SCRIPTS/nightly.pl cat $OUT >> $ADM/logs/nightly.log $MAIL -s "Nightly Store problems" $PERSONS < $OUT exit 0 |
On another host, where logs aren't as important, the "store" user's crontab file starts the nightly.pl script directly:
lastebil:/store/store/lastebil/Adm$ crontab -l 1 1 * * * perl /store/etc/internal/nightly.pl | \ /usr/sbin/Mail -s "Nightly Store problems" arnej hanche vindvad |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The most common way to do nightly commands is to
write a small script. So rplay, a sound package with
remote sound possibilities, has a registered Nightly Command
with the value perl /store/etc/make-rplay.conf.pl
that is run on each cclient
run.
As is usual in such cases, the purpose of the script is to
update a configuration file, so the registered Not Links value
is etc/rplay.conf
, meaning that the perl script should
construct /store/etc/rplay.conf (in this case, by finding sound
files by searching `/store/lib/sound').
Another example is the makewhatis packages. The relevant parts of the registration file looks like this:
Nightly Command ... : /store/etc/catman Not Links . ... ... : man/whatis.* gnu/man/whatis.* |
The `/store/etc/catman' script itself is quite short, so is reproduced here as a good example of how to write a nightly command script:
#!/bin/sh topdir=${TOPDIR-/store} for MD in $topdir/man $topdir/gnu/man ; do if test -d $MD && test -w $MD; then rm -rf /tmp/mkw.log.* /tmp/mkw.err.* perl /store/etc/makewhatis.pl -M $MD \ >/tmp/mkw.log.$$ 2>/tmp/mkw.err.$$ if test -s /tmp/mkw.err.$$; then echo "(Warning) Errors when trying to run makewhatis on $MD:" sed 's/^/ /' < /tmp/mkw.err.$$ ( cat /tmp/mkw.log.$$ /tmp/mkw.err.$$ \ >> /store/store/Adm/logs/makewhatis.log ) 2>/dev/null rm -f /tmp/mkw.log.$$ /tmp/mkw.err.$$ else rm -f /tmp/mkw.log.$$ /tmp/mkw.err.$$ fi fi done |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Here's a list of packages that I consider to be some of the most important in repository, as indicated by the fact that they are compiled for most architectures. The report format is as generated by the report utility. The selection is obviously somewhat biased, but I can't list everything: On last count we had more than 500 applications total.
P R O G R A M S I N S T O R E Page 1 386netbsd ---+ +--- sgi4i5 Examples ---+ dsult4 ---+| |+--- hp700ux9 Online help ---+| sun4os5 ---+|| ||+--- linux Hardcopy Documentation ---+|| sun4os4 ---+||| |||+--- rs6000 Manual pages ---+||| i386sol24 ---+|||| ||||+--- allarchs Emacs info ---+|||| ||||| ||||| ||||| Name PrimVer VVVVV VVVVV Categ. Sign Short description VVVVV ------------------------------------------------------------------------------ X11 5.26 ***** **-*+ os TE MIT Reference Port of X11 -*--- amd 920824 -*+*- ****+ os AHJ AutoMounter Daemon ***-- bash 1.14.3 ***** ****+ os TE FSF's bourne shell ****- bison 1.21 ***** ****+ pwb AHJ GNU version of yacc ***-- byacc 1.9 -**** *-*-+ pwb AHJ Berkeley version of yacc -*--- c-archie 1.4.1 ***** ***++ info AHJ Archie commandline client -*--- chimera 1.63 -**** ****+ info AHJ Web client (X/Athena) -*-*- ctwm 3.2p1 ***** ****+ app MS Fancy window manager -*--- detach 1.1 ***** ****+ adm AHJ Start programs in background -*--- dvipsk 5.55a -**-* **--+ tex HH-O DVI to PostScript converter **-*- elm 2.4.23 ***** **-++ mail Sig Interactive mail program -***- emacs19 19.28 ***** ****+ edit HE The Editor. ---*- fileutils 3.9 ***** ****+ shu AHJ Various file utilities -*--- flex 2.4.6 -**** ****+ pwb AHJ GNU version of lex from PWB **--- fvwm 1.24r ***** ****+ app SSB Motif-like fast virtual WM -*--- gawk 2.15.2 -**** ***-+ shu AHJ GNU version of the awk languag ***-- gcc 2.5.8 ****- ****+ pl AHJ C, C++ and ObjC compiler ***-- gdb 4.13 ****- ****+ pwb HE GNU debugger **--- gdiff 2.5 ***** ****+ shu AHJ difference-computing programs *---- gfind 3.8 -**** ****+ shu AHJ GNU version of find -*--- ghostscrip 2.6.1. ***** ****+ app HaNH Postscript interpreter -**-- ghostview 1.5 -**** ****+ app HE Frontend for Ghostscript -**-- gm4 1.4 ***** ****+ shu AHJ Macropreprosessor *---- gmake 3.69 ***** ****+ pwb AHJ GNU make(1) program *---- gnuplot 3.5 -**** **-*+ app MS Interactive plotting program -*-** gpatch 2.1 ***** **-*+ pwb AHJ Update sources from diffs -*--- groff 1.08 -**** ****+ os AHJ GNU [nt]roff text formatter -**-- gtar 1.11.2 -***- **-*+ arch HE backup/archival tool *---- gzip 1.2.4 ***** ****+ arch AHJ GNU (de)compression - *.gz ***-- P R O G R A M S I N S T O R E Page 2 386netbsd ---+ +--- sgi4i5 Examples ---+ dsult4 ---+| |+--- hp700ux9 Online help ---+| sun4os5 ---+|| ||+--- linux Hardcopy Documentation ---+|| sun4os4 ---+||| |||+--- rs6000 Manual pages ---+||| i386sol24 ---+|||| ||||+--- allarchs Emacs info ---+|||| ||||| ||||| ||||| Name PrimVer VVVVV VVVVV Categ. Sign Short description VVVVV ------------------------------------------------------------------------------ host 930926 ***** ****+ net AHJ Simple yet powerful DNS tool -*--- ispell 3.1.13 -**** **-*+ app Sig Spelling checker **-*- latex2e 1994.1 ***** ***** tex HH-O Macro package for TeX --*-- less 177 ***** ****+ app HE Pages, searches, &c -*-*- libg++ 2.5.2 ****- ****+ lib AHJ GNU C++ class library -*--- lndir 5 ***** ****+ pwb AHJ Create shadow tree to sourceco -*--- lynx 2.3 -**** ****+ info MS Curses based W3 browser --*** makewhatis 1990 ***** ***** adm AHJ Create whatis databases ----- mosaic 2.5 ****- ****+ info SSB X-based WWW client from NCSA ---*- ncftp 1.7.1 ***-* **-*+ net HH-O Alternative UI for FTP -*-*- pbmplus 1mar19 ***** ***-+ ip MS Image conversion and manip. -*--- perl 4.036 ***** ****+ pl AHJ Scripting language -*--- rcs 5.6.0. ***** **-*+ os SSB Simple revision control system -*--- rdist 6.1bet -**** **--+ adm TE Distribution of files -*--- shellutils 1.12 ***** ****+ shu AHJ Various shell utilities **--- startxcmd 1.2 ***** ***** shu AHJ Start remote X programs ----- storedoc 2.3 ***** ***** doc AHJ Documentation of Store *-*-- tcsh 6.05p ***** *-**+ sh MS C shell variant -**-- texinfo 3.1 ***** **-++ tex AHJ Emacs-info utilities ***-- textutils 1.11 -**** ****+ shu AHJ Various text utilities **--- web2c 5.8515 -**** **-*+ tex HH-O web2c with TeX, MF and utils -*--- xdvik 1.8 -**** **-++ tex HH-O Preview DVI files under X11 -*--- xlock 1.08ah -**** ****+ app AHJ Lock your screen (for X) -*--- |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This chapter should provide an understanding of the typical nightly STORE job output, and how to fix the problems it indicates.
Store format is formatted according to a schema so it should be easy to
parse (both for humans and computers). There is a label (in parantheses)
indicating severity (typically one of Error, Warning, Info, or Trace) -
normally you only get Info and Trace messages when running a program
interactively. An Error always indicates something requiring
human intervention, while a Warning may signify a transient
condition. A particular version of an application in a repository is
indicated using the schema <app@repository vver>
,
so for example version 2.1 of the zoo
application at
repository khym
is <.zoo@khym v2.1>
.
8.0.1 Top 10 errors and warnings Some common output types.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Here are some of the most common output types illustrated with examples and explanations.
(Warning) These applications will not be used by khym: gindent nova (supports sun4os4) |
slaveapp
and linkup
to get it.
unwantedfile
.
(Warning) Empty symlinks in /store on khym (removed): doc/elm ==> Ref.ps Users.ps |
(Error) <traceroute@ludvig> has no registration file |
(Warning) bin/gmake symlink -> /store/store/ludvig/gmake/ver-3.67/bin/gmake symlink -> make i.e. nowhere! |
(Error) <latex-nfss@ild> No winning master |
linkdown
and
rm -rf
).
(Warning) Changed link <- /store/store/kari/.elm/ver-2.4.23/man/man1/frm.1 -> /store/store/kari/fsp/ver-271/man/man1/frm (Warning) Changed link <- /store/store/kari/fsp/ver-271/man/man1/frm -> /store/store/kari/.elm/ver-2.4.23/man/man1/frm.1 |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This chapter has some background information on STORE: The background and history of STORE, the authors, the current TODO list, and where to reach us.
9.1 The problem background The problem background that created STORE 9.2 The history of STORE 9.3 About the authors 9.4 Todo list 9.5 Contact persons Where to reach us, and how to get STORE
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
STORE was created out of the needs that we felt, managing a large, heterogenous network of Unix machines. Despite claims in trade rags, administrating unix isn't trivial. A list of factors create complexity in the total system (different hardware, different OSes, lots of third-party programs, different versions of "everything"). This complexity makes for a messy and unmanageable system. Some of the most common problems a system administrator meets is:
/local/bin
, /local/lib
and
/local/man/man1
often contains a great mass of files, but nobody
really knows what all the files do. Nobody dares to remove
anything, because it may be important.
When the next version of the program needs to be installed, the same adjustments must be reconstructed. The same problems appear when one fixes a bug locally that is not merged into the official distribution.
These are the problems STORE is trying to solve.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The idea and basic concepts behind STORE has evolved from the similar "depot" system made by NIST and CMU. The first pilot version was implemented (mostly with shell scripts) and saw some use on the student computing labs.
Later, a new and enhanced prototype version was implemented on behalf of the IMF by Anders Christensen, a student at IDT, as a half-year project (spring of 1992). It was renamed STORE so as not to be confused with the NIST/CMU depot system.
At this time, the basic concepts were well-defined. Coming into full use at IMF and Alkymi, many of the more practical tools made possible by STORE was written, and needed optimizations was implemented. During the following year, the internals of STORE changed a great deal, and attempts was made to translate most of the programs' external interfaces into English.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The original versions of STORE was conceived and implemented by Anders Christensen. Arne Henrik Juul did a lot of the improvements and further hacking as well as writing the examples on how to install software under STORE. Steinar Bang wrote the original version of this TeXinfo document, translating documentation written by the other two and adding some of his own. Also involved with the underlying algorithms has been Tor Egge.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This section holds the current todo list for STORE:
inistore
distribution and installation script
for STORE. Document it.
proginfo
, a user-oriented script.
status
tool, reporting disk usage,
changes, etc.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
For electronic mail contact, try arnej@lise.unit.no
and if
you do not receive a prompt answer, try storeadm@imf.unit.no
whereby you'll reach a greater group using STORE.
The primary distribution site for STORE is ftp.unit.no
,
our local FTP server. Currently it is put into the
/local/store
directory in the anonymous FTP area.
To reach us by phone, try:
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Jump to: | /
A C D G I L M N P R S U V |
---|
Jump to: | /
A C D G I L M N P R S U V |
---|
[Top] | [Contents] | [Index] | [ ? ] |
It will not look exactly like this, of course.
The normal STORE deinstallation process would remove all links pointing to a particular package.
The other programs only becomes interesting when you wish to create your own Gopher server, which is not a suitable program package to install under STORE
Tells make to print what it will do following a given make rule, but not to actually do it.
[Top] | [Contents] | [Index] | [ ? ] |
1. License information
2. What is STORE?
3. Introduction to STORE
3.1 The /store directory tree4. Concepts and conventions of STORE
3.2 The main utility programs.
3.2.1 cmaster utility
3.2.2 cslave utility
3.2.3 cclient utility
3.2.4 report utility
3.2.5 status utility (planned)
3.2.6 autocomp utility
4.1 The central repository concept5. Installing STORE
4.2 The macro view
4.3 Machines having one or several repositories
4.4 The application concept
4.5 Versions of applications
4.6 Master repositories
4.7 Slave repositories
4.8 Compile Servers
4.9 Compile trees
4.10 Generalized architectures
4.11 The administrative area
4.12 Cooperating administrative domains
4.13 Different nightly scripts
4.14 Using persons' initials for reporting
5.1 Requirements for installing STORE6. Installing software under STORE
5.2 Description of preliminary actions
5.3 The 'inistore' setup script
5.4 Completing the setup
5.4.1 Fixing the nightly script
5.4.2 Changes to user setup to accomodate STORE.
6.1 Installation goals7. Example configuration files
6.2 Installing programs -- checklist
6.3 Tools used when installing
6.3.1 "shadow"6.4 Handling documentation
6.3.2 "unshadow" and "fix"
6.3.3 "postinst"
6.3.4 "register"
6.3.5 "slaveapp"
6.3.6 "linkup"
6.3.7 "linkdown"
6.5 Example installation: Gopher
6.6 Example installation: Xgopher
6.7 Installing emacs lisp packages
6.8 Example installation: ange-ftp
6.9 Example installation: gcc
7.1 Example registration file8. Understanding STORE output
7.1.1 Manually entered information7.2 Configuration file
7.1.2 Computed information
7.2.1 Quick guide to etc/config features7.3 The genarchs configuration file
7.2.2 Metrics
7.2.3 Full walkthrough of the etc/config syntax
7.2.4 Simple config example
7.2.5 Complex config example
7.2.6 A configuration file with foreign linktrees
7.3.1 Adding architectures7.4 night.sh script examples
7.3.2 Adding and changing domains
7.5 Nightly Command examples
7.6 List of core applications
9. Miscellaneous8.0.1 Top 10 errors and warnings
9.1 The problem backgroundConcept Index
9.2 The history of STORE
9.3 About the authors
9.4 Todo list
9.5 Contact persons
[Top] | [Contents] | [Index] | [ ? ] |
1. License information
2. What is STORE?
3. Introduction to STORE
4. Concepts and conventions of STORE
5. Installing STORE
6. Installing software under STORE
7. Example configuration files
8. Understanding STORE output
9. Miscellaneous
Concept Index
[Top] | [Contents] | [Index] | [ ? ] |
Button | Name | Go to | From 1.2.3 go to |
---|---|---|---|
[ < ] | Back | previous section in reading order | 1.2.2 |
[ > ] | Forward | next section in reading order | 1.2.4 |
[ << ] | FastBack | previous or up-and-previous section | 1.1 |
[ Up ] | Up | up section | 1.2 |
[ >> ] | FastForward | next or up-and-next section | 1.3 |
[Top] | Top | cover (top) of document | |
[Contents] | Contents | table of contents | |
[Index] | Index | concept index | |
[ ? ] | About | this page |