go 语言对接 c 语言的问题

2020-04-29 14:29:36 +08:00
 xmge

项目背景:

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

这个正在等同事的消息。

大佬们有没有什么建议呢?

3390 次点击
所在节点    程序员
22 条回复
noisywolf
2020-04-29 15:44:13 +08:00
用 cgo 调用 c 写的模块
BlackBerry999
2020-04-29 15:46:54 +08:00
go 是可以执行命令的 c 那边可否改为执行命令?
noisywolf
2020-04-29 15:51:17 +08:00
rrfeng
2020-04-29 15:57:13 +08:00
1 不稳定???性能差???
xmge
2020-04-29 15:58:33 +08:00
@rrfeng 对 c 语言不太了解,如果可以用 http,那就简单很多了。
xmge
2020-04-29 16:02:11 +08:00
@noisywolf 大佬,在调用过程中如何设置超时时间呢,比如调用时,c 那边程序阻塞了,go 这边调用的协程可以直接返回吗?
cgo 的会占用一个线程,如果阻塞几个,程序就停了。
qq1340691923
2020-04-29 16:02:39 +08:00
@xmge php7 了解一下
xmge
2020-04-29 16:10:49 +08:00
@qq1340691923 ??? 我们用的 go 啊。
neoblackcap
2020-04-29 16:15:14 +08:00
有那么多 C 写的 http server 整天在跑着,我都不知道 C 怎么就性能差了
如果是上 zmq 的话,你就得自己维护消息队列的深度了,要不然信息多会爆。你们是 C 写的话,其实可以用 nanomsg,可能会更好
pmispig
2020-04-29 16:18:15 +08:00
@rrfeng 哈哈,我都是惊讶了,在想楼主是不是反过来了
reus
2020-04-29 16:20:03 +08:00
@xmge 占用线程有什么问题?你用 C/C++写难道就不是占用线程?阻塞几个就停了?建议学习下 go 调度器的基本知识再下判断。或者写个 demo 来验证自己的想法是对是错。
Leigg
2020-04-29 16:20:54 +08:00
c 性能差???
reus
2020-04-29 16:25:43 +08:00
另外 linux ipc 直接用 syscall 包就行,不需要 cgo 。我看你这个同事也有点菜吧。

如果用 cgo,就是直接调 c 的函数,不需要 ipc
boboliu
2020-04-29 16:27:55 +08:00
不是很懂需求,不过看起来应该可以直接 cgo,只是复杂性可能会变得一言难尽 那就不算重构了
zjsxwc
2020-04-29 16:31:36 +08:00
c 语言写的不怕内存泄露吗
xmge
2020-04-29 16:32:51 +08:00
@pmispig 额。没写过 c,同事说的。我感觉 c 偏底层,应该更快的啊。
useben
2020-04-29 16:41:28 +08:00
go 调用 so 就行, 我这里的图像识别算法都是封装成 so 给我 go 用的
gamexg
2020-04-29 16:41:54 +08:00
需求简单 c 语言直接封装成 dll,go 去调用。go 也可以直接内嵌 c 代码。

不过如果对同事信心不足,那么还是隔离开不要一个进程内好。

@xmge #6
>cgo 的会占用一个线程,如果阻塞几个,程序就停了。

不会,没大印象了,但是记得 go 的 syscall 调用诸塞时会自动建立新的操作系统线程,不会出现出现 c 代码把所有操作系统线程占据的情况。
buzailianxi
2020-04-29 19:46:37 +08:00
都是甩锅,直接调 clib 把省事
join
2020-04-29 21:09:55 +08:00
读业务逻辑全部重写,想啥呢?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/667279

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX