Banyan Julia is a suite of libraries for processing big data with massive parallelism in the cloud. The difference between Banyan Julia and alternatives (such as Dagger.jl, Distributed, MPI.jl) is that anything you can compute
can be instantly sample
d.
- BanyanArrays.jl for reading/writing large HDF5 datasets and distributed map-reduce computation
- BanyanImages.jl for massively parallel image processing
- BanyanDataFrames.jl for distributed reading/writing Parquet/CSV/Arrow datasets and selecting, aggregating, and transforming data
- BanyanONNXRunTime.jl for high-performance ML inference (bring your own PyTorch and TensorFlow models!)
- BanyanDBInterface.jl (WIP - please contact [email protected]) for extracting from and loading to your database
- Banyan.jl's Custom Scripting for running single-worker or many-worker Julia scripts with easy access to MPI, parallel HDF5, and Amazon S3 (with the mounted
s3/
directory)
You can effectively be able to use these libraries as drop-in replacements of the standard library Arrays and the DataFrames.jl library. By changing an import statement, you can run your code as is with Banyan scaling to arbitrary data or compute needs and read in array/image/table data from S3 or the Internet (e.g., GitHub or public APIs).
Visit Banyan Computing for full documentation.
Banyan is the best way to unleash Julia on big data in the cloud! To get started:
- Follow the getting started steps (15 minutes)
- Create a cluster on the dashboard
- Start a cluster session wherever you are running Julia with
start_session
(between 15s and 30min) - Use functions in BanyanArrays.jl or BanyanDataFrames.jl for big data processing!
- End the cluster session with
end_session
- Destroy the cluster on the dashboard
Please create branches named according the the author name and the feature name
like {author-name}/{feature-name}
. For example: caleb/add-tests-for-hdf5
.
Then, submit a pull request on GitHub to merge your branch into the branch with
the latest version number.
When pulling/pushing code, you may need to add the appropriate SSH key. Look up GitHub documentation for how to generate an SSH key, then make sure to add it. You may need to do this repeatedly if you have multiple SSH keys for different GitHub accounts. For example, on Windows you may need to:
eval `ssh-agent`
ssh-add -D
ssh-add /c/Users/Claris/.ssh/id_rsa_clarisw
git remote set-url origin [email protected]:banyan-team/banyan-website.git
To see an example of how to add tests, see BanyanArrays/test/runtests.jl
and BanyanArrays/test/hdf5.jl
.
To run tests, ensure that you have a Banyan account connected to an AWS account.
Then, cd
into the directory with the Banyan Julia project you want to run
tests for (e.g., Banyan
for Banyan.jl or BanyanDataFrames
for
BanyanDataFrames.jl) and run julia --project=. -e "using Pkg; Pkg.test()"
.
To filter and run a subset of test sets (where each test set is defined with
@testset
) with names matching a given pattern, run
julia --project=. -e "using Pkg; Pkg.test(test_args=[\"{pattern 1}\", \"{pattern 2}\"])"
where
the pattern could be, for example, Sampl(.*)parquet
(a regular expression)
or Sample collection
.
You must then specify the cluster name with the BANYAN_CLUSTER_NAME
environment variable. You must also specify the relevant BANYAN_*
and AWS_*
environment variables to provide credentials. AWS
credentials are specified in the same way as they would be if using
the AWS CLI (either use environment variables or use the relevant
AWS configuration files) and the Banyan environment variables
are saved in banyanconfig.toml
so you don't need to specify it
every time.
You must also specify the branch you would like to test with the BANYAN_JULIA_BRANCH
environment variables.
For example, if you have previously specified your Banyan API key, user ID, and AWS credentials, you could:
cd BanyanDataFrames
BANYAN_CLUSTER_NAME=pumpkincluster0 BANYAN_JULIA_BRANCH=v0.1.3 julia --project=. -e "using Pkg; Pkg.test(test_args=[\"ample\"])
If your AWS credentials are saved under a profile named banyan-testing
, you could use AWS_DEFAULT_PROFILE=banyan-testing
.
Make sure to use the ] dev ...
command or Pkg.dev(...)
to ensure that when you
are using BanyanArrays.jl or BanyanDataFrames.jl you are using the local version.