问题:C++编写的核心模块如何暴露给外部HTTP Web服务接口???

本文探讨了将C++编写的核心模块暴露给HTTP Web服务接口的四种方法:直接使用C++编写HTTP服务器、通过Python WSGI封装、采用FastCGI以及利用gRPC+protobuf。分别分析了各种方法的优缺点,如Boost.Python的编译配置、C++处理HTTP协议的复杂性、gRPC的高效数据传输等。最终认为,对于特定场景,如高性能、小数据量传输和C++后端服务,gRPC+protobuf是较为合适的选择。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:C++编写的核心模块,其API调用接口是一个C/C++函数:输入是一个复杂的嵌套struct,输出也是一个复杂的嵌套struct(注意,这里的struct定义应该只用于序列化传输,不是内存表示,因此其内部应该包含指针类型、内部id引用等等),如何暴露给外部HTTP Web服务接口???

方法0:使用C/C++编写http server模块的代码,借助ACE、Boost.Asio这些库来实现。缺点:需要在C++语言代码中处理http协议相关的解析逻辑,且容易出内存问题,技术难度 高。

方法1:使用Python WSGI编写HTTP层的服务接口,Python代码再跨语言调用C++,这里通过Boost.Python进行C++接口函数的封装,封装后对于Python来说相当于一个独立的python模块。在产品环境中部署时,Python WSGI应用可放在uWSGI容器中运行,而uWSGI又进一步通过mod_wsgi嵌入到nginx/apache/lighttpd中。主要缺点:Boost.Python的编译配置环境稍微麻烦一点,但也不是特别麻烦。

方法2:C++模块包装为一个FastCGI应用进程,它作为upstream与nginx之间可以直接通信。(像Nginx-FPM就是PHP语言的一个FastCGI应用容器)缺点:没有成熟的C++ FastCGI容器,而且对于FastCGI来说,被封装的C++代码里面将会看到原始的http请求头部,以及需要自己设置http响应头部。也就是说,仍然需要自己在C++代码里面处理http协议解析相关的内容。只不过相对于方法0来说,更稳定更可靠一点。

方法3:通过gRPC+protobuf,Web前端服务可用Java编写,然后将请求数据序列化封装为二进制格式,跨节点(如果是前端后端Web在一台机器上那就是跨进程)传给C++后端服务 。后端就是C++代码实现的gRPC server端。缺点:需要预先仔细描述RPC message格式(protobuf),假如现有C++模块的接口函数中struct定义已经有了的话,两者还需要做一个适配转换。


20171015 更新:

我要更新一下我的说法了:传统的异步IO的HTTP服

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值