视频传送门:https://www.bilibili.com/video/BV1og4y1q7M4 记得三连
Docker概述
Docker为什么出现
一款产品:开发-上线两套环境!应用环境,应用配置!
开发—运维。问题:我在我的电脑上可以运行!版本更新,导致服务不可用!对于运维来说,考验就十分大?
环境配置是十分的麻烦,每一个机器都要部署环境(集群Redis、ES、Hadoop.…)!费时费力。
发布一个项目(jar+(Redis MySQL jdkES)),项目能不能都带上环境安装打包!
之前在服务器配置一个应用的环境Redis MySQL jdk ES Hadoop,配置超麻烦了,不能够跨平台。
Windows,最后发布到Linux!
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程做完!
java–apk–发布(应用商店)—张三使用apk—安装即可用!
java–jar(环境)—打包项目带上环境(镜像)—(Docker仓库:商店)—下载我们发布的镜像–直接运行即可!
Docker的思想就来自于集装箱!
JRE–多个应用(端囗冲突)–原来都是交叉的!
隔离:Docker核心思想!打包装箱!每个箱子是互相隔离的。
Docker通过隔离机制,可以将服务器利用到极致!
Docker历史
2010年,几个搞IT的年轻人,就在美国成立了一家公司dotcloud做一些pass的云计算服务!LXC有关的容器技术!
他们将自己的技术(容器化技术)命名就是Docker!
Docker刚刚诞生的时候,没有引起行业的注意!dotCloud,就活不下去开源开发源代码!2013年,Docker开源!Docker越来越多的人发现了docker的优点!火了,Docker每个月都会更新一个版本!2014年4月9日,Docker1.0发布!
Docker为什么这么火?十分的轻巧!
在容器技术出来之前,我们都是使用虚拟机技术!
虚拟机:在window中装一个Vmware,通过这个软件我们可以虚拟出来一台或者多台电脑!笨重!
在容器技术出来之前,我们都是使用虚拟机技术!
虚拟机:在window中装一个Vmware,通过这个软件我们可以虚拟出来一台或者多台电脑!笨重!虚拟机也是属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!
Docker能干什么
虚拟机技术缺点
1、资源占用十分多
2、冗余步骤多
3、启动慢
容器化技术不是模拟一个完整的操作系统
比较Docker和虚拟机技术的不同:
·传统虚拟机,虚拟出一套硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
·容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
·每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统,互不影响。
应用更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用了Docker之后,我们部署应用就和搭积木一样!
项目打包为一个镜像,扩展服务器A!服务器B
更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的。
更高效的计算资源利用:
Docker是内核级别的虚拟化,可以再一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致。
Docker安装
安装详细
#1、卸载旧版本,官方文档查找 https://docs.docker.com/
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
# 2、设置存储库
# 安装yum-utils包(提供yum-config-manager 实用程序)并设置稳定存储库。
sudo yum install -y yum-utils
3、#设置镜像的仓库,使用国内阿里云镜像
sudo 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 企业版
sudo yum install docker-ce docker-ce-cli containerd.io
5、#启动docker
systemctl start docker
6、#查看docker版本
docker version
7、#运行hello-world
没找到镜像,pulling向官方远程拉取镜像,签名信息表示已经拉取到
8、#查看hello-world镜像
[root@localhost admin]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest d1165f221234 3 months ago 13.3kB
9、#卸载依赖、删除资源
sudo yum remove docker-ce docker-ce-cli containerd.io
sudo rm -rf /var/lib/docker #/var/lib/docker docker默认工作路径
阿里云镜像加速
作用:使用加速器可以快速获取docker官方镜像的速度
1、登录阿里云找到容器服务 容器镜像服务
2、配置使用
sudo mkdir -p /etc/docker #新建一个目录 #给daemon.json配置一个阿里云的地址
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://he8hkd5j.mirror.aliyuncs.com"]
}
EOF
#将镜像服务和docker重启
sudo systemctl daemon-reload
sudo systemctl restart docker
回顾helloworld流程
Docker底层原理
docker是怎么工作的?
Docker是一个Client-Server结构的服务器,Docker的守护进程运行在主机上,通过Socket从客户端访问!Docker-Server接收到Docker-Client指令,就会执行这个命令。
docker为什么比VM快?
1、Docker有着比虚拟机更少的抽象层
2、docker利用的是宿主机的内核,vm需要是Guest os
所以说,新建一个容器的时候,docker不需要想虚拟机一样重新加载一个操作系统内核,避免引导。虚拟机是加载 GuestOS,分钟级别的,而docker是利用宿主机的操作系统吗,省略了这个复杂的过程,秒级!
Docker的常用命令
帮助命令
docker version #查看docker版本信息
docker info #显示docker系统信息,包括镜像和容器的数量
docker --help #帮助命令
帮助文档:https://docs.docker.com/reference/
https://docs.docker.com/engine/reference/commandline/docker/
镜像命令
https://docs.docker.com/engine/reference/commandline/images/
[root@localhost etc]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest d1165f221234 4 months ago 13.3kB
镜像的仓库源 标签 镜像ID 镜像创建时间 镜像大小
使用docker images --help 查看images参数命令
常见参数
-a:列出本地所有镜像
-q:只列出镜像ID
–digests:显示镜像的摘要信息
–no trunc:显示完整的镜像信息
-s:列出收藏数不小于指定值的镜像
#过滤docker search 中的信息
[root@localhost ~]# docker search tomcat --filter=STARS=3000
docker pull 下载镜像
docker pull 镜像名[:tag],如果不写tag,默认是latest
[root@localhost ~]# docker pull mysql //等价于docker pull mysql.io/library/mysql:latest
#下载mysql指定的版本
[root@localhost ~]# docker pull mysql:5.7 //5.7版本在docker官网中必须有。
删除镜像 docker rmi 镜像ID
[root@localhost ~]# docker rmi 镜像ID 镜像ID 镜像ID
#删除所有镜像
[root@localhost ~]# docker rmi -f $(docker images -qa)
容器命令
说明:我们有了镜像才可以创建容器,linux,下载一个centos镜像测试学习
docker run 在新容器中运行命令,该docker run
命令首先creates
在指定映像上创建一个可写容器层,然后starts
使用指定的命令。
[root@localhost ~]# docker run [可选参数] image
#参数说明
--name="Name" //Name是容器名字,如tomcat01,tomcat02
-d //后台方式运行
-it //使用交互式运行,进入容器查看内容
-p //指定容器端口 -p 8080:8080
-p ip:主机端口:容器端口
-p 主机端口:容器端口
-p 容器端口
-p //随机指定端口
启动和停止容器操作
[root@localhost ~]# docker start/restart/stop/kill 容器Id
测试
[root@localhost ~]# docker run -it centos /bin/bash #在指定镜像上创建一个可写容器层
[root@21b5801833c3 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var
#从容器中退回主机使用exit,若要重新进入该容器,则
[root@localhost ~]# docker start 21b5801833c3
21b5801833c3
[root@localhost ~]# docker exec -it 21b5801833c3 /bin/bash
[root@21b5801833c3 /]#
#退出容器不停止,ctrl+p+q
[root@localhost ~]# docker ps #列出当前运行的容器,找到该容器id
[root@localhost ~]# docker exec -it 941d1f71a17d /bin/bash #直接使用exec连接
列出所有运行的容器
docker ps 命令
#列出当前正在运行的容器
-a #列出当前正在运行的容器+带出历史运行过的容器
-n=? #?指历史记录,1表示-a的第一列,以此类推
-q #只显示容器
删除容器
[root@localhost ~]# docker rm 容器ID #删除指定容器,不能删除运行中的容器,可强制删除 -f
[root@localhost ~]# docker rm -f $(docker ps -qa) #删除所有容器
其他常用命令
后台启动容器
[root@localhost /]# docker run -d centos
6f114cdff4d934d0a2f005baeaeb86f2285573263094ac3f392f26348c761376
[root@localhost /]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
# 问题后台启动centos,docker ps 发现centos 停止了
# 原因:
docker容器使用后台运行,必须有一个前台的进程,docker发现没有前台应用,就会自动停止
如:nginx,启动后发现自己没有提供服务,就会立即停止,就没有程序了
查看日志
docker logs -tf --tail number 容器id
#自己编写一段脚本,并后台运行
[root@localhost /]# docker run -d centos /bin/sh -c "while true;do echo kuangshen;sleep 1;done"
85d460f6ad9657b8df88dcb1a25b4707c7b5d932bebd761af799cc619098700b
[root@localhost /]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
85d460f6ad96 centos "/bin/sh -c 'while t…" 5 seconds ago Up
4 seconds exciting_beaver
-tf #显示日志
--tail number #要显示日志条数
[root@localhost /]# docker logs -tf --tail 10 85d460f6ad96
查看容器中的进程信息ps
# 语法:docker top 容器id
[root@localhost /]# docker top 85d460f6ad96
UID PID PPID C STIME TTY TIME CMD
root 110110 110090 0 15:23 ? 00:00:00 /bin/sh -c while true;do echo kuangshen;sleep 1;done
root 128910 110110 0 15:37 ? 00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 1
查看镜像的元数据
docker inspect 容器id #返回有关 Docker 对象的低级信息
进入当前运行的容器
# 方式一
# 我们通常使用的容器都是后台方式运行的,进入容器,修改一些配置
# 命令
docker exec -it 容器id bashshell
# 测试
[root@localhost /]# docker exec -it 85d460f6ad96 /bin/bash
[root@85d460f6ad96 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var
[root@85d460f6ad96 /]# ps -ef
UID PID PPID C STIME TTY TIME CMD
root 1 0 0 07:23 ? 00:00:01 /bin/sh -c while true;do echo kuangshen;sleep 1;done
root 1607 0 0 07:50 pts/0 00:00:00 /bin/bash
root 1659 1 0 07:51 ? 00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sl
root 1660 1607 0 07:51 pts/0 00:00:00 ps -ef
# 方式二
docker attach 容器id
# 测试
[root@localhost /