Docker镜像管理

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。

搭建Docker服务

Docker 是一个开源的容器引擎,用于创建、管理和编排容器,可以轻松为任何应用创建一个轻量级、可移植、自给自足的容器。本步骤将在ECS上部署一个Docker服务,并配置DockerHub的镜像加速器。
  1. 安装Docker的依赖库。
yum install -y yum-utils device-mapper-persistent-data lvm2
  1. 添加Docker CE的软件源信息。
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  1. 安装Docker CE。
yum makecache fast &&
yum -y install docker-ce
  1. 启动Docker服务。
systemctl start docker
  1. 配置DockerHub镜像加速器。
tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://registry.docker-cn.com"]
}
EOF
  1. 重启Docker服务。
systemctl restart docker

准备应用代码和Dockerfile

本步骤操作将在工作空间下创建一个基于Golang的HelloWorld代码文件和一个用来构建运行Hello代码所需环境镜像的Dockerfile文件。
  1. 创建工作空间。
mkdir -p /tmp/demo && cd /tmp/demo
  1. 在工作空间下创建HelloWorld代码文件,用来在容器环境中监听HTTP服务,输出HelloWorld字符串。
cat > /tmp/demo/main.go << EOF
package main

import (
        "fmt"
        "net/http"
)

func main() {
        http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
                fmt.Fprintf(w, "Hello! World\n")
        })

        fmt.Println("start to serve...")
        http.ListenAndServe(":80", nil)
}
EOF
  1. 在工作空间下创建Dockerfile文件。
cat > /tmp/demo/Dockerfile << EOF
FROM golang:1.12-alpine

# change current working dir
WORKDIR /go/src/app

# copy main.go into /go/src/app
COPY . .

# go build and install the app
RUN go install -v ./...

# run the app by default
CMD ["app"]
EOF

本地构建镜像并运行镜像

本步骤将指导您使用Docker基本命令构建和运行镜
  1. 使用docker build命令构建镜像。
docker build . -t demo:v1

说明:

  • 参数.表示指定当前路径作为构建上下文,即Dockerfile所在的本地路径。
  • 参数-t demo:v1指定镜像名称和标签。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker build . -t demo:v1
Sending build context to Docker daemon  3.072kB
Step 1/5 : FROM golang:1.12-alpine
1.12-alpine: Pulling from library/golang
c9b1b535fdd9: Pull complete 
cbb0d8da1b30: Pull complete 
d909eff28200: Pull complete 
665fbbf998e4: Pull complete 
4985b1919860: Pull complete 
Digest: sha256:3f8e3ad3e7c128d29ac3004ac8314967c5ddbfa5bfa7caa59b0de493fc01686a
Status: Downloaded newer image for golang:1.12-alpine
 ---> 76bddfb5e55e
Step 2/5 : WORKDIR /go/src/app
 ---> Running in 532c0ed59d58
Removing intermediate container 532c0ed59d58
 ---> caea8e8d17fc
Step 3/5 : COPY . .
 ---> 492c4f6e5a46
Step 4/5 : RUN go install -v ./...
 ---> Running in 74993ab4d732
app
Removing intermediate container 74993ab4d732
 ---> 2f6312a3e1f5
Step 5/5 : CMD ["app"]
 ---> Running in a68d245aa154
Removing intermediate container a68d245aa154
 ---> c335f97d355f
Successfully built c335f97d355f
Successfully tagged demo:v1
  1. 使用docker run命令运行镜像。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker run -d -p 8000:80 demo:v1
d8ab44f58e4fe0c0a573d9576bdac71b5bd4ea1c7ae220dacea8cb841c77a9aa

说明:

  • 参数-d设置容器运行模式为后台运行。
  • 参数-p 8000:80将容器内部使用的网络端口映射到主机上,其中8000为主机端口,80为容器内部使用端口。
  1. 使用curl工具访问容器中的HelloWorld服务。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# curl localhost:8000
Hello! World
  1. 使用docker rm命令删除容器。
docker rm -f $(docker ps -a | grep "demo:v1" | awk '{print $1}')
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker rm -f $(docker ps -a | grep "demo:v1" | awk '{print $1}')
d8ab44f58e4f

创建远程镜像仓库

本步骤操作将使用自己的阿里云账号开通容器镜像服务并创建镜像仓库。阿里云容器镜像服务默认实例版可免费使用。
  1. 使用您的阿里云主账号登录容器镜像服务控制台
  2. 在容器镜像服务控制台,依次单击 【个人实例】 > 【命名空间】 > 【创建命名空间】,在 【创建命名空间】 弹框中填写命令空间名称,然后单击 【确定】 。

image-20220222091748335

  1. 选择 【镜像仓库】 > 【创建镜像仓库】,在 【创建镜像仓库】 弹框中选择 【命名空间】 ,填写 仓库名称 和 摘要 ,然后单击 【下一步】 。

image-20220222091922530

  1. 单击 【本地仓库】 > 【创建镜像仓库】

image-20220222092018281

  1. 在镜像仓库列表,选择上一步创建的镜像仓库,单击 【管理】 ,查看镜像仓库详情。

image-20220222092122163

推送镜像

本步骤操作将本地镜像推送到远程仓库中,并运行远程仓库中的指定版本镜像。请将本步骤命令中涉及的远程镜像地址替换为步骤五中创建的镜像仓库的公网地址。
  1. 执行以下命令登录到阿里云Docker Registry。
用于登录的用户名为阿里云账号全名,密码为开通服务时设置的密码。

您可以在访问凭证页面修改凭证密码。

说明: 请将下面命令中的用户名替换为您的阿里云账号全名,回车后输入远程镜像仓库密码,密码为步骤六开通服务时设置的密码。

请登录阿里云用户中心查看您的主账号用户名称。

==没有设置访问凭证,需要设置访问密码。==

[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker login --username=xuyebaodiy registry.cn-shanghai.aliyuncs.com
Password: 
Error response from daemon: Get "https://registry.cn-shanghai.aliyuncs.com/v2/": unauthorized: authentication required

image-20220222092954820

[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker login --username=xuyebaodiy registry.cn-shanghai.aliyuncs.com
Password: 
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[root@iZuf6avpg1mqspnfry4xzvZ demo]# 
  1. 标记本地镜像,将其归入远程仓库。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker tag demo:v1 registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo:v1
  1. 将本地镜像推送到远程仓库。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker push registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo:v1
The push refers to repository [registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo]
69e98ea749dd: Pushed 
0a31e2bc4c60: Pushed 
5d7129c092ee: Pushed 
7306dca01e79: Pushed 
3957f7032fc4: Pushed 
12c4e92b2d48: Pushed 
45182158f5da: Pushed 
5216338b40a7: Pushed 
v1: digest: sha256:f388dab92e4c37274ccf53cedf461eb4b5dd7bcf35fbf19c0fc40347adb72b76 size: 1990
  1. 拉取指定版本的远程镜像。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker pull registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo:v1
v1: Pulling from xybdiy-test/demo
Digest: sha256:f388dab92e4c37274ccf53cedf461eb4b5dd7bcf35fbf19c0fc40347adb72b76
Status: Image is up to date for registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo:v1
registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo:v1
  1. 运行拉取的远程镜像。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# docker run -d -p 8000:80 registry.cn-shanghai.aliyuncs.com/xybdiy-test/demo:v14ec9c8d3600cb5df7537f4d38b3f86be98751a07019f210fd814f4a06319c928
  1. 访问HelloWorld服务。
[root@iZuf6avpg1mqspnfry4xzvZ demo]# curl localhost:8000
Hello! World
相关实践学习
通过容器镜像仓库与容器服务快速部署spring-hello应用
本教程主要讲述如何将本地Java代码程序上传并在云端以容器化的构建、传输和运行。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。 &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情:&nbsp;https://www.aliyun.com/product/kubernetes
目录
相关文章
|
12天前
|
Docker 容器
将本地的应用程序打包成Docker镜像
将本地的应用程序打包成Docker镜像
|
12天前
|
数据库 Docker 容器
Docker在现代软件开发中扮演着重要角色,通过Dockerfile自动化构建Docker镜像,实现高效、可重复的构建过程。
Docker在现代软件开发中扮演着重要角色,通过Dockerfile自动化构建Docker镜像,实现高效、可重复的构建过程。Dockerfile定义了构建镜像所需的所有指令,包括基础镜像选择、软件安装、文件复制等,极大提高了开发和部署的灵活性与一致性。掌握Dockerfile的编写,对于提升软件开发效率和环境管理具有重要意义。
30 9
|
1月前
|
缓存 Linux 网络安全
docker的镜像无法下载如何解决?
【10月更文挑战第31天】docker的镜像无法下载如何解决?
1322 29
|
12天前
|
存储 缓存 运维
Docker镜像采用分层存储,每层代表镜像的一部分,如基础组件或应用依赖,多层叠加构成完整镜像
Docker镜像采用分层存储,每层代表镜像的一部分,如基础组件或应用依赖,多层叠加构成完整镜像。此机制减少存储占用,提高构建和传输效率。Docker还通过缓存机制提升构建和运行效率,减少重复工作。文章深入解析了Docker镜像分层存储与缓存机制,包括具体实现、管理优化及实际应用案例,帮助读者全面理解其优势与挑战。
32 4
|
29天前
|
存储 关系型数据库 Linux
【赵渝强老师】什么是Docker的镜像
Docker镜像是一个只读模板,包含应用程序及其运行所需的依赖环境。镜像采用分层文件系统,每次修改都会以读写层形式添加到原只读模板上。内核bootfs用于加载Linux内核,根镜像相当于操作系统,上方为应用层。镜像在物理存储上是一系列文件的集合,默认存储路径为“/var/lib/docker”。
|
1月前
|
存储 监控 Linux
docker构建镜像详解!!!
本文回顾了Docker的基本命令和管理技巧,包括容器和镜像的增删改查操作,容器的生命周期管理,以及如何通过端口映射和数据卷实现容器与宿主机之间的网络通信和数据持久化。文章还详细介绍了如何使用Docker部署一个简单的Web应用,并通过数据卷映射实现配置文件和日志的管理。最后,文章总结了如何制作自定义镜像,包括Nginx、Python3和CentOS镜像,以及如何制作私有云盘镜像。
129 2
|
1月前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
120 1
|
1月前
|
存储 Java 开发者
成功优化!Java 基础 Docker 镜像从 674MB 缩减到 58MB 的经验分享
本文分享了如何通过 jlink 和 jdeps 工具将 Java 基础 Docker 镜像从 674MB 优化至 58MB 的经验。首先介绍了选择合适的基础镜像的重要性,然后详细讲解了使用 jlink 构建自定义 JRE 镜像的方法,并通过 jdeps 自动化模块依赖分析,最终实现了镜像的大幅缩减。此外,文章还提供了实用的 .dockerignore 文件技巧和选择安全、兼容的基础镜像的建议,帮助开发者提升镜像优化的效果。
|
1月前
|
存储 缓存 Java
Java应用瘦身记:Docker镜像从674MB优化至58MB的实践指南
【10月更文挑战第22天】 在容器化时代,Docker镜像的大小直接影响到应用的部署速度和运行效率。一个轻量级的Docker镜像可以减少存储成本、加快启动时间,并提高资源利用率。本文将分享如何将一个Java基础Docker镜像从674MB缩减到58MB的实践经验。
73 1
|
29天前
|
缓存 JavaScript 安全
深入理解Docker镜像构建过程
深入理解Docker镜像构建过程
65 0