容器技术入门1:Docker镜像管理快速入门

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 参加冬季实战营第四期:零基础容器技术实战。参加学习一下,教程很好,做笔记记录一下

1. 搭建Docker服务

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

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


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

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

 

yum-config-manager --add-repo http://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

 

 

2. 编写Dockerfile

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

1. 创建工作空间。


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


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

 

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

本步骤将指导您使用Docker基本命令构建和运行镜

1. 使用docker build命令构建镜像。


docker build . -t demo:v1

命令运行结果如下所示:

 

image.png

 

说明:

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


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


docker run -d -p 8000:80 demo:v1

 

命令运行结果如下所示:

image.png

 

说明:

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


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


curl localhost:8000

 

命令运行结果如下所示:

image.png

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

 

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

命令运行结果如下所示:

 image.png


4. 远程镜像仓库操作

1. 推送镜像

本步骤操作将本地镜像推送到远程仓库中,并运行远程仓库中的指定版本镜像。

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

 

命令运行结果如下所示:

 image.png 

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


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

 

命令运行结果如下所示:

 image.png 

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


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

 

命令运行结果如下所示:

 

image.png

 


 



相关文章
|
2天前
|
监控 Kubernetes Docker
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
【5月更文挑战第9天】本文探讨了Docker容器中应用的健康检查与自动恢复,强调其对应用稳定性和系统性能的重要性。健康检查包括进程、端口和应用特定检查,而自动恢复则涉及重启容器和重新部署。Docker原生及第三方工具(如Kubernetes)提供了相关功能。配置检查需考虑检查频率、应用特性和监控告警。案例分析展示了实际操作,未来发展趋势将趋向更智能和高效的检查恢复机制。
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
|
2天前
|
存储 安全 持续交付
【Docker 专栏】Docker 镜像的版本控制与管理
【5月更文挑战第9天】本文探讨了Docker镜像版本控制与管理的重要性,包括可重复性、回滚能力、协作开发和持续集成。常用方法有标签、构建参数和版本控制系统。管理策略涉及定期清理、分层管理和镜像仓库。语义化标签、环境变量和配置文件在版本控制中有应用。版本系统与Docker结合能跟踪历史和促进协作。注意点包括优化镜像大小、确保安全性和兼容性。案例分析和未来趋势展示了持续发展的镜像管理技术,为Docker应用的稳定与进步保驾护航。
【Docker 专栏】Docker 镜像的版本控制与管理
|
1天前
|
NoSQL Redis Docker
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
10 0
|
2天前
|
存储 安全 数据库
【Docker 专栏】Docker 容器内应用的状态持久化
【5月更文挑战第9天】本文探讨了Docker容器中应用状态持久化的重要性,包括数据保护、应用可用性和历史记录保存。主要持久化方法有数据卷、绑定挂载和外部存储服务。数据卷是推荐手段,可通过`docker volume create`命令创建并挂载。绑定挂载需注意权限和路径一致性。利用外部存储如数据库和云服务可应对复杂需求。最佳实践包括规划存储策略、定期备份和测试验证。随着技术发展,未来将有更智能的持久化解决方案。
【Docker 专栏】Docker 容器内应用的状态持久化
|
2天前
|
机器学习/深度学习 监控 Kubernetes
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
【5月更文挑战第9天】本文探讨了Docker容器服务的自动扩展与缩容原理及实践,强调其在动态业务环境中的重要性。通过选择监控指标(如CPU使用率)、设定触发条件和制定扩展策略,实现资源的动态调整。方法包括云平台集成和使用Kubernetes等框架。实践中,电商平台和实时数据处理系统受益于此技术。注意点涉及监控数据准确性、扩展速度和资源分配。未来,智能算法将提升扩展缩容的效率和准确性,成为关键技术支持。
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
|
2天前
|
运维 安全 Docker
【Docker 专栏】Docker 镜像安全扫描与漏洞修复
【5月更文挑战第9天】Docker技术在软件开发和部署中带来便利,但其镜像安全问题不容忽视。本文探讨了Docker镜像安全扫描与漏洞修复,强调了镜像安全对应用和系统的重要性。文中介绍了静态和动态扫描方法,列举了软件漏洞、配置漏洞和恶意软件等常见安全问题,并提到了Clair和Trivy等扫描工具。修复策略包括更新软件、调整配置和重建镜像。此外,加强安全意识、规范镜像制作流程和定期扫描是管理建议。未来,将持续面对新的安全挑战,需持续研究和完善安全技术。
【Docker 专栏】Docker 镜像安全扫描与漏洞修复
|
2天前
|
Java 数据库连接 Docker
【Docker 专栏】Docker 容器内环境变量的管理与使用
【5月更文挑战第9天】本文介绍了Docker容器中环境变量的管理与使用,环境变量用于传递配置信息和设置应用运行环境。设置方法包括在Dockerfile中使用`ENV`指令或在启动容器时通过`-e`参数设定。应用可直接访问环境变量或在脚本中使用。环境变量作用包括传递配置、设置运行环境和动态调整应用行为。使用时注意变量名称和值的合法性、保密性和覆盖问题。理解并熟练运用环境变量能提升Docker技术的使用效率和软件部署质量。
【Docker 专栏】Docker 容器内环境变量的管理与使用
|
3天前
|
运维 安全 Linux
深入理解Docker自定义网络:构建高效的容器网络环境
深入理解Docker自定义网络:构建高效的容器网络环境
|
3天前
|
Java Linux 数据安全/隐私保护
Docker自定义JDK镜像并拉取至阿里云镜像仓库全攻略
Docker自定义JDK镜像并拉取至阿里云镜像仓库全攻略
|
3天前
|
存储 弹性计算 运维
Docker数据集与自定义镜像:构建高效容器的关键要素
Docker数据集与自定义镜像:构建高效容器的关键要素