使用 stunnel 建立到 DUKASCOPY 的连接

问题描述 投票:0回答:3

寻求一些帮助,以通过 FIX4.4 协议使用 stunnel 和 quickfix python 与我的经纪人 DUKASCOPY 建立连接。

这是我的通道配置:

client = yes
cert = /etc/stunnel/stunnel.pem

[OKSERVER]
accept = 9443
connect = demo-api.dukascopy.com:10443

我的 quickfix cfg 文件:

[DEFAULT]
ConnectionType=initiator
LogonTimeout=30
ReconnectInterval=30
ResetOnLogon=Y
FileLogPath=./Logs/

[SESSION]
BeginString=FIX.4.4
SenderCompID=SENDER_ID # replaced with anonymous value for this post
TargetCompID=TARGET_ID # replaced with anonymous value for this post
StartTime=00:00:00
EndTime=00:00:00
HeartBtInt=30
CheckLatency=N
MaxLatency=240
SocketConnectPort=10443
SocketConnectHost=demo-api.dukascopy.com
UseDataDictionary=Y
DataDictionary=/home/jaspal/qfsample/quickfix/spec/FIX44.xml
FileStorePath=./Sessions/

当我尝试登录时,我得到:

20181002-22:26:23.972817000 : Created session
20181002-22:26:23.978505000 : Connecting to demo-api.dukascopy.com on port 10443 (Source :0)
20181002-22:26:24.023770000 : Initiated logon request
20181002-22:26:24.065703000 : Socket Error: Connection reset by peer.
20181002-22:26:24.065799000 : Disconnecting

我可以确认我正在监听传入端口:

~/qfsample/quickfix-python-sample$ netstat -an | grep 9443
    tcp        0      0 0.0.0.0:9443            0.0.0.0:*               LISTEN

我还在我的路由器上配置了 9443 端口转发到客户端机器。

这是我从应用程序收到的消息:

onCreate(self=<__main__.Application; proxy of <Swig Object of type 'FIX::Application *' at 0x7f87db719030> >, sessionID=<quickfix.SessionID; proxy of <Swig Object of type 'FIX::SessionID *' at 0x7f87db6674e0> >)
toAdmin(self=<__main__.Application; proxy of <Swig Object of type 'FIX::Application *' at 0x7f87db719030> >, sessionID=<quickfix.Message; proxy of <Swig Object of type 'FIX::Message *' at 0x7f87db667e70> >, message=<quickfix.SessionID; proxy of <Swig Object of type 'FIX::SessionID *' at 0x7f87db667d20> >)

非常欢迎在这里找到问题的任何帮助!!

python quickfix fix-protocol stunnel
3个回答
8
投票

好的。所以我想我不可避免地会从这个伟大的论坛获得一些帮助或自己解决!在这种情况下是后者!

这是我出错的地方:

当您使用 stunnel 创建隧道时,您必须将目标设置到您在 stunnel 配置中为“接受”创建的端口上的本地计算机,而不是您的代理地址。现在很明显!这是我的 cfg 文件现在的样子:

SocketConnectPort=9443
SocketConnectHost=localhost

3
投票

感谢@Jaspal 发布您的问答!我最初有同样的问题,发现这张图片在概念上很有帮助(暂时忽略防火墙),即将 FIX 引擎指向本地主机上的 stunnel: 顺便说一句(这是一个功能请求而不是一个问题,但有一天可能是一个解决方案,手指交叉)在 github/quickfix 上有一个问题将 SSL/TLS 添加到 python(它已经在 C++ 中)这将避免需要 stunnel。


0
投票

是否可以共享用于连接设置的 python 代码?我是 python 的新手,通常使用 R。不幸的是,R 不提供任何可用的修复引擎,所以我正在寻找解决方法。 或者对网站/书籍有帮助的任何推荐?

© www.soinside.com 2019 - 2024. All rights reserved.