- Google Cloud Platform Cookbook
- Legorie Rajan PS
- 359字
- 2021-08-27 19:13:25
Containerizing the KeystoneJS application
Follow these steps:
- Clone the repository in your development space:
$ git clone https://github.com/legorie/gcpcookbook.git
- Navigate to the directory where the mysite application is stored:
$ cd gcpcookbook/Chapter01/mysite-gke
- With your favorite editor, create a filename .env in the mysite folder:
PORT=8080 COOKIE_SECRET=<a very long string> MONGO_URI=mongodb://mongo/mysite
A custom port of 8080 is used for the KeystoneJS application. This port will be mapped to port 80 later in the Kubernetes service configuration. Similarly, mongo will be the name of the load-balanced MongoDB service that will be created later.
- The Dockerfile in the folder is used to create the application's Docker image. First, it pulls a Node.js image from the registry, then it copies the application code into the container, installs the dependencies, and starts the application. Navigate to /Chapter01/mysite-gke/Dockerfile:
# https://github.com/GoogleCloudPlatform/nodejs-getting-started/blob/master/optional-container-engine/Dockerfile # Dockerfile extending the generic Node image with application files for a # single application. FROM gcr.io/google_appengine/nodejs # Check to see if the version included in the base runtime satisfies # '>=0.12.7', if not then do an npm install of the latest available # version that satisfies it. RUN /usr/local/bin/install_node '>=0.12.7' COPY . /app/ # You have to specify "--unsafe-perm" with npm install # when running as root. Failing to do this can cause # install to appear to succeed even if a preinstall # script fails, and may have other adverse consequences # as well. # This command will also cat the npm-debug.log file after the # build, if it exists. RUN npm install --unsafe-perm || \ ((if [ -f npm-debug.log ]; then \ cat npm-debug.log; \ fi) && false) CMD npm start
- The .dockerignore file contains the file paths which will not be included in the Docker container.
- Build the Docker image:
$ docker build -t gcr.io/<Project ID>/mysite .
Troubleshooting:
- Error: Cannot connect to the Docker daemon. Is the Docker daemon running on this host?
- Solution: Add the current user to the Docker group and restart the shell. Create a new Docker group if needed.
- You can list the created Docker image:
$ docker images
- Push the created image to Google Container Registry so that our cluster can access this image:
$ gcloud docker --push gcr.io/<Project ID>/mysite
推薦閱讀
- 輕松學Java Web開發
- Java實用組件集
- Getting Started with Oracle SOA B2B Integration:A Hands-On Tutorial
- ServiceNow Cookbook
- 新手學電腦快速入門
- 電腦上網輕松入門
- Cloud Security Automation
- Unity Multiplayer Games
- 嵌入式Linux系統實用開發
- 重估:人工智能與賦能社會
- 簡明學中文版Photoshop
- AMK伺服控制系統原理及應用
- Generative Adversarial Networks Projects
- Win 7二十一
- EDA技術及其創新實踐(Verilog HDL版)