Jadex Platform

For Active Components to be executed, a Platform needs to be running. The Jadex Platform provides important runtime services such as lifecycle management, remote service invocation and component management. For more information about services provided by the Jadex Platform itself, skip to Platform services.

This chapter will explain how to start a Jadex Platform from Java code (i.e. the main() method), so in consequence, components can be started on this platform.

Starting a Platform

Starting a platform with default parameters is easy. Use the jadex.base.Starter class:

IFuture<IExternalAccess> fut = Starter.createPlatform()
IExternalAccess platform = fut.get();

The object returned by Starter.createPlatform() is called a Future. It represents a result that is not yet available - method calls returning a Future will typically return it instantly. Futures are used for asynchronous programming - please refer to chapter Futures.
Using get() will block until the result is available so you can work with it.

If you want to adjust the platform to your needs, you can pass a PlatformConfiguration object:

PlatformConfiguration platformConfig = PlatformConfiguration.getDefault();

// Pass to Starter:
IExternalAccess platform = Starter.createPlatform(platformConfig).get();

The IExternalAccess object returned by the starter plays an important role for interaction with the platform, so be sure to keep it accessible.

Now that you know how to start a Jadex Active Components Platform you can proceed to Components to see how to implement your own components and start them.

Configuring the Platform

The PlatformConfiguration provides many ways to configure the platform. Some of them are listed below. For further information, please see the API documentation of PlatformConfiguration.

The configuration options are also explained in more detail here.

Configuration examples

Here you can find some examples for commonly used configuration options.

Run without GUI (JCC) and CLI:

platformConfig.setGui(false);
platformConfig.setCli(false);

Enable logging (useful for debugging):

platformConfig.setLogging(true); // enables the printing of info and warning messages in addition to severe messages.

Enable future debugging:

platformConfig.setDebugFutures(true); // enables stacktraces of exceptions

Do not print password or welcome message on startup:

platformConfig.setWelcome(false);
platformConfig.setPrintPass(false);

Set platform name:

platformConfig.setPlatformName("jadexplatform");

Set available component kernels:

rootConfig.setKernels(PlatformConfiguration.KERNEL.micro,
                PlatformConfiguration.KERNEL.component,
                PlatformConfiguration.KERNEL.v3);

Disable platform awareness:

platformConfig.setAwareness(false);

Set Awareness mechanisms:

platformConfig.setAwaMechanisms(PlatformConfiguration.AWAMECHANISM.broadcast, 
    PlatformConfiguration.AWAMECHANISM.relay);

Disable Password protection (Caution!):

platformConfig.setUsePass(false);

Platform services

Sorry, this section is not yet available.

Packaging an Application

If you deploy your application to end users you will want to have some deployment package of your application that can be started by a double-click.

Alternative 1: Executable Jar

When you develop with eclipse you are almost done, because eclipse allows exporting a project directly as an executable jar file. An executable jar is in the essence a zip file including your Java classes and contains additional meta information, so that Java knows which main class to start, when the jar file is executed.

  • Make sure that you have an up-to-date launch configuration and that your application works as expected.
  • Right-click on the project and choose Export...
  • In the appearing dialog choose Java -> Runnable JAR File and hit Next > (see image for step 1).
  • In the next dialog, choose your launch configuration to be exported, the target file name and specify the library handling (see image for step 2).

09 Application Integration@export1.png
Exporting a jar file (step 1)

In the second step as shown below you can specify the way the dependencies of the application are exported. Your application depends on the jars from the Jadex distribution. You can either extract, package, or copy the required libraries. Extraction means that classes and support files from the dependency jars are extracted and repackaged directly in the newly produced jar file. For packaging, the dependent jar files are kept unchanged but are included in the new jar file, such that as before only one output file is produced. In the last option 'copy' the dependencies are stored in a separate folder besides the generated jar. Which option you choose is mostly a matter of taste.

09 Application Integration@export2.png
Exporting a jar file (step 2)

  • Export your application with the chosen options.
  • Test the exported application by double-clicking on the jar file.

Alternative 2: Launch Script

If you are a little bit used to Java, you may know that you can start an executable jar as produced in the last section by typing 'java -jar filename.jar' in the console. Therefore you can use the same command in a .bat file (on Windows) or an .sh script (on Linux). But it is also quite easy to start your application from the console or a batch script even without producing an executable jar file.

  • Locate the jadex-platform-standalone-launch-3.0.117.jar from the Jadex distribution (the version number might differ depending on which Jadex version you use).
  • Create a batch file (.bat or .sh) in your eclipse project using right-click New -> File
  • Open the script in a text editor and add the following line for windows:
java -classpath "<path to jadex launch jar>;bin" mypackage.Main
  • or for Linux (note the ':' instead of the ';'):
java -classpath "<path to jadex launch jar>:bin" mypackage.Main
  • Of course in both scripts you have to change the path to the Jadex launch jar to the actual value on your system and also change the package, if your package is not name 'mypackage'.
  • The scripts assume that your compiled classes are in the bin directory, which is the default for eclipse. Your directory structure should look like the following:

09 Application Integration@script.png
Location of start scripts