Skip to main content

MongoDB

MongoDB is a developer data platform that quickly builds applications with optimal performance and scalability. It provides data distribution and mobility across multiple cloud environments. In addition, this multi-cloud database service provides you with resilience, data privacy, and security.

Add MongoDB to an App Profile

Use the following steps to add MongoDB to an app profile.


Prerequisite

A Spectro Cloud account.


Enablement

You can use the following steps to learn how to add MongoDB to your app profile.

  1. Log in to Palette.
  1. On the right side of the window, click the User Menu to expand it and select Switch to App Mode.
  1. From the Main Menu click App Profiles to create a new profile. Check out the Create an App Profile guide to learn about different app profile types and how to create them. Provide the following basic information and click Next.
ParameterDescription
Application Profile NameA custom name for the App Profile.
Version (optional)The default value is 1.0.0. You can create multiple versions of an App Profile using the format major.minor.patch.
Description (optional)Description of the App Profile.
Tag (optional)Assign tags to the app profile.
  1. Select MongoDB from the database services and start the configuration.
  1. Provide the following information to the wizard:
  • Name: The DB name. You can use the default Palette-generated name or create a custom name.

  • Username: The user name for database access control.

  • Password: The password for the username.

  • Database Volume Size: Select the volume size for the database. Ensure you stay within the storage amount available in the cluster group and virtual clusters.

  • Version: Select the version from the Version drop-down.

  1. Click Save Changes.

Validate

  1. Log in to Palette and switch to App Mode.
  1. Navigate to the left Main Menu and select Apps.
  1. Select the application that contains MongoDB.
  1. Validate your application is displaying the green status. The color code in the app profile box shows the status of the service deployment.
Color CodeDescription
GreenSuccessfully Deployed
BlueUnder Deployment
RedError State

Output Variables

The exposed output variables of this service layer may be used in other service layers. These output variables are typically used for connectivity purposes.

ParameterOutput VariableDescription
Database Username{{.spectro.app.$appDeploymentName.<service-name>.USERNAME}}The database user name.
Database User Password{{.spectro.app.$appDeploymentName.<service-name>.PASSWORD}}The password of the database user name.
Connection String{{.spectro.app.$appDeploymentName.<service-name>.MONGO_URI}}The MongoDB connection string that contains the Kubernetes service hostname of the database. The connection string is prefixed with mongodb://
DNS Seed{{.spectro.app.$appDeploymentName.<service-name>.MONGO_URI_SRV}}Represents the MongoDB DNS seed list connection format. The SRV indicates to the client that the host name that follows corresponds to a DNS SRV record. Contains the prefix mongodb+srv

Database Password

You can get the database password by reading the content of the Kubernetes secret created for the database user. To retrieve the password for the MongoDB database user, use the following command format.

kubectl get secret <app-name>-<service-name>-<user-name> \
--namespace <app-name>-<service-name>-ns --output jsonpath='{.data.password}' | base64 --decode

Replace the values with the respective names.

  • app-name: represents the name of the app provided during the Palette app creation process.
  • service-name: The name of the service layer in the app profile.
  • user-name: The name of the database user.

Example:

  • App Name: app-tarfful

  • Service Name: mongodb-1

  • Database User: myuser

kubectl get secret app-tarfful-mongodb-1-myuser  \
--namespace app-tarfful-mongodb-1-ns --output jsonpath='{.data.password}' | base64 --decode

Output:

.Hr1}%DrA2MFf

Next Steps

Palette Dev Engine removes the traditional challenges encountered when deploying a MongoDB instance. You can add MongoDB to your application profile and get started with MongoDB today. Check out the MongoDB Tutorials to learn how to integrate MongoDB with your applications.

Resources