Skip to content

Latest commit

 

History

History
85 lines (64 loc) · 5 KB

README.md

File metadata and controls

85 lines (64 loc) · 5 KB

Banyan Julia

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 sampled.

  • 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.

Getting Started

Banyan is the best way to unleash Julia on big data in the cloud! To get started:

  1. Follow the getting started steps (15 minutes)
  2. Create a cluster on the dashboard
  3. Start a cluster session wherever you are running Julia with start_session (between 15s and 30min)
  4. Use functions in BanyanArrays.jl or BanyanDataFrames.jl for big data processing!
  5. End the cluster session with end_session
  6. Destroy the cluster on the dashboard

Contributing

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

Testing

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.

Development

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.