其他提示

可能?可能是的,但它需要一些工作。

对于初学者,您需要编写一个自定义WCF传输通道来处理基于TCP / IP的协议的细节(即,您需要编写所有套接字处理代码并将其挂钩到WCF通道模型中)。这是因为WCF中的TCP通道不适用于此类工作,而是使用相对专有且未记录的有线协议。

我对FIX不够熟悉,不知道它会有多复杂,但在该区域编写WCF频道和文档时有一些问题。

您需要处理的第二部分是邮件编码。对于WCF,所有消息都是XML。也就是说,一旦消息传递到WCF堆栈,它就必须在运行时看起来像XML信息集。 FIX不使用XML(afaik),因此您需要稍微调整一下。

有两种方法可以解决它:

  1. 简单方法:假设服务器/客户端将使用特定的数据接口和格式,并让您的频道完成将FIX消息转换为该格式或从该格式转换的所有艰苦工作。最简单的示例是让您的WCF代码使用一个简单的服务契约,其中一个方法接受一个字符串,然后将FIX消息字符串封装成满足该合同的数据协定序列化程序的XML格式。不过,用户代码仍然需要处理解码FIX格式。

  2. 在自定义WCF MessageEncoder中完成所有艰苦工作。它有点复杂,但可能更干净,更可重复(你可以做更复杂的事情,比如更好的流媒体等)。

  3. 但最重要的问题是这是否值得。您想要使用WCF的原因是什么?利用编程模型?我认为这是一个重要的考虑因素,但请记住,WCF提供的抽象是有代价的。特别是,如果您有非常实时的要求,WCF的某些方面可能会有问题,我理解这种要求在您正在考虑的金融环境中很常见。

    如果是这种情况,很可能会通过跳过WCF并更贴近金属来获得更好的服务。无论如何你都需要进行套接字工作,因此需要考虑这个问题。

    希望这会有所帮助:)

这样。我有一个系统,我几乎开始工作,应该几乎完全这样做(来自互联网的WCF over HTTP)。服务器提供商似乎不想允许它,因此您需要在该端使用正确的权限才能使其正常工作。

向上拍摄:我不明白为什么不这样做。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top