SGI products are licensed by the FLEXlm application. To set up and maintain the licensing scheme for these products at your site, use the FLEXlm End User Manual (available online through IRIS InSight) as your primary source of license administration information. The InSight version of the FLEXlm guide contains icons that identify information that either does not apply to the SGI implementation of FLEXlm or requires additional explanation. This chapter of IRIX Admin: Software Installation and Licensing provides the alternative and additional information that is marked by the icons.
This chapter contains these sections:
“Starting and Stopping Licensing Daemons”
Note: Some older applications running on SGI systems use NetLS licensing; please see the Network License System Administration Guide for information on managing these licenses. |
Users license their applications with License Manager, a graphical tool that can be accessed from the System toolchest. The License Manager dialog is shown in Figure 10-1. Whenever a user installs, updates, or removes a floating licence with this dialog, License Manager restarts (or stops, for license removals) the local license manager daemon to put the user's change into effect.
Starting with IRIX 6.5, the License Manager dialog contains an Options button. This button allows users to manage licenses for Alias/Wavefront applications in addition to the group of applications that are normally licensed on SGI systems.
See the LicenseManager(1M) reference page for more information on the user interface to licensing.
The FLEXlm implementation on SGI systems supports these license types:
A node-locked license permits a particular system to run an application. The number of users is not restricted with this type of license.
Floating licenses permit a fixed number of users on a network to use an application simultaneously.
Incremental licenses permit the number of users on a floating license to be increased. The total number of users permitted to use an application is the sum of users specified on the INCREMENT lines for an application listed in the floating license file (see “FLEXlm Files and Utilities on SGI Systems”).
Package licenses permit several applications to use a single license. The license is listed in a PACKAGE line in the floating license file. This line contains a COMPONENTS attribute that identifies the applications that the package licenses (see “FLEXlm Files and Utilities on SGI Systems”).
Figure 10-2 illustrates the events in the license request process.
The license request process consists of this sequence of events:
When it starts, the master license daemon (lmgrd) reads the server copy of the license file and starts the vendor daemons listed in the file.
When it starts, the user application searches the client copy of the license file for the address of the license server, which includes the port number for lmgrd.
The user application requests the vendor daemon's address from the master daemon.
The master daemon sends the address of the vendor daemon to the user application.
The user application requests a license from the vendor daemon, using the address it received.
The vendor daemon checks its memory for available licenses and grants or denies a license.
SGI Origin3000 and Onyx3000 systems give you the flexibility to distribute and manage a partitioned system environment on a large CPU server system. In most cases, software licensing behaves in the same manner on a single system image as in a partitioned environment. However, there are some differences as discussed in this section.
In a partitioned system, you can divide a single distributed shared memory (DSM) system image into smaller system images. Each partition is logically separated from other partitions in the same shared memory system, with each partition having its own memory, IRIX operating system, IP address and I/O.
For example, a 128 CPU system can be partitioned into four partitions as:
Table 10-1. System Partition Example
Partition 1 = 64 CPUs | Partition 3 = 32 CPUs |
Partition 2 = 16 CPUs | Partition 4 = 16 CPUs |
Note: The number and size of the partitions are reconfigurable. |
Unlike most SGI software products which use GLOBEtrotter FLEXlm as the standard software license manager for node-locked and floating software licenses, partitioned systems are licensed by CPU count. Depending on your system, therefore, you must purchase licenses to support N CPUs. Products that are licensed per-CPU include, for example, SGI MIPSPro compilers and CXFS, the clustered XFS file system.
The following table explains how software licenses work in a partitioned system environment.
Note: lmhostid returns the identical value for each partition on a system. See the lmhostid(1) reference page for more information. |
Table 10-2. How Software Licenses Work in Partitioned Environments
Type of Software License | Behavior on Partitioned System |
---|---|
Demo license | No restrictions - can be run on any number of copies of IRIX on a partitioned system. |
FLEXlm node-locked uncounted concurrent license | If you purchase a node-locked license, you will be able to use it concurrently on any of the partitions. |
FLEXlm node-locked counted concurrent license | A license for N concurrent use can only be used on a specific partition since the license manager is tied to the hostid/hostname of the partition. |
FLEXlm floating licenses over a network | If you purchase a set number of concurrent licenses to be used over a network, N licenses will be available from your license server. These can can be installed either on the partitioned system or somewhere else in the network. |
Licensed for number of CPUs | In most cases, this type of license is purchased for the total number of CPUs on a system, not for the number of CPUs in a partition. This license can then be used on any subset of CPUs in any partition. Depending on the policy from the company selling the software license, you may be able to purchase a license to run on a single partition only. There are some limitations for this type of licensing, however. If the partition is reconfigured to support a larger number of CPUs than allowed by the license, the license may cease to work. If the partition is likewise reconfigured to support a smaller number of CPUs, the license will most likely continue to work. Furthermore, this license can be used on other partitions if it is not tied to a unique identifier on the partition. A unique identifier could be the hostid or partition number. To enable all partitions to use the software license without restrictions, the license should support the total number of CPUs on the system, not the number of CPUs in the partition. |
Proprietary software license | The software vendor is responsible to modify the license code as necessary. There are some OS commands that behave in the following manner on a partitioned environment: lmhostid(1) - returns the same value for each partition. hostid(1) - returns a unique value for each partition. hostid is based upon the internet address that is unique for each partition. hinv(1) - returns the hardware configuration specific to the partition. |
When you install FLEXlm software on SGI systems, licensing files and programs are stored in these locations:
/usr/etc/lmgrd | license manager daemon | |
/usr/etc/sgifd | SGI vendor daemon | |
/var/flexlm/licensefile.db | database of license files for SGI applications | |
/var/flexlm/license.dat | license file for node-locked licenses | |
/var/flexlm/license_<hostname>.dat | license file for floating licenses on the hostname server | |
/usr/sbin (lmdiag, lmdown, and so on) | FLEXlm license administration tools | |
/etc/init.d/flexlm | Startup script for the FLEXlm license daemon | |
/etc/config/lmgrd.options | Configuration file containing arguments to the lmgrd command | |
/etc/config/flexlm | Text file for enabling or disabling automatic startup of the FLEXlm daemon |
Licenses for Alias/Wavefront applications are stored in separate files:
/var/flexlm/aw.dat | license file for node-locked licenses to Alias/Wavefront applications | |
/var/flexlm/aw_<hostname>.dat | license file for floating licenses to Alias/Wavefront applications on the hostname server |
To locate their licenses, SGI applications search the /var/flexlm/licensefile.db file, which is located on the client system and contains a list of license files and directories. These applications search each file listed in licensefile.db whose name ends in .dat; they also search all .dat files stored in licensefile.db directories. The contents of /var/flexlm/licensefile.db are illustrated in Example 10-1, which contains one license directory and two license files:
Example 10-1. Database of License Locations
/var/flexlm /var/flexlm/license.dat /usr/lib/SoftWindows/FLEXlm/license.dat |
A license file in /var/flexlm/licensefile.db might direct the application to a license server to continue its search for a license (see “The USE_SERVER Feature” for details). If you plan to store licenses in a directory or filename that is different from those specified in /var/flexlm/licensefile.db, or if you create new locations for license files, you must modify /var/flexlm/licensefile.db to reflect your changes.
Note: The license daemon does not search /var/flexlm/licensefile.db to determine license file locations; licensefile.db is used only by SGI applications. See “Specifying License File Locations”, which follows. |
Neither the license manager daemon (lmgrd) nor the vendor daemons use /var/flexlm/licensefile.db to determine license file locations. These daemons locate license files by other methods:
On Silicon graphics servers, the master license daemon is started with parameters specified in the /etc/config/lmgrd.options file. The -c argument in this file specifies the location of the license file. If you change the location of the license file, you must modify /etc/config/lmgrd.options to specify the new license file location.
Applications whose license files are not listed in /var/flexlm/licensefile.db locate license files by means of the LM_LICENSE_FILE environment variable (also see “The port@host Feature”). To specify the location of license files, enter a line like the sample below in the .cshrc file (.profile or .kcshrc for Bourne or Korn shells) on the client system:
LM_LICENSE_FILE=<licensefile_path1>:<licensefile_path2>... |
The FLEXlm application contains two new features that can be implemented with applications using FLEXlm version 5 (or later): USE_SERVER and an enhancement to the port@host feature.
Version 5 of the FLEXlm application offers USE_SERVER, which eliminates the need to copy and maintain the server's license file on client systems. With this feature, only two lines are required in the client's license file: a SERVER line and the USE_SERVER line. When an application reads the USE_SERVER line, it reads the license file on the specified server instead of reading the local file.
Example 10-2 illustrates a client license file that implements the USE_SERVER feature. In this example, the application is directed to server sparkplug to read its license file:
Example 10-2. Client License File With the USE_SERVER Feature
SERVER sparkplug 023456 1701 USE_SERVER |
Note: The USE_SERVER feature is valid only for applications built with FLEXlm version 5. |
The version 5 enhancement to the port@host specification provides the same function as the USE_SERVER feature: it directs applications to read their license file from a remote server instead of reading it locally. Like earlier versions of port@host, the enhanced port@host uses the LM_LICENSE_FILE environment variable to specify the server. For example, the specification in Example 10-3 directs applications to read the license from sparkplug by means of a connection to port 1701.
It is possible to specify unenhanced port@host processing (FLEXlm version 4) for applications built with FLEXlm version 5. To specify unenhanced port@host processing, prepend a minus sign (–) to the LM_LICENSE specifications (shown in Example 10-4).
The installation process installs a startup script, /etc/init.d/flexlm, that starts and stops the FLEXlm license daemon. This script executes the lmgrd command to start the license daemon, using the values in the configuration file /etc/config/lmgrd.options.
In its startup sequence, the system reads the file /etc/config/flexlm to determine whether to start the license daemon. By default, this file contains the value off, which prevents the daemon from starting. To enable the lmgrd daemon, change the value in /etc/config/flexlm to on using this commands:
# /etc/chkconfig flexlm on |
To start the FLEXlm license daemon, enter this command as superuser:
# /etc/init.d/flexlm start |
To stop the FLEXlm license daemon when it is running, enter this command:
# /etc/init.d/flexlm stop |
Note: The FLEXlm daemon is started and stopped automatically when a workstation user installs, updates, or removes a license with the License Manager (see “About License Manager”). |