I want to thank Kirk Wylie for an excellent write up and detailed overview of the Solace hardware appliance. I recently started a new and we've began to leverage a Tibco Messaging Appliance which runs on one of these Solace devices. I thought his article gave great insights at a very high level.
Please check it out and follow Kirk!
http://kirkwylie.blogspot.com/2008/11/meeting-with-solace-systems-hardware.html
This is a techonology blog dedicated to high-performance trading, market data, and low latency infrastructure and technology.
Sunday, March 15, 2015
Monday, February 23, 2015
Low Latency
Low latency is a function of many things, the two most important ones being:
- network latency - i.e. the time taken on the network to transmit/receive messages.
- processing latency - i.e. the time taken by your application to act on a message/event.
So, if you are say writing an Order Matching system, the network latency would represent how soon within your network were you able to receive the order matching request. And processing latency would represent the time taken by your application to match the Order against existing, open orders.
Multicast, UDP, reliable multicast, Kernel bypass (supported by Java 7, Informatica Ultra Messaging, and many others) on Infiniband networks are some common technologies used by all companies in this field.
Additionally, there are low latency programming frameworks like disruptor (http://code.google.com/p/disruptor/) which implement design patterns for dealing with low latency applications. What could kill you is having to write to a DB or log files as part of your main workflow. You will have to come up with unique solutions that fulfill the requirements of the problem you are trying to solve.
In languages like Java, implementing your app such that it creates (almost) zero garbage becomes extremely important to latency. As Adamski says, having a knowledge of Java memory model is extremely important. Understand different JVM implementations, and their limitations. Typical Java design patterns around small object creation are the first things that you will throw out of the window - one can never fix the Java Garbage Collector enough to achieve low latency - the only thing that can be fixed is the garbage.
Subscribe to:
Posts (Atom)