Docker学习路线6:使用第三方镜像

小万哥
• 阅读 306

第三方镜像是在Docker Hub或其他容器注册表上提供的预构建Docker容器镜像。这些镜像由个人或组织创建和维护,可以作为您容器化应用程序的起点。

查找第三方镜像

Docker Hub 是最大和最受欢迎的容器镜像注册表,包含官方和社区维护的镜像。您可以根据名称或要使用的技术搜索镜像。

例如:如果您正在寻找一个 Node.js 镜像,您可以在Docker Hub上搜索“node”,您将找到官方Node.js镜像以及许多其他社区维护的镜像。

在Dockerfile中使用镜像

要在Dockerfile中使用第三方镜像,只需要使用 FROM 指令将镜像名称设置为基本镜像。以下是使用官方Node.js镜像的示例:

FROM node:14# The rest of your Dockerfile...

注意安全问题

请注意,第三方镜像可能存在安全漏洞或配置错误。在将其用于生产之前,始终验证镜像的来源并检查其声誉。最好使用官方镜像或维护良好的社区镜像。

维护您的镜像

使用第三方镜像时,保持其更新以包括最新的安全更新和依赖项更改至关重要。定期检查基本镜像的更新并相应地重建您的应用程序容器。

使用 Docker 创建交互式测试环境

Docker 允许您创建隔离、一次性的环境,测试完成后可以删除。这样可以更轻松地使用第三方软件、测试不同的依赖项或版本,以及快速实验,而不会损坏本地设置。

使用 Docker 创建交互式测试环境

为了演示如何设置交互式测试环境,让我们以 Python 编程语言为例。我们将使用在 Docker Hub 上可用的公共 Python 镜像。

  • 要使用 Python 镜像启动交互式测试环境,只需运行以下命令:
docker run -it --rm python

这里,-it 标志确保您在交互模式下使用 tty 运行容器,而 --rm 标志将在停止容器后删除容器。

  • 现在,您应该在容器内部的交互式 Python shell 中。您可以执行任何 Python 命令或使用 pip 安装其他软件包。
print("Hello, Docker!")
  • 完成交互式会话后,只需键入 exit() 或按 CTRL+D 退出容器即可。容器将按 rm 标志指定的方式自动删除。

更多交互式测试环境的示例

您可以使用 Docker Hub 上提供的多个第三方镜像,并创建各种交互式环境,例如:

  • Node.js:要启动交互式 Node.js shell,可以使用以下命令:
docker run -it --rm node
  • Ruby:要启动交互式 Ruby shell,可以使用以下命令:
docker run -it --rm ruby
  • MySQL:要启动临时 MySQL 实例,可以使用以下命令:
docker run -it --rm --name temp-mysql -e MYSQL_ALLOW_EMPTY_PASSWORD=yes -p 3306:3306 mysql

这将启动一个临时 MySQL 服务器,可以通过主机端口 3306 访问。容器在停止后将被删除。

使用 Docker 来创建交互式测试环境,可以让您更高效、更干净地处理各种第三方软件,而不必担心损坏本地机器或安装不必要的依赖项。

命令行工具

Docker映像可以包含命令行实用程序或独立应用程序,我们可以在容器内运行它们。当使用第三方映像时,这样做非常有用,因为我们要使用的工具已经打包并可供运行,无需任何安装或配置。

BusyBox

BusyBox是一个小巧(1-2 Mb)且简单的命令行应用程序,提供了许多常用的Unix实用程序,例如 awkgrepvi等。要在Docker容器内运行BusyBox,您只需要拉取映像并使用Docker运行它:

docker pull busyboxdocker run -it busybox /bin/sh

进入容器后,您可以像在常规命令行上一样开始运行各种BusyBox实用程序。

cURL

cURL是一个众所周知的命令行工具,可用于使用各种网络协议传输数据。它经常用于测试API或从互联网下载文件。要在Docker容器内使用cURL,您可以使用Docker Hub上提供的官方cURL映像:

docker pull curlimages/curldocker run --rm curlimages/curl <https://example.com>

在此示例中,使用 --rm 标志在命令完成后删除容器。当您只需要运行单个命令然后清理容器时,这非常有用。

其他命令行实用程序

Docker映像中有许多命令行实用程序可用,包括但不限于:

  • wget:用于从Web下载文件的免费实用程序。
  • imagemagick:用于图像处理和转换的功能强大的软件套件。
  • jq:轻量级且灵活的命令行JSON处理器。

要使用其中任何一种工具,您可以在Docker Hub上搜索它们,然后按照其各自存储库中提供的说明进行操作。

总之,使用第三方Docker映像进行命令行实用程序可以节省时间,简化开发设置,并有助于确保在不同计算机上具有一致的环境。随着您扩展Docker的知识和使用,您可以尝试不同的工具和实用程序。

最后

为了方便其他设备和平台的小伙伴观看往期文章,链接奉上:

公众号 Let us Coding牛客知乎开源中国CSDN思否掘金InfoQ简书博客园慕课51CTOhelloworld腾讯开发者社区阿里开发者社区

看完如果觉得有帮助,欢迎点赞、收藏关注

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
3年前
typeScript数据类型
//布尔类型letisDone:booleanfalse;//数字类型所有数字都是浮点数numberletdecLiteral:number6;lethexLiteral:number0xf00d;letbinaryLiteral:number0b101
Wesley13 Wesley13
3年前
PPDB:今晚老齐直播
【今晚老齐直播】今晚(本周三晚)20:0021:00小白开始“用”飞桨(https://www.oschina.net/action/visit/ad?id1185)由PPDE(飞桨(https://www.oschina.net/action/visit/ad?id1185)开发者专家计划)成员老齐,为深度学习小白指点迷津。
Wesley13 Wesley13
3年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Easter79 Easter79
3年前
SpringBoot整合Redis乱码原因及解决方案
问题描述:springboot使用springdataredis存储数据时乱码rediskey/value出现\\xAC\\xED\\x00\\x05t\\x00\\x05问题分析:查看RedisTemplate类!(https://oscimg.oschina.net/oscnet/0a85565fa
Wesley13 Wesley13
3年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Stella981 Stella981
3年前
Jenkins 插件开发之旅:两天内从 idea 到发布(上篇)
本文首发于:Jenkins中文社区(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fjenkinszh.cn)!huashan(https://oscimg.oschina.net/oscnet/f499d5b4f76f20cf0bce2a00af236d10265.jpg)
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(