快速入门Docker镜像管理

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker镜像管理

一.Docker镜像

概念

Docker 镜像可以看作是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。镜像不包含任何动态数据,其内容在构建之后也不会被改变。

二.搭建Docker服务

1.安装Docker的依赖库

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

image.png

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

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

image.png

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

image.png

6.重启Docker服务

systemctl restart docker

三.准备应用代码和Dockerfile

1.创建工作空间

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

image.png

2.创建HelloWorld代码文件

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

3.创建Dockerfile文件

cat > /tmp/demo/Dockerfile << EOF
FROM golang:1.12-alpine
# change current working dirWORKDIR /go/src/app
# copy main.go into /go/src/appCOPY . .
# go build and install the appRUN go install -v ./...
# run the app by defaultCMD ["app"]
EOF

四.本地构建镜像并运行镜像

1.构建镜像

docker build . -t demo:v1

image.png

注:

  • 参数.表示指定当前路径作为构建上下文,即Dockerfile所在的本地路径
  • 参数-t demo:v1指定镜像名称和标签

2.运行镜像

docker run -d-p8000:80 demo:v1

image.png

注:

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

3.访问容器中的HelloWorld服务

curl localhost:8000

image.png

4.删除容器

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

image.png

五.创建远程镜像仓库

本步骤操作将指导您使用自己的阿里云账号开通容器镜像服务并创建镜像仓库。阿里云容器镜像服务默认实例版可免费使用,其使用限制请参见容器镜像服务计费说明。

1.登录容器镜像服务控制台

访问:容器镜像服务控制台并且登录。

image.png

2.单击【设置Registry登录密码】

TB1hzDeLVT7gK0jSZFpXXaTkpXa-1035-267.png

3.设置阿里云Docker Registry登录密码

TB1ftevaCR26e4jSZFEXXbwuXXa-530-348.png

4.创建命名空间

在容器镜像服务控制台,依次单击 【个人实例】 > 【命名空间】 > 【创建命名空间】,在 【创建命名空间】 弹框中填写命令空间名称,然后单击 【确定】

TB1842cL1H2gK0jSZJnXXaT1FXa-1915-613.png

5.创建镜像仓库

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

TB1Lf5_LYY1gK0jSZTEXXXDQVXa-775-691.png

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

TB1iM_rL1L2gK0jSZFmXXc7iXXa-775-328.png

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

TB1mIYlL4v1gK0jSZFFXXb0sXXa-1897-734.png

六.推送镜像

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

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

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

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

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

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

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

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

5.运行拉取的远程镜像

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

6.访问HelloWorld服务

curl localhost:8000
相关实践学习
通过容器镜像仓库与容器服务快速部署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
目录
相关文章
|
3天前
|
消息中间件 Kafka 流计算
docker环境安装kafka/Flink/clickhouse镜像
通过上述步骤和示例,您可以系统地了解如何使用Docker Compose安装和配置Kafka、Flink和ClickHouse,并进行基本的验证操作。希望这些内容对您的学习和工作有所帮助。
50 28
|
16天前
|
网络协议 Linux 网络安全
docker centos镜像 npm安装包时报错“npm ERR! code ECONNRESET”
通过上述步骤,您可以有效解决在 Docker 中使用 CentOS 镜像安装 npm 包时遇到的 "npm ERR! code ECONNRESET" 错误。希望这些方法能帮助您顺利进行 npm 包的安装。
94 26
|
1月前
|
存储 Docker 容器
Docker-基础(数据卷、自定义镜像、Compose)
通过数据卷实现持久化存储,通过自定义镜像满足特定需求,通过Docker Compose方便地管理多容器应用
88 27
|
1月前
|
存储 Docker 容器
Docker-基础(数据卷、自定义镜像、Compose)
通过数据卷实现持久化存储,通过自定义镜像满足特定需求,通过Docker Compose方便地管理多容器应用。掌握这些Docker基础概念和操作,可以显著提高开发和部署效率,确保应用程序的可移植性和可扩展性。
74 22
|
1月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
160 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
1月前
|
Ubuntu NoSQL 开发工具
《docker基础篇:4.Docker镜像》包括是什么、分层的镜像、UnionFS(联合文件系统)、docker镜像的加载原理、为什么docker镜像要采用这种分层结构呢、docker镜像commit
《docker基础篇:4.Docker镜像》包括是什么、分层的镜像、UnionFS(联合文件系统)、docker镜像的加载原理、为什么docker镜像要采用这种分层结构呢、docker镜像commit
213 70
|
1月前
|
Ubuntu NoSQL 关系型数据库
《docker基础篇:6.本地镜像发布到私有库》包括本地镜像发布到私有库流程、docker regisry是什么、将本地镜像推送到私有库
《docker基础篇:6.本地镜像发布到私有库》包括本地镜像发布到私有库流程、docker regisry是什么、将本地镜像推送到私有库
127 29
|
2月前
|
NoSQL PHP MongoDB
docker push推送自己搭建的镜像
本文详细介绍了如何搭建和复盘两个Web安全挑战环境:人力资源管理系统和邮件管理系统。首先,通过Docker搭建MongoDB和PHP环境,模拟人力资源管理系统的漏洞,包括nosql注入和文件写入等。接着,复盘了如何利用这些漏洞获取flag。邮件管理系统部分,通过目录遍历、文件恢复和字符串比较等技术,逐步绕过验证并最终获取flag。文章提供了详细的步骤和代码示例,适合安全研究人员学习和实践。
70 3
docker push推送自己搭建的镜像
|
2月前
|
Docker 容器
|
2月前
|
Docker 容器
将本地的应用程序打包成Docker镜像
将本地的应用程序打包成Docker镜像