Skip to content
/ h2 Public
forked from hyperium/h2

HTTP 2.0 client & server implementation for Rust.

License

Notifications You must be signed in to change notification settings

eaufavor/h2

This branch is 12 commits behind hyperium/h2:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

87c9be0 · Nov 11, 2024
Nov 11, 2024
Apr 9, 2024
Nov 4, 2024
May 6, 2024
May 31, 2017
Nov 15, 2023
Nov 3, 2024
Aug 6, 2024
Dec 12, 2022
May 10, 2018
Aug 19, 2024
Apr 24, 2024
Aug 19, 2024
Dec 16, 2017
Nov 15, 2023

Repository files navigation

H2

A Tokio aware, HTTP/2 client & server implementation for Rust.

License: MIT Crates.io Documentation

More information about this crate can be found in the crate documentation.

Features

  • Client and server HTTP/2 implementation.
  • Implements the full HTTP/2 specification.
  • Passes h2spec.
  • Focus on performance and correctness.
  • Built on Tokio.

Non goals

This crate is intended to only be an implementation of the HTTP/2 specification. It does not handle:

  • Managing TCP connections
  • HTTP 1.0 upgrade
  • TLS
  • Any feature not described by the HTTP/2 specification.

This crate is now used by hyper, which will provide all of these features.

Usage

To use h2, first add this to your Cargo.toml:

[dependencies]
h2 = "0.4"

Next, add this to your crate:

extern crate h2;

use h2::server::Connection;

fn main() {
    // ...
}

FAQ

How does h2 compare to solicit or rust-http2?

The h2 library has implemented more of the details of the HTTP/2 specification than any other Rust library. It also passes the h2spec set of tests. The h2 library is rapidly approaching "production ready" quality.

Besides the above, Solicit is built on blocking I/O and does not appear to be actively maintained.

Is this an embedded Java SQL database engine?

No.

About

HTTP 2.0 client & server implementation for Rust.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 99.2%
  • Other 0.8%