This chapter describes the procedure for installing GemStone/S 64 Bitâ„¢ version 3.5. We recommend that you set up GemStone initially on a single machine, to ensure that all the pieces work together. At the end of this chapter, we suggest refinements you might want to make. Further setup to run a distributed system are described in the System Administration Guide. You will need to adjust the installation process to meet your specific needs.
If you are upgrading to this release from a previous version of GemStone/S 64 Bit, follow the instructions in the appropriate later chapter of this Installation Guide. These upgrade instructions will provide details on steps that need to be taken before and after the installation as described in this chapter.
The following list summarizes the steps to install GemStone/S 64 Bit.
Before you install GemStone/S 64 Bit, ensure that the following system requirements are satisfied. Systems meeting these requirements are suitable for installing GemStone/S 64 Bit and beginning development, but additional system resources may be necessary to support large applications.
For Compiler and Debugger versions, refer to the GemBuilder for C manual.
Due to the way GemStone uses memory, systems with insufficient page space allocated have a risk of memory errors even if there is available RAM.
The repository files should be located on a disk drive that does not contain page space. Use of multiple disk drives is advisable for servers.
To use extents in the file system larger than 2 GB or to increase the number of file descriptors available, make these changes in /etc/security/limits:
Fsize = -1
nofiles = 2000
You must also have the Large File System enabled when creating a jfs file system using SMIT.
We recommend that you pregrow such extents to a size greater than 2 GB so any configuration difficulty is detected when the server is first started.
The default file descriptor limit of 1024 is adequate for up to about 500 GemStone users. Each user session requires two file descriptors, and others are needed for extents, transaction logs, and overhead. Use caution and increase the default setting only when necessary because doing so can have system side effects.
If you are using UNIX authentication for GemStone logins, or if you run NetLDI as root with setuid (i.e. not in guest mode), you must have PAM (Pluggable Authentication Module) configured on the server. You may include a specific GemStone authorization service name, or allow the default “other” authentication definitions to be used.
PAM authentication definitions are in /etc/pam.conf.
The specific GemStone service names are gemstone.gem for user authentication, and gemstone.netldi for a NetLDI running with authentication. The libraries that are specified in the stack depend on how you are configuring PAM to perform the authentication. AIX does not provide an LDAP module as part of the core.
For example, to allow GemStone UNIX authentication, which uses PAM, to authenticate via a custom LDAP module:
gemstone.gem auth required /usr/lib/security/pam_ldap
For NetLDI running as root, to authenticate directly to the AIX security subsystem, use the following. This only applies for process running as root.
gemstone.netldi auth required /usr/lib/security/pam_aix
If the following “other” stack is available in /etc/pam.conf, GemStone can use this to authenticate, via a custom LDAP module:
OTHER auth required /usr/lib/security/pam_ldap
Consult your System Administrators for more information on how authentication is handled on your system.
The default size for memory pages is 4K (small), and AIX also transparently supports 64K (medium) pages; AIX automatically adjusts between these two page sizes.
Current releases of AIX also support larger pages sizes, including 16MB (large) pages. If you have a large repository, using large pages may improve performance. To use large pages, you must configure AIX to allocate large pages, and configure GemStone to request large pages.
To configure GemStone to use Large Pages:
a. Determine the number of huge pages that will be needed, based on your GemStone configuration. This is calculated by the utility largememorypages. This utility needs several details to compute the number of required pages: the shared page cache size, the maximum number of GemStone processes, and the number of shared counters. These can be provided by arguments or read from an existing configuration file.
largememorypages [-e path ][-z path][-F cacheFrames | -M cacheKB]
[ -P maxProcesses] [-C maxSharedCounters]
You may specify the required values using a valid configuration file. This is parsed as a Stone configuration file and the necessary values extracted.
-e path
specifies an executable config file (same as startstone -e).
-z path
specifies a system config file (same as startstone -z).
If a config file is not specified, then -M or -F and -P and -C are required. These arguments can be used in addition to the configuration file, in which case they override values set or computed in the configuration file:
-F cacheFrames
shared cache size expressed in 16 KB frames
-M cacheKB
shared cache size in bytes, with a optional units suffix.
-P maxProcesses
setting for SHR_PAGE_CACHE_NUM_PROCS
-C maxSharedCounters
setting for SHR_PAGE_CACHE_NUM_SHARED_COUNTERS.
The following example is for an (approximately) 20GB shared page cache, 200 processes, and 1900 shared counters, with 2 MB memory pages:
unix> largememorypages -P 200 -M 20GB -C 1900
Cache config is 1310720 pages = 20480 MB, total is 22064 MB, overhead 7% of configured size
Large page size requested is: 16 MB.
Large page overhead: 4.80 MB
For 1310720 pages, 200 processes and 1900 shared counters, 10 pusherThreads
required cache size is 23135780864 bytes.
Number of 16 MB large pages required: 1379
<with further update commands>
b. Configure AIX to use large pages using the following commands, which are also output by largememorypages.
unix> vmo -r -o lgpg_regions=numPages -o lgpg_size=16777216
unix> vmo -p -o v_pinshm=1
After this has been executed, the bosboot command must be run to build a new kernel image, and the system must be rebooted
You can confirm large memory pages are available for use using vmstat -l.
c. The UNIX user running the shared cache monitor must be given permission to use large memory pages.
chuser capabilities=CAP_BYPASS_RAC_VMM,CAP_PROPAGATE <user id>
Alternatively, you can run the SPC monitor process with an effective user ID of root:
chown root $GEMSTONE/sys/shrpcmonitor $GEMSTONE/sys/startshrpcmon
chmod u+s $GEMSTONE/sys/shrpcmonitor $GEMSTONE/sys/startshrpcmon
d. Configure GemStone to request large pages by setting the configuration option SHR_PAGE_CACHE_LARGE_MEMORY_PAGE_POLICY = 2.
The configuration option SHR_PAGE_CACHE_SIZE_KB defines the size (in KBytes) of extent page space in the shared page cache. The maximum acceptable value for this configuration option is limited by system memory, kernel configurations, cache space allocated by SHR_PAGE_CACHE_NUM_PROCS and space allocated for other GemStone caches.
For more general information about these and other configuration options, see Appendix A of the System Administration Guide.
The system clock must be set to the correct time. When GemStone opens the repository at startup, it compares the current system time with the recorded checkpoint times as part of a consistency check. A system time earlier than the time at which the last checkpoint was written may be taken as an indication of corrupted data and prevent GemStone from starting. The time comparisons use GMT.
GemStone processes ordinarily use the TCP keepalive option to determine how long they will wait after communications activity ceases unexpectedly. This setting can be useful for reaping stale RPC Gems, but the operating system default may not be appropriate for this purpose. For further information, refer to your operating system documentation.
Installing GemStone can be done as a regular user, but in order to setup shared security, some portions of the installation should be done when logged in as the root user. Other steps of the installation are done as the unix user who will be the GemStone administrative account.
In addition to the installation directory, these are the portions of the system that are affected by the installation of GemStone:
/dev/rhdisk*
Optional raw partitions for repository extents and transaction logs.
/etc/services
Internet services database, for NetLDI name lookup.
/opt/gemstone
Default location for server lock files, host name id file, and log files for GemStone network servers (NetLDIs). See the System Administration Guide for details.
1. Log in as the GemStone administrator to the machine on which you are installing GemStone. This part of the installation should not be done as root, to ensure all the files are not owned by root.
2. Determine that adequate page space is available.:
We recommend that you allow at least 10 LPs of page for running GemStone and an additional 10 LPs if you will be developing GemStone applications.
To determine the current size of the paging device(s), which is usually found on the root volume group, rootvg:
% /etc/lsvg rootvg -l
Paging devices are of TYPE paging, and the LPs column shows the size of each device. An LP is 4 MB.
Page space can be expanded dynamically (without rebooting) using SMIT.
3. Select the drive on which you will install the GemStone software, and the installation directory on this drive, InstallDir. Make this directory the current working directory.
We recommend that you avoid choosing either an NFS-mounted partition or one containing UNIX page space for the initial installation. Mounted partitions can result in executables running on the wrong machine and in file permission problems. Existence of page space on the same drive can dramatically slow GemStone disk accesses.
4. GemStone/S 64 Bit is provided as a zipped archive file with a name similar to GemStone64Bit3.5.0-RISC6000.AIX.zip. Move this distribution file to the directory location in which GemStone will be installed, InstallDir.
5. Unzip the distribution file using unzip.
6. The InstallDir now contains a GemStone directory with a name similar to GemStone64Bit3.5.0-RISC6000.AIX.
In addition to subdirectories, this directory also contains two text files: PACKING, which lists all of the GemStone files, and version.txt, which identifies this particular product and release of GemStone.
Perform the following steps to properly configure the operating environment.
1. Set the environment variable GEMSTONE.
a. If more than one installation of any GemStone/S product resides on this machine, check for existing GemStone environment variables:
> env | grep GEM
All GemStone environment variables are displayed.
b. If any environment variables exist and are not appropriate for the new installation, you must specifically unset each one. For example:
> unset GEMSTONE GEMSTONE_SYS_CONF
c. Set the environment variable GEMSTONE to the full pathname (starting with a slash) of your new GemStone installation directory. For example:
> export GEMSTONE=InstallDir/GemStone64Bit3.5.0-RISC6000.AIX
To run GemStone, you must have a key file for the correct version of GemStone/S 64 Bit and for the appropriate platform. The keyfile must be located where GemStone can find it on startup:
Licenced customers can email keyfiles@gemtalksystems.com or contact GemTalk Technical Support to request a keyfile for version 3.5 for their platform or platforms. Keyfiles for previous versions of GemStone are not valid with v3.5.
To specify the location and name of the keyfile using the KEYFILE configuration parameter, edit the configuration file that will be used by the v3.5 stone to include the location and name of the keyfile.
You may also put the keyfile in the default location, $GEMSTONE/sys/gemstone.key. This requires modifying the write permissions of the $GEMSTONE/sys directory; ensure you change this back to not writable, after this update.
To run GemStone, TCP/IP must be functioning, even if your machine is not connected to a network.
Verify that TCP/IP networking software is functioning (1 is the number 1):
> /etc/ping hostname 8 1
where hostname is the name of your machine. If ping responds with statistics, TCP/IP is functioning.
The NetLDI service, by default gs64ldi, should be defined in your system services database. A NetLDI is required for certain kinds of local and remote sessions to log into GemStone, and if it cannot be resolved by name, you must refer to it by port number. For clients on remote machines, the same NetLDI service name and port number must be defined on the remote machines as well as the main host.
If you are upgrading from a previous version, you may need to keep the NetLDI for that version running. In this case, select a distinct name and port for the NetLDI for GemStone/S 64 Bit 3.5.
1. Determine whether the gs64ldi service is already defined. How to do this will depend on how your system is set up. The GemStone distribution includes an executable that will allow you to do this:
unix> $GEMSTONE/install/getservbyname gs64ldi
s_name=gs64ldi s_port = 50377 s_proto = tcp
If gs64ldi is defined, skip the rest of this procedure and continue with the installation at Run the Installation Script.
If it is not defined, continue performing this procedure.
2. Add an entry similar to the following to the system services database:
gs64ldi 50377/tcp #GemStone/S 64 Bit 3.5
Choose a port number that is not being used by another service. The port number should be in the range 49152 <= port <= 65535, to confirm to IANA standards (http://www.iana.org/assignments/port-numbers).
3. If several machines will be running GemStone, have the UNIX system administrator update the system services database for each machine. This includes Windows client machines as well as UNIX nodes. Note that the port number must be the same for every machine.
Although you can complete the installation as a non-root user, we do not recommend this when installing a multi-user system. During installation, GemStone system security is established through file permissions and process attributes. To ensure that the installation is successful, you must install as root. See the System Administration Guide for details on setting up GemStone server file security.
2. Invoke the installation script from the install subdirectory:
cd $GEMSTONE/install
./installgs
installgs is an interactive script that analyzes your system configuration and makes suggestions to guide you through installing GemStone on your machine.
NOTE
You can usually terminate execution of the installation script with Ctrl-C without risk to your files. When it is not safe to do so, the message Please do not interrupt appears on the screen. If this happens, wait for the message now it is OK to interrupt before you interrupt the script. You can run the script again from the beginning as many times as necessary.
After running installgs, log out as user root. Further work, such as setting the TimeZone, is done as the GemStone administrative user.
During installation, you are asked several questions. The entire installation dialog is not reproduced here, but the main points are addressed. Some questions may not be asked, depending on answers to previous questions.
Whenever you are asked to answer “yes” or “no,” answer with y or n. When the script offers a default answer in square brackets (such as “[y]”), press Enter to accept the default.
The default location for server lock files and NetLDI log files is /opt/gemstone, although for compatibility with earlier products /usr/gemstone is used only if it exists. If the environment variable GEMSTONE_GLOBAL_DIR is defined to point to a valid directory, this overrides the default server lock files and log file location; however, all Gemstone processes that will interact on this machine must have this environment variable set to the same directory.
If these directories do not exist, the installation script offers to create /opt/gemstone and the subdirectories locks and log. Then, the script offers to set access (770) to these directories.
If you answer no to creating the directories, you must create them (or provide a symbolic link) before starting the server.
If you answer yes, the script will prompt you for the owner and group you want to use. Refer to Chapter 1 of the System Administration Guide for more information about setting owner and group permissions.
If you answer no, the permissions will remain the same as when the files were extracted from the distribution media.
The default, which we recommend, gives only the owner read and write access (600) through ordinary UNIX commands. Other users can read and write the repository through a GemStone session. If you choose not to protect the repository, the setuid bit is cleared from all executables, which causes them to run under ownership of the user who invokes them.
Default: Set the repository permission to 600, and leave the setuid bit applied.
Do you want the installation script to allow non-root users to start a NetLDI that runs as root?
The NetLDI is a network server that permits remote processes to interact with the repository. There are two ways to set up a NetLDI so that it can provide services to all GemStone users: it can run as root, or it can run in guest mode with a captive account.
If the NetLDI uses a port number less than 1024, it must run as root.
Default: Change ownership of the netldi executable to root, and set its setuid bit.
Do you want the installation script to set up an extent now?
GemStone is distributed with a read-only copy of the initial repository in
$GEMSTONE/bin/extent0.dbf. Before you can start GemStone, this file must be copied to a suitable location and made writable. The script offers to copy the file to its default location of $GEMSTONE/data.
If you are a new GemStone user, we recommend that you answer y. If you are an existing GemStone user, you might prefer to answer n, then copy the extent to a different location yourself. (If you choose a location other than the default, you must edit your configuration file before starting GemStone. For information, see the System Administration Guide.)
Default: Place a writable copy of extent0.dbf in $GEMSTONE/data.
Do you want the installation script to start a NetLDI?
If you prefer, you can start these processes manually at any time.
Almost every host needs a NetLDI. You must start a NetLDI when the Stone repository monitor or Gem session processes will run on this machine.
You can start a NetLDI that runs as root by answering yes to this prompt and the confirmation that follows. However, if you want to start the NetLDI in guest mode with a captive account, you must do that after completing the installation. For more information about guest mode with captive account, see Chapter 3 of the System Administration Guide.
GemStone comes with a number of built-in System user accounts, which are needed to perform administrative operations (such as adding application user accounts).
The initial password for these administrative accounts is swordfish.
Access to each of these accounts should be restricted; you should always change the passwords for these accounts, to provide basic security for your application.
The chapter entitled User Accounts and Security in the System Administration Guide tells you how to change the passwords
For each of the users in your system, you should establish GemStone accounts, which involves creating an individual UserProfile in GemStone.
The chapter entitled “User Accounts and Security” in the System Administration Guide provides information on how create accounts for GemStone users, and the options for authentication. This task can be done by executing Smalltalk code, or using GemBuilder for Smalltalk tools. See the GemBuilder for Smalltalk Users’s Guide for information on the GUI tools in GemBuilder.
After GemStone/S 64 Bit 3.5 has been installed, you should notify each person who will be using GemStone about the installation, and explain how to setup their environment.
These last two steps can be done using scripts that are part of the GemStone distribution. The directory $GEMSTONE/bin contains the files gemsetup.sh and gemsetup.csh, which define the GemStone environment for users by modifying the PATH and MANPATH variables to include $GEMSTONE/bin and $GEMSTONE/doc, respectively.
export GEMSTONE=installdir
export PATH=$GEMSTONE/bin:$PATH
export MANPATH=$MANPATH:$GEMSTONE/doc
If the user will use GemStone frequently, consider adding these steps to the login shell initialization file.
GemStone/S 64 Bit is shipped with a default time zone of US Pacific. If you are in another Time Zone, edit the file installtimezone.txt in the GemStone upgrade directory, then file it in as SystemUser.
This chapter has guided you through installation of GemStone/S 64 Bit 3.5, with the objective of getting a simple, default configuration up and running.
The next chapters explain the process of upgrading a previous version of GemStone/S 64 Bit to version 3.5; and Chapter 4 provides information on GemBuilder for Smalltalk.
For more information and details on customizing your GemStone object server, Gem client processes, and setting up distributed configurations, see the System Administration Guide.