微信扫一扫 分享朋友圈

已有 1742 人浏览分享

开启左侧

Docker入门学习教程

[复制链接]
1742 0
1. Docker概述
(1)基本介绍
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。
容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版),我们用社区版就可以了。官网:https://docs.docker.com/

(2)应用场景
    Web 应用的自动化打包和发布。
    自动化测试和持续集成、发布。
    在服务型环境中部署和调整数据库或其他的后台应用。
    从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
(3)Docker 的优势
Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。

1、快速,一致地交付您的应用程序。Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。
容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:
您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。
他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。
当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。
测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。

2、响应式部署和扩展
Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。
Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。

3、在同一硬件上运行更多工作负载
Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。

2. 虚拟化技术和容器化技术
虚拟化技术特点:1.资源占用多 2.冗余步骤多 3.启动很慢
容器化技术:容器化技术不是模拟的一个完整的操作系统
比较Docker和虚拟机的不同:
1.传统虚拟机,虚拟出硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。
2.Docker容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟硬件。
3.每个容器都是相互隔离的,每个容器都有属于自己的文件系统,互不影响。

容器化带来的好处:
image.png

3. Docker的基本组成
Docker的基本组成图如下:
image.png
image.png
4. Docker的安装
查看系统的内核:
uname -r
系统内核版本为3.10.0
[root@iZwz99sm8v95sckz8bd2c4Z ~]# uname -r
3.10.0-957.21.3.el7.x86_64

查看系统配置
cat /etc/os-release
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# cat /etc/os-release
  2. NAME="CentOS Linux"
  3. VERSION="7 (Core)"
  4. ID="centos"
  5. ID_LIKE="rhel fedora"
  6. VERSION_ID="7"
  7. PRETTY_NAME="CentOS Linux 7 (Core)"
  8. ANSI_COLOR="0;31"
  9. CPE_NAME="cpe:/o:centos:centos:7"
  10. HOME_URL="https://www.centos.org/"
  11. BUG_REPORT_URL="https://bugs.centos.org/"

  12. CENTOS_MANTISBT_PROJECT="CentOS-7"
  13. CENTOS_MANTISBT_PROJECT_VERSION="7"
  14. REDHAT_SUPPORT_PRODUCT="centos"
  15. REDHAT_SUPPORT_PRODUCT_VERSION="7"
复制代码
Docker的安装步骤:
(1)卸载旧的版本
  1. yum remove docker \
  2.                   docker-client \
  3.                   docker-client-latest \
  4.                   docker-common \
  5.                   docker-latest \
  6.                   docker-latest-logrotate \
  7.                   docker-logrotate \
  8.                   docker-engine
复制代码
(2)下载需要的安装包
yum install -y yum-utils
(3)设置镜像的仓库
  1. yum-config-manager \
  2.     --add-repo \
  3.     https://download.docker.com/linux/centos/docker-ce.repo  #国外的地址
  4.    
  5.     # 设置阿里云的Docker镜像仓库
  6. yum-config-manager \
  7.     --add-repo \
  8.     https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo  #国外的地址
复制代码
(4)更新yum软件包索引
yum makecache fast

(5)安装docker相关的配置
docker-ce 是社区版,docker-ee 企业版
yum install docker-ce docker-ce-cli containerd.io
出现了completed即安装成功。

(6)启动Docker
systemctl start docker
# 查看当前版本号,是否启动成功
docker version
# 设置开机自启动
systemctl enable docker

结果:
image.png
下载hello-world镜像进行测试
image.png
查看下载的hello world镜像
  1. [root@iZwz99sm8v95sckz8bd2c4Z lib]# docker images
  2. REPOSITORY    TAG       IMAGE ID       CREATED         SIZE
  3. hello-world   latest    bf756fb1ae65   11 months ago   13.3kB
复制代码
5. Docker的卸载
  1. # 1. 卸载依赖
  2. yum remove docker-ce docker-ce-cli containerd.io
  3. # 2. 删除资源  . /var/lib/docker是docker的默认工作路径
  4. rm -rf /var/lib/docker
复制代码
6. 配置阿里云镜像加速
(1)进入阿里云官网,搜索容器镜像服务

image.png
(2)依次执行官方的这四条命令
  1. sudo mkdir -p /etc/docker
  2. sudo tee /etc/docker/daemon.json <<-'EOF'
  3. {
  4.   "registry-mirrors": ["https://axvfsf7e.mirror.aliyuncs.com"]
  5. }
  6. EOF
  7. sudo systemctl daemon-reload
  8. sudo systemctl restart docker
复制代码
8. Docker容器运行流程
启动一个容器,Docker的运行流程如下图:

image.png
9. 底层原理
Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问!Docker Server接收到Docker-Client的指令,就会执行这个指令!

image.png
Docker为什么比VM Ware快?
1、Docker比虚拟机更少的抽象层
2、docker利用宿主机的内核,VM需要的是Guest OS

image.png
Docker新建一个容器的时候,不需要像虚拟机一样重新加载一个操作系统内核,直接利用宿主机的操作系统,而虚拟机是需要加载Guest OS。Docker和VM的对比如下:

image.png
10. Docker常用命令

10.1 基础命令
docker version          #查看docker的版本信息
docker info             #查看docker的系统信息,包括镜像和容器的数量
docker 命令 --help       #帮助命令(可查看可选的参数)
docker COMMAND --help
命令的帮助文档地址:https://docs.docker.com/engine/reference/commandline/docker/

10.2 镜像命令
1.docker images 查看本地主机的所有镜像
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker images
  2. REPOSITORY    TAG       IMAGE ID       CREATED         SIZE
  3. hello-world   latest    bf756fb1ae65   11 months ago   13.3kB

  4. #解释:
  5. 1.REPOSITORY  镜像的仓库源

  6. 2.TAG  镜像的标签

  7. 3.IMAGE ID 镜像的id

  8. 4.CREATED 镜像的创建时间

  9. 5.SIZE 镜像的大小


  10. # 可选参数

  11. -a/--all 列出所有镜像

  12. -q/--quiet 只显示镜像的id
复制代码
2.docker search 搜索镜像
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search mysql
  2. NAME                              DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
  3. mysql                             MySQL is a widely used, open-source relation…   10308     [OK]
  4. mariadb                           MariaDB is a community-developed fork of MyS…   3819      [OK]
  5. mysql/mysql-server                Optimized MySQL Server Docker images. Create…   754                  [OK]
  6. percona                           Percona Server is a fork of the MySQL relati…   517       [OK]
  7. centos/mysql-57-centos7           MySQL 5.7 SQL database server                   86
  8. mysql/mysql-cluster               Experimental MySQL Cluster Docker images. Cr…   79
  9. centurylink/mysql                 Image containing mysql. Optimized to be link…   60                   [OK]


  10. #可选参数

  11. Search the Docker Hub for images

  12. Options:
  13.   -f, --filter filter   Filter output based on conditions provided
  14.       --format string   Pretty-print search using a Go template
  15.       --limit int       Max number of search results (default 25)
  16.       --no-trunc        Don't truncate output
  17.       
  18.       
  19. #搜索收藏数大于3000的镜像
  20. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search mysql --filter=STARS=3000
  21. NAME      DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
  22. mysql     MySQL is a widely used, open-source relation…   10308     [OK]
  23. mariadb   MariaDB is a community-developed fordockerk of MyS…   3819      [OK]
复制代码
3.docker pull 镜像名[:tag] 下载镜像
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull mysql
  2. Using default tag: latest            #如果不写tag默认就是latest
  3. latest: Pulling from library/mysql
  4. 6ec7b7d162b2: Pull complete          #分层下载,docker image的核心-联合文件系统
  5. fedd960d3481: Pull complete
  6. 7ab947313861: Pull complete
  7. 64f92f19e638: Pull complete
  8. 3e80b17bff96: Pull complete
  9. 014e976799f9: Pull complete
  10. 59ae84fee1b3: Pull complete
  11. ffe10de703ea: Pull complete
  12. 657af6d90c83: Pull complete
  13. 98bfb480322c: Pull complete
  14. 6aa3859c4789: Pull complete
  15. 1ed875d851ef: Pull complete
  16. Digest: sha256:78800e6d3f1b230e35275145e657b82c3fb02a27b2d8e76aac2f5e90c1c30873 #签名
  17. Status: Downloaded newer image for mysql:latest
  18. docker.io/library/mysql:latest  #下载来源的真实地址  #docker pull mysql等价于docker pull docker.io/library/mysql:latest
复制代码
指定版本下载
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull mysql:5.7
  2. 5.7: Pulling from library/mysql
  3. 6ec7b7d162b2: Already exists
  4. fedd960d3481: Already exists
  5. 7ab947313861: Already exists
  6. 64f92f19e638: Already exists
  7. 3e80b17bff96: Already exists
  8. 014e976799f9: Already exists
  9. 59ae84fee1b3: Already exists
  10. 7d1da2a18e2e: Pull complete
  11. 301a28b700b9: Pull complete
  12. 529dc8dbeaf3: Pull complete
  13. bc9d021dc13f: Pull complete
  14. Digest: sha256:c3a567d3e3ad8b05dfce401ed08f0f6bf3f3b64cc17694979d5f2e5d78e10173
  15. Status: Downloaded newer image for mysql:5.7
  16. docker.io/library/mysql:5.7
复制代码
4.docker rmi 删除镜像
  1. #1.删除指定的镜像id
  2. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker rmi -f  镜像id
  3. #2.删除多个镜像id
  4. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker rmi -f  镜像id 镜像id 镜像id
  5. #3.删除全部的镜像id
  6. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker rmi -f  $(docker images -aq)
复制代码
10.3 容器命令
如拉取一个centos镜像
docker pull centos
运行容器的命令说明:

  1. docker run [可选参数] image

  2. #参数说明
  3. --name="名字"           指定容器名字
  4. -d                     后台方式运行
  5. -it                    使用交互方式运行,进入容器查看内容
  6. -p                     指定容器的端口
  7. (
  8. -p ip:主机端口:容器端口  配置主机端口映射到容器端口
  9. -p 主机端口:容器端口
  10. -p 容器端口
  11. )
  12. -P                     随机指定端口(大写的P)
复制代码
运行并进入容器centos
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -it centos /bin/bash
  2. [root@bd1b8900c547 /]# ls      
  3. bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
复制代码
退出容器命令:
  1. #exit 停止并退出容器(后台方式运行则仅退出)
  2. #Ctrl+P+Q  不停止容器退出
  3. [root@bd1b8900c547 /]# exit
  4. exit
  5. [root@iZwz99sm8v95sckz8bd2c4Z ~]#
复制代码
列出运行过的容器命令:
  1. #docker ps
  2.      # 列出当前正在运行的容器
  3. -a   # 列出所有容器的运行记录
  4. -n=? # 显示最近创建的n个容器
  5. -q   # 只显示容器的编号


  6. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  7. CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES
  8. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps -a
  9. CONTAINER ID   IMAGE          COMMAND       CREATED         STATUS                     PORTS     NAMES
  10. bca129320bb5   centos         "/bin/bash"   4 minutes ago   Exited (0) 3 minutes ago             optimistic_shtern
  11. bd1b8900c547   centos         "/bin/bash"   6 minutes ago   Exited (0) 5 minutes ago             cool_tesla
  12. cf6adbf1b506   bf756fb1ae65   "/hello"      5 hours ago     Exited (0) 5 hours ago               optimistic_darwin
复制代码
删除容器命令:
  1. docker rm 容器id                 #删除指定的容器,不能删除正在运行的容器,强制删除使用 rm -f
  2. docker rm -f $(docker ps -aq)   #删除所有的容器
  3. docker ps -a -q|xargs docker rm #删除所有的容器
复制代码
启动和停止容器命令:
  1. docker start 容器id          #启动容器
  2. docker restart 容器id        #重启容器
  3. docker stop 容器id           #停止当前运行的容器
  4. docker kill 容器id           #强制停止当前容器
复制代码
10.4 其他常用命令
10.4 1 日志的查看
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker logs --help

  2. Usage:  docker logs [OPTIONS] CONTAINER

  3. Fetch the logs of a container

  4. Options:
  5.       --details        Show extra details provided to logs
  6.   -f, --follow         Follow log output
  7.       --since string   Show logs since timestamp (e.g. 2013-01-02T13:23:37Z) or relative (e.g. 42m for 42 minutes)
  8.   -n, --tail string    Number of lines to show from the end of the logs (default "all")
  9.   -t, --timestamps     Show timestamps
  10.       --until string   Show logs before a timestamp (e.g. 2013-01-02T13:23:37Z) or relative (e.g. 42m for 42 minutes)

  11. 常用:
  12. docker logs -tf 容器id
  13. docker logs --tail number 容器id #num为要显示的日志条数


  14. #docker容器后台运行,必须要有一个前台的进程,否则会自动停止
  15. #编写shell脚本循环执行,使得centos容器保持运行状态
  16. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -d centos /bin/sh -c "while true;do echo hi;sleep 5;done"
  17. c703b5b1911ff84d584390263a35707b6024816e1f46542b61918a6327a570dc
  18. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  19. CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS     NAMES
  20. c703b5b1911f   centos    "/bin/sh -c 'while t…"   13 seconds ago   Up 10 seconds             pedantic_banach
  21. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker logs -tf --tail 10 c703b5b1911f
  22. 2020-12-27T03:34:07.255599560Z hi
  23. 2020-12-27T03:34:12.257641517Z hi
  24. 2020-12-27T03:34:17.259706294Z hi
  25. 2020-12-27T03:34:22.261693707Z hi
  26. 2020-12-27T03:34:27.262609289Z hi
  27. 2020-12-27T03:34:32.267862677Z hi
  28. 2020-12-27T03:34:37.270382873Z hi
  29. 2020-12-27T03:34:42.272414182Z hi
  30. 2020-12-27T03:34:47.274823243Z hi
  31. 2020-12-27T03:34:52.277419274Z hi
复制代码
10.4 2 查看容器中进程信息
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker top c703b5b1911f
  2. UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
  3. root                11156               11135               0                   11:31               ?                   00:00:00            /bin/sh -c while true;do echo hi;sleep 5;done
  4. root                11886               11156               0                   11:43               ?                   00:00:00            /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 5
复制代码
10.4.3 查看容器的元数据
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker inspect 容器id
复制代码
10.4.4 进入当前正在运行的容器
因为通常我们的容器都是使用后台方式来运行的,有时需要进入容器修改配置
方式一:

  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it c703b5b1911f /bin/bash
  2. [root@c703b5b1911f /]# ls
  3. bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
  4. [root@c703b5b1911f /]# ps -ef      
  5. UID        PID  PPID  C STIME TTY          TIME CMD
  6. root         1     0  0 03:31 ?        00:00:00 /bin/sh -c while true;do echo hi;sleep 5;done
  7. root       279     0  0 03:54 pts/0    00:00:00 /bin/bash
  8. root       315     1  0 03:56 ?        00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 5
  9. root       316   279  0 03:56 pts/0    00:00:00 ps -ef
复制代码
方式二:
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker attach c703b5b1911f
复制代码
docker exec 进入容器后开启一个新的终端,可以在里面操作
docker attach 进入容器正在执行的终端,不会启动新的进程
10.4.5 拷贝操作
拷贝操作的命令如下:
  1. #拷贝容器的文件到主机中
  2. docker cp 容器id:容器内路径  目的主机路径

  3. #拷贝宿主机的文件到容器中
  4. docker cp 目的主机路径 容器id:容器内路径
复制代码
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it c703b5b1911f /bin/bash
  2. [root@c703b5b1911f /]# cd home
  3. [root@c703b5b1911f home]# ls
  4. #touch 新建文件
  5. [root@c703b5b1911f home]# touch test.java
  6. [root@c703b5b1911f home]# ls
  7. test.java
  8. [root@c703b5b1911f home]# exit
  9. exit
  10. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  11. CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS     NAMES
  12. c703b5b1911f   centos    "/bin/sh -c 'while t…"   35 minutes ago   Up 35 minutes             pedantic_banach
  13. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker cp c703b5b1911f:/home/test.java /home
  14. [root@iZwz99sm8v95sckz8bd2c4Z ~]# ls /home
  15. hai  pan  test.java
复制代码
image.png
11. 图形化管理工具Portaniner安装
Portaniner是Docker的图形化管理工具,类似的工具还有Rancher(CI/CD再用)
下载运行Portaniner镜像并运行,设置本机映射端口为8088
  1. [root@localhost conf]# docker run -d -p 8088:9000 --restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer
  2. Unable to find image 'portainer/portainer:latest' locally
  3. latest: Pulling from portainer/portainer
  4. 94cfa856b2b1: Pull complete
  5. 49d59ee0881a: Pull complete
  6. a2300fd28637: Pull complete
  7. Digest: sha256:fb45b43738646048a0a0cc74fcee2865b69efde857e710126084ee5de9be0f3f
  8. Status: Downloaded newer image for portainer/portainer:latest
  9. 8c525a0137be22965bd1e3944da622a2c4248f8ad20883f4b3ea4f8a6b11e163
  10. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  11. CONTAINER ID   IMAGE                 COMMAND        CREATED         STATUS         PORTS                    NAMES
  12. 7789d4505a00   portainer/portainer   "/portainer"   6 seconds ago   Up 5 seconds   0.0.0.0:8088->9000/tcp   quirky_sinoussi
复制代码
第一次登录设置admin用户的密码
image.png
如果是阿里云服务器记得设置安全组,选择连接本地的Docker,整体界面预览如下图:
image.png
12. Docker镜像详解
12.1 什么是镜像
镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需要的所有内容,包括代码,运行时(一个程序在运行或者在被执行的依赖)、库,环境变量和配置文件。

12.2 Docker镜像加载原理
Docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统是UnionFS联合文件系统。

image.png
12.3 分层理解
image.png

  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker image inspect nginx:latest
  2. [
  3.     {
  4.         "Id": "sha256:ae2feff98a0cc5095d97c6c283dcd33090770c76d63877caa99aefbbe4343bdd",
  5.         "RepoTags": [
  6.             "nginx:latest"
  7.         ],
  8.         "RepoDigests": [
  9.             "nginx@sha256:4cf620a5c81390ee209398ecc18e5fb9dd0f5155cd82adcbae532fec94006fb9"
  10.         ],
  11.         "Parent": "",
  12.         "Comment": "",
  13.         "Created": "2020-12-15T20:21:00.007674532Z",
  14.         "Container": "4cc5da85f27ca0d200407f0593422676a3bab482227daee044d797d1798c96c9",
  15.         "ContainerConfig": {
  16.             "Hostname": "4cc5da85f27c",
  17.             "Domainname": "",
  18.             "User": "",
  19.             "AttachStdin": false,
  20.             "AttachStdout": false,
  21.             "AttachStderr": false,
  22.             "ExposedPorts": {
  23.                 "80/tcp": {}
  24.             },
  25.             "Tty": false,
  26.             "OpenStdin": false,
  27.             "StdinOnce": false,
  28.             "Env": [
  29.                 "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
  30.                 "NGINX_VERSION=1.19.6",
  31.                 "NJS_VERSION=0.5.0",
  32.                 "PKG_RELEASE=1~buster"
  33.             ],
  34.             "Cmd": [
  35.                 "/bin/sh",
  36.                 "-c",
  37.                 "#(nop) ",
  38.                 "CMD ["nginx" "-g" "daemon off;"]"
  39.             ],
  40.             "Image": "sha256:13bffe371b56f4aeed88218ec17d0c6f653a83b49bd3e211fc8cfa2ca5d7a3d3",
  41.             "Volumes": null,
  42.             "WorkingDir": "",
  43.             "Entrypoint": [
  44.                 "/docker-entrypoint.sh"
  45.             ],
  46.             "OnBuild": null,
  47.             "Labels": {
  48.                 "maintainer": "NGINX Docker Maintainers <docker-maint@nginx.com>"
  49.             },
  50.             "StopSignal": "SIGQUIT"
  51.         },
  52.         "DockerVersion": "19.03.12",
  53.         "Author": "",
  54.         "Config": {
  55.             "Hostname": "",
  56.             "Domainname": "",
  57.             "User": "",
  58.             "AttachStdin": false,
  59.             "AttachStdout": false,
  60.             "AttachStderr": false,
  61.             "ExposedPorts": {
  62.                 "80/tcp": {}
  63.             },
  64.             "Tty": false,
  65.             "OpenStdin": false,
  66.             "StdinOnce": false,
  67.             "Env": [
  68.                 "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
  69.                 "NGINX_VERSION=1.19.6",
  70.                 "NJS_VERSION=0.5.0",
  71.                 "PKG_RELEASE=1~buster"
  72.             ],
  73.             "Cmd": [
  74.                 "nginx",
  75.                 "-g",
  76.                 "daemon off;"
  77.             ],
  78.             "Image": "sha256:13bffe371b56f4aeed88218ec17d0c6f653a83b49bd3e211fc8cfa2ca5d7a3d3",
  79.             "Volumes": null,
  80.             "WorkingDir": "",
  81.             "Entrypoint": [
  82.                 "/docker-entrypoint.sh"
  83.             ],
  84.             "OnBuild": null,
  85.             "Labels": {
  86.                 "maintainer": "NGINX Docker Maintainers <docker-maint@nginx.com>"
  87.             },
  88.             "StopSignal": "SIGQUIT"
  89.         },
  90.         "Architecture": "amd64",
  91.         "Os": "linux",
  92.         "Size": 132935043,
  93.         "VirtualSize": 132935043,
  94.         "GraphDriver": {
  95.             "Data": {
  96.                 "LowerDir": "/var/lib/docker/overlay2/cb791e78a08db7091bf2ce1d78603f1758f52199e57f1805156fe30e39067aae/diff:/var/lib/docker/overlay2/1e73a72b25af68ee9abf4eb443f778d31226e12e9af428fcc14c7b044c83b258/diff:/var/lib/docker/overlay2/88c9c01762f2af8327db65d0b0d4a64785e87c9c2ab76c62e7d03619db03a985/diff:/var/lib/docker/overlay2/7304ab112ac4a9cb91fc6f74730be28fecbe19f042e92d321aa9181424cc4b2e/diff",
  97.                 "MergedDir": "/var/lib/docker/overlay2/48b288740bbb2b07b41ed43a4d17a005c46b08d3357d2960b5ef7db4b2de6618/merged",
  98.                 "UpperDir": "/var/lib/docker/overlay2/48b288740bbb2b07b41ed43a4d17a005c46b08d3357d2960b5ef7db4b2de6618/diff",
  99.                 "WorkDir": "/var/lib/docker/overlay2/48b288740bbb2b07b41ed43a4d17a005c46b08d3357d2960b5ef7db4b2de6618/work"
  100.             },
  101.             "Name": "overlay2"
  102.         },
  103.         "RootFS": {
  104.             "Type": "layers",
  105.             "Layers": [
  106.                 "sha256:87c8a1d8f54f3aa4e05569e8919397b65056aa71cdf48b7f061432c98475eee9",
  107.                 "sha256:5c4e5adc71a82a96f02632433de31c998c5a9e2fccdcbaee780ae83158fac4fa",
  108.                 "sha256:7d2b207c26790f693ab1942bbe26af8e2b6a14248969e542416155a912fec30d",
  109.                 "sha256:2c7498eef94aef8c40d106f3e42f7da62b3eee8fd36012bf7379becc4cd639a2",
  110.                 "sha256:4eaf0ea085df254fd5d2beba4e2c11db70a620dfa411a8ad44149e26428caee4"
  111.             ]
  112.         },
  113.         "Metadata": {
  114.             "LastTagTime": "0001-01-01T00:00:00Z"
  115.         }
  116.     }
  117. ]
复制代码
这里指示了分层信息:
  1.         "RootFS": {
  2.             "Type": "layers",
  3.             "Layers": [
  4.                 "sha256:87c8a1d8f54f3aa4e05569e8919397b65056aa71cdf48b7f061432c98475eee9",
  5.                 "sha256:5c4e5adc71a82a96f02632433de31c998c5a9e2fccdcbaee780ae83158fac4fa",
  6.                 "sha256:7d2b207c26790f693ab1942bbe26af8e2b6a14248969e542416155a912fec30d",
  7.                 "sha256:2c7498eef94aef8c40d106f3e42f7da62b3eee8fd36012bf7379becc4cd639a2",
  8.                 "sha256:4eaf0ea085df254fd5d2beba4e2c11db70a620dfa411a8ad44149e26428caee4"
  9.             ]
  10.         },
复制代码
image.png
image.png
image.png
image.png
12.4 提交镜像
使用docker commit 命令提交容器成为一个新的版本
docker commit -m=“提交的描述信息”  -a="作者" 容器id 目标镜像名:[TAG]

由于默认的Tomcat镜像的webapps文件夹中没有任何内容,需要从webapps.dist中拷贝文件到webapps文件夹。下面自行制作镜像:就是从webapps.dist中拷贝文件到webapps文件夹下,并提交该镜像作为一个新的镜像。使得该镜像默认的webapps文件夹下就有文件。具体命令如下:

  1. #1.复制文件夹
  2. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -it tomcat /bin/bash
  3. root@2a3bf3eaa2e4:/usr/local/tomcat# cd webapps
  4. root@2a3bf3eaa2e4:/usr/local/tomcat/webapps# ls
  5. root@2a3bf3eaa2e4:/usr/local/tomcat/webapps# cd ../
  6. root@2a3bf3eaa2e4:/usr/local/tomcat# cp -r webapps.dist/* webapps
  7. root@2a3bf3eaa2e4:/usr/local/tomcat# cd webapps
  8. root@2a3bf3eaa2e4:/usr/local/tomcat/webapps# ls
  9. ROOT  docs  examples  host-manager  manager
  10. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  11. CONTAINER ID   IMAGE                 COMMAND        CREATED         STATUS         PORTS                    NAMES
  12. 2a3bf3eaa2e4   tomcat                "/bin/bash"    4 minutes ago   Up 4 minutes   8080/tcp                 competent_torvalds
  13. 7789d4505a00   portainer/portainer   "/portainer"   24 hours ago    Up 24 hours    0.0.0.0:8088->9000/tcp   quirky_sinoussi
  14. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it 2a3bf3eaa2e4 /bin/bash
  15. root@2a3bf3eaa2e4:/usr/local/tomcat# cd webapps
  16. root@2a3bf3eaa2e4:/usr/local/tomcat/webapps# ls
  17. ROOT  docs  examples  host-manager  manager
  18. root@2a3bf3eaa2e4:/usr/local/tomcat/webapps# cd ../
  19. root@2a3bf3eaa2e4:/usr/local/tomcat# read escape sequence
  20. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  21. CONTAINER ID   IMAGE                 COMMAND        CREATED         STATUS         PORTS                    NAMES
  22. 2a3bf3eaa2e4   tomcat                "/bin/bash"    8 minutes ago   Up 8 minutes   8080/tcp                 competent_torvalds
  23. 7789d4505a00   portainer/portainer   "/portainer"   24 hours ago    Up 24 hours    0.0.0.0:8088->9000/tcp   quirky_sinoussi
  24. #2.提交镜像作为一个新的镜像

  25. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker commit -m="add webapps" -a="Ethan" 2a3bf3eaa2e4 mytomcat:1.0
  26. sha256:f189aac861de51087af5bc88a5f1de02d9574e7ee2d163c647dd7503a2d3982b
  27. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker images
  28. REPOSITORY            TAG       IMAGE ID       CREATED         SIZE
  29. mytomcat              1.0       f189aac861de   7 seconds ago   653MB
  30. mysql                 5.7       f07dfa83b528   6 days ago      448MB
  31. tomcat                latest    feba8d001e3f   10 days ago     649MB
  32. nginx                 latest    ae2feff98a0c   12 days ago     133MB
  33. centos                latest    300e315adb2f   2 weeks ago     209MB
  34. portainer/portainer   latest    62771b0b9b09   5 months ago    79.1MB
  35. elasticsearch         7.6.2     f29a1ee41030   9 months ago    791MB

  36. #3.运行容器

  37. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -it mytomcat:1.0 /bin/bash
  38. root@1645774d4605:/usr/local/tomcat# cd webapps
  39. root@1645774d4605:/usr/local/tomcat/webapps# ls
  40. ROOT  docs  examples  host-manager  manager
  41. wz99sm8v95sckz8bd2c4Z ~]# docker images
  42. REPOSITORY            TAG       IMAGE ID       CREATED         SIZE
  43. mytomcat              1.0       f189aac861de   7 seconds ago   653MB
  44. mysql                 5.7       f07dfa83b528   6 days ago      448MB
  45. tomcat                latest    feba8d001e3f   10 days ago     649MB
  46. nginx                 latest    ae2feff98a0c   12 days ago     133MB
  47. centos                latest    300e315adb2f   2 weeks ago     209MB
  48. portainer/portainer   latest    62771b0b9b09   5 months ago    79.1MB
  49. elasticsearch         7.6.2     f29a1ee41030   9 months ago    791MB
复制代码
13. 常用容器部署
13.1 Nginx部署
(1)搜索并下载镜像
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search nginx
  2. NAME                               DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
  3. nginx                              Official build of Nginx.                        14207     [OK]      
  4. jwilder/nginx-proxy                Automated Nginx reverse proxy for docker con…   1932                 [OK]
  5. richarvey/nginx-php-fpm            Container running Nginx + PHP-FPM capable of…   797                  [OK]
  6. linuxserver/nginx                  An Nginx container, brought to you by LinuxS…   137                  
  7. jc21/nginx-proxy-manager           Docker container for managing Nginx proxy ho…   123                  
  8. tiangolo/nginx-rtmp                Docker image with Nginx using the nginx-rtmp…   107                  [OK]
  9. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull nginx
  10. Using default tag: latest
  11. latest: Pulling from library/nginx
  12. 6ec7b7d162b2: Already exists
  13. cb420a90068e: Pull complete
  14. 2766c0bf2b07: Pull complete
  15. e05167b6a99d: Pull complete
  16. 70ac9d795e79: Pull complete
  17. Digest: sha256:4cf620a5c81390ee209398ecc18e5fb9dd0f5155cd82adcbae532fec94006fb9
  18. Status: Downloaded newer image for nginx:latest
  19. docker.io/library/nginx:latest
  20. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker images;
  21. REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
  22. mysql        5.7       f07dfa83b528   5 days ago    448MB
  23. nginx        latest    ae2feff98a0c   11 days ago   133MB
  24. centos       latest    300e315adb2f   2 weeks ago   209MB
复制代码
可以到dockerhub官网查看Nginx的详细版本信息 :https://hub.docker.com/_/nginx
(2)运行测试
  1. docker run -d --name nginx01 -p 3334:80 nginx

  2. -d 后台运行
  3. --name 给容器命名
  4. -p 3334:80 将宿主机的端口3334映射到该容器的80端口
复制代码
运行结果:
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it nginx01 /bin/bash
  2. Error: No such container: nginx01
  3. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -d --name nginx01 -p 3334:80 nginx
  4. 20c896637ff5de8be835797109d62ee2465e28d9d716be5a8d550ef7d547fcf5
  5. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  6. CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                  NAMES
  7. 20c896637ff5   nginx     "/docker-entrypoint.…"   7 seconds ago   Up 5 seconds   0.0.0.0:3334->80/tcp   nginx01
复制代码
image.png
(4)访问测试
本地主机访问测试,curl命令发起请求,如果使用阿里云服务器需要设置安全组。
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  2. CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                  NAMES
  3. 20c896637ff5   nginx     "/docker-entrypoint.…"   7 minutes ago   Up 7 minutes   0.0.0.0:3334->80/tcp   nginx01
  4. [root@iZwz99sm8v95sckz8bd2c4Z ~]# curl localhost:3334
  5. <!DOCTYPE html>
  6. <html>
  7. <head>
  8. <title>Welcome to nginx!</title>
  9. <style>
  10.     body {
  11.         width: 35em;
  12.         margin: 0 auto;
  13.         font-family: Tahoma, Verdana, Arial, sans-serif;
  14.     }
  15. </style>
  16. </head>
  17. <body>
  18. <h1>Welcome to nginx!</h1>
  19. <p>If you see this page, the nginx web server is successfully installed and
  20. working. Further configuration is required.</p>

  21. <p>For online documentation and support please refer to
  22. <a >nginx.org</a>.<br/>
  23. Commercial support is available at
  24. <a >nginx.com</a>.</p>

  25. <p><em>Thank you for using nginx.</em></p>
  26. </body>
  27. </html>
复制代码
5)安装vim
我们使用Nginx往往需要编写配置文件,但是Nginx官方镜像没有安装vim,需要我们手动进行安装。使用以下命令进行安装:
apt-get install vim

如果执行上述命令出现提示:
  1.         Reading package lists... Done
  2.         Building dependency tree      
  3.         Reading state information... Done
  4.         E: Unable to locate package vim
复制代码
则需要先同步 /etc/apt/sources.list 和 /etc/apt/sources.list.d 中列出的源的索引,这样才能获取到最新的软件包。执行以下命令来更新:

apt-get update

更新完毕再安装即可。我们修改了配置文件,只要重新启动容器docker restart 容器id,改动就可以生效了。
解决vim在终端不能复制的问题:在vim 中输入 :set mouse=r。
拓展:启动项目并设置数据卷,为避免nginx因为修改配置文件导致的错误而无法启动容器,我们可以通过cp命令覆盖配置文件,但是设置数据卷会更为方便。启动Nginx容器的同时设置数据卷的命令:

  1. docker run
  2. --name my_nginx
  3. -d -p 80:80  
  4. -v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
  5. -v /data/nginx/log:/var/log/nginx
  6. -v /data/nginx/html:/usr/share/nginx/html
  7. nginx
复制代码
参数说明:
第一个-v:挂载nginx的主配置文件,以方便在宿主机上直接修改容器的配置文件
第二个-v:挂载容器内nginx的日志,容器运行起来之后,可以直接在宿主机的这个目录中查看nginx日志
第三个-v:挂载静态页面目录

13.2 Tomcat部署
(1)下载并运行

  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull tomcat
  2. Using default tag: latest
  3. latest: Pulling from library/tomcat
  4. 6c33745f49b4: Pull complete
  5. ef072fc32a84: Pull complete
  6. c0afb8e68e0b: Pull complete
  7. d599c07d28e6: Pull complete
  8. e8a829023b97: Pull complete
  9. d04be46a31d1: Pull complete
  10. db6007c69c35: Pull complete
  11. e4ad4c894bce: Pull complete
  12. 248895fda357: Pull complete
  13. 277059b4cba2: Pull complete
  14. Digest: sha256:57dae7dfb9b62a413cde65334c8a18893795cac70afc3be589c8336d8244655d
  15. Status: Downloaded newer image for tomcat:latest
  16. docker.io/library/tomcat:latest
  17. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -d -p 3335:8080 --name tomcat01 tomcat
  18. 7136295a6082cb0f805b025a1471bde02ead4864be3e2c9dcd337b1dde0a3113

复制代码
(2)进入容器
1.容器中的命令是少了
2.阿里云镜像默认下载的是最小的镜像,保证最小的运行环境。

  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it tomcat01 /bin/bash
  2. root@7136295a6082:/usr/local/tomcat# ls
  3. BUILDING.txt  CONTRIBUTING.md  LICENSE        NOTICE        README.md  RELEASE-NOTES  RUNNING.txt  bin  conf  lib  logs  native-jni-lib  temp  webapps  webapps.dist  work
  4. root@7136295a6082:/usr/local/tomcat# cd webapps.dist
  5. root@7136295a6082:/usr/local/tomcat/webapps.dist# ls
  6. ROOT  docs  examples  host-manager  manager
  7. root@7136295a6082:/usr/local/tomcat/webapps.dist# cd ROOT
  8. root@7136295a6082:/usr/local/tomcat/webapps.dist/ROOT# ls
  9. RELEASE-NOTES.txt  WEB-INF  asf-logo-wide.svg  bg-button.png  bg-middle.png  bg-nav.png  bg-upper.png  favicon.ico  index.jsp  tomcat.css  tomcat.svg
  10. root@7136295a6082:/usr/local/tomcat/webapps.dist/ROOT# cd ../../
  11. root@7136295a6082:/usr/local/tomcat# cd webapps
  12. root@7136295a6082:/usr/local/tomcat/webapps# ls
  13. root@7136295a6082:/usr/local/tomcat/webapps# cp -r /usr/local/tomcat/webapps.dist/* /usr/local/tomcat/webapps/
  14. root@7136295a6082:/usr/local/tomcat/webapps# ls
  15. ROOT  docs  examples  host-manager  manager
  16. root@7136295a6082:/usr/local/tomcat/webapps# exit
  17. exit
复制代码
(3)访问测试
  1. [root@iZwz99sm8v95sckz8bd2c4Z ~]# curl localhost:3335

  2. <!DOCTYPE html>
  3. <html lang="en">
  4.     <head>
  5.         <meta charset="UTF-8" />
  6.         <title>Apache Tomcat/9.0.41</title>
  7.         <link href="favicon.ico" rel="icon" type="image/x-icon" />
  8.         <link href="tomcat.css" rel="stylesheet" type="text/css" />
  9.     </head>

  10.     <body>
  11.         <div id="wrapper">
  12.             <div id="navigation" class="curved container">
  13.                 <span id="nav-home"><a >Home</a></span>
  14.                 <span id="nav-hosts"><a href="/docs/">Documentation</a></span>
  15.                 <span id="nav-config"><a href="/docs/config/">Configuration</a></span>
  16.                 <span id="nav-examples"><a href="/examples/">Examples</a></span>
  17.                 <span id="nav-wiki"><a >Wiki</a></span>
  18.                 <span id="nav-lists"><a >Mailing Lists</a></span>
  19.                 <span id="nav-help"><a >Find Help</a></span>
  20.                 <br class="separator" />
  21.             </div>
复制代码
13.3 ElasticSearch部署
添加 ’-e ES_JAVA_OPTS=“-Xms128m -Xmx512m” ‘ 配置ElasticSearch的虚拟机占用的内存大小。
docker stats 查看资源占用情况
  1. $ docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms128m -Xmx512m" elasticsearch:7.6.2


  2. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -d --name elasticsearch01 -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms128m -Xmx512m" elasticsearch:7.6.2
  3. 3b8cd4991814896c523ee67b84ce198e32bd82b1a62d512b198138a58ca946f1
  4. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
  5. CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS         PORTS                                            NAMES
  6. 3b8cd4991814   elasticsearch:7.6.2   "/usr/local/bin/dock…"   10 seconds ago   Up 6 seconds   0.0.0.0:9200->9200/tcp, 0.0.0.0:9300->9300/tcp   elasticsearch01
  7. [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker stats
复制代码
13.4 MySQL部署
(1)下载并运行

  1. #拉取并运行容器
  2. docker run -d --name mysql-5.7 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
复制代码
参数说明:
  1. -p 3306:3306 :映射容器服务的 3306 端口到宿主机的 3306 端口,外部主机可以直接通过 宿主机ip:3306 访问到 MySQL 的服务。
  2. MYSQL_ROOT_PASSWORD=123456:设置 MySQL 服务 默认账号root 用户的密码。
复制代码
(2)进入容器查看MySQL服务
进入容器,并通过账号root查看MySQL服务能否正常连接。

  1. docker exec -it 9b3aad6819ff /bin/bash
  2. mysql -h localhost -u root -p
复制代码
image.png
免责声明:
1,海欣资源网所发布的资源由网友上传和分享,不保证信息的正确性和完整性,且不对因信息的不正确或遗漏导致的任何损失或损害承担责任。
2,海欣资源网的资源来源于网友分享,仅限用于学习交流和测试研究目的,不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
3,海欣资源网所发布的资源由网友上传和分享,版权争议与本站无关,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。
4,如果您喜欢,请支持正版,购买正版,得到更好的正版服务,如有侵权,请联系我们删除并予以真诚的道歉,联系方式邮箱 haixinst@qq.com
海欣资源-企业信息化分享平台。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

0

关注

0

粉丝

28

主题
热度排行
回复排行
最新贴子

Archiver|手机版|海欣资源 ( 湘ICP备2021008090号-1 )|网站地图

GMT+8, 2024-9-16 11:36 , Gzip On, MemCached On.

免责声明:本站所发布的资源和文章均来自网络,仅限用于学习交流和测试研究目的,不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。 本站信息来自网络,版权争议与本站无关,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 如果您喜欢,请支持正版,购买正版,得到更好的正版服务,如有侵权,请联系我们删除并予以真诚的道歉。