This is a proof-of-concept HDFS client written natively in Rust. All other clients I have found in any other language are simply wrappers around libhdfs and require all the same Java dependencies, so I wanted to see if I could write one from scratch given that HDFS isn't really changing very often anymore. Several basic features are working, however it is not nearly as robust and the real HDFS client.
What this is not trying to do is implement all HDFS client/FileSystem interfaces, just things involving reading and writing data.
Here is a list of currently supported and unsupported but possible future features.
``` brew install gsasl krb5
export BINDGENEXTRACLANGARGS="-I/opt/homebrew/include" export LIBRARYPATH=/opt/homebrew/lib cargo build --all-features ```
apt-get install clang libkrb5-dev libgsasl-dev
cargo build --all-features
token
- enables token based DIGEST-MD5 authentication support. This uses the gsasl
native library and only supports authentication, not integrity or confidentialitykerberos
- enables kerberos GSSAPI authentication support. This uses the libgssapi
crate and supports integrity as well as confidentialityobject_store
- provides an object_store
wrapper around the HDFS clientprotobuf-src
- builds protobuf from source to avoid having to pre-install it