Mobile Licensing
Chapter 8
End users often want to use applications on computers that do not have a continuous connection to a FLEXnet license server system. These situations include:
FLEXnet Licensing supports licenses that allow one of several kinds of mobile licensing:
License rehosting is the consequence of an end user wanting to move a license without using one of these methods. This means a new node-locked license file is generated by the vendor for each new client computer. Rehosting incurs administrative overhead because the vendor is involved for each move.
Node-Locked to a Laptop Computer
If a license is to be used exclusively on one laptop computer, that license is simply node-locked to an address associated with that computer. The license file resides on the laptop computer.
Node-locked to a FLEXid (Windows Only)
If a license is to be moved between different Windows machines, it is node-locked to a FLEXid (a dongle that connects to a parallel or USB port). This license is moved between machines by installing a copy of the license file on each machine and moving the FLEXid from one machine to another. Since the license is tied to the FLEXid, only the machine with the FLEXid has use of the license.
Node-Locked to a FLEXid with FLOAT_OK (Windows Only)
This method of license mobility has an advantage over simply using a license node-locked to a FLEXid, because the FLEXid is attached to a license server machine and its license floats on the network. Licenses with a FLOAT_OK keyword that are node-locked to a FLEXid are supported only where both the FLEXenabled application and the license server system are running on Windows.
A vendor issues a license file with a FEATURE line node-locked to a FLEXid and containing the FLOAT_OK keyword and a FLEXid for that FEATURE line. One FEATURE line containing the FLOAT_OK keyword and one FLEXid is needed for each instance of a license that is mobile. When the FLEXid is attached to a license server machine, the license floats on the network. When the FLEXid is removed from the license server machine, the license is available only on the standalone computer.
This method supports parallel or USB FLEXids. Because it is simpler to attach multiple USB dongles to a computer, USB FLEXids may be preferable.
Initiating FLEXid with FLOAT_OK
A vendor issues the end user a FLEXid, a FLEXid driver installer, and a license file that contains a FEATURE line node-locked to that FLEXid containing the FLOAT_OK keyword. An end user then:
While the FLEXids are attached to the license server machine, the node-locked licenses associated with them float on the network. Each of the FLOAT_OK uncounted node-locked FEATURE lines has a count of one while it is available on the network.
To transfer a license from the pool of floating licenses to a disconnected computer, the end user:
- Copies the license file containing the FLOAT_OK node-locked FEATURE line from the license file on the license server machine to a license file on the client computer in the location where the FLEXenabled application expects to find its license file.
- Moves the FLEXid matching the node-locked FEATURE line from the license server machine to the client computer. When the FLEXid is removed from the license server machine, this license is unavailable on the network.
- Installs the FLEXid drivers on the client computer, if they are not already installed.
- Disconnects the client computer from the network. Now the license is available on the computer with the FLEXid, even though that computer is disconnected from the network.
Returning a FLEXid with FLOAT_OK License
To return the license to the license server machine so it floats on the network again, the end user:
- Removes the FLEXid from the client machine and replaces it on the license server machine.
- Rereads the license file for the license server system that serves the floating version of the license by running
lmreread
. When the FLEXid is returned to the license server machine, the FLOAT_OK license does not float on the network again untillmreread
is run.FLEXid with FLOAT_OK Example
The following is a sample license file issued to a end-user site. It is shipped with two FLEXids: FLEXID=7-b28520b9 and FLEXID=7-b2857678.
SERVER myhost ANY
VENDOR sampled
FEATURE f1 sampled 1.0 permanent uncounted FLOAT_OK \
HOSTID=FLEXID=7-b28520b9 SIGN=123456789012
FEATURE f1 sampled 1.0 permanent uncounted FLOAT_OK \
HOSTID=FLEXID=7-b2857678 SIGN=ABCDEF123456The end user installs the license file and the two FLEXids on the license server machine. When attached to the license server machine, each uncounted FLOAT_OK license floats on the network and allows a single use. Therefore, up to two users can use "f1" on the end user's network, except on the license server machine itself, where the license use is disallowed.
If an end user wants to work at home, the end user installs a license file that contains the FEATURE line node-locked to FLEXID=7-b28520b9 (this only needs to be done once), transfers the FLEXid FLEXID=7-b28520b9 from the license server machine to the client computer, and installs the FLEXid driver on the client computer (this also only needs to be done once). The end user disconnects the client computer from the network and uses the transferred FLOAT_OK license on the client computer. The license server system allows only the single remaining FLOAT_OK license to float on the network.
After returning the FLEXid to the license server machine, the end user (or the system administrator) runs
lmreread
so the returned license can float again.
FLEXnet Licensing Version Notes
License Borrowing with BORROW
If a license is to be used on a computer that is intermittently connected to a license server system, that license can be issued as a floating license with the BORROW keyword. A BORROW license can be borrowed from a license server system via a special checkout and used later to run an application on a computer that is no longer connected to the license server system. License borrowing must be enabled by a vendor before an end user can borrow licenses.
With license borrowing, a vendor issues a floating license with a FEATURE line that contains the BORROW keyword. An end user specifies the expiration date a borrowed license is to be returned and runs the application while connected to the network which writes borrowing information on the client computer. The license server system keeps the borrowed license checked out. The FLEXenabled application automatically uses the local borrowing data to do checkouts during the borrow period. If enabled by the vendor, borrowed licenses can be returned early, that is, before the borrow period expires. Upon the earlier of either the expiration of the borrow period or the early return of a borrowed license, the local borrowing data no longer authorizes checkouts and the license server system returns the borrowed license to the pool of available licenses. No clock synchronization is required between the license server machine and the machine running the FLEXenabled application.
Initiating License Borrowing
If a vendor has enabled license borrowing by issuing a license file that contains a FEATURE line with the BORROW keyword, an end user initiates license borrowing in one of three ways:
Application Interface
The user initiates license borrowing this way only if the application provides a borrowing interface. Information about this is supplied by the vendor.
Running the lmborrow Utility
lmborrow
is one of thelmutil
/LMTOOLS utilities. To initiate borrowing, the user runslmborrow
from the command line or through LMTOOLS:lmborrow {
vendor
|all}enddate
[time
]where
vendor
is the vendor daemon that serves the licenses to be borrowed, orall
specifies all vendor daemons in the license server system.enddate
is the date the license is to be returned indd
-
mmm
-
yyyy
format.time
is optional and is specified in 24-hour format (hh
:
mm
) in the FLEXenabled application's local time. Iftime
is unspecified, the checkout lasts until the end of the given end date.For example:
lmborrow sampled 20-aug-2001 13:00
Setting the LM_BORROW Environment Variable Directly
The
lmborrow
utility is a user interface to setLM_BORROW
in either the registry (Windows) or in$HOME/.flexlmborrow
(UNIX).LM_BORROW
can also be set directly as an environment variable:
today
:{vendor
|all}:enddate
[:time
]where:
For example:
LM_BORROW=15-aug-2001:sampled:20-aug-2001:13:00
In this example, one or more licenses served by the
sampled
vendor daemon are borrowed on August 15, 2001, and are scheduled to be returned at 1 pm on August 20, 2001.Borrowing a License
To borrow a license for a desired feature, on the same day and the same machine that the end user runs
lmborrow
or setsLM_BORROW
(and while still connected to the network), the end user runs the application to check out and borrow the license. If the end user runs the application more than once that day, no duplicate license is borrowed. No license is borrowed if the application is run on a day different than the date borrowing was set to be initiated.For example, say that today you want to borrow a license for the PageWizard feature for a week. The PageWizard feature is served by the
sampled
vendor daemon. Today, while you are connected to the network, runlmborrow
or setLM_BORROW
directly. For example:lmborrow sampled
enddate
Today, after you run
lmborrow
, while you are connected to the network, run the application that checks out a license for the PageWizard feature. After the license is checked out, close the application and disconnect your machine from the network. The license that you just checked out stays checked out from the license server system until the borrow period expires-that license now is used on your disconnected machine until the borrow period expires. Once checked out, it remains checked out for the full borrow period. The borrow period cannot be renewed until the period has expired.Clearing the Borrow Period
Once you have borrowed all the licenses that you need for the current borrow period (defined by the
LM_BORROW
environment variable), prevent licenses for any additional features from being borrowed by runninglmborrow -clear
. This clears the LM_BORROW setting in the registry (Windows) or$HOME/.flexlmborrow
(UNIX).lmborrow -clear
does not clear the local information about licenses you have already borrowed.Checking Borrow Status
To print information about borrowed features, issue the following command on the machine from which they are borrowed:
lmborrow -status
The borrowing system does not have to be connected to the network to determine the status.
Returning a Borrowed License Early
To return a borrowed license before the borrow period expires, first reconnect the borrowing system back to the network and then, from the same machine that initiated the borrowing, issue the command:
lmborrow -return [-c
license_file_list
]feature
This option may or may not be allowed by your vendor. Check directly with your vendor to determine if early borrowed-license return is supported.
Returning the license early has the effect of clearing the LM_BORROW setting for the vendor daemon that serves the returned license.
Support for License Borrowing
See the following sections for more information about the utilities and end-user options that support license borrowing:
FLEXnet Licensing Version Notes
Node-locked to a User Name
If a license is to be used exclusively by one user on different machines, that license can be node-locked to the user's user name. The license file is copied to the different machines on which the user might work; the user's user name must be identical on each machine. For this method to be useful, individual user names in an organization need to be unique.
Fulfilled from a Prepaid License Pool
In this method, the end user buys a prepaid number of license-days from the vendor. The end user can then fulfill a license using a partial amount of the total license-days for the given borrow period, node-locked to a particular machine. For example, in preparation for a business trip (or even during a business trip), the end user fulfills a license that expires in 5 days that is node-locked to their laptop. Each fulfillment can be node-locked to a different machine (or even multiple times to the same machine), thus allowing mobility of license usage within the pre-paid number of license-days.
This model is like pay-per-use because each fulfillment is made from a decreasing number license-days. It is different than other pay-per-use models because, once node-locked to a machine, that machine is allowed unlimited use of the application until the license expires. This short-term license cannot be returned early; once fulfilled, those license-days cannot be refunded. Other pay-per-use models charge based on the number of times the application is used.
FLEXnet Licensing End User Guide |
Version 10.8 |
July 2005 |
copyright |