边缘计算原因后台项目必须用 C++做,有没有大佬有这方面经验的,需要跟前端交互,给些技术关键词
1 smoon 2022-06-24 11:03:21 +08:00 CGI |
2 wslzy007 2022-06-24 11:04:25 +08:00 socket || database || queue || cache... |
3 sunny352787 2022-06-24 11:06:23 +08:00 难不成你说的是 TCP/UDP/WebSocket/轮询 /长轮询...这类东西? |
![]() | 4 hncqp 2022-06-24 11:07:11 +08:00 http |
5 Yuan2One OP C++没有成熟的框架,或者解决方案这种吗 |
6 ceflib 2022-06-24 11:26:53 +08:00 cpprestsdk |
![]() | 7 2NUT 2022-06-24 11:29:23 +08:00 使用约定协议交互 通常用 http websocket 等; |
![]() | 8 ShayneWang 2022-06-24 11:34:30 +08:00 在用 Socket |
![]() | 9 cheng6563 2022-06-24 11:41:19 +08:00 你的前端是啥? cli ? gui ? web ? |
10 GeruzoniAnsasu 2022-06-24 11:48:07 +08:00 c++后台一般不直接跟 web 交互 可选的方式有: 1. 编译成动态库,暴露 C ABI 的 API ,这样 goalng 之类的后台基本可以即插即用(需要共享一个头文件和一个不需要实现具体功能,即 stub 的动态库二进制文件) 2. 使用 unix socket ,交互 json 数据或者 protobuf 之类的(无队列) 3. 使用消息队列中间件,随便选一个两边语言都有 binding 的 |
![]() | 11 RatioPattern 2022-06-24 11:58:34 +08:00 queue |
12 GeruzoniAnsasu 2022-06-24 12:02:30 +08:00 假设 c++库 /程序叫 core: - core 在内存中保存配置或者控制位 - core 如果需要被外部控制,可以序列化成比较通用的结构化数据比如 json/msgpack ,外部控制器(比如 golang 写的 web 后端)来负责持久化它们,存取数据库之类的,core 只解析 web 后端传过来的结构化数据 - 转发器直接将流量转到 core ,比如 nginx module 或者集成了 libpcap 的东西,它们可以直接通过 IPC 手段与 core 存取同一个共享 buffer - core 执行必要的计算并且在内存中保存计算状态 - 等待 web 后端异步地来读取这个状态,或者 RPC 通知后端状态发生变化 - 在 RPC 里传递计算结果,这时候就还是通用结构化数据 |
![]() | 13 wtsamuel 2022-06-24 12:12:59 +08:00 rpc 或者 restful 写法的 web api 底层都是通过 socket 转发数据 |
14 microxiaoxiao 2022-06-24 12:17:01 +08:00 via Android 这问题我熟悉呀,你提供一些接口,让做 web 服务器的在对应 url 路由调用你的函数,不然自己实现一个简单 HTTP |
15 alexsunxl 2022-06-24 12:17:26 +08:00 c++ --- java/go --- client 通过 rpc ,中间加一层比较好。 涉及到前后端对接和业务需求变动,中间这层变化老快了。你要是把所有和前度对接的逻辑都堆到 c++去,也不是不行,但是改动,编译,debug 这些老费劲了。 |
![]() | 16 coderluan 2022-06-24 12:23:58 +08:00 中间加一层+1 |
![]() | 17 renhou 2022-06-24 13:02:46 +08:00 最常用的就是 websocket |
18 Yuan2One OP 中间比如说用 java/go 转一层不是合理的解决方式,相当于把 C++的算法封成 SDK 用呗,但是 C++操作控制器传感器这些更麻烦了,完了对系统资源要求也更高了 |
19 jones2000 2022-06-24 15:12:02 +08:00 用 cpython 封装下, 直接用 py 做一个 webapi 就可以了, 省事。 |
![]() | 20 gainsurier 2022-06-24 15:34:10 +08:00 via iPhone oatpp 可以用这个 web 框架 |
![]() | 21 newmlp 2022-06-24 16:06:06 +08:00 rpc 或者 http |
22 xlzyxxn 2022-06-24 16:14:04 +08:00 前台是 web 不就是 restful 吗,啥意思啊 |
23 littlewing 2022-06-24 16:17:14 +08:00 grpc |
![]() | 24 sleeepyy 2022-06-24 16:46:39 +08:00 ![]() |
25 3166 2022-06-24 16:56:33 +08:00 site:v2ex.com/t c++ http |
![]() | 26 mingl0280 2022-06-24 17:07:12 +08:00 via Android 后端吐 CGI 出来或者 JSON 字符串出来就完事了(需遵循 HTTP 协议,如果你要用 HTTP 的话),没啥难度。 |
27 nightwitch 2022-06-24 19:00:48 +08:00 cgi QQ 邮箱现在还在用,稳定服务几亿用户 |
28 nightwitch 2022-06-24 19:04:15 +08:00 不过老实说 C++处理字符串相关的很麻烦,调试起来也要反复编译,用在 web 这种场景很费力气。 真不如用脚本语言粘一层。 |
29 786375312123 2022-06-24 19:13:53 +08:00 protobuff |
30 EminemW 2022-06-24 23:21:38 +08:00 啊,为什么要在中间套一层 Java/Golang/Python , 难道 c++ 发展这么多年没有 http 库么,不应该把 |
![]() | 31 steins2628 2022-06-25 12:15:30 +08:00 http://stefanfrings.de/qtwebapp/ 都是 c++,可以看看这个,这样的话前后端分离,只要定 api 就行 |
32 cwaken 2022-06-25 12:42:44 +08:00 via iPhone usocket 库,17 写法 |
![]() | 33 linuxyz 2022-06-25 20:59:52 +08:00 @littlewing 正解 gRPC Cpp Quick Start 走一波 https://grpc.io/docs/languages/cpp/quickstart/ |
34 spygg 2022-06-26 10:04:53 +08:00 看你具体需求了,一般来说就 http 和 websocket, 当然如果只是和前端交互的话 cef/webkit 之类的也可以 |