Let us suppose you have received a 2-user license for a module. Normally you will have obtained a floating license, meaning that you will be able to use the module from any machine, and two users can be busy with it at the same time.
Server side: The License Manager Daemon
To be able to enforce the license, there must be a piece of software somewhere that keeps track of who is using the module. That is the License Manager Daemon (LMD). The LMD can run on any machine, also on machines that you will never use the module itself on. Good candidates are stable UNIX servers.
When the LMD is started, it looks at a file containing the information about what should be supported. This file is called the License File. Actually, the LMD can only be started on the machine indicated in the license file. The license file could look like this:
SERVER licserv 000347e8b845
VENDOR dgbld /apps/opendtect/7.0.0/bin/lux64/lm.dgb/dgbld
FEATURE dTect dgbld 2022.12 1-jan-2023 2 6592FDC619EA DUP_GROUP=D
FEATURE dTectDS dgbld 2022.12 1-jan-2023 2 011D5153D870 DUP_GROUP=D
The first line tells us that the LMD must be started on the machine licserv
, with FlexNet ID 000347e8b845
. The second line is interesting for the LMD only but then you see two actual license FEATURE
lines (dTect
and dTectDS
). These licenses are valid for software that have been released up to december 2022, until the 1st of January 2023, for two users (2022.12 1-jan-2023 2
).
The Client side: Your program
Now let's look at the machine that you run your software on. The program will at some point in time need to check whether there is a license for what you are trying to do. For this, the program looks at the same license file. It sees that it has to contact the machine 'licserv' to ask for permission. The LMD keeps track of the number of users already using the license feature. If a license is granted, your program will go on, otherwise you'll get an error message.
Non-floating licenses
In some cases the software will never be used other than on a certain machine. In that case a node-locked license can be issued. For such a license you do not need to start a license manager daemon - an unlimited number of users can use the module at the same time provided they work on that particular machine. A special case is the unlimited demo license, which grants unlimited access for any number of users on any machine. It goes without saying that this kind of license is always for short periods.
Host identification
For the above schemes to work, the license server or the running machine must be uniquely identified. Therefore, you will be asked to provide a unique host ID and a hostname when you want to obtain a license. Different operating systems require different ways to obtain this information:
- Windows: On windows, there is a FlexNet utility that delivers both in a simple file that can be sent by e-mail. It is delivered together with commercial plugins so you need to install one of those first. From the Start menu, select OpendTect > License Manager Tools. Select the tab 'System Settings'. Then push the 'Save HOSTID Info to a File' button
- Linux and macOS: The hostname is obtained with the unix command hostname. The host ID differs per distribution, but can always be obtained by the 'lmhostid' tool. This tool is delivered with OpendTect, and can be run from the Utilities > Batch Programs dialog.
If you need to obtain the host ID before OpendTect is installed:
- Windows: Open a 'command prompt' (For example, by running 'cmd') and issue a command like:
ipconfig /all > c:\Temp\ipcfg.txt
You can send ipcfg.txt or look for the 'Physical address' - Linux and macOS: Run
ifconfig
in a terminal. Or if ifconfig is not installed runip a
. Look forHWAddr
orether
. You want the MAC address, looking likexx:xx:xx:xx:xx:xx
- that's 6 groups of 2 hex numbers. Example:00:1C:C0:38:22:F1
. Usually you would want to provide the one that is reported with devicename eth0 or eno1. In doubt you can provide all.
If for some reason one of these commands does not work: we need the MAC address of the main network card. Sending the IP address of a machine is never helpful.
Conclusion (Manager's summary)
The FlexNet license system is based upon internet technology. Therefore you can run your software on any machine, using any operating system, to get licenses from any other machine regardless of operating system or physical location. Thus, a Linux license server in Houston can manage the licenses for Windows, Linux and macOS machines in Houston, Caracas and Paris. The only restriction is the number of users actually using the 'feature' at a certain time, but that is what you pay for.
For more information, see FlexNet Licensing End User Guide.