NVIDIA NIMs provide a simplified way to deploy optimized AI applications into production that support a large list of AI models.
Existing NVIDIA components such as NVIDIA drivers, the NVIDIA Container Toolkit, the NVIDIA CUDA Toolkit, or the NVIDIA GPU Operator exist and are installed on the host or into a Kubernetes cluster to enable AI applications. NVIDIA NIMs run on top of this GPU-enabled platform to deliver AI applications that developers can embed directly into their programs using API calls.
The NIM Deploy Project is made up components that outline various deployment scenarios (KServe, Helm, Operator, CSP, ISV, etc.), along with guides that are meant as example material to show end to end workflows for deployment and demo usage, there maybe be references to several related NVIDIA projects including:
The NIM Deploy Project leverages the following software components, but they are not included as part of the NIM Deploy project. The associated code is linked to each of the components below:
The NVIDIA NIM Deploy Project is open-source and its components are licensed under the permissive Apache 2.0 license.
The NVIDIA NIM Deploy has four artifacts as part of the project release:
- Guides
- KServe YAML
- Helm Charts
- Operator Source Code
There is currently no defined release flow, as this project is meant for experimental design and integrations.
NVIDIA is willing to work with partners for adding platform support for NVIDIA NIM. The NVIDIA NIM Deploy Project is open-source and permissively licensed under the Apache 2.0 license with only minimal requirements for source code contributions.
Please work with the NVIDIA team through GitHub issues to determine appropriate testing and CI for new platform support.
Want to hack on the NVIDIA NIM Deploy Project? Awesome!
We require that all contributions are certified under the terms of the Developer Certificate of Origin (DCO), Version 1.1.
This certifies that the contribution is your original work or you have the right to submit it under the same or compatible license. Any public contribution that contains commits that are not signed off will not be accepted.
To simplify the process, we accept GPG-signed commits as fulfilling the requirements of the DCO.
A GPG-signed commit provides cryptographic assurance that the commit was made by the holder of the corresponding private key. By configuring your commits to be signed by GPG, you not only enhance the security of the repository but also implicitly certify that you have the rights to submit the work under the project's license and agree to the DCO terms.
-
Generate a GPG key pair:
If you don't already have a GPG key, you can generate a new GPG key pair by following the instructions here: Generating a new GPG key.
-
Add your GPG key to your GitHub/GitLab account:
After generating your GPG key, add it to your GitHub account by following these steps: Adding a new GPG key to your GitHub account.
-
Configure Git to sign commits:
Tell Git to use your GPG key by default for signing your commits:
git config --global user.signingkey YOUR_GPG_KEY_ID
-
Sign commits:
#dividual commits using the
-S
flaggit commit -S -m "Your commit message"
Or, enable commit signing by default (recommended):
git config --global commit.gpgsign true
Troubleshooting and Help: If you encounter any issues or need help with setting up commit signing, please refer to the GitHub documentation on signing commits. Feel free to contact the project maintainers if you need further assistance.
To ensure the quality and legality of the code base, all contributors are required to certify the origin of their contributions under the terms of the Developer Certificate of Origin (DCO), Version 1.1:
Developer Certificate of Origin
Version 1.1
Copyright (C) 2004, 2006 The Linux Foundation and its contributors.
1 Letterman Drive
Suite D4700
San Francisco, CA, 94129
Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed.
Developer's Certificate of Origin 1.1
By making a contribution to this project, I certify that:
(a) The contribution was created in whole or in part by me and I have the right to submit it under the open source license indicated in the file; or
(b) The contribution is based upon previous work that, to the best of my knowledge, is covered under an appropriate open source license and I have the right under that license to submit that work with modifications, whether created in whole or in part by me, under the same open source license (unless I am permitted to submit under a different license), as indicated in the file; or
(c) The contribution was provided directly to me by some other person who certified (a), (b) or (c) and I have not modified it.
(d) I understand and agree that this project and the contribution are public and that a record of the contribution (including all personal information I submit with it, including my sign-off) is maintained indefinitely and may be redistributed consistent with this project or the open source license(s) involved.
We look forward to your contributions to the NVIDIA NIM Deploy Project!