1、Docker概述
1.1 基本介绍
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。
容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版),我们用社区版就可以了。官网:docs.docker.com/
2.2 应用场景
- Web 应用的自动化打包和发布。
- 自动化测试和持续集成、发布。
- 在服务型环境中部署和调整数据库或其他的后台应用。
- 从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
2.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.每个容器都是相互隔离的,每个容器都有属于自己的文件系统,互不影响。
容器化带来的好处:
- 应用更快的交付和部署
- 更便捷的升级和扩缩容
- 更简单的系统运维
- 更高效的计算资源利用
3、Docker的基本组成
镜像images:
docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像==>run==>tomcat01容器,通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中)
容器container
Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的
启动,停止,删除,基本命令
目前就可以把这个容器理解为就是一个简易的linux系统
仓库repository
仓库就是存放镜像的地方
仓库分为共有仓库私有仓库
Docker Hub(默认是国外的)
4、Docker的安装
查看系统的内核:uname -r
1 | shell复制代码[root@iZuf682v6un2qg2cl6bgijZ ~]# uname -r |
Docker安装步骤
- 卸载旧版本
1 | shell复制代码yum remove docker \ |
- 下载需要的安装包
1 | shell复制代码yum install -y yum-utils |
- 设置镜像的仓库
1 | shell复制代码yum-config-manager \ |
- 更新yum软件包索引
1 | shell复制代码yum makecache fast |
- 安装docker相关的配置
docker-ce 是社区版,docker-ee 企业版
1 | shell复制代码yum install docker-ce docker-ce-cli containerd.io |
- 启动Docker
1 | shell复制代码systemctl start docker |
5、Docker的卸载
1 | shell复制代码# 1. 卸载依赖 |
6、配置阿里云镜像加速
- 进入阿里云官网,搜索容器服务
- 依次执行官方的这四条命令
1 | shell复制代码sudo mkdir -p /etc/docker |
7、Docker容器运行流程
8、底层原理
Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socker从客户端访问!Docker Server接收到Docker-Client的指令,就会执行这个指令!
Docker为什么比VM Ware快?
1、Docker比虚拟机更少的抽象层
2、docker利用宿主机的内核,VM需要的是Guest OS
Docker新建一个容器的时候,不需要像虚拟机一样重新加载一个操作系统内核,直接利用宿主机的操作系统,而虚拟机是需要加载Guest OS。Docker和VM的对比如下:
9、Docker常用命令
9.1 基础命令
1 | shell复制代码docker version # 查看docker的版本信息 |
命令的帮助文档地址:docs.docker.com/engine/refe…
9.2 镜像命令
- docker images 查看本地主机的所有镜像
1 | shell复制代码[root@iZuf682v6un2qg2cl6bgijZ ~]# docker images |
- docker search 搜索镜像
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search mysql |
- docker pull 镜像名[:tag] 下载镜像
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull mysql |
指定版本下载
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull mysql:5.7 |
- docker rmi 删除镜像
1 | shell复制代码#1.删除指定的镜像id |
9.3 容器命令
如拉取一个centos容器docker pull centos
运行容器
1 | shell复制代码docker run [可选参数] image |
进入容器
1 | shell复制代码[root@iZuf682v6un2qg2cl6bgijZ ~]# docker run -it centos /bin/bash |
退出容器
1 | shell复制代码#exit 停止并退出容器(后台方式运行则仅退出) |
列出运行过的容器
1 | shell复制代码#docker ps |
删除容器
1 | shell复制代码docker rm 容器id #删除指定的容器,不能删除正在运行的容器,强制删除使用 rm -f |
启动和停止容器
1 | shell复制代码docker start 容器id #启动容器 |
9.4 其他常用命令
1. 日志的查看
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker logs --help |
2. 查看容器中进程信息
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker top c703b5b1911f |
3. 查看容器的元数据
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker inspect 容器id |
4. 进入当前正在运行的容器
因为通常我们的容器都是使用后台方式来运行的,有时需要进入容器修改配置
方式一:
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it c703b5b1911f /bin/bash |
方式二:
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker attach c703b5b1911f |
docker exec 进入容器后开启一个新的终端,可以在里面操作
docker attach 进入容器正在执行的终端,不会启动新的进程
拷贝容器的文件到主机中
docker cp 容器id:容器内路径 目的主机路径
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it c703b5b1911f /bin/bash |
10、图形化管理工具Portaniner
Portaniner是Docker的图形化管理工具,类似的工具还有Rancher(CI/CD再用)
下载运行Portaniner镜像并运行,设置本机映射端口为8088
1 | shell复制代码[root@localhost conf]# docker run -d -p 8088:9000 --restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer |
第一次登录设置admin用户的密码
如果是阿里云服务器记得设置安全组,选择连接本地的Docker,整体界面预览如下图:
11、Docker镜像详解
11.1 什么是镜像
镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需要的所有内容,包括代码,运行时(一个程序在运行或者在被执行的依赖)、库,环境变量和配置文件。
11.2 Docker镜像加载原理
Docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统是UnionFS联合文件系统。
11.3 分层理解
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker image inspect nginx:latest |
这里指示了分层信息:
1 | shell复制代码 "RootFS": { |
11.4 提交镜像
1 | shell复制代码使用docker commit 命令提交容器成为一个新的版本 |
由于默认的Tomcat镜像的webapps文件夹中没有任何内容,需要从webapps.dist中拷贝文件到webapps文件夹。下面自行制作镜像:就是从webapps.dist中拷贝文件到webapps文件夹下,并提交该镜像作为一个新的镜像。使得该镜像默认的webapps文件夹下就有文件。具体命令如下:
1 | shell复制代码#1.复制文件夹 |
12、常用容器部署
12.1 Nginx部署
(1)搜索并下载镜像
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search nginx |
可以到dockerhub官网查看Nginx的详细版本信息 :hub.docker.com/_/nginx
(2)运行测试
1 | shell复制代码docker run -d --name nginx01 -p 3334:80 nginx |
运行结果:
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it nginx01 /bin/bash |
(3) 配置文件
进入容器,自定义配置文件
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it nginx01 /bin/bash |
(4) 访问测试
本地主机访问测试,curl命令发起请求,如果使用阿里云服务器需要设置安全组。
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps |
12.2 Tomcat部署
(1)下载并运行
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull tomcat |
(2) 进入容器
1.容器中的命令是少了
2.阿里云镜像默认下载的是最小的镜像,保证最小的运行环境。
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it tomcat01 /bin/bash |
(3)访问测试
1 | shell复制代码[root@iZwz99sm8v95sckz8bd2c4Z ~]# curl localhost:3335 |
12.3 ElasticSearch部署
添加 ’-e ES_JAVA_OPTS=”-Xms128m -Xmx512m” ‘ 配置ElasticSearch的虚拟机占用的内存大小。
docker stats 查看资源占用情况
1 | shell复制代码$ 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 |
本文转载自: 掘金