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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker作为开源的应用容器引擎,可以把应用程序和其相关依赖打包生成一个Image镜像文件,是一个标准的运行环境,提供可持续交付的能力。
前言:该系列文章,围绕持续集成: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
相关文章
|
21天前
|
Docker 容器
进入Docker容器中
进入Docker容器中
34 2
|
1天前
|
存储 运维 监控
构建高效稳定的Docker容器监控体系
【4月更文挑战第18天】 在现代微服务架构中,Docker容器已成为部署和运行应用的标准环境。随之而来的挑战是如何有效监控这些容器的性能与健康状况,确保系统的稳定性和可靠性。本文将探讨构建一个高效稳定的Docker容器监控体系的关键技术和方法,包括日志管理、性能指标收集以及异常检测机制,旨在为运维人员提供实用的指导和建议。
7 0
|
7天前
|
JSON Kubernetes Go
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
17 0
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
|
10天前
|
Linux Docker 容器
docker 容器常用命令
docker 容器常用命令
12 0
|
10天前
|
Linux Shell 虚拟化
linux 部署docker容器虚拟化平台(二)--------docker 镜像制作方法
linux 部署docker容器虚拟化平台(二)--------docker 镜像制作方法
15 0
|
10天前
|
存储 Linux Shell
centos 部署docker容器 安装 、基本使用方法(一)
centos 部署docker容器 安装 、基本使用方法(一)
19 0
|
18天前
|
Kubernetes 网络协议 Docker
Docker 容器的DNS
Docker 容器的DNS
23 1
|
21天前
|
关系型数据库 MySQL Nacos
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
45 1
|
22天前
|
NoSQL 关系型数据库 MySQL
安装Docker&镜像容器操作&使用Docker安装部署MySQL,Redis,RabbitMQ,Nacos,Seata,Minio
安装Docker&镜像容器操作&使用Docker安装部署MySQL,Redis,RabbitMQ,Nacos,Seata,Minio
102 1
|
22天前
|
运维 监控 云计算
构建高效稳定的Docker容器监控体系
随着微服务架构的普及,Docker容器作为其核心承载单元,在系统运维中扮演着日益重要的角色。本文旨在探讨如何构建一个高效且稳定的Docker容器监控体系,以确保容器运行的可靠性和系统的高可用性。文章首先分析了容器监控的必要性,接着详细介绍了监控体系的设计理念和组件选择,最后提供了实施过程中的关键步骤与最佳实践。通过本文,读者将掌握构建和维护Docker容器监控体系的有效方法。