HDFS Native Client in Rust based on hdfs-sys.
```rust use std::io::{Read, Write};
use hdrs::Client;
fn main() -> Result<(), Box
let mut f = fs
.open("/tmp/hello.txt", libc::O_WRONLY | libc::O_CREAT)?;
let n = f.write("Hello, World!".as_bytes())?;
let mut f = fs.open("/tmp/hello.txt", libc::O_RDONLY)?;
let mut buf = vec![0; 1024];
let n = f.read(&mut buf)?;
let _ = fs.delete("/tmp/hello.txt", false)?;
Ok(())
} ```
hdrs
depends on hdfs-sys which links libjvm
and libhdfs
to work.
Please make sure JAVA_HOME
, HADOOP_HOME
and LD_LIBRARY_PATH
is set correctly:
shell
export JAVA_HOME=/path/to/java
export HADOOP_HOME=/path/to/hadoop
export LD_LIBRARY_PATH=${HADOOP_HOME}/lib/native:${JAVA_HOME}/lib/server:${LD_LIBRARY_PATH}
hdrs
depends on hdfs-sys which uses JNI to call functions provided by jars that provided by hadoop releases.
Please also make sure CLASSPATH
is set correctly during runtime:
shell
export CLASSPATH=${HADOOP_HOME}/share/hadoop/common/*:${HADOOP_HOME}/share/hadoop/common/lib/*:${HADOOP_HOME}/share/hadoop/hdfs/*:${HADOOP_HOME}/share/hadoop/hdfs/lib/*:${HADOOP_HOME}/etc/hadoop/*
Check out the CONTRIBUTING.md guide for more details on getting started with contributing to this project.
Submit issues for bug report or asking questions in discussion.
This project is highly inspired by clang-sys
Licensed under Apache License, Version 2.0.