michaelwills / metatrader4-server

Provides a high-level trading interface to MetaTrader 4 via ZeroMQ.

Repository from Github https://github.commichaelwills/metatrader4-serverRepository from Github https://github.commichaelwills/metatrader4-server

MetaTrader 4 Server

Provides a remote interface and high-level API for MetaTrader 4 via ZeroMQ sockets.
See API for supported operations.

Diagram 1

Installation

  1. Copy metatrader4 into your MetaTrader 4 profile directory, merging the folder contents.
  2. Copy mql-zmq/Include/ into the MQL4/Include subdirectory of your MetaTrader 4 profile directory, merging the folder contents.
  3. Copy mql-zmq/Library/MT4/ into the MQL4/Libraries subdirectory of your MetaTrader 4 profile directory, merging the folder contents.
  4. Launch MetaEditor, open MQL4/Scripts/ZeroMQ_Server.mq4 in your MetaTrader 4 profile directory and compile it.
  5. Start MetaTrader 4 and add the ZeroMQ Server script to any chart (chart symbol does not matter). The server begins listening for client requests and responds synchronously.

Configuration

The default listening port is TCP/28282 but is configurable in the script parameters popup in the MetaTrader terminal, along with other parameters such as socket timeouts. If Windows Defender Firewall is running, you must forward the port.

Usage

Typical client usage:

  1. Create a ZeroMQ context and a REQ socket with appropriate send/receive timeouts and options.
  2. Connect the REQ socket to the server's REP socket.
  3. Perform the following sequence any number of times:
    1. Construct an API request.
    2. Send the request to the REQ socket.
    3. Receive a JSON-formatted string response from the REQ socket.
  4. Close the socket connection and destroy the ZeroMQ context.

It is recommended to use one of the following client libraries to abstract away these details:

Limitations

The REQ-REP socket connection enforces a strict request-response cycle and may deadlock if connection is lost. The client libraries use ZMQ_REQ_RELAXED and ZMQ_REQ_CORRELATE socket options to prevent this in most cases. If a response is dropped, the client may want to catch the exception and check whether or not the operation was successful.

Development

If you want to make changes to the server implementation, it's useful to setup a local dev environment.

About

Provides a high-level trading interface to MetaTrader 4 via ZeroMQ.

License:MIT License


Languages

Language:MQL4 58.3%Language:MQL5 34.6%Language:Shell 3.4%Language:Smarty 1.9%Language:Batchfile 1.8%