copyright | lastupdated | ||
---|---|---|---|
|
2018-11-14 |
{:shortdesc: .shortdesc} {:new_window: target="_blank"} {:codeblock: .codeblock} {:screen: .screen} {:tip: .tip} {:pre: .pre}
{: #mean-stack}
This tutorial walks you through the creation of a web application using the popular MEAN stack. It is composed of a Mongo DB, Express web framework, Angular front end framework and a Node.js runtime. You will learn how to run a MEAN starter locally, create and use a managed database-as-a-service (DBasS), deploy the app to {{site.data.keyword.cloud_notm}} and monitor the application.
{: #objectives}
- Create and run a starter Node.js app locally.
- Create a managed database-as-a-service (DBasS).
- Deploy the Node.js app to the cloud.
- Scale MongoDB resources.
- Learn how to monitor application performance.
{: #products}
This tutorial uses the following {{site.data.keyword.Bluemix_notm}} services:
Attention: This tutorial might incur costs. Use the Pricing Calculator to generate a cost estimate based on your projected usage.
{:#architecture}
- User access the application using a web browser.
- The Node.js app goes to the {{site.data.keyword.composeForMongoDB}} database to fetch data.
{: #prereqs}
And to develop and run the application locally:
{: #runapplocally}
In this section, you will run a local MongoDB database, clone a MEAN sample code, and run the application locally to use the local MongoDB database.
{: shortdesc}
- Follow the instructions here to install and run MongoDB database locally. Once installation completed, use the command below to confirm that mongod server is running. using the Confirm your database is running with the following command.
mongo
{: codeblock}
- Clone the MEAN starter code.
git clone https://github.com/IBM-Cloud/nodejs-MEAN-stack
cd nodejs-MEAN-stack
{: codeblock}
- Install the required packages.
npm install
{: codeblock}
-
Copy .env.example file to .env. Edit the information needed, at a minimum add your own SESSION_SECRET.
-
Run node server.js to start your app
node server.js
{: codeblock}
- Access your application, create a new user and log in
{: #createdatabase}
In this section, you will create a {{site.data.keyword.composeForMongoDB}} database in the cloud. {{site.data.keyword.composeForMongoDB}} is database-as-a-service that usually easier to configure and provides built-in backups and scaling. You can find many different types of databases in the IBM cloud catalog. To create {{site.data.keyword.composeForMongoDB}} follow the steps below.
{: shortdesc}
- Login to your {{site.data.keyword.cloud_notm}} account via the command line and target your {{site.data.keyword.cloud_notm}} account.
ibmcloud login
ibmcloud target --cf
{: codeblock}
You can find more CLI commands here.
- Create an instance of {{site.data.keyword.composeForMongoDB}}. This can also be done using the console UI. The service name must be named mean-starter-mongodb as the application is configured to look for this service by this name.
ibmcloud cf create-service compose-for-mongodb Standard mean-starter-mongodb
{: codeblock}
{: #deployapp}
In this section, you will deploy the node.js app to the {{site.data.keyword.cloud_notm}} that used the managed MongoDB database. The source code contains a manifest.yml file that been configured to use the "mongodb" service created earlier. The application uses VCAP_SERVICES environment variable to access the Compose MongoDB database credentials. This can be viewed in the server.js file.
{: shortdesc}
-
Push code to the cloud.
ibmcloud cf push
{: codeblock}
-
Once the code been pushed, you should be able to view the app in your browser. A random host name been generated that can look like:
https://mean-random-name.mybluemix.net
. You can get your application URL from the console dashboard or command line.
{: #scaledatabase}
If your service needs additional storage, or you want to reduce the amount of storage allocated to your service, you can do this by scaling resources.
{: shortdesc}
- Using the console dashboard, go to connections section and click on the MongoDB instance database.
- In the deployment details panel, click on the scale resources option.
- Adjust the slider to raise or lower the storage allocated to your {{site.data.keyword.composeForMongoDB}} database service.
- Click Scale Deployment to trigger the rescaling and return to the dashboard overview. A 'Scaling initiated' message will appear at the top of the page to let you know the rescaling is in progress.
{: #monitorapplication}
To check the health of your application, you can use the built-in Availability Monitoring service. The Availability Monitoring service is automatically attached to your applications in the cloud. The availability Monitoring service runs synthetic tests from locations around the world, around the clock to proactively detect and fix performance issues before they impact your visitors. Follow the steps below to get to the monitoring dashboard.
{: shortdesc}
- Using the console dashboard, under your application, select the Monitoring tab.
- Click View All Tests to view the tests.
{: #related}
- Set up source control and continuous delivery.
- Secure web application across multiple locations.
- Create, secure and manage REST APIs.