Cross-platform, C implementation of the IETF QUIC protocol, exposed to C, C++, C# and Rust.
Перейти к файлу
dependabot[bot] 9c4dceb625
Bump github/codeql-action from 3.26.6 to 3.26.7 (#4549)
Bumps [github/codeql-action](https://github.com/github/codeql-action) from 3.26.6 to 3.26.7.
- [Release notes](https://github.com/github/codeql-action/releases)
- [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md)
- [Commits](4dd16135b6...8214744c54)

---
updated-dependencies:
- dependency-name: github/codeql-action
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-09-14 12:52:18 -07:00
.azure Refactoring Azure pipeline for publishing package (#4464) 2024-08-26 23:17:38 +09:00
.devcontainer Container based build workflow for Linux (#3760) 2023-07-16 07:53:53 -04:00
.docker Update Dockerfile for xdp and cross compile (#4336) 2024-06-07 20:10:12 -07:00
.github Bump github/codeql-action from 3.26.6 to 3.26.7 (#4549) 2024-09-14 12:52:18 -07:00
cmake Build and sign arm/arm64 Onebranch pipeline for linux (#2987) 2022-08-17 07:28:14 -04:00
docs Update Release.md (#4430) 2024-08-05 16:39:22 -04:00
scripts Log QUIC_TLS_SECRETS on all TestConnections and write to disk on cleanup (#4349) 2024-08-28 15:29:15 -07:00
src Set SO_REUSEADDR on epoll tcp listener sockets (#4544) 2024-09-11 14:25:33 -07:00
submodules Bump submodules/xdp-for-windows from `eaf9907` to `0b2c598` (#4491) 2024-09-11 08:19:51 -07:00
.CodeQL.yml CodeQL Classification (#4247) 2024-04-17 11:44:31 -04:00
.dockerignore update msquic to clog 0.4.0 (#2260) 2022-01-04 10:11:46 -05:00
.gitattributes Fix jpg image file 2021-01-17 09:02:54 -08:00
.gitignore Add DocFx Integration (#3833) 2023-09-19 16:48:18 -07:00
.gitmodules Submodule XDP (#3967) 2023-11-27 12:16:40 -05:00
.sscignore Update .sscignore (#3797) 2023-08-09 08:07:19 -04:00
CMakeLists.txt Better Support for Disabling Pool Allocations (#4539) 2024-09-09 06:53:19 -07:00
CMakePresets.json Add CMake Presets file. (#3369) 2023-01-24 13:52:11 -05:00
Cargo.toml Update bitfield requirement from 0.16.1 to 0.17.0 (#4547) 2024-09-14 12:50:18 -07:00
LICENSE Normalize Line Endings (#384) 2020-05-12 19:08:05 -07:00
README.md Add documentation for getting started with the sample server-client app (#3985) 2023-12-05 16:32:34 -05:00
THIRD-PARTY-NOTICES Remove miTLS (#1398) 2021-03-29 17:21:54 -07:00
codecov.yml Configure Codecov to reduce noise (#3802) 2023-08-10 10:35:00 -07:00
msquic.kernel.sln Completely remove 32 bit windows kernel mode (#2462) 2022-03-09 08:10:16 -05:00
version.json Update Minor Version after release/2.4 Fork 2024-08-05 08:31:12 -04:00

README.md

MsQuic logo

Documentation Perf Dashboard Build Status Test Status Stress Status codecov CodeQL CII Best Practices Discord crates.io nuget

MsQuic is a Microsoft implementation of the IETF QUIC protocol. It is cross-platform, written in C and designed to be a general purpose QUIC library. MsQuic also has C++ API wrapper classes and exposes interop layers for both Rust and C#.

Protocol Features

QUIC has many benefits when compared to existing "TLS over TCP" scenarios:

  • All packets are encrypted and handshake is authenticated with TLS 1.3.
  • Parallel streams of (reliable and unreliable) application data.
  • Exchange application data in the first round trip (0-RTT).
  • Improved congestion control and loss recovery.
  • Survives a change in the clients IP address or port.
  • Stateless load balancing.
  • Easily extendable for new features and extensions.

Library Features

MsQuic has several features that differentiates it from other QUIC implementations:

  • Optimized for client and server.
  • Optimized for maximal throughput and minimal latency.
  • Asynchronous IO.
  • Receive side scaling (RSS) support.
  • UDP send and receive coalescing support.

Documentation

Contributing

For information on contributing, please see our contribution guidelines. Feel free to take a look at our Good First Issues list if you're looking for somewhere to start. If you'd just like to talk, come chat with us on Discord.