刚刚入职的新公司,想要将之前的 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 。
|