- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
最近我正在学习 nanomsg 和 zeromq 以及 Golang 绑定(bind)。我已经使用可以工作的 Req-Rep 进行了测试,但是使用这种机制来构建可靠的内部服务器以在高并发请求(但来自有限的客户端源 < 30)下提供数据是否是一个正确的想法?
一些伪代码可能看起来像,
for {
data, conn = socketRep.readData()
go func(data, conn){
result=process(data)
conn.sendReply(result)
conn.close()
}()
}
如何在 nanomsg 中实现类似的通信模式?有没有可用的示例(C 可以)?
====更新====
抱歉,这个问题看起来太宽泛了。对我来说最重要的问题是,“周围是否有任何可行的 Req/Rep 示例(C 可以)?”
最佳答案
学习任何新的图书馆都是令人兴奋的,并且会产生很多新的见解。
一个非常重要的见解是承担大小合适且合理的挑战以及自己的学习曲线轨迹。
如果 Pieter Hintjens,ZeroMQ 的创始人之一,写了 [几乎是粗体] 以下评论在关于设计任何可靠服务的章节中,他非常清楚为什么要在接下来的关于此类设计的段落之前加上类似的突出警告...
高级哲学思想来自 Pieter Hintjens 高级设计书籍,构建“超越基本的 ZeroMQ”可扩展正式通信模式保持基本相同
恕我直言,在开始任何编码之前,最好多花几周时间研究 Pieter Hintjens 两本书中的想法和设计范例和故事。
都是 400 多页的书 The ZeroMQ Guide - for Python Developers, Section II., Advanced ZeroMQ,(即第 6.2、6.7、7.1 和 7.5 章)
和
一本300多页的书“Code Connected Volume 1”,(即第5章增加可靠性的过程——无论是为了可靠性本身还是为了解锁通过资源池上的负载平衡实现更高级别的性能)
将帮助任何人开始探索分布式系统架构这一伟大而激动人心的领域,并将帮助获得设计可生存方法所需的观点,而无需重新探索许多已被证明是死胡同的死胡同。
关于go - 基于 nanomsg 的内部服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25157479/
我可以在 nanomsg 的 pub/sub 协议(protocol)中进行纯多播吗?由于可以有 N 个订阅者对单个发布者的特定数据感兴趣,因此相同的订阅数据在 N 个不同的流中流动。如果我的单个流的
我刚开始使用 C# 进行 nnanomsg 编程。对于一个简单的客户端/服务器示例,我从以下示例开始,其中客户端与服务器连接以获取下一个数字。现在,这个例子是针对本地主机的,除了我硬编码了我的网络 I
当服务器短暂脱机或完全脱机然后恢复时,我在处理重新连接时遇到问题。我无法让我的客户自动重新连接。此外,在我可以看到套接字状态(套接字已断开连接?)的任何地方都没有属性,因此我可以手动重新连接。我错过了
我是消息传递世界的新手,开始使用 Nanomsg我的应用程序中的库。我想知道服务器和客户端之间的消息是否默认由Nanomsg加密图书馆。如果没有,如何添加加密来保护通信节点之间的消息? 最佳答案 消息
我有两个 .js 文件 - pub.js 用于发布,sub.js 用于订阅。这些文件实际上是 node-nanomsg GitHub site 中所示示例的“拆分”版本. pub.js 写入 tcp:
我尝试了 Rust nanomsg pubsub example , 但它不起作用。 我在单独的控制台窗口中执行了这些操作中的每一个: cargo run --example pubsub -- de
我在使用 C++ 的系统中使用 Nanomsg 执行 IPC。我想创建一个后台线程来处理发送和接收消息。我使用 pair 范式并使用 nn_poll 检查套接字 fd 是否可写或可读,如果可读则读取;
是否可以对 nanomsg 套接字使用 QSocketNotifier,以便在收到任何数据时执行某些操作?我尝试使用此代码,但当我运行 nanocat --req --connect ipc:///t
我也在 Arduino 部分发布了这个,但这个问题可能更多是由于我对 nanomsg 和一般连接的无知而不是 Arduino 问题造成的。 我正在尝试与使用 nanomsg 的服务器通信使用 Ardu
最近我正在学习 nanomsg 和 zeromq 以及 Golang 绑定(bind)。我已经使用可以工作的 Req-Rep 进行了测试,但是使用这种机制来构建可靠的内部服务器以在高并发请求(但来自有
我正在使用 nanomsg 库 int sock = nn_socket (AF_SP, NN_PAIR); 断言 (nn_bind (sock, url) >= 0); 现在我想知道如果客户端连接,
如何编写一个在等待来自多个源的消息时阻塞的主循环? As I understand it , 编写事件处理循环的首选方法是让它在等待事件时阻塞。 但是,当消息可能来自多个来源时,如何正确处理阻塞? 我
我有来自 here 的 nanomsg 和 Android.mk .我尝试使用 Android NDK 为 Android 构建它。我有错误: [armeabi] Compile thumb : n
我需要构建一种即时通讯系统。根据我的简要探索,ZeroMQ 和 nanomsg 旨在后端分布式系统中的服务器-服务器通信,而不是管理 +100K 并发的最终用户客户端连接。那是准确的吗?如果是这样,是
我正在研究 nanomsg 对 IPC 的使用,并想使用 SURVEY -原型(prototype)架构描述here . 在此过程中,进程作为客户端和服务器运行并交换数据。现在服务器有以下代码(也在提
如何在 nanomsg 中实现 IP 多播? 我知道在 ZeroMQ 消息传递中,IP 多播是通过 Pragmatic General Multicast ( PGM ) 协议(protocol)实现
我正在试验 nanomsg。 是否可以使用 .NET's Socket class 从客户端连接到 nanomsg 套接字?或者就此而言,除了另一个 nanomsg 客户端之外的任何其他套接字库? 是
我已经下载了 nanomsg 库,我知道它支持 TCP 套接字。我试图用它在 C 中制作一个简单的 TCP 服务器,但它有这么多不同类型的套接字,我不知道哪一个适合简单地制作 TCP 服务器。有管道、
我已经使用 zeromq 一段时间了,并且广泛使用了多部分消息。在 C++ 中,我使用 zmq_sendiov/zmq_recviov 发送/接收多部分消息。好处是我可以将每条消息“帧”放在一个 io
如果有更好的东西我们应该考虑,请大声说出来: 我正在寻找一种非常快速和简单的方法来获取多个程序(例如 5 个)- 每个程序都在私有(private) OpenStack 云上的不同节点上运行以相互通信
我是一名优秀的程序员,十分优秀!