- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想要多线程 zmq
客户端的 C 示例,我已经在使用多线程服务器,但我有要求让每个客户端从多线程而不是从单个线程发送请求。
我看过:
http://zguide.zeromq.org/c:asyncsrv
https://github.com/booksbyus/zguide/blob/master/examples/C/
但我没有看到使用 ZMQ_DEALER
套接字的多线程与多线程服务器(一个 ZMQ_ROUTER
套接字)通信的客户端示例
所以我正在寻找 DEALER
和 ROUTER
模式。我希望客户端(DEALER
)是多线程的:
或
pthread_create
就够了吗?目前我的客户端类似于hello world C:
zctx_t ctx = zctx_new ();
void *client = zsocket_new (ctx, ZMQ_REQ);
assert (client);
zsocket_connect (client, config.SERVER_ENDPOINT);
// SKIPPED: I get the data (hm->body.p) to be send through zmq...
// We send a request, then we work to get a reply
zstr_sendf(client, "%.*s", (int) hm->body.len,hm->body.p);
char *reply = zstr_recv (client);
if ( reply ) {
zsys_info ("server replied (%s)", reply);
free (reply);
}
请帮助我使我的 C 客户端成为多线程 zmq
客户端。
更新 1(更多详细信息):
3pa
)。 3pa
平均每秒发送约 4 个 HTTP POST
请求(每个请求的大小约 60 KB)到 HTTP 监听器(我正在使用 mongoose ).3pa
仅在收到 "HTTP/1.1 200 OK\r\n"
"reply"< 后发送下一个 HTTP POST
strong>OR 在发送请求超时后。所以3pa
似乎是单线程的。200 OK
,3pa
将继续在内存中排队,直到崩溃。3pa
的请求时,我需要使用 ZMQ 通过 3G 移动数据包网络将其发送到后端服务器。由于 3G-mobile-packet 网络延迟和带宽,每个请求需要大约 1-3 秒才能发送,ZMQ 重放大约需要 1-3 秒 new ZFrame("OK")
到启动、传输和交付(在 3pa
端接收)。因此,如果我们进行初等微积分,由于 3G 移动分组网络性能,3pa
队列容量将很快被填满。
最佳答案
根据 OP/Update 1 中提供的一些细节,
让我们先关注问题的根本原因,
然后再讨论增加线程数的想法。
鉴于 3pa
已作为 BlackBox 引入,具有经验丰富的阻塞设计(由永远等待表示,直到交付200 OK
,在超时事件时逃逸)
最好的第一步将操作 3pa
按原样,而是托管/托管在一些更好的 NIX 对等/托管中心,而不是延迟昂贵的 3G 移动数据包 radio 接入网络的当前“外围”最后一英里部分,这将两者都避免/防止容量驱动的 DoS 引入的数据包重新传输,以防任何优先调用流量抢占 3G 信道并使 RAN 拥塞,并且绝对会降低往返延迟的成本,目前在某个地方支付的上述水平以上2~6+秒。
下一步可能,如果 3pa
搬迁到 NIX-proximity 本身不足以拯救游戏,将创建一个单一用途的 http-proxy,它将接收那些60KB+ http 请求(然后将中继到适当的目标)并且会立即将 200 OK
响应下游注入(inject) 3pa
,以便将其从内部阻塞循环中解锁,并允许其发送另一个出列的 HTTP POST
。
肮脏?是和不是。它解决了糟糕的 3pa
设计的弱点,并允许在特定情况下运行它。
REQ/REP
模式。虽然 ZeroMQ 可扩展正式通信模式构建 block 是多方通信方案的智能示例,但不要指望它们不受 LoS、丢失消息和其他现实世界问题的影响。 REQ/REP
模式能够在脱轨的内部 FSA 状态下自行死锁,从中没有(字面上为零)工具来保存/恢复内部 -来自无法挽救的相互死锁状态的孪生 FSA 状态机。
在此类设计中使用其他一些可扩展的正式通信模式,并准备好在出现问题时提供额外的信号发送方式,以表示可能需要挽救状态。 ZeroMQ 有很多工具可以更聪明地做到这一点,而不是仅仅依赖于一个简单的原型(prototype),闭上眼睛并相信一切都将永远无错误地工作的小说(这不是我们生活的现实,对吧: o)).
真实世界的客户端操作许多 zmq-socket 实例,一些用于信号,一些用于传输服务,一些用于远程访问客户端的内部 CLI 界面,一些用于分布式日志收集器,一些用于 self 诊断和托管系统健康检查。简单的、主要是非阻塞设计的客户端可能包含几千个 SLOC,所以不要期望任何此类解决方案仅包含来自图书馆 wiki 页面或一些 Shiny 的博客文章的几个 SLOC 的副本。
One might also like to read other ZeroMQ posts, with also a link to the fabulous Pieter HINTJENS' book, that has been my must-read recommendation for those interested since I started to love the ZeroMQ way of thinking and design priorities. Worth the time and efforts, believe me or not, distributed processing has other, more important rules, than just asking for more threads for otherwise poor and un-feasible design.
Being able to change a poor design into a better one, one can still operate a single-threaded, well designed, application that can move xKB-messages and keep the end-to-end latencies under a few tens of milliseconds, even with a remote server doing a complex AI/ML-processing of the "fat"-data payloads.
Worth a try, isn't it?
关于c - ZMQ 多线程 C 客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40404493/
我将 Bootstrap 与 css 和 java 脚本结合使用。在不影响前端代码的情况下,我真的很难在css中绘制这个背景。在许多问题中,人们将宽度和高度设置为 0%。但是由于我的导航栏,我不能使用
我正在用 c 编写一个程序来读取文件的内容。代码如下: #include void main() { char line[90]; while(scanf("%79[^\
我想使用 javascript 获取矩阵数组的所有对 Angular 线。假设输入输出如下: input = [ [1,2,3], [4,5,6], [7,8,9], ] output =
可以用pdfmake绘制lines,circles和other shapes吗?如果是,是否有documentation或样本?我想用jsPDF替换pdfmake。 最佳答案 是的,有可能。 pdfm
我有一个小svg小部件,其目的是显示角度列表(参见图片)。 现在,角度是线元素,仅具有笔触,没有填充。但是现在我想使用一种“内部填充”颜色和一种“笔触/边框”颜色。我猜想line元素不能解决这个问题,
我正在为带有三角对象的 3D 场景编写一个非常基本的光线转换器,一切都工作正常,直到我决定尝试从场景原点 (0/0/0) 以外的点转换光线。 但是,当我将光线原点更改为 (0/1/0) 时,相交测试突
这个问题已经有答案了: Why do people write "#!/usr/bin/env python" on the first line of a Python script? (22 个回
如何使用大约 50 个星号 * 并使用 for 循环绘制一条水平线?当我尝试这样做时,结果是垂直(而不是水平)列出 50 个星号。 public void drawAstline() { f
这是一个让球以对角线方式下降的 UI,但球保持静止;线程似乎无法正常工作。你能告诉我如何让球移动吗? 请下载一个球并更改目录,以便程序可以找到您的球的分配位置。没有必要下载足球场,但如果您愿意,也可以
我在我的一个项目中使用 Jmeter 和 Ant,当我们生成报告时,它会在报告中显示 URL、#Samples、失败、成功率、平均时间、最短时间、最长时间。 我也想在报告中包含 90% 的时间线。 现
我有一个不寻常的问题,希望有人能帮助我。我想用 Canvas (android) 画一条 Swing 或波浪线,但我不知道该怎么做。它将成为蝌蚪的尾部,所以理想情况下我希望它的形状更像三角形,一端更大
这个问题已经有答案了: Checking Collision of Shapes with JavaFX (1 个回答) 已关闭 8 年前。 我正在使用 JavaFx 8 库。 我的任务很简单:我想检
如何按编号的百分比拆分文件。行数? 假设我想将我的文件分成 3 个部分(60%/20%/20% 部分),我可以手动执行此操作,-_-: $ wc -l brown.txt 57339 brown.tx
我正在努力实现这样的目标: 但这就是我设法做到的。 你能帮我实现预期的结果吗? 更新: 如果我删除 bootstrap.css 依赖项,问题就会消失。我怎样才能让它与 Bootstrap 一起工作?
我目前正在构建一个网站,但遇到了 transform: scale 的问题。我有一个按钮,当用户将鼠标悬停在它上面时,会发生两件事: 背景以对 Angular 线“扫过” 按钮标签颜色改变 按钮稍微变
我需要使用直线和仿射变换绘制大量数据点的图形(缩放图形以适合 View )。 目前,我正在使用 NSBezierPath,但我认为它效率很低(因为点在绘制之前被复制到贝塞尔路径)。通过将我的数据切割成
我正在使用基于 SVM 分类的 HOG 特征检测器。我可以成功提取车牌,但提取的车牌除了车牌号外还有一些不必要的像素/线。我的图像处理流程如下: 在灰度图像上应用 HOG 检测器 裁剪检测到的区域 调
我有以下图片: 我想填充它的轮廓(即我想在这张图片中填充线条)。 我尝试了形态学闭合,但使用大小为 3x3 的矩形内核和 10 迭代并没有填满整个边界。我还尝试了一个 21x21 内核和 1 迭代,但
我必须找到一种算法,可以找到两组数组之间的交集总数,而其中一个数组已排序。 举个例子,我们有这两个数组,我们向相应的数字画直线。 这两个数组为我们提供了总共 7 个交集。 有什么样的算法可以帮助我解决
简单地说 - 我想使用透视投影从近裁剪平面绘制一条射线/线到远裁剪平面。我有我认为是使用各种 OpenGL/图形编程指南中描述的方法通过单击鼠标生成的正确标准化的世界坐标。 我遇到的问题是我的光线似乎
我是一名优秀的程序员,十分优秀!