Docker容器基础(一)
该笔记由b站学习视频 https://www.bilibili.com/video/BV1og4y1q7M4所记录
Docker概述
Docker为什么出现?
一款产品:开发–上线 两套环境!应用环境,应用配置!
开发 — 运维。问题:我在我的电脑上可以运行!版本更新,导致服务不可用!对于运维来说,考验就十分大?
环境配置十分麻烦,每一个机器都要部署环境(集群Redis、ES、Hadoop…)!费时费力。
发布一个项目 (jar+(Redis、MySQL、jdk、ES )),项目能不能都带上环境安装打包!
之前在服务器配置一个应用的环境Redis、MySQL、jdk、ES、Hadoop,配置超级麻烦,不能跨平台。
Windows最后发布到Linux!
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程做完!
Docker给以上的问题,提出了解决方案!
Docker的思想来自于集装箱!
JRE – 多个应用(端口冲突)—原来都是交叉的!
隔离:Docker核心思想!打包装箱!每个箱子都是互相隔离的。
Docker通过隔离机制,可以将服务器利用到极致!
本质:所有的技术都是因为出现了一些问题,我们需要去解决,才去学习!
Docker的历史
2010年,几个搞IT的年轻人,就在美国成立了一家公司dotCloud
做一些 pass 的云计算服务!LXC(Linux Containers)有关的容器技术!
他们将自己的技术(容器化技术)命名为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/(Docker的文档时超详细的!)
仓库地址:https://hub.docker.com/
Docker能干嘛
之前的虚拟机技术
虚拟机技术的缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢
容器化系统
容器化技术不是模拟的一个完整的操作系统
比较 Docker 和 虚拟机技术的不同:
- 传统虚拟机,虚拟出一套硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
- 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
- 每个容器间是互相隔离的,每个容器内都有一个属于自己的文件系统,互不影响
DevOps(开发、运维)
应用更快捷的的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用了Docker以后,我们部署应用就和搭积木一样!
更简单的系统运维
在容器化之后,我们的开发、测试环境都是高度一致的。
更高效的计算资源利用
Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例!服务器的性能可以被压榨到极致!
Docker的安装
Docker的基本组成
镜像(image):
docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像===>run ==>tomcat01容器(提供服务器)
通过这个镜像可以创建多个容器(最终服务运行或项目运行就是在容器中的)。
容器(container):
Docker利用容器技术,独立运行一个或者一组应用,通过镜像来创建。
启动,停止,删除,基本命令!
目前就可以把这个容器理解为一个建议的Linux系统
仓库(repository):
仓库就是存放镜像的地方!
仓库分为共有仓库和私有仓库!
Docker Hub
阿里云…都有容器服务器(配置镜像加速!)
安装Docker
环境准备
1、需要会一点点的Linux的基础
2、CentOS 7(我使用的是虚拟机下的linux,配置详见我的另一篇博客)
3、up主使用的Xshell远程连接的服务器(博主使用的是SecureCRT)
环境查看
//系统内核是3.10以上的
[root@laptop-1eenft75 ~]# uname -r
3.10.0-1160.6.1.el7.x86_64
//系统版本
[root@laptop-1eenft75 ~]# 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、卸载旧的版本
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
//2、需要的安装包
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
sudo systemctl start docker
//6、使用docker version查看是否安装成功!
//7、hello world
sudo docker run hello-world
//8、查看一下下载的这个hello-world 镜像
[root@laptop-1eenft75 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest bf756fb1ae65 12 months ago 13.3kB
了解:卸载docker
//1、卸载依赖
sudo yum remove docker-ce docker-ce-cli containerd.io
//2、删除资源
sudo 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://1cysr2dx.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
回顾helloworld流程
底层原理
Docker是怎么工作的?
Docker是一个Client-Server 结构的系统,Docker的守护进程运行在主机上。通过Socket从客户端访问。
Docker-Server 接收到 Docker- Client 的指令,就会执行这个命令!
Docker为什么比VM快?
1、Docker有着比虚拟机更少的抽象层。
2、Docker利用是宿主机的内核,VM需要是Guest OS。
所以说,新建一个容器的时候,docker不需要像虚拟机一样加载一个操作系统内核,避免引导。虚拟机是加载Guest OS,分钟级别的,而docker是利用宿主机的操作系统,省略了这个复杂的过程,秒级!
之后学习完所有命令,再回头来看这段理论,就会很清晰!