《Docker 简易速速上手小册》第1章 Docker 基础入门(2024 最新版)

在这里插入图片描述

文章目录

  • 1.1 Docker 简介与历史
    • 1.1.1 Docker 基础知识
    • 1.1.2 重点案例:Python Web 应用的 Docker 化
    • 1.1.3 拓展案例 1:使用 Docker 进行 Python 数据分析
    • 1.1.4 拓展案例 2:Docker 中的 Python 机器学习环境
  • 1.2 安装与配置 Docker
    • 1.2.1 重点基础知识
    • 1.2.2 重点案例:使用 Docker 运行 Python 脚本
    • 1.2.3 拓展案例 1:使用 Docker 部署 Flask Web 应用
    • 1.2.4 拓展案例 2:在 Docker 中运行 Python 数据分析环境
  • 1.3 Docker 的基本命令
    • 1.3.1 重点基础知识
    • 1.3.2 重点案例:使用 Docker 运行 Python 脚本
    • 1.3.3 拓展案例 1:Docker 中的 Flask 应用
    • 1.3.4 拓展案例 2:Docker 中的 Jupyter Notebook

1.1 Docker 简介与历史

欢迎来到 Docker 的世界!在这一节中,我们将从 Docker 的基础知识和历史开始,然后通过一些精彩的案例来深入探讨它的实用性和强大功能。让我们一起开启这趟知识之旅吧!

1.1.1 Docker 基础知识

要深入了解 Docker,我们首先需要掌握一些关键概念。Docker 是一个开源的容器化技术,它允许开发者和系统管理员在所谓的容器中打包、分发和运行应用。这些容器是轻量级的、可移植的、自给自足的包,它们包含了运行应用所需的一切:代码、运行时环境、库、环境变量和配置文件。

容器 vs. 虚拟机

容器经常被与虚拟机(VM)相比较。虽然它们都提供资源隔离和分配的功能,但容器更为轻量级。与虚拟机不同的是,容器共享主机系统的内核,不需要运行整个操作系统。这就意味着容器启动得更快,占用的资源更少。

镜像

Docker 镜像是容器的蓝本。它是一个轻量级的、不可变的、可执行的软件包,包含运行应用所需的所有内容——代码、运行时环境、库、环境变量和配置文件。通过 Dockerfile,一个简单的文本文件,可以定义如何构建镜像。

Docker Hub 和仓库

Docker Hub 是 Docker 的公共仓库,用户可以在此上传和下载镜像。除了 Docker Hub,用户还可以在私有仓库存储镜像。仓库可以被视为镜像的集合,它允许用户版本控制和分享。

Dockerfile

Dockerfile 是一个文本文件,包含了一系列的指令和参数,用于定义如何从基础镜像构建新的镜像。通过 Dockerfile,可以自动化创建镜像的过程,确保环境的一致性和可重复性。

Docker Compose

Docker Compose 是一个用于定义和运行多容器 Docker 应用的工具。通过一个 YAML 文件,可以配置应用服务的所有参数。这使得管理容器化应用更加容易,特别是在处理多个相互依赖的容器时。

网络和数据存储

Docker 容器可以通过网络进行通信,并可以使用卷(volume)来持久化和共享数据。Docker 网络功能允许容器之间的相互连接,以及容器与外部世界的通信。通过卷,可以将数据持久化存储在容器外部,确保数据的安全和持续性。

了解这些基本概念后,你就已经准备好进一步探索 Docker 的强大功能和实际应用了。在接下来的章节中,我们将通过实际案例,让你更深入地了解如何使用 Docker 来改善你的开发和运维工作。

1.1.2 重点案例:Python Web 应用的 Docker 化

在这个案例中,我们将创建一个简单的 Python Web 应用,并通过 Docker 容器化技术部署它。这个案例将向你展示如何将现代 Web 开发流程与 Docker 相结合,从而提高开发效率和应用的可移植性。

步骤 1: 创建 Flask 应用

我们的第一步是创建一个基本的 Python Flask 应用。Flask 是一个轻量级的 Web 应用框架,非常适合快速开发和原型设计。以下是我们的简单 Flask 应用代码:

# 文件名:app.py

from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello, Docker!'

if __name__ == '__main__':
    app.run(debug=True, host='0.0.0.0')

在这个应用中,我们定义了一个根路由 /,当访问这个路由时,它返回“Hello, Docker!”。

步骤 2: 编写 Dockerfile

接下来,我们需要创建一个 Dockerfile 来定义如何在 Docker 容器中运行我们的 Flask 应用。Dockerfile 是构建 Docker 镜像的蓝图,包含了必要的指令和步骤。

# Dockerfile

# 使用官方 Python 运行时作为父镜像
FROM python:3.8-slim

# 设置工作目录
WORKDIR /app

# 将当前目录内容复制到位于 /app 的容器中
COPY . /app

# 安装 Flask
RUN pip install flask

# 使得端口 5000 可供此容器外的环境使用
EXPOSE 5000

# 定义环境变量
ENV NAME World

# 运行 app.py 时启动应用
CMD ["python", "./app.py"]

这个 Dockerfile 从一个 Python 3.8 镜像开始,将我们的应用代码复制到镜像中,并安装 Flask。然后,它将容器的 5000 端口暴露出来,并指定了启动应用时运行的命令。

步骤 3: 构建和运行 Docker 容器

最后一步是构建我们的 Docker 镜像,并在容器中运行它。

首先,我们使用以下命令构建镜像:

docker build -t flask-app .

这个命令会读取 Dockerfile,并构建一个名为 flask-app 的镜像。

接下来,运行这个镜像:

docker run -p 5000:5000 flask-app

这个命令会启动一个新的容器实例,将本地的端口 5000 映射到容器的端口 5000,并在该容器中运行我们的 Flask 应用。

现在,打开浏览器并访问 http://localhost:5000,你应该能看到显示“Hello, Docker!”的页面。

通过这个简单的案例,你可以看到 Docker 如何帮助我们轻松地部署 Web 应用,并保证了在不同环境中的一致性和可移植性。这只是 Docker 众多强大功能中的一个简单示例。随着你对 Docker 的进一步学习,你将能够发现并利用更多高级功能来优化你的开发和部署流程。

1.1.3 拓展案例 1:使用 Docker 进行 Python 数据分析

在这个案例中,我们将通过 Docker 创建一个 Python 数据分析环境。这个环境将包括 Jupyter Notebook,这是一个非常受欢迎的工具,允许你在浏览器中编写和执行 Python 代码,并且能够可视化数据和分析结果。让我们一步一步来完成这个案例。

步骤 1: 创建 Dockerfile

首先,我们需要创建一个 Dockerfile 来定义我们的数据分析环境。这个环境将基于 Python 3,并安装 Jupyter Notebook 以及一些常用的数据分析库,如 Pandas 和 NumPy。

# Dockerfile

# 从 Python 官方镜像开始构建
FROM python:3.8-slim

# 安装 Jupyter Notebook
RUN pip install jupyter

# 安装常用的数据分析库
RUN pip install numpy pandas matplotlib seaborn

# 设置工作目录
WORKDIR /data

# 使得端口 8888 可供此容器外的环境使用
EXPOSE 8888

# 当容器启动时,启动 Jupyter Notebook
CMD ["jupyter", "notebook", "--ip='*'", "--port=8888", "--no-browser", "--allow-root"]

这个 Dockerfile 从 Python 3.8 镜像开始,安装了 Jupyter Notebook 和几个常用的数据分析库。它还将容器的 8888 端口暴露出来,以便访问 Jupyter Notebook。

步骤 2: 构建 Docker 镜像

使用以下命令构建我们的 Docker 镜像:

docker build -t python-data-analysis .

这个命令会根据 Dockerfile 构建一个名为 python-data-analysis 的镜像。

步骤 3: 运行 Docker 容器

接下来,运行这个镜像:

docker run -p 8888:8888 python-data-analysis

这个命令启动了一个容器实例,将本地的 8888 端口映射到了容器的 8888 端口,并在该容器中启动了 Jupyter Notebook。

在容器启动后,你将看到一个 URL,其中包含一个 token。将这个 URL 复制到浏览器中,就可以开始使用 Jupyter Notebook 了。

数据分析示例

在 Jupyter Notebook 中,你可以开始编写 Python 代码进行数据分析。例如,你可以使用以下代码来创建一个简单的数据集,并用 Matplotlib 生成一个图表:

# 导入所需库
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

# 创建一个简单的数据集
data = pd.DataFrame({
    'x': range(10),
    'y': np.random.randn(10)
})

# 绘制图表
plt.plot(data['x'], data['y'])
plt.show()

通过这个案例,你可以看到 Docker 如何帮助我们快速搭建一个完整的数据分析环境,无论你在哪里工作,都能保证环境的一致性和可移植性。使用 Docker,你可以专注于数据分析本身,而不是环境配置的问题。

1.1.4 拓展案例 2:Docker 中的 Python 机器学习环境

在这个案例中,我们将展示如何使用 Docker 搭建一个 Python 机器学习环境。这个环境将包括 Python 的机器学习库,如 scikit-learn 和 TensorFlow,使得机器学习项目的开发和部署更加容易和一致。

步骤 1: 创建 Dockerfile

首先,我们需要创建一个 Dockerfile,以定义我们的机器学习环境。这个环境将基于 Python 3,并安装 scikit-learn 和 TensorFlow 这两个流行的机器学习库。

# Dockerfile

# 从 Python 官方镜像开始构建
FROM python:3.8-slim

# 安装 scikit-learn 和 TensorFlow
RUN pip install scikit-learn tensorflow

# 设置工作目录
WORKDIR /ml

# 运行时,保持容器运行
CMD ["tail", "-f", "/dev/null"]

这个 Dockerfile 从 Python 3.8 镜像开始,安装了 scikit-learn 和 TensorFlow。它还设置了工作目录,并使用 tail 命令来保持容器运行。

步骤 2: 构建 Docker 镜像

使用以下命令来构建我们的 Docker 镜像:

docker build -t python-ml .

这个命令会根据 Dockerfile 构建一个名为 python-ml 的镜像。

步骤 3: 运行 Docker 容器

接下来,运行这个镜像:

docker run -it --name ml-container python-ml

这个命令启动了一个名为 ml-container 的容器实例,并进入交互式模式。

机器学习示例

在这个容器中,你可以开始使用 Python 进行机器学习实验。例如,你可以使用以下代码来训练一个简单的线性模型:

# 导入所需库
from sklearn.linear_model import LinearRegression
from sklearn.model_selection import train_test_split
from sklearn.datasets import load_boston
import pandas as pd

# 加载数据集
boston = load_boston()
X = pd.DataFrame(boston.data, columns=boston.feature_names)
y = pd.DataFrame(boston.target, columns=["MEDV"])

# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)

# 创建并训练模型
model = LinearRegression()
model.fit(X_train, y_train)

# 测试模型
score = model.score(X_test, y_test)
print(f"Model Accuracy: {score}")

通过这个案例,你可以看到 Docker 如何帮助我们快速搭建一个包含必要机器学习库的环境,使得在不同环境中的机器学习开发和部署变得更加容易和一致。使用 Docker,你可以专注于机器学习模型的构建和训练,而无需担心环境配置问题。

通过以上案例,你不仅能够理解 Docker 的基本概念和历史背景,还能深入学习如何在实际工作中应用 Docker 来提升 Python 开发和数据科学项目的效率和一致性。这些案例旨在提供实用性强且贴近实际生产的应用场景,帮助你更好地理解和运用 Docker 技术。

1.2 安装与配置 Docker

在这一节中,我们将详细讲解 Docker 的安装和配置过程,重点关注在不同操作系统上的安装步骤。随后,我们将通过一些实用的 Python 应用案例,展示如何在 Docker 环境中运行和管理 Python 应用。

1.2.1 重点基础知识

在深入探讨如何使用 Docker 运行 Python 应用之前,了解 Docker 的基本安装和配置步骤是非常重要的。以下是一些关键的基础知识点:

  1. 下载 Docker:

    • WindowsMacOS: 对于 Windows 和 MacOS 用户,推荐使用 Docker Desktop。它提供一个直观的用户界面,并包含了 Docker Engine、Docker CLI 客户端、Docker Compose 等工具。您可以从 Docker 的官方网站下载对应的安装程序。
    • Linux: Linux 用户需要通过命令行安装 Docker。不同的 Linux 发行版(如 Ubuntu、Fedora、Debian)有着不同的安装命令。例如,在 Ubuntu 上,你可以使用 sudo apt-get install docker.io 来安装 Docker。
  2. 安装 Docker:

    • 在 Windows 或 MacOS 上,双击下载的安装包并遵循安装向导的指示完成安装。
    • 在 Linux 上,通常需要使用特定的包管理器进行安装,并可能需要配置 Docker 以便非 root 用户也能运行 Docker 命令。
  3. 启动 Docker:

    • 在 Windows 或 MacOS 上,安装完成后,Docker 将作为一个应用程序出现。你只需点击它来启动 Docker。
    • 在 Linux 上,你可能需要使用命令 sudo systemctl start docker 来启动 Docker 服务。
  4. 验证 Docker 安装:

    • 无论在哪个平台上,都可以通过在终端或命令行中运行 docker --version 来检查 Docker 是否安装成功。这将显示 Docker 的版本信息。
  5. 运行 Docker 的 Hello World:

    • 为了验证 Docker 是否被正确安装和配置,可以运行 Docker 的 Hello World 示例。在命令行中输入 docker run hello-world。这将从 Docker Hub 下载一个测试镜像,并在一个容器中运行它。如果一切顺利,你将在终端中看到一条欢迎消息。
  6. Docker 用户组:

    • 在 Linux 上,建议将用户添加到 Docker 用户组中。这允许非 root 用户执行 Docker 命令。可以通过 sudo usermod -aG docker $USER 命令来实现。
  7. 配置 Docker:

    • Docker 提供了多种配置选项,包括网络设置、存储选项等。这些配置可以通过修改 /etc/docker/daemon.json 文件(在 Linux 上)或通过 Docker Desktop 应用程序(在 Windows 和 MacOS 上)进行。

通过掌握这些基础知识,您将为使用 Docker 创建和运行容器应用打下坚实的基础。接下来的案例将指导您如何在这个设置中运行 Python 应用,无论是简单的脚本还是复杂的 Web 应用。

1.2.2 重点案例:使用 Docker 运行 Python 脚本

在这个案例中,我们将演示如何使用 Docker 来运行一个简单的 Python 脚本。这将帮助你理解如何在 Docker 容器中运行 Python 程序,从而为更复杂的项目打下基础。

步骤 1: 创建 Python 脚本

首先,我们需要创建一个 Python 脚本。让我们编写一个简单的脚本,它会输出一条欢迎信息。在你的工作目录中,创建一个名为 hello.py 的文件,并添加以下内容:

# hello.py
print("Hello from Docker!")

这个脚本非常简单,只是打印出一条消息。

步骤 2: 编写 Dockerfile

接下来,我们需要创建一个 Dockerfile 来定义如何在 Docker 容器中运行这个脚本。Dockerfile 是一个文本文件,包含了一系列的指令,用于告诉 Docker 如何构建镜像。

在你的工作目录中,创建一个名为 Dockerfile 的文件(无文件扩展名),并添加以下内容:

# 使用官方 Python 运行时作为父镜像
FROM python:3.8

# 将工作目录设置为 /app
WORKDIR /app

# 将当前目录中的文件复制到容器的 /app 目录
COPY . /app

# 运行 hello.py 脚本时,调用 Python 解释器
CMD ["python", "./hello.py"]

这个 Dockerfile 从一个 Python 3.8 镜像开始,将工作目录设置为 /app,将当前目录下的文件复制到这个位置,然后定义了运行容器时要执行的命令。

步骤 3: 构建 Docker 镜像

现在,我们可以使用以下命令来构建我们的 Docker 镜像:

docker build -t hello-python .

这条命令告诉 Docker 构建一个新的镜像,并将这个镜像标记(tag)为 hello-python. 指的是当前目录,Docker 会在这里查找 Dockerfile。

步骤 4: 运行 Docker 容器

一旦镜像构建完成,我们就可以运行一个基于该镜像的容器了:

docker run hello-python

当这个命令执行时,它会启动一个新的容器实例,容器会运行 hello.py 脚本,并显示输出。你应该会在命令行中看到 “Hello from Docker!” 的消息。

通过这个简单的案例,你已经学会了如何将 Python 脚本容器化,并在 Docker 中运行它。这是理解 Docker 容器如何工作的基础,并且是向更复杂的应用迈进的第一步。

1.2.3 拓展案例 1:使用 Docker 部署 Flask Web 应用

在这个案例中,我们将演示如何使用 Docker 来部署一个简单的 Flask Web 应用。Flask 是一个轻量级的 Python Web 框架,非常适合快速开发。通过 Docker 化 Flask 应用,你可以确保你的 Web 应用在任何环境中都能以相同的方式运行。

步骤 1: 创建 Flask 应用

首先,我们创建一个基本的 Flask 应用。在你的工作目录中,创建两个文件:app.pyrequirements.txt

  • app.py - Flask 应用的主要文件:

    # app.py
    from flask import Flask
    
    app = Flask(__name__)
    
    @app.route('/')
    def hello():
        return 'Hello, Docker!'
    
    if __name__ == '__main__':
        app.run(debug=True, host='0.0.0.0')
    
  • requirements.txt - 列出所需的 Python 包:

    flask
    

步骤 2: 编写 Dockerfile

接下来,我们需要创建一个 Dockerfile 来定义如何在 Docker 容器中运行我们的 Flask 应用。

在你的工作目录中,创建一个名为 Dockerfile 的文件,并添加以下内容:

# 使用官方 Python 镜像
FROM python:3.8

# 将工作目录设置为 /app
WORKDIR /app

# 将当前目录中的文件复制到容器的 /app 目录
COPY . /app

# 安装 requirements.txt 中的所有依赖
RUN pip install --no-cache-dir -r requirements.txt

# 让世界可以访问你的应用
EXPOSE 5000

# 定义环境变量
ENV FLASK_APP=app.py

# 运行 Flask 应用
CMD ["flask", "run", "--host=0.0.0.0"]

这个 Dockerfile 从 Python 3.8 镜像开始,设置工作目录,复制文件,并安装依赖。它还将容器的 5000 端口暴露出来,并定义了运行 Flask 应用的命令。

步骤 3: 构建 Docker 镜像

使用以下命令来构建我们的 Flask 应用的 Docker 镜像:

docker build -t flask-app .

这条命令会创建一个名为 flask-app 的镜像。

步骤 4: 运行 Docker 容器

构建完镜像后,使用以下命令运行容器:

docker run -p 5000:5000 flask-app

这个命令启动了一个容器实例,将你的机器的 5000 端口映射到容器的 5000 端口。

现在,你的 Flask 应用应该在 Docker 容器中运行了。在浏览器中访问 http://localhost:5000,你应该能看到 “Hello, Docker!” 的消息。

通过这个案例,你已经成功地使用 Docker 部署了一个 Flask Web 应用。这个案例演示了 Docker 如何帮助你保证应用在不同环境中的一致性,同时也展示了 Docker 在现代 Web 开发中的应用。

1.2.4 拓展案例 2:在 Docker 中运行 Python 数据分析环境

在这个案例中,我们将通过 Docker 创建一个 Python 数据分析环境。这个环境将包括 Jupyter Notebook 和常用的数据分析库,如 Pandas、NumPy 和 Matplotlib。这种方法非常适合数据科学家和分析师,因为它提供了一个一致且易于共享的工作环境。

步骤 1: 创建 Dockerfile

首先,我们需要创建一个 Dockerfile 来定义我们的数据分析环境。在你的工作目录中,创建一个名为 Dockerfile 的文件,并添加以下内容:

# 从官方 Python 镜像开始构建
FROM python:3.8-slim

# 安装 Jupyter 和常见的数据分析库
RUN pip install jupyter pandas numpy matplotlib seaborn

# 设置工作目录,用于在容器内部运行 Jupyter Notebook
WORKDIR /data

# 暴露 Jupyter Notebook 运行的端口
EXPOSE 8888

# 启动 Jupyter Notebook
CMD ["jupyter", "notebook", "--ip=0.0.0.0", "--port=8888", "--no-browser", "--allow-root"]

这个 Dockerfile 从 Python 3.8 镜像开始,安装了 Jupyter Notebook 和几个常用的数据分析库。它还设置了工作目录并暴露了运行 Jupyter Notebook 所需的端口。

步骤 2: 构建 Docker 镜像

接下来,我们可以使用以下命令来构建我们的 Docker 镜像:

docker build -t python-data-analysis .

这个命令会根据 Dockerfile 构建一个名为 python-data-analysis 的镜像。

步骤 3: 运行 Docker 容器

现在,我们可以运行这个镜像了:

docker run -p 8888:8888 python-data-analysis

这个命令会启动一个 Docker 容器,并将本地机器的 8888 端口映射到容器的 8888 端口。当容器启动后,它将运行 Jupyter Notebook。

在容器运行后,你会在命令行中看到一个 URL,其中包含了访问 Jupyter Notebook 的 token。复制并粘贴这个 URL 到浏览器中,你就可以开始在 Jupyter Notebook 中进行数据分析了。

数据分析示例

在 Jupyter Notebook 中,你可以执行各种数据分析任务。例如,你可以使用 Pandas 来加载和分析数据,使用 Matplotlib 和 Seaborn 来进行数据可视化。以下是一个简单的示例:

# 导入所需的库
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import seaborn as sns

# 创建一个简单的数据集
data = pd.DataFrame({
    'x': range(1, 11),
    'y': np.random.rand(10),
})

# 使用 Seaborn 画一个散点图
sns.scatterplot(x='x', y='y', data=data)
plt.show()

通过这个案例,你可以看到如何快速地在 Docker 中搭建一个完整的数据分析环境,这个环境可以在不同机器上轻松复制和共享。这为数据分析和科学研究提供了极大的便利,特别是在协作和远程工作的场景中。

通过这些案例,你将能够掌握在 Docker 中安装、配置和运行 Python 应用的基本技巧,这些技巧在实际的生产和工作环境中非常有用。这些案例不仅提供了一个实用的起点,也帮助你理解 Docker 在不同应用场景中的灵活性和强大功能。

1.3 Docker 的基本命令

掌握 Docker 的基本命令对于有效使用 Docker 来说至关重要。这一节将详细介绍 Docker 的一些核心命令,并通过实用的 Python 案例来展示这些命令的使用。

1.3.1 重点基础知识

为了有效地使用 Docker,了解其核心命令是至关重要的。这些命令涉及到容器的创建、运行、管理和镜像的处理。以下是 Docker 常用命令的详细讲解:

  1. docker run: 这是启动新容器的基本命令。例如,docker run -d -p 5000:5000 flask-app 会在后台运行一个 Flask 应用,并将容器的端口 5000 映射到主机的端口 5000。

  2. docker build: 此命令用于从 Dockerfile 创建一个新的镜像。例如,docker build -t my-image-name . 会根据当前目录的 Dockerfile 构建一个名为 my-image-name 的镜像。

  3. docker images: 用来列出本地所有的 Docker 镜像。这有助于查看已有的镜像及其标签和大小。

  4. docker ps: 列出当前运行的容器。使用 docker ps -a 可以查看所有容器,包括未运行的。

  5. docker stop: 用于停止一个或多个正在运行的容器。例如,docker stop container_id 会停止指定的容器。

  6. docker rm: 删除一个或多个容器。需要注意的是,只有停止的容器才能被删除。例如,docker rm container_id 会删除指定的容器。

  7. docker rmi: 删除一个或多个镜像。这是管理本地镜像空间的重要命令。例如,docker rmi image_id 会删除指定的镜像。

  8. docker logs: 查看容器的日志输出。这对于调试和了解容器的行为非常有用。例如,docker logs container_id 会显示指定容器的日志。

  9. docker exec: 在运行中的容器内执行命令。这常用于调试或修改容器内的设置。例如,docker exec -it container_id bash 会在指定的容器内启动一个交互式 bash shell。

  10. docker pull: 从 Docker Hub 或其他 Docker 仓库拉取(下载)镜像。例如,docker pull ubuntu 会从 Docker Hub 下载最新的 Ubuntu 镜像。

  11. docker push: 将本地镜像推送到 Docker Hub 或其他 Docker 仓库。在执行此命令之前,需要先登录到 Docker Hub。例如,docker push my-username/my-image

通过理解和实践这些基本命令,你将能够有效地管理 Docker 容器和镜像,为构建和部署应用提供坚实的基础。

1.3.2 重点案例:使用 Docker 运行 Python 脚本

在这个案例中,我们将展示如何使用 Docker 来运行一个简单的 Python 脚本。这个脚本会打印出当前的日期和时间,演示了如何在 Docker 容器中执行 Python 代码。

步骤 1: 创建 Python 脚本

首先,我们需要编写一个 Python 脚本。在你的工作目录中,创建一个名为 date_time_script.py 的文件,并添加以下内容:

# date_time_script.py
from datetime import datetime

print(f"Current date and time: {datetime.now()}")

这个脚本简单地输出当前的日期和时间。

步骤 2: 编写 Dockerfile

接下来,我们需要创建一个 Dockerfile 来定义如何在 Docker 容器中运行这个脚本。在你的工作目录中,创建一个名为 Dockerfile 的文件,并添加以下内容:

# 使用官方 Python 运行时作为父镜像
FROM python:3.8

# 将工作目录设置为 /app
WORKDIR /app

# 将当前目录中的文件复制到容器的 /app 目录
COPY date_time_script.py /app/

# 运行 date_time_script.py 脚本时,调用 Python 解释器
CMD ["python", "./date_time_script.py"]

这个 Dockerfile 使用 Python 3.8 官方镜像作为基础,设置工作目录,并将我们的脚本复制到容器中。最后,它指定了容器启动时执行的命令。

步骤 3: 构建 Docker 镜像

现在,我们可以使用以下命令来构建我们的 Docker 镜像:

docker build -t datetime-python .

这个命令会根据 Dockerfile 构建一个名为 datetime-python 的镜像。

步骤 4: 运行 Docker 容器

一旦镜像构建完成,我们就可以运行一个基于该镜像的容器了:

docker run datetime-python

当这个命令执行时,它会启动一个新的容器实例,容器会运行 date_time_script.py 脚本,并显示输出。你应该会在命令行中看到类似 “Current date and time: 2023-02-24 15:30:00.123456” 的消息。

通过这个案例,你学会了如何使用 Docker 构建一个 Python 应用的运行环境,并且理解了 Docker 容器如何运行 Python 脚本。这为使用 Docker 处理更复杂的 Python 应用提供了基础。

1.3.3 拓展案例 1:Docker 中的 Flask 应用

在这个案例中,我们将通过 Docker 容器来部署一个简单的 Flask Web 应用。这个案例展示了如何使用 Docker 来封装和运行一个基于 Python 的 Web 应用,确保应用在不同环境下的一致性。

步骤 1: 创建 Flask 应用

首先,我们需要创建 Flask 应用的基础代码。在你的工作目录中,创建一个名为 app.py 的文件,并添加以下内容:

# app.py
from flask import Flask

app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello, Dockerized Flask!'

if __name__ == '__main__':
    app.run(debug=True, host='0.0.0.0')

此代码创建了一个简单的 Flask 应用,它在根 URL (/) 上返回一条消息。

步骤 2: 添加依赖文件

接下来,创建一个名为 requirements.txt 的文件,列出 Flask 应用的依赖:

flask

步骤 3: 编写 Dockerfile

现在,我们编写一个 Dockerfile 来定义 Flask 应用的容器化。在你的工作目录中,创建一个名为 Dockerfile 的文件,并添加以下内容:

# 使用官方 Python 运行时作为父镜像
FROM python:3.8

# 将工作目录设置为 /app
WORKDIR /app

# 将当前目录中的文件复制到容器的 /app 目录
COPY . /app

# 安装 requirements.txt 中的所有依赖
RUN pip install --no-cache-dir -r requirements.txt

# 使得端口 5000 可供此容器外的环境使用
EXPOSE 5000

# 定义环境变量
ENV FLASK_APP=app.py

# 运行 Flask 应用
CMD ["flask", "run", "--host=0.0.0.0"]

步骤 4: 构建 Docker 镜像

使用以下命令来构建 Docker 镜像:

docker build -t flask-app .

这个命令会根据 Dockerfile 构建一个名为 flask-app 的镜像。

步骤 5: 运行 Docker 容器

构建完镜像后,使用以下命令运行容器:

docker run -p 5000:5000 flask-app

这个命令会启动一个基于 flask-app 镜像的容器,并将容器的 5000 端口映射到主机的 5000 端口。

现在,Flask 应用已在 Docker 容器中运行。在浏览器中访问 http://localhost:5000,你应该能看到 “Hello, Dockerized Flask!” 的消息。

通过这个案例,你可以看到 Docker 如何帮助我们轻松地部署一个 Flask Web 应用,并保证应用在不同环境中的一致性。这种方法不仅适用于开发和测试环境,也适用于生产环境,使得部署变得更加简单和可靠。

1.3.4 拓展案例 2:Docker 中的 Jupyter Notebook

在这个案例中,我们将演示如何使用 Docker 容器来部署 Jupyter Notebook,这是一个广泛使用的工具,用于数据分析和科学计算。Docker 化 Jupyter Notebook 可以确保在任何环境中都能以相同的方式运行,方便共享和协作。

步骤 1: 编写 Dockerfile

我们从创建 Dockerfile 开始,该文件定义了 Jupyter Notebook 运行所需的环境。在你的工作目录中,创建一个名为 Dockerfile 的文件,并添加以下内容:

# 从官方 Python 镜像开始构建
FROM python:3.8-slim

# 安装 Jupyter Notebook
RUN pip install notebook

# 设置工作目录
WORKDIR /workspace

# 暴露 Jupyter Notebook 运行的端口
EXPOSE 8888

# 启动 Jupyter Notebook
CMD ["jupyter", "notebook", "--ip=0.0.0.0", "--port=8888", "--no-browser", "--allow-root"]

这个 Dockerfile 使用 Python 3.8 官方镜像作为基础,安装 Jupyter Notebook,并设置工作目录。它还暴露了运行 Jupyter Notebook 所需的端口,并定义了容器启动时执行的命令。

步骤 2: 构建 Docker 镜像

接下来,使用以下命令来构建 Docker 镜像:

docker build -t jupyter-notebook .

这个命令会根据 Dockerfile 构建一个名为 jupyter-notebook 的镜像。

步骤 3: 运行 Docker 容器

现在,我们可以运行这个镜像了:

docker run -p 8888:8888 jupyter-notebook

这个命令启动了一个 Docker 容器,将本地机器的 8888 端口映射到容器的 8888 端口。当容器启动后,它将运行 Jupyter Notebook。

在容器运行后,你会在命令行中看到一个 URL,其中包含了访问 Jupyter Notebook 的 token。复制并粘贴这个 URL 到浏览器中,你就可以开始在 Jupyter Notebook 中工作了。

使用 Jupyter Notebook

在 Jupyter Notebook 中,你可以创建新的笔记本来写 Python 代码,进行数据分析和可视化。例如,你可以导入数据分析和科学计算的库,如 Pandas、NumPy 和 Matplotlib,来分析数据集并绘制图表。

通过这个案例,你可以看到 Docker 如何帮助我们快速搭建一个数据分析环境。这个环境可以在不同机器上轻松复制和共享,非常适合团队合作和远程工作。使用 Docker 化的 Jupyter Notebook,数据科学家和分析师可以保证在任何地方都能以一致的方式工作,无需担心环境配置的不一致性。

这些案例展示了 Docker 在不同 Python 应用场景中的实用性,从简单脚本的执行到复杂的 Web 应用和数据分析环境的部署,反映了 Docker 在现代软件开发和数据科学中的广泛应用。通过这些案例,你可以更好地理解和掌握 Docker 的基本命令及其在实际生产环境中的应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/407175.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《隐私计算简易速速上手小册》第9章:实现隐私计算的步骤(2024 最新版)

文章目录 9.1 规划与设计:描绘你的隐私保护蓝图9.1.1 基础知识9.1.2 主要案例:设计一个隐私保护的数据分享平台9.1.3 拓展案例 1:创建一个隐私保护的健康数据分析系统9.1.4 拓展案例 2:开发一个加密的即时通讯应用9.2 实施与部署:从蓝图到现实9.2.1 基础知识9.2.2 主要案例…

BentoML:如何使用 JuiceFS 加速大模型加载?

BentoML 是一个开源的大语言模型(LLM) AI 应用的开发框架和部署工具,致力于为开发者提供最简单的构建大语言模型 AI 应用的能力,其开源产品已经支持全球数千家企业和组织的核心 AI 应用。 当 BentoML 在 Serverless 环境中部署模型…

牛客网 HJ10 字符个数统计

思路: 我们创建两个数组,一个数组接受输入的字符,另一个数组用来统计字符种数 同时将该字符作为下标传给另一个数组,如果另一个数组的这个下标对应的值为0,说明该字符没有被统计过,计数器加1,…

在当前源文件的目录或生成系统路径中未找到文件

vsqt中增加,减少文件,都必须要动一下cmakelist.txt,点一下换行或者保存 因为vsqt反应不过来 1。都必须要动一下cmakelist.txt,点一下换行或者保存 2.然后全部重新生成,或者重新扫描解决方案(多扫几次)

现货黄金中短线投资该怎么做?

要明确什么是现货黄金的中短线投资,中短线投资是指在短期内(一般为几天至几周)对现货黄金进行买卖操作,以期获得收益的投资方式。相较于长线投资,中短线投资的风险相对较大,但同时收益也更为可观。那么&…

只需三步即可更改centos7系统语言,centos7系统语言更换,centos7系统中文互换

只需三步即可更改centos7系统语言,centos7系统语言更换,centos7系统中文互换 操作系统:centOS7.8 64位 ssh登录工具:FinalShell FinalShell可以点此下载 先查看系统的默认语言 locale #zh_CN 中文如何验证是中文,可以使用umtui来验证 umtui是一款…

【MATLAB源码-第146期】基于matlab的信源编码仿真GUI,对比霍夫曼编码,算术编码和LZ编码。

操作环境: MATLAB 2022a 1、算法描述 霍夫曼编码、算术编码和LZ编码是三种广泛应用于数据压缩领域的编码技术。它们各自拥有独特的设计哲学、实现方式和适用场景,因此在压缩效率、编解码速度和内存使用等方面表现出不同的特点。接下来详细描述这三种编…

Spring基础之AOP和代理模式

文章目录 理解AOPAOP的实现原理 AOP代理模式静态代理动态代理1-JDK动态代理2-CGLIB动态代理 总结 理解AOP OOP - - Object Oriented Programming 面向对象编程 AOP - - Aspect Oriented Programming 面向切面编程 AOP是Spring提供的关键特性之一。AOP即面向切面编程&#xff0…

Java+SpringBoot,打造极致申报体验

✍✍计算机编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java实战 |…

Vivado MIG ip核使用教程

Step 1 在ip catalog中搜索mig ip核并打开,检查硬件配置 Step 2 Step 3 选择对其他芯片类型的兼容性,若无此方面需求,可直接点击next Step 4 选择存储器类型 Step 5 配置DDR3芯片工作频率、用户时钟、mig ip核输入时钟、DDR3芯片类型…

中兴通讯携吉林移动迈向5G-A新阶段,完成3CC技术应用

日前,中兴通讯携手中国移动吉林移动分公司,在5G-A领域取得新突破。具体来说,双方基于MTK芯片M80终端,完成了5G-A三载波聚合试点,实测下行速率达到理论峰值4.25Gbps,相比2.6G单载波速率提升2.5倍。如此成绩&…

目标检测新SOTA:YOLOv9 问世,新架构让传统卷积重焕生机

在目标检测领域,YOLOv9 实现了一代更比一代强,利用新架构和方法让传统卷积在参数利用率方面胜过了深度卷积。 继 2023 年 1 月 YOLOv8 正式发布一年多以后,YOLOv9 终于来了! 我们知道,YOLO 是一种基于图像全局信息进行…

如何查看电脑使用记录?保障个人隐私和安全

查看电脑使用记录是了解电脑活动的一种重要方式,可以帮助用户追踪应用程序的使用情况、登录和关机时间、文件的访问记录等。在本文中,我们将介绍如何查看电脑使用记录的三个方法,以分步骤详细说明如何查看电脑使用记录,帮助用户更…

Java知识点一

hello,大家好!我们今天开启Java语言的学习之路,与C语言的学习内容有些许异同,今天我们来简单了解一下Java的基础知识。 一、数据类型 分两种:基本数据类型 引用数据类型 (1)整型 八种基本数…

【Spring MVC篇】简单案例分析

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【Spring MVC】 本专栏旨在分享学习Spring MVC的一点学习心得,欢迎大家在评论区交流讨论💌 目录 一、加法计算器二…

【苍穹外卖】一些开发总结

1、DTO、VO的区别 DTO:如果前端返回的实体类和对应的实体类比较较大差别 使用DTO来封装数据 后面在使用 BeanUtils.copyProperties() 将熟悉复制到对应的实体类中 VO:主要用于展示数据,例如在控制器层和视图层之间。它通常包含一些与显示相关的属性,如标题、描述等。 2…

Fastjson【RCE1.2.47】漏洞复现

★★免责声明★★ 文章中涉及的程序(方法)可能带有攻击性,仅供安全研究与学习之用,读者将信息做其他用途,由Ta承担全部法律及连带责任,文章作者不承担任何法律及连带责任。 1、Fastjson介绍 fastjson是阿里巴巴的开源JSON解析库&…

STM32_IIC_AT24C02_1_芯片简介即管脚配置

STM32的IIC总线是存在bug,感兴趣的可以上网搜一搜。我们可以使用两个I/O口和软件的方式来模拟stm32的iic总线的控制,所以就不需要使用stm32的硬件控制器了,同理数据手册中的I2C库函数也没有用了。 ROM(只读存储器)和…

普中51单片机学习(EEPROM)

EEPROM IIC串行总线的组成及工作原理 I2C总线的数据传送 数据位的有效性规定 I2C总线进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,只有在时钟线上的信号为低电平期间,数据线上的高电平或低电平状态才允许…

微服务-微服务Spring Security6实战

1. Spring Security介绍 1.1 Spring Security定义 Spring Security 是一个能够为基于 Spring 的企业应用系统提供声明式的安全访问控制解决方案的安全框 架。 Spring Security 主要实现了 Authentication (认证,解决 who are you? ) 和…