These instructions describe installing the GsDevKit tODE client on a desktop machine, on a different node than the GsDevKit server (stone) will be running. You should first install the GsDevKit server, on the node you will use as the server.
You must first have git installed, and be in the directory in which you want to install. In the git bash shell on windows, to reduce issues with path length, this should be ~ (i.e., cd ~
).
Note that you need to specify the same GemStone version (here, 3.3) as the server you installed or intend to use.
git clone https://github.com/GsDevKit/GsDevKit_home.git
cd GsDevKit_home
export GS_HOME=`pwd`
export PATH=$GS_HOME/bin:$PATH
installClient 2>&1 | tee $GS_HOME/install.log
downloadGemStone 3.3.0 2>&1 | tee -a $GS_HOME/install.log
createClient tode1 2>&1 | tee -a $GS_HOME/install.log
Note: On Windows, a Pharo usage dialog may pop up on your desktop. Press enter and the installation will complete correctly.
After executing this script, there are additional steps to connect to your server.
Clients may be installed on Linux, Mac or Windows.
- Determine your installation directory and clone GsDevKit_home to that location
Install from the directory in which you want the GsDevKit checkout to be located. On Windows, it is strongly recommended to install in the root of the user's home directory (cd ~
), to avoid path length restrictions.
You must use bash; on Windows, the Git Shell executable provided by the GitHub desktop.
cd <githubdirectory>
git clone https://github.com/GsDevKit/GsDevKit_home.git
cd GsDevKit_home
-
Set the environment
The environment variable $GS_HOME and the updated $PATH are required to use DevKit, so you should add them to your
.bashrc
or another initialization script.export GS_HOME=<githubdirectory> export PATH=$GS_HOME/bin:$PATH
-
Perform the Client installation
The installation is performed by GsDevKit scripts. These scripts takes care of cloning the required projects to your client and downloading the GemStone client.
you will need to know the version of the GsDevKit stone on your server; the client GemStone needs to be the compatible version.
Script to install the client:
installClient downloadGemStone <myGemStoneVersion>
The
installClient
script invokes the following sub-scripts:installOsPrereqs cloneGsDevKitProjects cloneSharedTodeProjects setupGsDevKit
-
Create the client The client (e.g., tODE) is created using the
createClient
script.
createClient <myClientName>
You may use any name for <myClientName>
, to distinguish it from other clients you may later create on this node. The examples below use tode1 as the client name.
Note: On Windows, a Pharo usage dialog may pop up on your desktop. Press enter and the installation will complete correctly.
You now have an instance of the tODE client installed on your client machine.
Connecting the client to the server is a matter of establishing a port that both the client and server can use and ensuring they look for the same port number.
This diagram shows the main components of the system; the ongoing connection is to the NetLDI via the port.
To establish the connection between the client and the server, a server process called the NetLDI listens on a well-known port, and the client must be configured to contact the server on this port. If the server and client machines are not on the same local network, you will also need to setup SSH port forwarding for this port.
Before starting the server, it is recommended to assign a reserved port number to a named NetLDI by adding an entry to the network services database, e.g. /etc/services. For example,
devKit_330_ldi 50378/tcp # Gemstone netldi
If not, you will need to lookup the port number that the system has assigned to the NetLDI for the GsDevKit server (stone) instance that this client will connect to. To do this, on the server node, execute the stones
command. this will return results similar to this:
$ stones
=================
GsDevKit script: stones
path: /benton1/users/lalmarod/github/GsDevKit_home/bin/stones
=================
Installed Stones:
3.3.0 devKit_33
Running Stones:
Status Version Owner Pid Port Started Type Name
------- --------- --------- ----- ----- ------------ ------ ----
exists 3.3.0 lalmarod 17175 45690 Feb 09 13:35 Stone devKit_33
Running Netldis:
Status Version Owner Pid Port Started Type Name
------- --------- --------- ----- ----- ------------ ------ ----
exists 3.3.0 lalmarod 15452 48334 Feb 01 13:48 Netldi devKit_33_ldi
The value in the Port column for the NetLDI, in this case 48334, is the required value.
To setup SSH port forwarding, you will connect the local port to the port on the remote server, using the -L argument to ssh; -L <localPort>:<hostNameOrIP>:<remotePort>
. You should also configure TCP Keeplives on the connection.
We are using the same port number on the client and server. In GemStone/S 64 Bit v3.2 and later, you only need to connect a single port, which can be used for multiple socket connections.
ssh -o TCPKeepAlive=no -o ServerAliveInterval=300 -o ServerAliveCountMax=3 <remoteUserId>@<remoteHost> -L <localPort>:<localhost>:<remotePort>
for example, if the server (stone) is running on a machine with the IP address 192.168.100.129, and the user name on the server is lalmarod, you could use:
ssh -o TCPKeepAlive=no -o ServerAliveInterval=300 -o ServerAliveCountMax=3 [email protected] -L 44834:localHost:44834
If you do not have passwordless ssh setup, you will be prompted for your password.
Your shell is now ssh'ed into the server. You will need to leave this shell connected in order to maintain the ssh port tunnel, so open another shell to start up the client.
If you have a firewall, you will need to open this port.
-
Edit your
.bashrc
, or create another intialization file, to include the lines:export GS_HOME=`pwd` export PATH=$GS_HOME/bin:$PATH
these will be needed to use tODE.
-
From the server installation, copy the server specification file to the client. This file is
$GS_HOME/sys/local/sessions/<myServerNodeName>
If you are using the same name as these examples, it will be named:
$GS_HOME/sys/local/sessions/devKit_33
to the same path on the client node.
- Edit this file to specify the server NetLDI port, and the gemHost localHost. The line item #netLDIPort : should be set to the port, and the line item #gemHost set to localHost or 127.0.0.1. The lines in this file may read, for example:
...
#gemHost : 'localHost',
#netLDI : 'devKit_33_ldi',
#netLDIPort : '48334',
#gemTask : 'gemnetobject',
...
While your Gem will actually be hosted on the remote server, by using ssh tunnelling you have setup such that it appears to your client that the NetLDI is on the local machine at the given port; and this port is inherited by the Gem, so the Gem also appears (from the point of view of the client) to be on the local machine at the given port. By opening up this port in your firewall, your tODE client can fully communicate with the remote Gem.
- Start your client
startClient tode1
- To confirm you are connected to your server, and for further details on using tODE, see Getting started with tODE