自动化集成:Docker容器入门简介

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker作为开源的应用容器引擎,可以把应用程序和其相关依赖打包生成一个Image镜像文件,是一个标准的运行环境,提供可持续交付的能力。

2000元阿里云代金券免费领取,2核4G云服务器仅664元/3年,新老用户都有优惠,立即抢购>>>


阿里云采购季(云主机223元/3年)活动入口:请点击进入>>>,


阿里云学生服务器(9.5元/月)购买入口:请点击进入>>>,

前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译、打包、镜像构建、部署等操作; 本篇文章主要描述Docker基础用法

00-0.png

一、Docker简介

1、基础描述

Docker作为开源的应用容器引擎,可以把应用程序和其相关依赖打包生成一个Image镜像文件,是一个标准的运行环境,提供可持续交付的能力,通过镜像文件可以创建多个Docker容器,这里可以理解为类创建对象的原理;镜像文件可以推送到仓库Repository中,这里可以理解为Git仓库管理代码的原理。

2、核心概念

  • Image镜像:包含应用和依赖的类库,配置等;
  • Container容器:通过镜像文件创建多个容器,运行打包应用;
  • Repository仓库:存放镜像文件的云端服务;

镜像文件与容器,可以理解为基于快照启动虚拟机;或者类与实例对象的关系。

3、架构原理

03-1.png

Docker基于客户端-服务器的架构模式,Docker的守护进程(daemon)监听客户端的请求命令,从而管理镜像文件、容器等。

二、管理命令

1、查docker信息

# 查看基础信息
docker info

# 查看版本信息
docker version

# 查看命令说明
docker --help

2、镜像文件

基础命令

# 查看本地镜像列表
docker images  或者 docker image ls

# 搜索镜像
docker search ImageName

# 拉取镜像
docker image pull ImageName

# 删除镜像
docker image rm ImageName

推送仓库

首先在云服务平台申请私有的镜像管理仓库,并配置好访问仓库的账号和密码,通过docker命令把本地镜像文件推送到该仓库,这里以阿里云为例:

# 1、登录仓库
docker login --username=账户名 仓库_url

提示输出仓库密码:Login Succeeded

# 2、查看本地镜像
docker images
REPOSITORY    TAG       IMAGE ID       CREATED          SIZE
cloud-app     latest    b11d221cc3e0   13 seconds ago   662MB

# 3、标记上述镜像
docker tag b11d221cc3e0 仓库_url/cicada-image/cloud-app:latest

# 4、执行推送命令
docker push 仓库_url/cicada-image/cloud-app:latest

# 5、拉取该镜像到本地
docker pull 仓库_url/cicada-image/cloud-app:latest

注意:cicada-image是仓库的命名空间,点击cloud-app可以查看镜像操作的步骤文档:

03-2.png

3、容器管理

# 列出正在运行或运行过的容器
docker ps -a

# 停止容器运行
docker stop 容器ID

# 删除指定容器
docker rm 容器ID

# 删除全部暂停容器
docker rm -f $(docker ps -a -q)

4、入门案例

- 拉取hello-world镜像
docker image pull hello-world

输出日志:
Using default tag: latest
latest: Pulling from library/hello-world

- 查看本地镜像
docker image ls
REPOSITORY    TAG       IMAGE ID       CREATED       SIZE
hello-world   latest    feb5d9fea6a5   7 weeks ago   13.3kB

- 运行hello-world
docker container run hello-world

输出日志:
Hello from Docker!
This message shows that your installation appears to be working correctly.

三、构建镜像

1、Dockerfile

Dockerfile是一个文本文档,包含构建Docker镜像的指令,通过读取该脚本中的指令并执行,完成相关build过程。

注意事项

  • 脚本命名Dockerfile并且没有任何后缀;
  • Docker在构建镜像时,默认识别该文件;
  • 通常脚本文件放在打包工程的根目录下;

2、基础样例

语法说明

  • FROM:指定需要使用的基础镜像;
  • MAINTAINER:定义脚本维护者;
  • VOLUME:指定持久化文件目录;
  • WORKDIR:切换到工作目录;
  • ADD:将指定文件添加到容器中;
  • COPY:将指定文件复制到容器中;
  • RUN:镜像构建时执行的命令;
  • ENTRYPOINT:容器参数配置;

使用案例

# 基础镜像
FROM java:8

# 维护者
MAINTAINER cicadasmile

# 持久化目录
VOLUME /data/docker/logs

# 添加应用服务JAR包
ADD auto-client.jar application.jar

# 配置参数
ENTRYPOINT ["java","-Dspring.profiles.active=dev","-Djava.security.egd=file:/dev/./urandom","-jar","/application.jar"]

3、构建镜像

项目打包

这里获取maven项目打包后的jar包,即auto-client.jar包,然后复制到docker镜像制作的目录下,与Dockerfile在同一级。

结构如下

03-3.png

镜像构建命令

docker build -t client-img:latest .

构建流程执行完之后,查看镜像列表,上面构建的镜像已经存在;

4、运行容器

# 执行命令
docker run -d -p 8079:8079 client-img:latest

# 查看日志
docker logs 容器ID

访问容器中应用的接口,查看响应正常即可。

四、源代码地址

GitEE·地址
https://gitee.com/cicadasmile/butte-auto-parent
Wiki·地址
https://gitee.com/cicadasmile/butte-java-note
相关文章
|
23小时前
|
运维 安全 Linux
深入理解Docker自定义网络:构建高效的容器网络环境
深入理解Docker自定义网络:构建高效的容器网络环境
|
23小时前
|
存储 弹性计算 运维
Docker数据集与自定义镜像:构建高效容器的关键要素
Docker数据集与自定义镜像:构建高效容器的关键要素
|
1天前
|
Kubernetes Java 调度
Java容器技术:Docker与Kubernetes
Java容器技术:Docker与Kubernetes
9 0
|
1天前
|
存储 Ubuntu Linux
Docker 从入门到实践:Docker介绍
Docker 从入门到实践:Docker介绍
|
1天前
|
算法 计算机视觉 Docker
Docker容器中的OpenCV:轻松构建可移植的计算机视觉环境
Docker容器中的OpenCV:轻松构建可移植的计算机视觉环境
Docker容器中的OpenCV:轻松构建可移植的计算机视觉环境
|
1天前
|
存储 Prometheus 监控
【Docker 专栏】Docker 容器内应用的调试与故障排除
【5月更文挑战第8天】本文探讨了Docker容器内应用的调试与故障排除,强调其重要性。方法包括:通过日志排查、进入容器检查、使用监控工具及检查容器配置。常见问题涉及应用启动失败、性能问题、网络连接和数据存储。案例分析展示了实战场景,注意事项提醒避免不必要的容器修改、备份数据和理解应用架构。掌握这些技能能确保Docker应用的稳定运行和性能优化。
【Docker 专栏】Docker 容器内应用的调试与故障排除
|
1天前
|
存储 测试技术 持续交付
【Docker 专栏】Docker 与 CI/CD 的集成策略
【5月更文挑战第8天】本文探讨了Docker在CI/CD流程中的作用,强调了环境一致性、快速部署和资源隔离等优势。通过在构建、测试和部署阶段集成Docker,可以提升软件开发效率和质量。具体集成策略包括使用Dockerfile构建镜像、整合CI/CD工具如Jenkins和GitLab。集成带来的好处包括提高效率、增强可靠性、加速交付和简化管理。然而,也需应对镜像管理、网络配置和安全等问题。通过案例分析,证明了Docker与CI/CD集成的有效性和必要性。
【Docker 专栏】Docker 与 CI/CD 的集成策略
|
1天前
|
负载均衡 网络协议 算法
【Docker 专栏】Docker 容器内服务发现与负载均衡
【5月更文挑战第8天】本文探讨了Docker容器中的服务发现与负载均衡。服务发现通过环境变量、DNS或集中式系统(如Consul、Zookeeper)来定位服务实例。负载均衡则采用轮询、随机等算法,可通过软件负载均衡器、云服务或容器编排工具(如Kubernetes)实现。服务发现与负载均衡结合使用,确保请求有效分发和系统稳定性。面对动态性、网络延迟及大规模部署的挑战,需采取相应措施优化。选择合适技术并持续优化,能提升Docker容器应用的性能和可靠性。
【Docker 专栏】Docker 容器内服务发现与负载均衡
|
1天前
|
存储 安全 数据中心
【Docker 专栏】Docker 容器与宿主机的资源隔离机制
【5月更文挑战第8天】Docker容器利用Namespace和Cgroups实现资源隔离,保证CPU、内存、网络和存储的独立,提升资源利用率和系统安全性。资源隔离有助于简化应用部署与管理,但也带来资源竞争、监控管理及安全挑战。理解并善用资源隔离机制能实现更高效、安全的容器运行。随着技术进步,Docker容器资源隔离将持续优化。
【Docker 专栏】Docker 容器与宿主机的资源隔离机制
|
1天前
|
运维 Linux Docker
Docker详解(十三)——Docker容器的内存和磁盘I/O限制配置
Docker详解(十三)——Docker容器的内存和磁盘I/O限制配置
8 1
http://www.vxiaotou.com