Skip to content

Latest commit

 

History

History
108 lines (74 loc) · 2.9 KB

README.md

File metadata and controls

108 lines (74 loc) · 2.9 KB

Example MongoDB Application

This simple application illustrates the use of the Mongodb data service in a Ruby application running on Cloud Foundry.

Installation

Create a MongoDB service instance

Find your MongoDB service via cf marketplace.

$ cf marketplace
Getting services from marketplace in org testing / space testing as me...
OK

service       plans     description
mongodb   default   A MongoDB database on demand

Our service is called mongodb. To create an instance of this service, use:

$ cf create-service mongodb default mongodb-instance

Push the Example Application

The example application comes with a Cloud Foundry manifest.yml file, which provides all of the defaults necessary for an easy cf push.

$ cf push
Using manifest file cf-mongodb-example-app/manifest.yml

Creating app mongodb-example-app in org testing / space testing as me...
OK

Using route mongodb-example-app.example.com
Binding mongodb-example-app.example.com to mongodb-example-app...
OK

Uploading mongodb-example-app...
Uploading from: cf-mongodb-example-app
...
Showing health and status for app mongodb-example-app in org testing / space testing as me...
OK

requested state: started
instances: 0/1
usage: 256M x 1 instances
urls: mongodb-example-app.10.244.0.34.xip.io

     state     since                    cpu    memory          disk
#0   running   2017-10-31 01:42:43 PM   0.0%   75.5M of 256M   0 of 1G

If you now curl the application, you'll see that the application has detected that it's not bound to a mongodb instance.

$ curl http://mongodb-example-app.example.com/

  You must bind a MongoDB service instance to this application.

  You can run the following commands to create an instance and bind to it:

$ cf create-service mongodb default mongodb-instance
$ cf bind-service mongodb-example-app mongodb-instance

Bind the Instance

Now, simply bind the mongodb instance to our application.

$ cf bind-service mongodb-example-app mongodb-instance
Binding service mongodb-instance to app mongodb-example-app in org testing / space testing as me...
OK
TIP: Use 'cf push' to ensure your env variable changes take effect
$ cf push

Usage

You can now create and drop collections by POSTing and DELETEing to myCollection.

$ export APP=http://mongodb-example-app.example.com
$ curl -X POST $APP/myCollection
$ curl -X DELETE $APP/myCollection
bar

Of course, be sure to replace example.com with the actual domain of your Cloud Foundry installation.

Cloud native buildpack

To run using docker: docker run -e PORT=8081 -p 8080:8081 mongodb-cnb-app

Warning

No VCAP_SERVICES as environment variable is provided in built image, you need to add one to run this sample app properly

$ export APP=http://localhost:8080
$ curl -X POST $APP/myCollection
$ curl -X DELETE $APP/myCollection
bar # or <h1>Internal Server Error</h1> when no service is provided