刚刚入职的新公司,想要将之前的 c 语言的项目陆续改为 go 语言的。现在需要写一个 go 调用 c 的接口的实现方案。考虑过以下几个方面:
1 、c 语言搭建 http 服务,直接调用。
c 语言同事那边说,c 写的 http 服务,第一不稳定,第二性能差。遂放弃。
2 、用 linux 系统内消息队列进行通信。
之前的同事写了一般,但是 需要用到 cgo 调用 c 的命令来做,但是调用过程没办法设置超时时间,而且 cgo 调用类似于阻塞 IO,它们在操作期间消耗一个系统线程。性能也不会很好
相关技术文章: https://www.jianshu.com/p/7e3045cf1ab8
3 、用 gprc 来通信
这个协议很靠谱,之前也用过,但是在调研过程中公司之前环境上 C/C++ 无法编译一些 ProtoBuf 文件,公司同事说,这个也不用考虑了。
4 、zmq 通过 zmq 来进行系统间通信
通过一种无需安装服务的消息队列的方式,这个正在调研
5 、json-rpc
这个正在等同事的消息。
大佬们有没有什么建议呢?
1 noisywolf 2020-04-29 15:44:13 +08:00 用 cgo 调用 c 写的模块 |
2 BlackBerry999 2020-04-29 15:46:54 +08:00 go 是可以执行命令的 c 那边可否改为执行命令? |
3 noisywolf 2020-04-29 15:51:17 +08:00 |
![]() | 4 rrfeng 2020-04-29 15:57:13 +08:00 1 不稳定???性能差??? |
![]() | 6 xmge OP @noisywolf 大佬,在调用过程中如何设置超时时间呢,比如调用时,c 那边程序阻塞了,go 这边调用的协程可以直接返回吗? cgo 的会占用一个线程,如果阻塞几个,程序就停了。 |
7 qq1340691923 2020-04-29 16:02:39 +08:00 @xmge php7 了解一下 |
![]() | 8 xmge OP @qq1340691923 ??? 我们用的 go 啊。 |
9 neoblackcap 2020-04-29 16:15:14 +08:00 有那么多 C 写的 http server 整天在跑着,我都不知道 C 怎么就性能差了 如果是上 zmq 的话,你就得自己维护消息队列的深度了,要不然信息多会爆。你们是 C 写的话,其实可以用 nanomsg,可能会更好 |
![]() | 11 reus 2020-04-29 16:20:03 +08:00 via Android @xmge 占用线程有什么问题?你用 C/C++写难道就不是占用线程?阻塞几个就停了?建议学习下 go 调度器的基本知识再下判断。或者写个 demo 来验证自己的想法是对是错。 |
![]() | 12 Leigg 2020-04-29 16:20:54 +08:00 via Android c 性能差??? |
![]() | 13 reus 2020-04-29 16:25:43 +08:00 via Android 另外 linux ipc 直接用 syscall 包就行,不需要 cgo 。我看你这个同事也有点菜吧。 如果用 cgo,就是直接调 c 的函数,不需要 ipc |
14 boboliu 2020-04-29 16:27:55 +08:00 |
![]() | 15 zjsxwc 2020-04-29 16:31:36 +08:00 c 语言写的不怕内存泄露吗 |
17 useben 2020-04-29 16:41:28 +08:00 go 调用 so 就行, 我这里的图像识别算法都是封装成 so 给我 go 用的 |
![]() | 18 gamexg 2020-04-29 16:41:54 +08:00 需求简单 c 语言直接封装成 dll,go 去调用。go 也可以直接内嵌 c 代码。 不过如果对同事信心不足,那么还是隔离开不要一个进程内好。 @xmge #6 >cgo 的会占用一个线程,如果阻塞几个,程序就停了。 不会,没大印象了,但是记得 go 的 syscall 调用诸塞时会自动建立新的操作系统线程,不会出现出现 c 代码把所有操作系统线程占据的情况。 |
19 buzailianxi 2020-04-29 19:46:37 +08:00 via Android 都是甩锅,直接调 clib 把省事 |
![]() | 20 join 2020-04-29 21:09:55 +08:00 读业务逻辑全部重写,想啥呢? |
21 Chenamy2017 2020-04-30 11:51:31 +08:00 说 C 写的 http 不稳定和性能差的我估计是说他自己写的代码吧。自己写当然差了,但是别人写的 nginx 就不一样了。 |
22 ddoocc 2020-04-30 14:47:48 +08:00 封装成 lib 直接调用啊,任何现代语言都兼容 c abi 。 |