lsquic使用《二》--echo服务

本文介绍了一个基于lsquic库的简易echo服务端和客户端实现,用于理解QUIC协议的工作流程。客户端利用libev进行事件驱动,监听stdin输入并发送数据,服务端则涉及SSL初始化和证书管理。文中强调了结构体变量初始化的重要性,并提供了cppdemo代码参考。

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

   官方实现的echo的客户端及服务端demo功能是客户端发送字符服务端原样返回,但是实现比较复杂,对于熟悉流程来说不友好,因此参考这个lsquic-tutorial实现了一个简单版本的,主要用于理解流程。

   lsquic的结构体变量定义后一定得memset将变量所有成员初始值设置为0(或者说NULL),不然会有意想不到的bug出现。

1、client端

1.1、数据输入并发送

   客户端使用libev作为事件循环的驱动,不断侦听stdin输入,遇到换行符即启动调用lsquic_stream_wantwrite函数启动lsquic的数据读入流程,即触发注册的on_write回调函数,在该回调函数中会调用lsquic_stream_flush函数,flush函数会触发注册的ea_packets_out回调函数。
在这里插入图片描述

1.2、网络数据读取

   侦听网络socket,有数据可读时将网络数据读出,此时读出的数据是quic封装数据,然后把这quic数据送入lsquic_engine_packet_in函数,数据送入该函数后会触发注册的on_read回调函数,在该函数中读取出解密后的真正使用的数据。
在这里插入图片描述

2、服务端

2.1、ssl初始化

   lsquic启动servcer时必须定义lsquic_engine_api结构体中ssl相关的以下4个成员的值

  • ea_get_ssl_ctx: 用于获取一个初始化好的ssl资源;
  • ea_lookup_cert: 用于根据ea_apln查找不同证书的ssl资源,需要维护一个以ea_apln为key的map(或者其它查找的数据结构);
  • ea_cert_lu_ctx: ea_lookup_cert函数的客制化参数;
  • ea_apln: 和DTLS连接时SSL_select_next_proto函数用(协商函数),客户端设置的apln如果与服务端的不一致则DTLS握手会失败;

注意:ea_get_ssl_ctx回调函数的第一个参数(void* 自定义参数)是从lsquic_engine_packet_in函数的第6个参数传进去的;

用户数据的读取和及交互数据的发送和客户端的流程一致,并无差别。

3、cppdemo

  详细代码demo见github代码

4、参考

《1》、lsquic官方
《2》、lsquic第三方demo旧版本lsquic

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值