Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

...

...

...

...

...

...

...

Table of Contents

Overview


FIX Edge Java is an application server providing FIX connectivity to multiple clients. Client applications communicate with FEJ through one of the multiple transport protocols (e.g. Simple Sockets, TIBCO, CORBAJMS, HTTPs) employing transport adaptors. It is designed to be as easy as possible to install, configure, administrate, and monitor trading information flows. It is written in Java and has a performance profile suitable for the needs of all clients up to and including large sell-side institutions and large-volume traders.

System Requirements

To get started, make sure your system has Java JDK 8.

Code Block
languagebash
$ java -version
java version "1.8.0_60"
Java(TM) SE Runtime Environment (build 1.8.0_60-b27)
Java HotSpot(TM) 64-Bit Server VM (build 25.60-b23, mixed mode)

Installation

To get started, you need to download the FEJ distribution. You should end up downloading a compressed ZIP file named something like fixedgej-1.0.0.zip. Once you have downloaded the FEJ zipball, installing and setting up a standalone FEJ node is pretty simple and straightforward. Let’s extract the compressed zip archive into /usr/share. On Linux, Mac OS X, or any other UNIX-like system you can use the following command to extract the distribution:

Code Block
languagebash
$ unzip fixedgej-1.0.0.zip -d /usr/share
$ cd /usr/share/fixedgej-1.0.0/
$ ls
CDDL-license.txt               apache-license-2.0.txt  bin   icons  license.txt  scripts    tmp          wrapperApp.jar
FixEdgeJavaVersionHistory.txt  bat                     conf  lib    log          templates  wrapper.jar

If you are using Windows, you will need to use a decompression tool such as WinZip to extract the distribution.

In the distribution directory you will find a bin directory that contains the scripts needed to start FEJ on UNIX platforms (Linux, Mac OS X, etc.) and a `bat' directory that contains the scripts for Windows. The conf directory holds configuration files. The lib directory contains Java JAR files, which are third-party files needed to run FEJ.

Once we have extracted the zipball, the next thing is to configure and start FEJ.

Starting the FEJ container on Windows (Unix)

Now, let’s go ahead and start FEJ. All FEJ administration scripts to start/stop the container for Windows are shipped along with the archive in the bat folder with the following content (Unix: similar in the bin folder):

Code Block
languagebash
$ pwd
/usr/share/fixedgej-1.0.0/bat
$ ls
installService.bat  runConsoleW.bat               setenv.bat        systemTrayIcon.bat    wrapper.bat
queryService.bat    runServicesManagerClient.bat  startService.bat  sytemTrayIconW.bat    wrapperW.bat
runConsole.bat      runServicesManagerServer.bat  stopService.bat   uninstallService.bat

To start FEJ as a console application on Windows system, you need to execute the runConsole.bat (unix: ./runConsole.sh):

Code Block
languagebash
$ ./runConsole.bat

To avoid going to the FEJ install directory to run these scripts, you can include it in your PATH variable as follows:

Code Block
languagebash
$ export PATH=$PATH:/usr/share/fixedgej-1.0.0/bat

To start FEJ as a Windows service you first need to install it. To install the application as a service execute installService.bat (unix: ./installDaemon.sh).

Info

You need to have administrative privileges to run these script.

A successful installation of the container will show the following output:

Code Block
languagebash
$ ./installService.bat

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>cd C:\cygwin64\usr\share\fixedgej-1.0.0\bat\

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>call setenv.bat
"java" -Xmx30m -Djna_tmpdir="C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../tmp"
-Djava.net.preferIPv4Stack=true -jar "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../wrapper.jar"
-i "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../conf/wrapper.conf"
YAJSW: yajsw-alpha-12.00
OS   : Windows 7/6.1/amd64
JVM  : Oracle Corporation/1.8.0_60/D:\Program Files\Java\jre1.8.0_60/64
Oct 13, 2015 11:59:16 AM org.apache.commons.vfs2.VfsLog info
INFO: Using "C:\cygwin64\tmp\vfs_cache" as temporary files store.
************* INSTALLING FixEdgeJava ***********************

.
<some omitted output>
.

Service FixEdgeJava installed 
Press any key to continue . . .

Service installation completes successfully.

We are now ready to start the service. Run the startService.bat (unix: ./startDaemon.sh):

Code Block
languagebash
$ ./startService.bat

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>cd C:\cygwin64\usr\share\fixedgej-1.0.0\bat\

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>call setenv.bat
"java" -Xmx30m -Djna_tmpdir="C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../tmp"
-Djava.net.preferIPv4Stack=true -jar "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../wrapper.jar"
-t "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../conf/wrapper.conf"
YAJSW: yajsw-alpha-12.00
OS   : Windows 7/6.1/amd64
JVM  : Oracle Corporation/1.8.0_60/D:\Program Files\Java\jre1.8.0_60/64
Oct 13, 2015 12:10:33 PM org.apache.commons.vfs2.VfsLog info
INFO: Using "C:\cygwin64\tmp\vfs_cache" as temporary files store.
************* STARTING FixEdgeJava ***********************

Service FixEdgeJava started 
Press any key to continue . . .

Service starts successfully.

To stop the service, you can use stopService.bat script (unix: ./stopDaemon.sh):

Code Block
languagebash
$ ./stopService.bat

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>cd C:\cygwin64\usr\share\fixedgej-1.0.0\bat\

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>call setenv.bat
"java" -Xmx30m -Djna_tmpdir="C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../tmp"
-Djava.net.preferIPv4Stack=true -jar "C:\cygwin64\usr\share\fixedgej-
1.0.0\bat\/../wrapper.jar" -p "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../conf/wrapper.conf"
YAJSW: yajsw-alpha-12.00
OS   : Windows 7/6.1/amd64
JVM  : Oracle Corporation/1.8.0_60/D:\Program Files\Java\jre1.8.0_60/64
Oct 13, 2015 12:13:36 PM org.apache.commons.vfs2.VfsLog info
INFO: Using "C:\cygwin64\tmp\vfs_cache" as temporary files store.
************* STOPPING FixEdgeJava ***********************

Service FixEdgeJava stopped 
Press any key to continue . . .

Service stopped successfully.

Finally, if you want to uninstall the service run uninstallService.bat (unix: ./uninstallDaemon.sh):

Code Block
languagebash
$ ./uninstallService.bat

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>cd C:\cygwin64\usr\share\fixedgej-1.0.0\bat\

C:\cygwin64\usr\share\fixedgej-1.0.0\bat>call setenv.bat
"java" -Xmx30m -Djna_tmpdir="C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../tmp"
-Djava.net.preferIPv4Stack=true -jar "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../wrapper.jar"
-r "C:\cygwin64\usr\share\fixedgej-1.0.0\bat\/../conf/wrapper.conf"
YAJSW: yajsw-alpha-12.00
OS   : Windows 7/6.1/amd64
JVM  : Oracle Corporation/1.8.0_60/D:\Program Files\Java\jre1.8.0_60/64
Oct 13, 2015 12:15:39 PM org.apache.commons.vfs2.VfsLog info
INFO: Using "C:\cygwin64\tmp\vfs_cache" as temporary files store.
************* REMOVING FixEdgeJava ***********************

Service FixEdgeJava removed 
Press any key to continue . . .

Service was removed successfully.

Configuration

This section will acquaint you with the basic information used during the configuration of the application.

All of the information in the configuration files is read at startup, meaning that any change to the files necessitates a restart of the application.

The conf folder holds the configuration files for FEJ.

...

languagebash

...

Installation

Get the License File

The FIXEdge Java license file can be obtained upon request to the Sales team. The license has an expiration date but it is possible to generate a perpetual license. License information is stored in the fixaj2-license.bin file for FIXEdge Java versions earlier than 1.10.3. Since FIXEdge Java 1.10.3 the license information is stored in the fixedgej-license.bin file. The license file is expected to be placed in the FIXEdge Java config.rootpath=./conf directory. In order to apply for a new license, it is enough to replace the current file with a newer one and restart FIXEdge Java.

Please, refer to the How to update license files article for additional information.

See in detail the step-by-step guides:

Testing

Set up the Echo Configuration to make sure that all components were deployed correctly. The test consists of sending a FIX message from FIX Client Simulator (aka Simple Client) to FIXEdge Java server and returning the same message back to Simple Client. The tool is based on .NET technologies and can be used to Simulate FIX buy and/or sell-side endpoints.

To perform the test download the FIX Client Simulator and follow the instructions from the How to configure Echo between FIXEdge Java and Simple Client article.

System Requirements

To get started, make sure your system has Java 8 or higher.

Note
titleImportant

Functionality was tested with Java 8. Higher versions of Java are also supported, but may require additional configuration changes.


Code Block
languagebash
$ java -version
java version "1.8.0_60"
Java(TM) SE Runtime Environment (build 1.8.0_60-b27)
Java HotSpot(TM) 64-Bit Server VM (build 25.60-b23, mixed mode)

Configuration

This section will acquaint you with the basic information used during the configuration of the application.

All of the information in the configuration files is read at startup, meaning that any change to the files necessitates a restart of the application.

The 'conf' folder holds the configuration files for FEJ.

Code Block
languagebash
C:\usr\share\fixedgej\conf>ls -la
total 39
drwxr-xr-x    1 root root     8192 Apr  4 15:30 .
drwxr-xr-x    1 root root     4096 Apr  4 15:25 ..
-rw-r--r--    1 root root     3280 Mar 24 14:20 cluster.xml                                            (1)
-rw-r--r--    1 root root     1462 Mar 24 14:20 sysconf/fej-context.xml                                (2)
-rw-r--r--    1 root root     1273 Mar 24 14:20 sysconf/fej-jms.xml                                    (3)
-rw-r--r--    1 root root     2562 Mar 24 14:20 sysconf/fej-monitoring.xml                             (4)
-rw-r--r--    1 root root     2745 Mar 24 14:20 sysconf/fej-replication.xml                            (5)
-rw-r--r--    1 root root     2837 Apr  3 20:36 sysconf/fej-routing.xml                                (6)
-rw-r--r--    1 root root     1655 Mar 24 14:20 sysconf/fej-scheduling.xml                             (7)
-rw-r--r--    1 root root     2502 Mar 24 14:20 sysconf/fej-security.xml                               (8)
-rw-r--r--    1 root root     1764 Mar 24 14:20 sysconf/fej-server.xml                                 (9)
-rw-r--r--    1 root root     2122 Mar 24 14:20 fixedge.properties                                     (10)
-rw-r--r--    1 root root      659 Mar 24 14:20 fixengine.properties                                   (11)
-rw-r--r--    1 root root     3196 Mar 24 14:20 jms-adaptor.properties                                 (12)
-rw-r--r--    1 root root     81921298 AprMar 24 4 1514:3020 log4j2.
drwxr-xr-xxml         1 root root     4096 Apr  4 15:25 .. -rw-r--r--    1 root root     3280 Mar 24 14:20 cluster.xml  							(1)
-rw-r--r--        (13)
drwxr-xr-x    19 root root     4096 1462Apr Mar 244 1415:20 fej-context.xml 						(2)
-rw-r--r--    1 root root25 reject                                            1273 Mar 24 14:20 fej-jms.xml 							(3(14)   
-rw-r--r--    1 root root     25623782 Apr Mar 244 14:2007 fej-monitoring.xml 						(4replication.properties                                 (15)
-rw-r--r--    1 root root     2745 313 Mar 24 14:20 fej-replicationrules.xml 						(4)
-rw-r--r--groovy      1 root root     2837 Apr  3 20:36 fej-routing.xml 						(5) -rw-r--r--    1 root root     1655 Mar 24 14:20 fej-scheduling.xml 						(6            (16)
-rw-r--r--    1 root root     2502 287 Mar 24 14:20 fej-securityschedules.xml 						(7)
-rw-r--r--       1 root root     1764 Mar 24 14:20 fej-server.xml 							(8)
-rw-r--r--    1 root root     2122 Mar 24 14:20 fixedge.properties  -rw-r--r--    1 root root (17)
drwxr-xr-x    3 659root Marroot 24 14:20 fixengine.properties  -rw-r--r--   0 1Apr root root4 15:25 session   3196 Mar 24 14:20 jms-adaptor.properties  -rw-r--r--    1 root root     1298 Mar 24 14:20 log4j2.xml 
drwxr-xr-x             9 root root     4096 Apr  4 15:25 reject (18)
-rw-r--r--    1 root root     3782 Apr383 Mar 424 14:0720 replicationshell.properties  -rw-r--r--    1 root root      313 Mar 24 14:20 rules.groovy                       (19)
-rw-r--r--    1 root root      287 30 Mar 24 14:20 schedulesusers.xmlproperties  drwxr-xr-x    3 root root        0 Apr  4 15:25 session  -rw-r--r--    1             (20)
-rw-r--r--    1 root root      38310835 Mar 24 14:20 shell.properties 
-rw-r--r--    1 root root       30 Mar 24 14:20 users.properties 
-rw-r--r--    1 root root    10835 Mar 24 14:20 wrapper.conf 20 wrapper.conf                                           (21)
  1. Hazelcast cluster configuration. See Cluster Service.
  2. Main Spring application context.
  3. JMS related beans. See JMS Transport Adapter.
  4. JMX and SSH related beans.
  5. Replication-related beans.
  6. Routing related beans.
  7. Scheduler configuration.
  8. Spring Security configuration. See Security configuration.
  9. FIX server configuration.
  10. FEJ configuration properties.
  11. FIXAJ configuration properties. See FIX Antenna Java configuration.
  12. JMS adaptor configuration properties. See JMS Transport Adapter.
  13. Logging configuration. See Logging configuration.
  14. Directory with templates for FIX reject messages
  15. Replication service configuration. See Replication Service.
  16. Custom routing rules go here. See Routing Rules.
  17. Custom scheduler tasks go here.
  18. Directory with session configuration. See FIX Session configuration.
  19. Remote shell configuration. See Administrative shell configuration.
  20. Properties file containing users for in-memory authentication. See In-Memory Authentication.
  21. Wrapper configuration. See Wrapper configuration.

Management

FIXEdge Java can be managed with Remote Shell and with the scripts to start/stop FIXEdge as a service/daemon. Also, there are additional options for FIXEdge for Windows.

More information about Remote Shell is presented in FIXEdge Java Administration.

Starting FIXEdge Java

Steps for Windows

  1. Run FIXEdge Java as a service in Windows Services
    • Go to Administrative tools --> Services. Find FIXEdgeJava service and select 'Start' option in the context menu.
  2. Run FIXEdge Java as a console application
    • Go to the B2BITS\fixedgej-x.x.x\bat\ and run the 'runConsole.bat' script.

Steps for Linux

  1. Run FIXEdge Java as a daemon with the script
    • Go to /home/user/B2BITS/fixedgej-x.x.x/bin and run the 'startDaemon.sh' script with sudo user rights.
  2. Run FIXEdge Java as a console application
    • Go to the /home/user/B2BITS/fixedgej-x.x.x/bin and run the 'runConsole.sh' script with sudo rights.

Stopping FIXEdge Java

Steps for Windows

  1. Stop FIXEdge Java service with the script
    • Go to the B2BITS\fixedgej-x.x.x\bat\ and run the 'stopService.bat' script as Administrator.
  2. Stop FIXEdge Java service with Windows Services
    • Go to Administrative tools --> Services. Find FIXEdgeJava service and select 'Stop' option in the context menu.
  3. The console version of FIXEdge Java can be stopped by pressing “Ctrl+C” keys combination.


Steps for Linux

  1. Stop FIXEdge Java daemon with the script
    • Go to /home/user/B2BITS/fixedgej-x.x.x/bin and run the 'stopDaemon.sh' script with sudo user rights.
  2. The console version of FIXEdge Java can be stopped by pressing “Ctrl+C” keys combination.

Session Management

Sessions can be configured, started, or stopped in the Remote Shell, see FIX Session management.

Analyzing Log Files with FIXEye

All log files with incoming and outgoing FIX messages can be viewed via FIXEyeFIXEye is a multi-purpose FIX session surveillance and visibility platform. 

See more about the FIX log analyzer here: FIXEye User Guide.

Useful Links

Frequently asked questions and "How to" articles can be found here: "How to" instructions