阿里巴巴发布的XQUIC库
-
是一个遵循IETF标准的QUIC和HTTP/3的客户端和服务端实现。 目前支持的QUIC版本是v1和draft-29。
-
是跨平台的。 目前支持Android、iOS、Linux、macOS和Windows。绝大部分代码被用于我们自己的产品,并已在安卓、iOS APP以及服务端上进行了大规模测试。
-
目前仍在积极开发中。 我们定期与其他QUIC实现进行互通性测试。
编译XQUIC,你需要:
- CMake
- BoringSSL 或者 BabaSSL
运行测试用例,你需要:
- libevent
- CUnit
XQUIC 支持 BoringSSL 和 BabaSSL。
# 获取 XQUIC 源码
git clone [email protected]:alibaba/xquic.git
cd xquic
# 编译 BabaSSL
git clone [email protected]:BabaSSL/BabaSSL.git ./third_party/babassl
cd ./third_party/babassl/
./config --prefix=/usr/local/babassl
make -j
SSL_TYPE_STR="babassl"
SSL_PATH_STR="${PWD}"
SSL_INC_PATH_STR="${PWD}/include"
SSL_LIB_PATH_STR="${PWD}/libssl.a;${PWD}/libcrypto.a"
cd -
# 使用 BabaSSL 编译 XQUIC
git submodule update --init --recursive
mkdir -p build; cd build
cmake -DGCOV=on -DCMAKE_BUILD_TYPE=Debug -DXQC_ENABLE_TESTING=1 -DXQC_SUPPORT_SENDMMSG_BUILD=1 -DXQC_ENABLE_EVENT_LOG=1 -DXQC_ENABLE_BBR2=1 -DXQC_DISABLE_RENO=0 -DSSL_TYPE=${SSL_TYPE_STR} -DSSL_PATH=${SSL_PATH_STR} -DSSL_INC_PATH=${SSL_INC_PATH_STR} -DSSL_LIB_PATH=${SSL_LIB_PATH_STR} ..
make -j
# 获取 XQUIC 源码
git clone [email protected]:alibaba/xquic.git
cd xquic
# 编译 BoringSSL
git clone [email protected]:google/boringssl.git ./third_party/boringssl
cd ./third_party/boringssl
mkdir -p build && cd build
cmake -DBUILD_SHARED_LIBS=0 -DCMAKE_C_FLAGS="-fPIC" -DCMAKE_CXX_FLAGS="-fPIC" ..
make ssl crypto
cd ..
SSL_TYPE_STR="boringssl"
SSL_PATH_STR="${PWD}"
SSL_INC_PATH_STR="${PWD}/include"
SSL_LIB_PATH_STR="${PWD}/build/ssl/libssl.a;${PWD}/build/crypto/libcrypto.a"
cd ../..
# 使用 BoringSSL 编译 XQUIC
git submodule update --init --recursive
mkdir -p build; cd build
cmake -DGCOV=on -DCMAKE_BUILD_TYPE=Debug -DXQC_ENABLE_TESTING=1 -DXQC_SUPPORT_SENDMMSG_BUILD=1 -DXQC_ENABLE_EVENT_LOG=1 -DXQC_ENABLE_BBR2=1 -DXQC_DISABLE_RENO=0 -DSSL_TYPE=${SSL_TYPE_STR} -DSSL_PATH=${SSL_PATH_STR} -DSSL_INC_PATH=${SSL_INC_PATH_STR} -DSSL_LIB_PATH=${SSL_LIB_PATH_STR} ..
make -j
sh ../scripts/xquic_test.sh
- 关于API的使用,详见 API文档。
- 关于平台支持的细节,详见 平台文档。
- 关于 IETF QUIC Protocol 的中文翻译,详见翻译文档。
- 关于event_log模块的使用, 详见 Event_log module docs。
- 关于测试,参见 测试文档。
- 关于常见问题,参见 FAQs 和 Trouble Shooting Guide。
我们希望你能为XQUIC做出贡献,帮助它变得比现在更好!我们鼓励并重视所有类型的贡献,请参阅我们的贡献指南了解更多信息。
如果你有任何问题,请随时在我们的讨论区开启一个新的讨论主题。
XQUIC 使用 Apache 2.0 许可证。