Docker概述
Docker为什么出现?
一款产品:开发–上线 两套环境!应用环境,应用配置!
开发—运维。问题:我在我电脑上可以运行!版本更新,导致服务不可用!对于运维来说,考验十分大?
环境配置十分麻烦,每个机器都要部署环境(集群Redis、ES、Hadoop…)!费时费力。
发布一个项目(jar+(Redis Mysql jdk ES)),项目能不能带上环境安装打包!
之前在服务器配置一个应用环境 Redis Mysql jdk ES Hadoop,配置超级麻烦,不能够跨平台。
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程做完!
java —apk–发布(应用商店)—张三使用apk–安装即可用!
Java—jar(环境)—打包项目带上环境(镜像)—(Docker仓库:商店)----下载发布的镜像–直接运行即可!
Docker给以上问题,提出了解决方案!
Docker的思想来自于集装箱!
JRE–多个应用(端口冲突)—原来都是交叉的
隔离:Docker核心思想!打包装箱!每个箱子是互相隔离的
Docker通过隔离机制,可以将服务器利用到极致
本质:所有技术都是因为出现了一些问题,需要去解决,才去学习
Docker的历史
2010年,几个搞IT的年轻人,就在美国成立了一家公司dotCloud
做一些pass的云计算服务!LXC有关的容器技术!
他们将自己的技术(容器化技术)命名就是Docker!
Docker刚刚诞生的时候,没有引起行业的注意!dotCloud,就活不下去!
2013年,Docker开源!
越来越多的人发现了docker的优点!火了,Docker每个月都会更新一个版本!
2014年4月9日,Docker1.0发布!
Docker为什么这么火?十分的轻巧!
在容器技术出现之前,我们都使用虚拟机技术!
虚拟机:在windows中装一个Vmware,通过这个软件我们可以虚拟出来一台或多台电脑!笨重!
虚拟机也属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!
vm,linux centos原生镜像(一个电脑) 隔离,需要开启多个虚拟机!几个G 几分钟
docker,隔离。镜像(最核心的环境 4m+jdk+mysql)十分的小巧,运行镜像就可以了!小巧! 几个M KB 秒级启动
到现在,所有开发人员都必须要学会Docker!
聊聊Docker
Docker是基于go语言开发的!开源项目
官网!https://www.docker.com/
文档!https://docs.docker.com/ 超级详细
仓库地址https://hub.docker.com/
Docker能干嘛!
之前的虚拟机技术
虚拟机技术缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢!
容器化技术
容器化技术不是模拟的一个完整的操作系统
比较Docker和虚拟机技术的不同:
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
- 容器内的应用是直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
- 每个容器间互相隔离,每个容器内都有一个属于自己的文件系统,互不影响
DevOps(开发、运维)
更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用了Docker之后,我们部署应用就和搭积木一样
项目打包为一个镜像,扩展 服务器A!服务器B
更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的
更高效的计算资源利用
1核2g的服务器!Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例!容器的性能可以被压榨到极致
Docker安装
Docker的基本组成
镜像(image):
docker镜像就好比是一个模版,可以通过这个模版来创建容器服务,tomcat镜像===》 run===》tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)
容器(container):
Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。
启动,停止,删除,基本命令!
目前就可以把这个容器理解为一个简易的linux系统
仓库(repository):
仓库就是存放镜像的地方!
仓库分为公有仓库和私有仓库!
Docker Hub(默认是国外的)
阿里云。。。都有容器服务器(配置镜像加速!)
安装docker
环境准备
1、需要会一点linux的基础
2、CentOS7
3、使用Xshell连接远程服务器进行操作!
环境查看
# 系统内核
[root@hadoop105 /]# uname -r
5.1.0-1.el7.elrepo.x86_64
[root@hadoop105 /]#
# 系统版本
[root@hadoop105 /]# cat /etc/os-release
NAME="CentOS Linux"
VERSION="7 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="7"
PRETTY_NAME="CentOS Linux 7 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:7"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"
CENTOS_MANTISBT_PROJECT="CentOS-7"
CENTOS_MANTISBT_PROJECT_VERSION="7"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="7"
安装
帮助文档:
# 1、卸载旧的版本
yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
# 2、需要的安装包
yum install -y yum-utils
# 3、设置镜像的仓库
yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo# 默认国外的
yum-config-manager \
--add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo# 推荐使用阿里云的
#更新yum软件包索引
yum makecache fast
# 4、安装docker相关的 docker-ce 社区 ee 企业版
yum install docker-ce docker-ce-cli containerd.io
# 5、启动docker
systemctl start docker
# 6、使用docker version 是否安装成功
# 7、hello-world
docker run hello-world
# 8、查看一下这个hello-world镜像
[root@hadoop105 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
daocloud.io/library/nginx latest 2622e6cca7eb 4 months ago 132MB
hello-world latest bf756fb1ae65 9 months ago 13.3kB
daocloud.io/library/tomcat 8.5.15-jre8 b8dfe9ade316 3 years ago 334MB
daocloud.io/library/mysql 5.7.4 aa5364eb3d85 6 years ago 252MB
了解:卸载docker
# 1、卸载依赖
yum remove docker-ce docker-ce-cli containerd.io
# 2、删除资源
rm -rf /var/lib/docker
# /var/lib/docker docker的默认工作路径
阿里云镜像加速
1、登陆阿里云找到容器服务
2、找到镜像加速地址
3、配置使用
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://xa2xb78w.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
回顾HelloWorld
底层原理
Docker是怎么工作的?
Docker 是一个Client -Server结构的系统,Docker的守护进程运行在主机上。通过Socket从客户端访问。
DockerServer接收到Docker-Client 的指令,就会执行这个命令。
Docker为什么比VM快?
1、Docker有着比虚拟机更少的抽象层
2、docker利用的是宿主机的内核,vm需要的是Guest OS
所以说,新建一个容器的时候,docker不需要像虚拟机一样重新加载一个操作系统,避免引导,虚拟机是加载Guest OS,分钟级别的,而docker是利用宿主机的操作系统,省略了这个复杂的过程,秒级!
之后学完所有命令,再回过头来看这段理论就会很清晰
Docker的常用命令
帮助命令
docker version #显示docker的版本信息
docker info #显示docker的系统信息,包括镜像和容器的数量
docker 命令 --help #帮助命令
帮助文档的地址:https://docs.docker.com/reference/#command-line-interfaces-clis
镜像命令
docker images查看所有本地的主机上的镜像
[root@hadoop105 /]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest bf756fb1ae65 9 months ago 13.3kB
# 解释
REPOSITORY 镜像的仓库源
TAG 镜像的标签
IMAGE ID 镜像的id
CREATED 镜像的创建时间
SIZE 镜像的大小
# 可选项
-a, --all # 列出所有镜像
-q, --quiet # 只显示镜像的id
docker search 搜索镜像
[root@hadoop105 /]# docker search mysql
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
mysql MySQL is a widely used, open-source relation… 10103 [OK]
mariadb MariaDB is a community-developed fork of MyS… 3708 [OK]
# 可选项,通过搜索过滤
--filter=STARS=3000 # 搜索出来的镜像就是STARS大于3000
[root@hadoop105 /]# docker search mysql --filter=STARS=3000
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
mysql MySQL is a widely used, open-source relation… 10103 [OK]
mariadb MariaDB is a community-developed fork of MyS… 3708 [OK]
[root@hadoop105 /]# docker search mysql --filter=STARS=5000
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
mysql MySQL is a widely used, open-source relation… 10103 [OK]
docker pull 下载镜像
# 下载镜像 docker pull 镜像名[:tag]
[root@hadoop105 /]# docker pull mysql
Using default tag: latest #如果不写tag,默认就是latest
latest: Pulling from library/mysql
bb79b6b2107f: Pull complete # 分层下载,docker image的核心 联合文件下载
49e22f6fb9f7: Pull complete
842b1255668c: Pull complete
9f48d1f43000: Pull complete
c693f0615bce: Pull complete
8a621b9dbed2: Pull complete
0807d32aef13: Pull complete
a56aca0feb17: Pull complete
de9d45fd0f07: Pull complete
1d68a49161cc: Pull complete
d16d318b774e: Pull complete
49e112c55976: Pull complete
Digest: sha256:8c17271df53ee3b843d6e16d46cff13f22c9c04d6982eb15a9a47bd5c9ac7e2d
Status: Downloaded newer image for mysql:latest #签名
docker.io/library/mysql:latest #真实地址
# 等价
docker pull mysql
docker pull docker.io/library/mysql:latest
#指定版本下载
[root@hadoop105 /]# docker pull mysql:5.7
5.7: Pulling from library/mysql
bb79b6b2107f: Already exists
49e22f6fb9f7: Already exists
842b1255668c: Already exists
9f48d1f43000: Already exists
c693f0615bce: Already exists
8a621b9dbed2: Already exists
0807d32aef13: Already exists
f15d42f48bd9: Pull complete
098ceecc0c8d: Pull complete
b6fead9737bc: Pull complete
351d223d3d76: Pull complete
Digest: sha256:4d2b34e99c14edb99cdd95ddad4d9aa7ea3f2c4405ff0c3509a29dc40bcb10ef
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7
docker rmi 删除镜像
[root@hadoop105 /]# docker rmi -f 容器id # 删除指定的容器
[root@hadoop105 /]# docker rmi -f 容器id 容器id 容器id #删除多个容器
[root@hadoop105 /]# docker rmi -f $(docker images -aq) # 删除全部的容器
容器命令
说明:有了镜像才可以创建容器,linux,下载一个centos镜像来测试
docker pull centos
新建容器并启动
docker run [可选参数] image
# 参数说明
--name="Name" 容器名字 tomcat01 tomcat02 用来区分容器
-d 后台方式运行
-it 使用交互方式运行,进入容器查看内容
-P 指定容器的端口 -p 8080:8080
-P ip:主机端口:容器端口
-P 主机端口:容器端口(常用)
-P 容器端口
容器端口
-p 随机指定端口
# 启动并进入容器
[root@hadoop105 /]# docker run -it centos /bin/bash
[root@9b861b70c610 /]#
[root@9b861b70c610 /]# ls #查看容器的centos,基础版本,很多命令都是不完善的
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var
# 从容器中退回主机
[root@9b861b70c610 /]# exit
exit
[root@hadoop105 /]# ls
bin boot dev etc ftpfile home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
列出所有运行的容器
# docker ps 命令
# 列出当前正在运行的容器
-a # 列出当前正在运行的容器,带出历史运行的容器
-n=?# 显示最近创建的容器
-q # 只显示容器的编号
[root@hadoop105 /]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6e54f39a423b daocloud.io/library/nginx:latest "/docker-entrypoint.…" 3 months ago Restarting (1) About a minute ago nginx
6d9a7cd4e9d0 daocloud.io/library/mysql:5.7.4 "/entrypoint.sh mysq…" 3 months ago Up 6 hours 0.0.0.0:3306->3306/tcp mysql
40629088ade0 daocloud.io/library/tomcat:8.5.15-jre8 "catalina.sh run" 3 months ago Up 6 hours 0.0.0.0:8080->8080/tcp tomcat
[root@hadoop105 /]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
9b861b70c610 centos "/bin/bash" 4 minutes ago Exited (0) 3 minutes ago hardcore_goldwasser
6b6a375b1228 hello-world "/hello" 22 hours ago Exited (0) 22 hours ago confident_elgamal
6e54f39a423b daocloud.io/library/nginx:latest "/docker-entrypoint.…" 3 months ago Restarting (1) 1 second ago nginx
6d9a7cd4e9d0 daocloud.io/library/mysql:5.7.4 "/entrypoint.sh mysq…" 3 months ago Up 6 hours 0.0.0.0:3306->3306/tcp mysql
40629088ade0 daocloud.io/library/tomcat:8.5.15-jre8 "catalina.sh run" 3 months ago Up 6 hours 0.0.0.0:8080->8080/tcp tomcat
退出容器
exit # 直接容器停止并退出
Ctrl+P+Q # 容器不停止退出
删除容器
docker rm 容器id # 删除指定容器,不能删除正在运行的容器,如果强制删除 rm -f
docker rm -f $(docker ps -aq) # 删除所有容器
docker ps -a -q|xargs docker rm # 删除所有容器
启动和停止容器的操作
docker start 容器id # 启动容器
docker restart 容器id # 重启容器
docker stop 容器id # 停止当前正在运行的容器
docker kill 容器id # 强制停止当前容器
常用的其他命令
后台启动容器
# 命令 docker run -d 镜像名
[root@hadoop105 ~]# docker run -d centos
# 问题docker ps,发现centos 停止了
# 常见的坑:docker 容器使用后台运行,就必须要有一个前台进程,docker发现没有应用,就会自动停止
# nginx,容器启动后,发现自己没有提供服务,就会立刻停止,就是没有程序了
查看日志
docker logs -f -t --tail 容器,没有日志
# 自己编写一段shell脚本
[root@hadoop105 /]# docker run -d centos /bin/sh -c "while true;do echo gn;sleep 1;done"
# [root@hadoop105 /]# docker ps
CONTAINER ID IMAGE
2108bee778a9 centos
# 显示日志
-tf #显示日志
--tail number # 要显示日志的条数
[root@hadoop105 /]# docker logs -tf --tail 10 2108bee778a9
查容器中的进程信息 ps
# 命令 docker top 容器id
[root@hadoop105 /]# docker top 2108bee778a9
UID PID PPID C STIME TTY TIME CMD
root 12999 12981 0 09:40 ? 00:00:00 /bin/sh -c while true;do echo gn;sleep 1;done
root 23214 12999 0 09:49 ? 00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 1
查看镜像元数据
# 命令
docker inspect 容器id
#测试
[root@hadoop105 /]# docker inspect 2108bee778a9
[
{
"Id": "2108bee778a923e00162edb5b2f9abd8efe4aac53994d6e61f04d8d89b2170c0",
"Created":