Docker 实践:学习 Docker 使用 Nodejs、Flask、PostgreSQL 编写文件
在上一篇文章中,我们提到了 Docker 教程。
- https://dev.to/omerberatsezer/docker-tutorial-dockerfile-commands-container-images-volume-network-docker-compose-2p9h
这一次,我们开始运行示例项目:重点关注使用 Nodejs、Flask、PostgreSQL 镜像的 Docker Compose 文件来实现不同的层:
- 前端(nodejs 和expressjs),
- 后端(烧瓶),
- 数据库(postgresql)。
它显示:
- 如何运行多个容器
- 如何使用depends_on顺序运行容器
- 如何在同一网络中运行容器
- 如何在撰写文件中创建卷
- 如何实现端口转发
GitHub 代码仓库: https://github.com/omerbsezer/Fast-Docker/tree/main/hands-on-sample-projects/full-stack-app
项目结构:
project-root/ ├── docker-compose.yaml ├── frontend/ │ ├── package.json │ ├── index.js │ ├── index.html │ ├── Dockerfile ├── backend/ │ ├── app.py │ ├── requirements.txt │ ├── Dockerfile
- 创建前端目录,创建Dockerfile:
FROM node:18 WORKDIR /home/app COPY . . EXPOSE 3000 RUN npm install CMD ["npm", "start"]
- 创建index.html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Frontend</title> </head> <body> <h1>Frontend is working!</h1> </body> </html>
- 创建index.js(express js):
const express = require("express"); const app = express(); const port=3000; app.get("/", (req, res) => { res.sendFile(__dirname + "/index.html"); }) app.listen(port, () => { console.log(`running at port ${port}`); });
- 创建package.json:
{ "name": "nodejsapp", "version": "1.0.0", "description": "nodejsapp description", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1", "start": "node index.js" }, "author": "", "license": "ISC", "dependencies": { "express": "^4.17.3" } }
- 然后,创建后端目录,并创建Dockerfile:
FROM python:3.11 WORKDIR /usr/src/app COPY . . RUN pip install -r requirements.txt EXPOSE 5000 CMD ["python", "app.py"]
- 使用 Flask 创建后端应用程序:
from flask import Flask, jsonify app = Flask(__name__) @app.route('/') def home(): return "Backend is working!" @app.route('/api', methods=['GET']) def api(): return jsonify({"message": "Hello from the backend!"}) if __name__ == '__main__': app.run(host='0.0.0.0', port=5000)
- 创建requirements.txt:
flask
- 最后在后端和前端目录之上创建 docker-compose.yaml:
services: frontend: build: context: ./frontend container_name: frontend ports: - "3000:3000" volumes: - ./frontend:/usr/src/app depends_on: - backend backend: build: context: ./backend container_name: backend ports: - "5000:5000" volumes: - ./backend:/usr/src/app command: sh -c "pip install -r requirements.txt && python app.py" db: image: postgres:15 container_name: db environment: POSTGRES_USER: user POSTGRES_PASSWORD: password POSTGRES_DB: mydatabase volumes: - db_data:/var/lib/postgresql/data ports: - "5432:5432" volumes: db_data:
- 然后,在 docker-compose.yaml 上运行命令:
user@docker:~$ docker compose up -d [+] Running 4/4 ✔ Network node_default Created 0.1s ✔ Container db Started 0.7s ✔ Container backend Started 0.7s ✔ Container frontend Started
- 然后,用curl检查前端、后端:
user@docker:~$ curl http://localhost:3000 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Frontend</title> </head> <body> <h1>Frontend is working!</h1> </body> user@docker:~$ curl http://localhost:5000/api {"message":"Hello from the backend!"} user@docker:~$ curl http://localhost:5000 Backend is working! </html>
- 最后,停止容器:
user@docker:~$ docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 3e51751b546c node-frontend "docker-entrypoint.s…" About a minute ago Up About a minute 0.0.0.0:3000->3000/tcp, :::3000->3000/tcp frontend d8d28325ce10 postgres:15 "docker-entrypoint.s…" About a minute ago Up About a minute 0.0.0.0:5432->5432/tcp, :::5432->5432/tcp db 04c1d04a5668 node-backend "sh -c 'pip install …" About a minute ago Up About a minute 0.0.0.0:5000->5000/tcp, :::5000->5000/tcp backend user@docker:~$ docker compose down [+] Running 4/4 ✔ Container frontend Removed 1.0s ✔ Container db Removed 0.5s ✔ Container backend Removed 10.5s ✔ Network node_default Removed 0.2s user@docker:~$ docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
结论
这篇文章展示了如何使用示例前端 (express.js)、后端 (flask)、数据库 (postgresql) 应用程序创建 Docker compose 文件。如果您以前没有看过,请查看下面的菜单,了解其他 Docker 内容。
关注 AWS、Kubernetes、Docker、Linux、DevOps、Ansible、机器学习、生成式 AI、SAAS 的提示、教程和实践实验室。
- https://github.com/omerbsezer/
- https://www.linkedin.com/in/omerberatsezer/
以上是Docker 实践:学习 Docker 使用 Nodejs、Flask、PostgreSQL 编写文件的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

探索前端中类似VSCode的面板拖拽调整功能的实现在前端开发中,如何实现类似于VSCode...
