Apache VCL logo Apache Software Foundation logo
Apache current event

Connect Methods

Overview

A connect method is the software used to connect to a reserved node.

Before 2.3, there were only a few, fixed connect methods used - RDP for Windows and ssh for Linux. In 2.3, the first stage of configurable connect methods was introduced. Potentially any connect method can now be configured for an image. For stage one, VCL admins must manually add available connect methods to the VCL database. Stage two will provide a way for available connect methods to be managed through the VCL web site.

There are two types of connect methods: those that can be automatically provisioned by vcld (or are considered to be part of an OS by default) and those that must be manually installed in the image by the image maintainer. Either type can be added to VCL and mapped to an image.

Connect Method schema

Understanding the connect method database schema is key to managing the available connect methods. There are two tables:

connectmethod definition:

connectmethodmap definition:

This table is “overloaded”, meaning it is used for two things. It both describes which connect methods can be mapped to an image/OS/OStype (entries with autoprovisioned set to 0 or 1) and which connect methods are mapped to an image/OS/OStype or not (entries with autoprovisioned set to NULL).

Only one of OStypeid, OSid, or imagerevisionid can have a non-NULL value. (i.e. A mapping is only done to an OS type or an OS or an image revision.)

The disabled field allows exceptions to be made. For example, if RDP is mapped to the Windows OS type, but there was an image where VNC should be used instead, entries would be added for any imagerevisionid of that image for RDP with disabled set to 1.

Default entries

The schema provided with Apache VCL 2.3 has four connect methods by default:

The default mapping for these methods is as follows:

Here are two of the actual table entries in connectmethodmap (values from referenced tables are in ()‘s):

connectmethodidOStypeidOSidimagerevisioniddisabledautoprovisioned
1 (ssh)2 (linux)NULLNULL01
2 (RDP)1 (windows)NULLNULL01
1 (ssh)2 (linux)NULLNULL0NULL
2 (RDP)1 (windows)NULLNULL0NULL

The first two entries listed above mean that those connect methods can be selected for being autoprovisioned for the specified OS. Specifically, the first entry means that on the edit image profile page for any linux images, ssh will be available as a connect method that can be selected for that image. The second entry means that on the edit image profile page for any windows images, RDP will be available as a connect method that can be selected for that image.

The second two entries mean that those connect methods are enabled for the specified OS. Specifically, the third entry means that on the edit image profile page for any linux images, ssh will be selected as one of the enabled connect methods. The fourth entry means that on the edit image profile page for any windows images, RDP will be selected as one of the enabled connect methods.

Examples

Adding VNC as an available option for Linux

In this example, we add VNC as an available connect method that can be selected on edit image profile page for any Linux images. However, we’ll set it with autoprovisioned set to 0, meaning that the image maintainer is responsible for installing VNC in the image.

First, we need to add VNC to the connectmethod table:

idnamedescriptionprotocolportconnecttextservicenamestartupscript
4VNCVNC on port 5900TCP5900(listed below)Xvnc/etc/init.d/vncserver start

This could be used as the connecttext:

You will need to have a VNC client on your local computer to connect to the system. 
Open your VNC client and use the following information when you are ready to connect:<br>
<UL><br>
<LI><b>Remote Computer</b>: #connectIP#</LI><br>
<LI><b>Remote Port</b>: #connectport#</LI>;<br>
<LI><b>User ID</b>: #userid#</LI><br>
<LI><b>Password</b>: #password#</LI><br>
</UL>

Next, we create an entry in the connectmethodmap table that allows VNC to be selected for any Linux images, but not as an autoprovisioned method (note that this only allows it to be selected, it does not actually assign it to be selected for anything):

connectmethodidOStypeidOSidimagerevisioniddisabledautoprovisioned
42NULLNULL00

Now, under the subimages section of the edit image profile page for any Linux images, “VNC on port 5900” will be available as a connect method that can be assigned. If it is selected, a warning message will be displayed stating that VCL cannot autoprovision VNC and that it must have already been installed in the image by the image maintainer.

Adding xRDP for Linux and Enabling it for OS type Fedora 16

In this example, we’ll add xRDP as an available option for any Linux images and set it as enabled for the OS type Fedora 16. We’ll use 23 as OS.id for Fedora 16.

First, we need to add xRDP to the connectmethod table:

idnamedescriptionprotocolportconnecttextservicenamestartupscript
5xRDPxRDPTCP3389(listed below)xrdp/etc/init.d/xrdp start

This could be used as the connecttext:

You will need to have an RDP client to connect to the system. 
Open your RDP client and use the following information when you are ready to connect:<br>
<UL><br>
<LI><b>Remote Computer</b>: #connectIP#</LI><br>
<LI><b>User ID</b>: #userid#</LI><br>
<LI><b>Password</b>: #password#</LI><br>
</UL>

Next, we create an entry in the connectmethodmap table that allows xRDP to be selected for any Linux images, and another entry that enables it for all Fedora 16 images.

connectmethodidOStypeidOSidimagerevisioniddisabledautoprovisioned
52NULLNULL00
5NULL23NULL0NULL

Now, under the subimages section of the edit image profile page for any Linux images, “xRDP” will be available as a connect method that can be assigned. If it is selected, a warning message will be displayed stating that VCL cannot autoprovision xRDP and that it must have already been installed in the image by the image maintainer. Additionally, for any Fedora 16 images, it will be listed as an assigned connect method by default (note: Fedora 16 does not include xRDP by default, it’s just being used an example here).

Understanding entries created by removing a default entry from an image

This is not something that a VCL admin would need to do manually in the database, but it is useful to understand what happens in the database when a connect method that is mapped by OS type or OS is removed from an image revision. Building on the xRDP example above, we start with the following entries in the connectmethodmap table, remember that connectmethod.id 5 is xRDP, OStype.id 2 is Linux, and OS.id 23 is Fedora 16:

connectmethodidOStypeidOSidimagerevisioniddisabledautoprovisioned
52NULLNULL00
5NULL23NULL0NULL

Let’s say we’ve created a web server image based on Fedora 16 from which we’ve removed X11, meaning that xRDP will no longer work as a connect method for this image. Instead, we just want to have ssh as the only connect method available for this image. We’d go to Manage Images->Edit Image Profiles->Edit for that image. Then, we’d expand the Advanced Options section, and click on Modify Connection Methods. Next, if ssh is not already enabled as a connect method, we’d select it from the drop-down box and click Add Method. Finally, we’d select xRDP from the list of enabled connect methods, and click Remove Selected Method(s). This final step of removing xRDP would add the following entry to the connectmethodmap table (we’ll use 582 as the imagerevisionid of the web server image):

connectmethodidOStypeidOSidimagerevisioniddisabledautoprovisioned
5NULLNULL5821NULL

The above entry means, “disable connect method 5 (xRDP) for image revision 582 (web server) even if it is enabled for the image’s OS or OS type”.

Screen Shots

Here are some screen shots to know what things look like in the web interface.

This image has the Connect Methods section of the Edit Image Profile page highlighted.

connect method region highlighted

This image has the Connect Methods dialog open.

connect method dialog opened