Docker镜像管理快速入门

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 一、 搭建Linux环境 (CentOS)二、 搭建Docker服务

一、 搭建Linux环境 (CentOS)

[云原生技术实践体验]    https://developer.aliyun.com/adc/expo/nativecloud

[Docker镜像管理快速入门]    https://developer.aliyun.com/adc/scenario/e6875b45034a4461b2a7769e06451657?spm=a2c6h.13858378.0.0.76352c903USMmt

查看系统版本

cat /etc/redhat-release

二、 搭建Docker服务

Docker 是一个开源的容器引擎,用于创建、管理和编排容器,可以轻松为任何应用创建一个轻量级、可移植、自给自足的容器。本步骤将在ECS上部署一个Docker服务,并配置DockerHub的镜像加速器。

1. 输入以下命令,安装Docker的依赖库。

yum install -y yum-utils device-mapper-persistent-data lvm2

2. 添加Docker CE的软件源信息。

yum-config-manager --add-repohttp://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3. 安装Docker CE。

yum makecache fast &&

yum -y install docker-ce

4. 启动Docker服务。

systemctl start docker

5. 配置DockerHub镜像加速器。

tee /etc/docker/daemon.json <<-'EOF'

{

 "registry-mirrors": ["https://registry.docker-cn.com"]

}

EOF

6. 重启Docker服务。

systemctl restart docker

三、 准备应用代码和Dockerfile

本步骤操作将在工作空间下创建一个基于Golang的HelloWorld代码文件和一个用来构建运行Hello代码所需环境镜像的Dockerfile文件。

1. 创建工作空间。

mkdir-p /tmp/demo && cd /tmp/demo

2. 在工作空间下创建HelloWorld代码文件,用来在容器环境中监听HTTP服务,输出HelloWorld字符串。

cat > /tmp/demo/main.go << EOF

packagemain

import (

       "fmt"

       "net/http"

)

funcmain() {

       http.HandleFunc("/", func(whttp.ResponseWriter, r*http.Request) {

               fmt.Fprintf(w, "Hello! World\n")

       })

       fmt.Println("start to serve...")

       http.ListenAndServe(":80", nil)

}

EOF

3. 在工作空间下创建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

2. 使用docker run命令运行镜像。

docker run -d-p8000:80 demo:v1

命令运行结果如下所示:

说明:

  • 参数-d设置容器运行模式为后台运行。
  • 参数-p 8000:80将容器内部使用的网络端口映射到主机上,其中8000为主机端口,80为容器内部使用端口。

3. 使用curl工具访问容器中的HelloWorld服务。

curl localhost:8000

4. 使用docker rm命令删除容器。

docker rm-f$(docker ps -a | grep "demo:v1" | awk '{print $1}')

五、创建远程镜像仓库

本步骤操作将指导您使用自己的阿里云账号开通容器镜像服务并创建镜像仓库。

详情见

[5. 创建远程镜像仓库]    https://developer.aliyun.com/adc/scenario/exp/e6875b45034a4461b2a7769e06451657

六、推送镜像

本步骤操作将本地镜像推送到远程仓库中,并运行远程仓库中的指定版本镜像。请将本步骤命令中涉及的远程镜像地址替换为步骤五中创建的镜像仓库的公网地址。

1.执行以下命令登录到阿里云Docker Registry。

docker login --username="用户名" registry.cn-shanghai.aliyuncs.com

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

2. 标记本地镜像,将其归入远程仓库。

docker tag demo:v1 registry.cn-shanghai.aliyuncs.com/space_test/demo:v1

3. 将本地镜像推送到远程仓库。

docker push registry.cn-shanghai.aliyuncs.com/space_test/demo:v1

4. 拉取指定版本的远程镜像。

docker pull registry.cn-shanghai.aliyuncs.com/space_test/demo:v1

命令运行结果如下所示:

5. 运行拉取的远程镜像。

docker run  -d-p8000:80 registry.cn-shanghai.aliyuncs.com/space_test/demo:v1

6. 访问HelloWorld服务。

curl localhost:8000


相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
2月前
|
JavaScript Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
278 100
|
2月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
241 99
|
2月前
|
缓存 Docker 容器
优化Docker镜像大小的五个实用技巧
优化Docker镜像大小的五个实用技巧
228 98
|
2月前
|
安全 Go Docker
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
|
22天前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
201 5
|
7月前
|
Docker 容器 Perl
云效flow构建docker镜像更换apt源为阿里镜像源
在 Dockerfile 中添加命令以更换 Debian 源为阿里云镜像,加速容器内软件包下载。核心命令通过 `sed` 实现源地址替换,并更新 apt 软件源。其中 `cat` 命令用于验证替换是否成功,实际使用中可删除该行。
1376 32
|
2月前
|
Java Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
115 8
|
3月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
206 16
kde
|
4月前
|
Docker 容器 应用服务中间件
Docker 客户端是如何拉取镜像的?
Docker客户端拉取镜像的过程遵循Docker Registry HTTP API V2规范,主要分为解析镜像名、鉴权、获取Manifest、拉取Layers及本地合并五个步骤。它与Docker Hub、Harbor等仓库通信,确保镜像正确下载和构建。
kde
637 59
|
3月前
|
运维 关系型数据库 数据库
应用官方 Docker 镜像已成熟,团队为何转向 Websoft9 而不再依赖 Bitnami
随着云原生发展,部署工具从 Bitnami 转向 Websoft9。后者基于官方镜像,提供多应用编排与统一运维,提升部署效率与维护能力,适合多系统协同场景。
应用官方 Docker 镜像已成熟,团队为何转向 Websoft9 而不再依赖 Bitnami

热门文章

最新文章

下一篇
开通oss服务