/BentoML

The Unified Model Serving Framework 🍱

Primary LanguagePythonApache License 2.0Apache-2.0

Unified Model Serving Framework Tweet

pypi_status downloads actions_status documentation_status join_slack

BentoML enables users to create a machine learning powered prediction service in minutes and bridges the gap between data science and DevOps.

👉 Pop into our Slack community! We're happy to help with any issue you face or even just to meet you and hear what you're working on :)

The BentoML version 1.0 is around the corner. For stable release version 0.13, see the 0.13-LTS branch. Version 1.0 is under active development, you can be of great help by testing out the preview release, reporting issues, contribute to the documentation and create sample gallery projects.

Why BentoML

  • The easiest way to turn your ML models into production-ready API endpoints.
  • High performance model serving, all in Python.
  • Standardize model packaging and ML service definition to streamline deployment.
  • Support all major machine-learning training frameworks.
  • Deploy and operate ML serving workload at scale on Kubernetes via Yatai.

Getting Started

  • Quickstart guide will show you a simple example of using BentoML in action. In under 10 minutes, you'll be able to serve your ML model over an HTTP API endpoint, and build a docker image that is ready to be deployed in production.
  • Main concepts will give a comprehensive tour of BentoML's components and introduce you to its philosophy. After reading, you will see what drives BentoML's design, and know what bento and runner stands for.
  • ML Frameworks lays out best practices and example usages by the ML framework used for training models.
  • Advanced Guides showcases advanced features in BentoML, including GPU support, inference graph, monitoring, and customizing docker environment etc.
  • Check out other projects from the BentoML team:

Community

Contributing

There are many ways to contribute to the project:

  • If you have any feedback on the project, share it with the community in Github Discussions of this project.
  • Report issues you're facing and "Thumbs up" on issues and feature requests that are relevant to you.
  • Investigate bugs and reviewing other developer's pull requests.
  • Contributing code or documentation to the project by submitting a Github pull request. See the development guide.
  • See more in the contributing guide.

Usage Reporting

BentoML by default collects anonymous usage data using Amplitude. It only collects BentoML library's own actions and parameters, no user or model data will be collected.  Here is the code that does it.

This helps the BentoML team to understand how the community is using this tool and what to build next. You can easily opt-out of usage tracking by running the BentoML commands with the --do-not-track option.

> bentoml [command] --do-not-track

You can also opt-out via setting environment variable BENTOML_DO_NOT_TRACK=True

> export BENTOML_DO_NOT_TRACK=True

License

Apache License 2.0

FOSSA Status