- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想创建自己的小型项目,其中包含供 WPF 应用程序使用的虚构大量数据(期权交易),以便更好地理解设计实时系统的设计概念和注意事项,并希望了解使用了何种技术和方法。请不要提及像 Tibco 这样的第三方解决方案——这是为了学习目的。我的意图是 WPF 应用程序每 5 秒刷新一次 UI
在设计我虚构的市场数据服务器时,考虑到高容量性能是一个标准,我想到了一些快速的想法 - 多播 UDP(这是不是太低级/一个糟糕的方向?),一种使用队列的消息传递架构例如 MSMQ 或 RabbitMQ,客户端应用程序通过 WCF TCP 绑定(bind)或 Web 服务向远程服务主机发起请求。
我的一个想法是客户维护自己的本地队列并订阅定价服务器使用消息传递解决方案广播的主题?或者,也许服务器会将数据平等地广播给所有客户端,然后将其留给客户端在本地过滤和整理数据?根据人们的经验,每种方法的优缺点是什么,还有我在这里错过的任何其他方法吗?我想这归结为 - 客户端应该提取数据还是服务器应该将数据推送给他们?
另一个问题是 - 这些消息将采用什么有线格式?我主要习惯于使用丰富的业务对象类,分为存储库层、域模型(具有验证和工作流逻辑的方法)和简单的服务层。我是否仍然可以利用这种方法并仍然保持我的性能目标,或者我是否需要创建一种更轻量级的数据有效负载格式?
最佳答案
在深入到网络级优化之前,我会从较高层开始设计这样的系统。
RabbitMQ 为路由消息提供了不同类型的交换。向每个客户端广播所有消息(扇出交换)的方法在 RabbitMQ 服务器端速度稍快,但这仅适用于低容量消息,并且前提是客户端通过高速链路(例如本地千兆以太网)连接。相反,使用直接或局部交换可能会显着降低您的网络延迟。您可以在 RabbitMQ 网站上阅读有关交换类型的更多信息。
你的最后一个问题是关于线格式的。理论上,RabbitMQ 允许任何字符串(甚至二进制)有效载荷,因此它是试图将更多信息压缩到更少字节中的问题。根据我的经验,只要您的消息不是通过网络数据包 MTU,压缩或选择巧妙的编码方案的 yield 都是微不足道的。
一般来说,想想您在每次优化上花费了多少时间,以及预期的投资返回率是多少。 IMO 一些优化比其他优化更有用。如果我是你,我会非常仔细地查看 RabbitMQ 配置参数。例如,看看您是否可以使用每个进程的消息队列设置 rabbit MQ 服务器。
关于c# - 为 WPF 应用程序设计大容量市场数据服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11993097/
我在 iOS 上有一个使用 WebSQL 数据库的 PhoneGap 应用程序。在某些地方,我读到存储容量是 5MB,而在其他地方,我读到它是 50MB,有人可以帮我解决这个问题吗?我还计划在数据库中
我想弄清楚如何更新节点的 pod 容量。我使用文档中概述的 Vagrant/VM 环境进行了简单的集群设置。我尝试使用 kubectl 修补节点的 pod 容量,执行以下操作: 通过以下方式发送补丁所
我想创建一个函数,根据某人系统上的可用 RAM 大小来导入不同批处理的数据。但是如何找到 R 中的可用 RAM 量呢?我可以使用 memory.size() 但这只适用于 Windows。 最佳答案
目前,我正在努力将 Power BI 内容嵌入到我的 Web 应用程序中。我已经通过服务主体实现了它,并且它按预期工作。但是对于产品环境,是否必须为我的报告或工作区添加容量?是否可以在不增加生产环境容
我有一个 3 节点 coros kubernetes 集群启动并运行。 我想使用来自独立 NFS 服务器的 persitentvolumes(pv)。 nfs.yaml apiVersion: v1
我正在学习golang一段时间。我遇到了 channel 问题。 我有两个例子。它们看起来一样,但是其中1个给出了错误。 当我分配 channel 容量(转换为缓冲 channel )时,问题已解决,
我正在尝试创建一个子例程,将一个字符串插入另一个字符串。我想检查主机字符串是否有足够的容量来容纳所有字符,如果没有,则返回错误整数。这需要使用类似 sizeof 的东西,但可以使用指针调用。我的代码如
这个问题在这里已经有了答案: size vs capacity of a vector? (8 个答案) 关闭 7 年前。 在下面的程序中,我只是创建了一个空 vector ,然后将大小调整为 5
免责声明 1 - 我是编程新手免责声明 2 - 我搜索了又搜索,但找不到我正在寻找的帮助。 对于一个项目,我或多或少地以更精简的形式重写了 vector 类。我挂断的部分是编写 push_back 方
我对 BTree 的理解是: if root BTree size is 32, the level 1 have 1024 keys capacity the level 2 can sort 10
我有一个使用 ActionBar 的应用程序,我自己处理方向更改: android:configChanges="keyboard|keyboardHidden|orientation|screenS
如何将 hadoop DFS 的配置容量从默认的 50GB 增加到 100GB? 我目前的设置是在 centOS6 机器上运行的 hadoop 1.2.1,使用了 450GB 中的 120GB。已使用
我的问题是关于 slice 长度和容量。我在这里学习 Go:https://tour.golang.org/moretypes/11 . (我的问题被标记为可能与 this 重复;但是,事实并非如此。
现在尝试从教程中学习 Go,并且有一个非常基本的问题: func main() { a := make([]int, 5) // [0,0,0,0,0] len=5 cap=5 b :=
如何以以下格式获取有关数据库中所有表空间的信息。 TABLESPACE_NAME | FILE_NAME | ALLOCATED_MB | FREE_MB | CAPACITY | 有没有办法自
我想基于每个作业更改群集的减少插槽容量。也就是说, 最初,我为Tasktracker配置了8个reduce插槽,因此对于具有100个reduce任务的作业,将同时运行(8 * datanode数量)r
我正在运行单节点 Hadoop 部署。我知道我的应用程序需要多少数据,我可以设置(和重新设置)HDFS 使用的最大容量吗? 我已经尝试了以下方法,但似乎无法实现。 检查 hdfs-site.xml 和
我安装了 splunk 来监控和分析 hadoop 作业。我在其他节点的Jobtracker、forwarder和TA中安装splunk core和splunk hadoop app后,HDFS ca
vector::operator= 会改变 vector 容量吗?如果有,怎么做? vector的拷贝构造函数是否拷贝容量? 我查看了文档,但找不到具体答案。是否依赖于实现? 最佳答案 您可以保证:
将 SQL 数据库导出到存储时,我们的 DTU 容量已达到,这本质上意味着我们的系统性能受到严重影响。 这对我们来说是一个问题,因为我们使用导出功能来备份和移动数据库。 这个问题有解决办法吗? 最佳答
我是一名优秀的程序员,十分优秀!