tk-sendfile

Crates.iotk-sendfile
lib.rstk-sendfile
version0.4.0
sourcesrc
created_at2016-10-17 15:05:14.591231
updated_at2017-03-30 15:03:31.646625
description A high-performance file serving library. Serves files in special IO threads. In this version it uses normal file reading, but we will optimize using `sendfile` on supported systems as quick as tokio allows us to do that.
homepagehttp://github.com/tailhook/tk-sendfile
repository
max_upload_size
id6885
size35,416
Paul Colomiets (tailhook)

documentation

http://docs.rs/tk-sendfile

README

Sendfile for Tokio

:Status: alpha :Documentation: http://docs.rs/tk-sendfile

A thread pool that can process file requests and send data to the socket with zero copy (using sendfile).

Challenges:

  1. While sendfile is non-blocking when writing to socket, it blocks for disk access for two cases: initial open() and for reading file inside the sendfile() system call itself

  2. Doing more than single sendfile operation requires some bookkeeping

  3. It should be possible to implement file cache (both opened files and in-memory file data) transparently for the user

  4. [TODO] Serving user-specified file paths requires non-trivial code to prevent symlink attacks

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Commit count: 0

cargo fmt