Node.js Bookshelf App

The Bookshelf app is a sample web app written in Node.js that shows how to use a variety of Google Cloud Platform products, including:

  • Google App Engine standard environment
  • Google Cloud SQL
  • Google Cloud Datastore
  • Google Cloud Storage
  • Google Cloud Pub/Sub

This tutorial explores the Bookshelf app in detail, and discusses how each feature of the app is implemented using familiar technologies and services provided by Cloud Platform.

Screen shot of the Bookshelf app showing controls and book covers

The Bookshelf sample app stores a collection of book titles. Anyone who has access to the app can add books to the list. The sample app offers these features:

  • Users can view the list of books, add books to the list, and remove books from the list.
  • Users can edit book details.
  • Users can upload cover images for books.


  • Clone or download the sample app.
  • Build the app and run it on your local machine.
  • Deploy the app to App Engine.
  • Walk through the sample code.
  • Learn how the app stores structured data.
  • Learn how the app stores binary data in Google Cloud Storage.


This tutorial uses billable components of Cloud Platform.

This tutorial has several steps, and each step is documented on its own page. The final page of the tutorial includes instructions for cleaning up resources, so you won't continue to be billed for Cloud Platform services. If you decide not to complete all the steps of the tutorial, see the cleanup instructions on the final page.

Before you begin

  1. Use the GCP Console to set up your Google Cloud Platform project:
    1. Create a new GCP project, and then create an App Engine application and enable billing in that project:
      Go to App Engine

      When prompted, select the region where you want your App Engine application located and then enable billing. After your GCP project is created, the Dashboard opens.

    2. Enable the Cloud Datastore, Cloud Pub/Sub, Cloud Storage JSON, Stackdriver Logging, and Google+ APIs.

      Enable the APIs

  2. Download, install, and initialize the Google Cloud SDK:
    Download the SDK
  3. Acquire local credentials for authenticating with Google Cloud Platform services:
    gcloud auth application-default login
  4. Verify that your default project is correct:
    gcloud config list
    If the project ID listed in the output is not the project that you intended to use for this tutorial, set the project by entering this command:
    gcloud config set project [YOUR_PROJECT_ID]
    where [YOUR_PROJECT_ID] is the ID of the project you created or chose to use for this tutorial.
  5. Clone the sample repository:

    git clone

    Alternatively, you can download the sample as a zip file and extract it.

This tutorial assumes that you are familiar with Node.js programming and that you have already Prepared Your Environment for Node.js Development.

Tutorial structure

The Bookshelf tutorial has several parts that demonstrate how the sample app uses various Cloud Platform services.

Was this page helpful? Let us know how we did:

Send feedback about...