news 2026/2/5 15:54:40

Docker使用案例-部署Python flask

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Docker使用案例-部署Python flask

环境准备

  • 操作系统-centsos9.0
  • docker 27.3.1

基础知识

  • 三个核心概念:
    • 镜像:一个静态只读的模版,运行起来成为“容器”。比如:ubuntu镜像,ngnix镜像。
    • 容器:镜像的运行实例,每个容器是相互隔离,安全的平台。
    • 仓库:集中存放镜像的地方。
  • 基本操作
    • 镜像操作
      • # 从 Docker Hub 拉取一个镜像 docker pull nginx:latest # 查看本地所有镜像 docker images # 删除一个本地镜像 docker rmi nginx:latest # 构建一个自定义镜像 (需要 Dockerfile) docker build -t my-custom-app:v1.0 .
    • 容器操作
      • # 运行一个容器 # -d: 后台运行 # -p 8080:80: 将宿主机的 8080 端口映射到容器的 80 端口 # --name my-nginx: 给容器起个名字 # nginx:latest: 使用的镜像 docker run -d -p 8080:80 --name my-nginx nginx:latest # 查看正在运行的容器 docker ps # 查看所有容器(包括已停止的) docker ps -a # 停止一个容器 docker stop my-nginx # 启动一个已停止的容器 docker start my-nginx # 重启一个容器 docker restart my-nginx # 删除一个容器 (必须先停止) docker rm my-nginx # 强制删除一个正在运行的容器 (不推荐) docker rm -f my-nginx
    • 管理操作
      • # 查看容器的标准输出日志 docker logs my-nginx # 实时跟踪容器日志 docker logs -f my-nginx # 进入一个正在运行的容器的内部 shell docker exec -it my-nginx /bin/bash # -i: 交互式操作 # -t: 分配一个伪终端
  • Dockerfile:一个包含一系列指令的文本文件,指导docker构建什么镜像
    • 简单示例
      • # 1. 基础镜像:从官方 Node.js 18 的 Alpine 版本开始 FROM node:18-alpine # 2. 设置工作目录 WORKDIR /app # 3. 复制 package.json 和 package-lock.json (如果有的话) # 这一步利用了 Docker 的层缓存,只有当这两个文件变化时才会重新安装依赖 COPY package*.json ./ # 4. 安装项目依赖 RUN npm install # 5. 复制项目所有源代码到工作目录 COPY . . # 6. 暴露应用端口 EXPOSE 3000 # 7. 定义容器启动时执行的命令 CMD [ "node", "server.js" ]
    • 运行启动
      • # -t: 给镜像打标签 (名称:版本) # .: 表示构建上下文是当前目录 docker build -t my-node-app:v1.0 .
  • 数据卷是什么?

    • 数据卷是Docker专门用来持久化和共享数据的一种特殊机制。容器本身是无状态和临时的,数据卷是为了解决删除一个容器时,避免部分文件被一起删除。

操作步骤

创建文件夹

mkdir ~/nginx-html cd /nginx-html/ touch index.html

添加html代码(略)

以数据卷方式运行Nginx

docker run -d -p 8123:80 \ --name mynginx-vol \ -v /root/ngnix-html:/usr/share/nginx/html:ro,Z \ nginx
参数分析
  • -d:后台运行
  • -p 8123:80: 端口映射,将主机的8123端口->容器80端口
  • --name myngnix-vol :设置名称
  • -v /root/ngnix-html:/usr/share/nginx/html:ro,Z:挂载数据卷
    • /root/ngnix-html: 主机路径,存放html文件
    • /usr/share/ngnix/html: 容器内路径-nginx默认网站根目录
    • ro: read-only只读-容器内不能修改改目录内容
    • Z: SELinux标签,自动设置SELinux上下文,运行容器访问

​​​​​​​运行结果​​​​​​​

访问ip:8123端口

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/29 10:54:35

OpenSpec定义AI模型接口标准助力Qwen3-VL-30B集成

OpenSpec定义AI模型接口标准助力Qwen3-VL-30B集成 在当今AI系统日益复杂的背景下,一个尖锐的现实摆在开发者面前:我们拥有越来越强大的模型,却越来越难把它们用起来。 以Qwen3-VL-30B为例——这款300亿参数的视觉语言大模型,能在毫…

作者头像 李华
网站建设 2026/1/29 14:19:04

英伟达B200:AI算力革命的新纪元引擎

英伟达B200:AI算力革命的新纪元引擎在人工智能算力竞赛进入白热化的2024年,英伟达B200 GPU的横空出世,不仅重新定义了数据中心的计算边界,更标志着通用计算架构向智能化跃迁的关键拐点。这款基于Blackwell架构的新一代旗舰产品&am…

作者头像 李华
网站建设 2026/2/5 23:46:15

自动批量混剪视频软件配置流程

这是一款可以自动批量混剪视频的软件,先来看一段通过软件批量增加了动态特效以及边框后的视频效果。 📌 **需要查看完整文档、参数详解与示例配置的朋友,可参考我整理的笔记: ** 👉 xk.xunbk.com 现在各个平台对于视…

作者头像 李华
网站建设 2026/1/29 10:54:46

多系统并行的权限治理难题:如何消除“权限孤岛”与安全风险?

在企业数字化转型浪潮中,数据被视为新的生产资料,其安全与合规性成为企业的生命线。然而,许多企业将安全投入的焦点放在了防火墙、入侵检测、加密技术等“外围防御”上,却往往忽略了内部数据安全的“命门”——权限管理&#xff0…

作者头像 李华