百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Dockerfile的基本写法、image构建、container运行

wptr33 2024-11-13 15:04 26 浏览

我们都知道Dockerfile是用来描述镜像文件的,其中包含一系列命令和指令,通过Docker构建后得到了镜像Image,运行镜像Image后就是我们熟悉的容器Container,那么Dockfile怎么编写呢?下面是一个基本的Dockerfile示例:

# 基础镜像
FROM ubuntu:latest
# 作者信息
LABEL maintainer="your name <youremail@example.com>"
# 安装依赖
RUN apt-get update && apt-get install -y curl git python
# 复制文件
COPY . /app
# 工作目录
WORKDIR /app
# 运行命令
CMD [ "python", "./app.py" ]

更详细写法请前往:https://docs.docker.com/engine/reference/builder/

该Dockerfile将使用最新版本的Ubuntu作为基础镜像,并安装一些依赖包。然后,它将复制当前目录中的文件到容器的/app目录下,并将工作目录设置为/app。最后,它将在容器启动时运行python ./app.py命令。

Docker的官方仓库DockerHub提供了很多制作好的镜像,一般来说基础镜像是Docker镜像构建的起点,即构建一个新的Docker镜像时,通常需要先选择一个已有的基础镜像作为起点,因为它包含了一组已安装好的操作系统、软件和应用程序等组件,可以理解为是一个“打包好”的操作系统和应用环境。通过在基础镜像上添加应用程序和配置,最终可以得到一个新的完整应用镜像。

Docker也可以将一个空镜像作为构建的起点,一般使用空镜像可以打包出最小的Docker镜像,如:

# 空镜像
FROM scratch

注意:基础镜像的选择应该根据实际需求和使用场景来决定。

在编写好Dockerfile后,使用命令行进入到该目录中,使用以下命令构建镜像:

# -t 参数指定要创建的镜像的名称,
# . 表示当前目录是构建上下文。
docker build -t <镜像名称> .

Docker会按照Dockerfile中定义的步骤信息进行构建镜像,一般来说构建过程需要一些时间,具体取决于镜像大小、依赖安装包等。

构建完成后,我们就可以查看所有的镜像列表:

# 查看所有的镜像列表
docker images
REPOSITORY        TAG       IMAGE ID       CREATED        SIZE
demo/demo   latest    a7d37dd51548   37 hours ago   461MB

此时我们已经通过Dockerfile构建出了镜像,要想运行镜像还需要执行:

# 运行镜像
docker run <镜像名称>

如果该镜像启动成功,将会在终端中输出运行的应用程序的信息,此时容器就启动了,如果想查看运行的容器的列表,可以执行以下命令:

# 查看所有运行的容器列表
docker ps
CONTAINER ID   IMAGE             COMMAND                  CREATED          STATUS          PORTS                 NAMES
f516b5ee2533   demo/demo   "/usr/bin/tini -- /u…"   51 seconds ago   Up 50 seconds   8080/tcp, 50000/tcp   charming_thompson

如果想要进入到容器中,可以执行以下命令:

# exec 表示在一个运行的容器中执行命令
# <CONTAINER ID> 就是从 docker ps 命令中得到的容器id
# /bin/sh 就是要执行的容器命令,表示进入到容器终端
docker exec -it <CONTAINER ID> /bin/sh

相关推荐

Python 中 必须掌握的 20 个核心:str()

str()是Python中用于将对象转换为字符串表示的核心函数,它在字符串处理、输出格式化和对象序列化中扮演着关键角色。本文将全面解析str()函数的用法和特性。1.str()函数的基本用法...

python中的函数报错后继续运行而不是停止整个程序

要让main...

如何在身份证号码中提取出生年月日的函数公式

在不同软件中,从身份证号码提取出生年月日的函数公式不同,以下是常见软件的方法:Excelo假设身份证号码在A列,在B列提取出生年月日,在B2单元格输入公式=TEXT(MID(A2,7,8),"...

sql中的一些CTE和开窗函数相关用法

CTE的优势提高可读性:将复杂查询分解为更简单的部分避免重复子查询:同一CTE可以在查询中多次引用递归查询:处理层次结构数据模块化SQL:将复杂查询拆分成逻辑模块...

【SQL】SQL 语法差异大全(PgSQL/MySQL/Oracle/TiDB/OceanBase)

以下是针对不同数据库系统的SQL语法差异总结,按功能分类展示:一、基础查询1.分页查询...

MySQL索引:从原理到实战的终极指南

MySQL索引原理揭秘MySQL索引是数据库高效查询的核心机制,其原理基于特定的数据结构(主要是B+Tree)和数据库引擎(如InnoDB)的实现策略。索引本质上是一种空间换时间的策略,虽然会占...

如何在本地安装开源人工智能Agent——AutoGen Studio的安装

AutoGen是微软出品的一个用于创建可自主行动,或与人类协同工作的多智能体AI应用程序的框架。下面来介绍如何在本地安装AutoGenStudio,AutoGenStudio是一个低代码界...

小巧WinForm库存系统,竟能实现这些功能?

第一次体验真正“握在手里的”库存控制,是在一个微型工厂的仓库运输带旁。顶着仓库里金属味和三十几平米的闷热,老王蹲在地上,一边用笔在账本上划格,一边嘴里嘟囔:“每次都说要数字化管理,数字在哪儿呢?”透过...

有关SQLite数据库的介绍

SQLite,是一种轻型的数据库,它的设计目标是嵌入式的,而且已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/U...

SQLite 数据库Web管理工具

概述SQLite数据库以其轻量级和易于配置的特点,成为了许多项目中的首选数据库。尽管它的便捷性受到了广泛的认可,但对于数据库的管理和维护,尤其是在没有图形界面工具的情况下,开发者往往需要通过复杂的命...

SqlLite数据库注意要点分析

1.验证sqlite是否安装配置好了。执行sqlite3命令。当执行该命令的时候没有传递任何参数表示默认连接到了一个内存数据库,当退出该程序的时候,数据库自动销毁。退出命令:.quit.ex...

python 连接sqlite

在Python中,你可以使用标准库sqlite3来连接SQLite数据库。在Python中,sqlite3模块是内置的,无需使用pip进行安装。sqlite3模块提供了与SQ...

提升数据库搜索效率:探索SQLite的向量搜索扩展

大家好!今天我们要聊一个特别酷炫的东西——sqlite-vec,一个能让SQLite飞起来的向量搜索扩展。如果你对数据库的搜索速度不满意,那你可得好好看看这篇文章了。...

Qt编程进阶(21):Qt操作SQLite数据库及实例

QtSql模块Qt提供的QtSql模块实现了对数据库的访问,同时提供了一套与平台和具体所用数据库均无关的调用接口。此模块为不同层次的用户提供了不同的丰富的数据库操作类。例如,对于习惯使用SQL语法的用...

5分钟快速掌握在Python使用SQLite数据库,

小巧、稳定、快速!我为什么喜欢用SQLite...