首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MT4 - Mysql通过PHP连接

MT4 - Mysql通过PHP连接
EN

Stack Overflow用户
提问于 2013-12-01 02:21:55
回答 3查看 6.3K关注 0票数 0

我需要从MT4获取数据,或者将数据发送到Mysql数据库。我使用了"libmysql.dll“或mysql_wrapper (也基于libmysql.dll),但它似乎不稳定。

我想我可以使用PHP作为服务器(在指定的端口创建TCP/IP套接字)和MT4 EA/脚本作为客户端。或者使用Apache作为服务器(创建PHP脚本来完成Mysql连接工作)和MT4 EA/scrip作为客户端。

因此,PHP是连接MT4和Mysql的桥梁。来自MT4的PHP get请求,连接到Mysql (如果需要,还可以进行计算),然后将结果发送回MT4。你能告诉我如何在Windows XP中做到这一点吗(我的Windows XP上安装了Apache、PHP、Mysql )?

谢谢,杰克

EN

回答 3

Stack Overflow用户

发布于 2013-12-01 12:04:49

我得到了这个PHP脚本,它打开一个特定的端口,并等待连接。我可以使用Telnet连接到它。有人知道如何使用MQL4连接到该端口吗?

谢谢

代码语言:javascript
复制
// usage example in command prompt: telnet 192.168.7.21  168168 
// To quit, type: quit 
// To shutdown PHP server, type: shutdown // //
// **************************************************************


<?php error_reporting(E_ALL);

/* Allow the script to hang around waiting for connections. */ set_time_limit(0);

/* Turn on implicit output flushing so we see what we're getting  * as it comes in. */ ob_implicit_flush();

$address = '192.168.7.21'; $port = 168168;

if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) === false) {
    echo "socket_create() failed: reason: " . socket_strerror(socket_last_error()) . "\n"; }

if (socket_bind($sock, $address, $port) === false) {
    echo "socket_bind() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n"; }

if (socket_listen($sock, 5) === false) {
    echo "socket_listen() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n"; }

do {
    if (($msgsock = socket_accept($sock)) === false) {
        echo "socket_accept() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
        break;
    }
    /* Send instructions. */
    $msg = "\nWelcome to the PHP Test Server. \n" .
        "To quit, type 'quit'. To shut down the server type 'shutdown'.\n";
    socket_write($msgsock, $msg, strlen($msg));

    do {
        if (false === ($buf = socket_read($msgsock, 2048, PHP_NORMAL_READ))) {
            echo "socket_read() failed: reason: " . socket_strerror(socket_last_error($msgsock)) . "\n";
            break 2;
        }
        if (!$buf = trim($buf)) {
            continue;
        }
        if ($buf == 'quit') {
            break;
        }
        if ($buf == 'shutdown') {
            socket_close($msgsock);
            break 2;
        }
        $talkback = "PHP server: You said '$buf'.\n";
        socket_write($msgsock, $talkback, strlen($talkback));
        echo "$buf\n";
    } while (true);
    socket_close($msgsock); } while (true);

socket_close($sock); ?>
票数 0
EN

Stack Overflow用户

发布于 2014-04-16 22:59:45

如果我在你那里我不会走那条路...

也许你应该看看消息队列(AMQP - RabbitMQ - ZeroMQ)...

请参阅该帖子http://worldwide-invest.org/threads/34585-Messaging-queue-AMQP-(RabbitMQ-ZeroMQ)-and-MT4

您将看到,我可以使用任何语言收集节拍数据,并将它们存储在支持RabbitMQ的语言支持的任何数据库中(通过C、C++、C# ...从Python语言到Java语言)。

在Metatrader和ZeroMQ https://github.com/AustenConrad/mql4zmq之间也有一座桥梁

票数 0
EN

Stack Overflow用户

发布于 2016-01-01 00:01:22

首先,我假设您正在尝试将MT4客户端(而不是服务器)连接到MySQL数据库。否则,就没有理由存在稳定性问题。如果您使用EA连接到数据库,只需小心处理连接,EA不是标准的可执行文件,EA中的代码在每个“滴答”上运行,所以要考虑到这一点。相信我,将PhP放在中间只会使事情变得复杂(并且会显著降低性能!)。如果我们能提供任何帮助,请告诉我们: www.mt4software.com

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20303936

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档