Docker的组成
镜像(image):
Docker镜像就相当于是一个文件系统,通俗来说就是为镜像用来创建容器的
容器(Container):
Docker 利用容器 (Container) 独立运行的一个或一组应用,容器是用镜像创建的运行实例,它可以被启动、开始、停止、删除,每个容器都是相互隔离的、保证安全的平台,可以把容器看做是一个简易版的Linux系统,可以简单用一句话来说,容器就是运行起来的镜像
容器就相当于Java中的对象,镜像相当于Java中的类
仓库(Repository)
仓库是集中存放镜像文件的场所
仓库注册服务器 (Registry) 上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签
仓库分为公开仓库和私有仓库两种形式
最大的公开仓库是DockerHub存放了数量庞大的镜像供用户下载,国内的公开仓库包括阿里云等
Docker的安装
1.需要Liunx版本为CentOS7.0以上
cat /etc/redhat-release
2.卸载旧版本(非必须项)
yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
3.安装Docker所需要依赖
#更新yum仓库
yum update
#安装依赖
yum install -y yum-utils
yum install -y device-mapper-persistent-data
yum install -y lvm2
4.设置镜像仓库
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
5.安装Docker
yum makacache fast
yum -y install docker-ce
6.设置阿里云镜像加速
1.登录阿里云开发者平
https://promotion.aliyun.com/ntms/act/kubernetes.html
2、点击创建我的容器镜像
https://account.aliyun.com/login/login.htm?oauth_callback=https%3A%2F%2Fcr.console.aliyun.com%2Fcn-hangzhou%2Finstances%2Frepositories
Docker中央仓库设置
1.Docker官方的中央仓库:这个仓库是镜像最全的,但是下载速度较慢。
https://hub.docker.com/
2.国内的镜像网站:网易蜂巢,daoCloud等,下载速度快,但是镜像相对不全。
https://c.163yun.com/hub#/home
http://hub.daocloud.io/ (推荐使用)
3.在公司内部会采用私服的方式拉取镜像(添加配置)
#需要创建 /etc/docker/daemon.json,并添加如下内容
{
"registry-mirrors":["https://registry.docker-cn.com"],
"insecure-registries":["ip:port"]
}
#重启两个服务
systemctl daemon-reload
systemctl restart docker
7.开启Dcoker服务
#centos启动方式
service docker start
#Ubuntu启动方式
sudo systemctl start docker
#设置开机启动
sudo systemctl enable docker
#停止docker
sudo systemctl stop docker
8.测试Docker-HelloWorld程序
[root@iZ8vbi9mx98t2s78lyxfpuZ ~]# docker run hello-world
Unable to find image 'hello-world:latest' locally
docker run hello-worldlatest: Pulling from library/hello-world
0e03bdcc26d7: Already exists
Digest: sha256:6a65f928fb91fcfbc963f7aa6d57c8eeb426ad9a20c7ee045538ef34847f44f1
Status: Downloaded newer image for hello-world:latest
Hello from Docker! --> 出现这句话代表Docker安装没有问题
This message shows that your installation appears to be working correctly.
9.卸载Docker
#1. 卸载依赖
yum remove docker-ce docker-ce-cli containerd.io
#2. 删除资源 /var/lib/docker 是docker的默认工作路径!
rm -rf /var/lib/docker
Docker的底层原理
Docker的工作原理
Docker是基于C/S结构的系统,Docker的守护进程运行在Linux服务器(宿主机)上,当我们在Liunx服务器上(Docker-Client)输入Docker相关命令就会被发送给Doker-Server
为什么Docker比VM(虚拟机)快
1、Docker有着比虚拟机更少的抽象层,由于Docker不需要Hypervisor实现硬件资源虚拟化,运行在Docker容器上的程序直接使用的都是实际物理机的硬件资源,因此在CPU、内存利用率上docker将会在效率上有明显优势
2、当新建一个容器时,Docker不需要和虚拟机一样重新加载一个操作系统内核,因而避免引导、加载操作系统内核返个比较费时费资源的过程,当新建一个虚拟机时,虚拟机软件需要加载GuestOS(虚拟机中的操作系统),这个新建过程是分钟级别的,而Docker由于直接利用宿主机的操作系统,则省略了这个复杂的过程,因此新建一个Docker容器只需要几秒钟
参考博客:https://www.warlock.live/Docker/197.html
总结
安装以上午了,总是报Job for docker.service failed because the control process exited with error code. See “systemctl status docker.service” and “journalctl -xe” for details.这个错误,百度了一大圈,又说Linux内核版本必须在3.10以上,,更新了内核!!
# 查看本机内核版本
uname -r
更新Linux内核
# 导入公钥
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
# 发现报错,连不上curl 不兼容或不支持的协议版本
解决方法
yum update -y nss curl libcurl
# 安装elrepo的yum源:
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-2.el7.elrepo.noarch.rpm
# 安装内核:
sudo yum --enablerepo=elrepo-kernel install kernel-ml-devel kernel-lt
# 安装后用rpm -qa | grep kernel检测是否安装成功,成功后在/boot文件夹下有新内核启动文件
# 切换内核
cat /boot/grub2/grub.cfg |grep menuentry命令查看当前操作系统有几个系统内核所有的内核
# 切换内核为4.4.234-1.el7.elrepo.x86_64
grub2-set-default 'Oracle Linux Server (4.4.234-1.el7.elrepo.x86_64 with Linux) 7.4'
# 重启
reboot
#查看是否修改成功
uanme -r
注意
如果内核是3.10都不需要更新了,这个错误其实是daemon.json文件内容不正确导致
更改内容为:
{
"storage-driver"
:
"devicemapper"
}
重启docker 发现问题解决!!!!!!!