Each project editor session and deployment consumes compute resources within the Workbench cluster. If you need to run applications that require more memory or compute power than Anaconda provides by default, you can create customized resource profiles and configure the number of cores and amount of memory/RAM available for them. You can then allow users to access your customized resource profiles either globally or based on their role, assigned group, or as individual users.

For example, if your installation includes nodes with GPUs, you can add a GPU resource profile so users can access the GPUs to accelerate computation within their projects, which is essential for AI/ML model training.

Resource profiles that you create are listed for users when they create or deploy a project. You can create as many resource profiles as needed.

  1. Connect to your instance of Workbench.
  2. View a list of your configmaps by running the following command:
kubectl get cm
  1. Edit the anaconda-enterprise-anaconda-platform.yml file.
kubectl edit cm anaconda-enterprise-anaconda-platform

Anaconda recommends making a backup copy of this file before you edit it. Any changes you make will impact how Workbench functions.

  1. Find the resource-profiles: section of the file.
  2. Add any additional resources using the following examples as a template for your resource profiles, then customize them for your environment:
  1. (Optional) By default, CPU sessions and deployments are allowed to run on GPU nodes. To reserve your GPU nodes for sessions and deployments that require them, comment out the affinity: specification in the file as shown:
  1. (Optional) If you need to schedule user workloads on a specific node, add a node_selector to your resource profile. Use node selectors when running different CPU types, such as Intel and AMD; or different GPU types, such as Tesla v100 and p100. To enable a node selector, add node_selector to the bottom of your resource profile, with the model: value matching the label you have applied to your worker node.
  1. Save your changes to the file.
  2. Restart the workspace and deploy services by running the following command:
kubectl delete pods -l 'app in (ap-workspace, ap-deploy)'

Open a project and view its settings to verify that the resource profiles you added appear in the Resource Profile dropdown.