Docker学习
- Docker概述
- Dokcer安装
- Docker命令
- 镜像命令
- 容器数据卷
- 操作命令
- …
- Docker镜像
- 容器数据卷
- DockerFile
- Docker网络原理
- IDEA整合Docker
- Docker Compose
- Docker Swarm
- CI\CD jenkins
弱小和无知不是生存的障碍,傲慢才是。
Docker 概述
Docker 为什么会出现?
一款产品:开发----上线 两套环境!应用环境,应用配置!
开发-----运维
开发即是运维
环境配置十分麻烦,每一个机器都要部署环境(集群Redis、ES…)
那就干脆把环境和应用一起打包带走。
window ----- linux
传统 : 开发给 jar包 ,运维来做!
现在: 开发打包部署上线,一套带走! 运维再见。。。、
Java 》》 apk 》》 发布(应用商店)---- 张三使用APK -- 安装即可用!
Java 》》 jar(环境) 》》打包项目带上环境(镜像)=》docker 镜像仓库 =》下载我们发布的镜像 =》直接运行即可
隔离:docker核心思想----打包装箱 哥哥应用互相隔离
Docker历史
2010年,几个搞IT的年轻人,在美国成立了一家公司dotcloud
做一些云计算服务!LXC有关的容器技术!
他们将自己的技术(容器化技术)命名,就是Docker!
Docker刚刚诞生的时候,没有引起行业的注意!
没办法 ---- 开源求活
2013年开放源代码
Docker越来越多的人发现了Docker的有点!火了!Docker每个月都会更新一个版本!
2014年4月9日 , Docker1.0发布!
Docker为什么这么火?十分轻巧!
docker
docker 基于Go语言开发的开源项目!
dockers 官方文档 :https://docs.docker.com/
仓库地址 :https://hub.docker.com/
docker能干什么?
原来的虚拟机
虚拟机技术缺陷:
1.资源占用多 很多!!
2.冗余步骤多 集群的时候
3.启动慢
docker 和 虚拟机技术的不同:
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。
- 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟硬件所以轻便了许多。
- 每个容器间是相互隔离的,每个容器内都有一个属于自己的文件系统,互不影响。
DevOps(开发、运维)
应用更快速地交付和部署
传统:一堆帮助文档,安装程序
Dockers:打包镜像发布测试,一键运行。
更快捷的升级和扩缩容
使用 docker之后,我们部署应用和搭积木一样!
项目打包为一个镜像,扩展服务器A!服务器B!
更简单的系统运维
容器化之后,我们的开发、测试环境都是高度一致的。
更高效的计算资源利用
docker是内核级别的虚拟化,可以在一个物理机上运行很多实例,服务器的性能可以压榨最极致。
docker 安装
镜像(image):
docker镜像就好比是一个模板(或者说一个类),可以通过这个模板创建容器服务,tomcat镜像–>run -->romcat容器(提供服务器),通过这个镜像可以创建很多个容器(最终服务运行或者项目运行就是在容器中的)。
容器(container):
Docker利用容器技术,独立运行一个或者一组应用,通过镜像创建的。
启动,停止,删除等基本命令要掌握。
目前就可以把这个容器理解为就是一个简易的Linux系统
仓库(repository):
仓库就存放进行的地方!
阿里云有国内镜像!!!
环境准备
1、需要Linux基础
2、CentOS 7
3、我们使用Xshell连接远程服务器进行操作!!!
环境查看
uname -r
安装Docker
官方文档
卸载原有Docker
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
更换镜像索引
sudo yum install -y yum-utils
sudo yum-config-manager \
--add-repo \
// https://download.docker.com/linux/centos/docker-ce.repo
https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
这里镜像仓库是国外的。更换阿里云国内镜像下载速度会快很多。
更新yum软件包索引
yum makeche fast
安装docker
yum install docker -ce docker-ce-cli containerd.io
启动docker
systemctl start docker
查看docker版本
docker verion
卸载Docker
//卸载依赖
yum remove docker-ce-cli containerd.io
删除资源rm -rf /var/lib/docker
阿里云镜像加速器
https://oqkxb48c.mirror.aliyuncs.com
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://oqkxb48c.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
回顾 Docker run halloword
底层原理
docker是怎么工作的
docker 是一个Client - Server 结构的系统,Server结构的系统,Dokcer的守护进程运行在主机上,通过Socker从客户端访问! DockerServer接收到Docker-Client的指令,就会执行这个命令。
Socket是什么呢?
Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket去组织数据,以符合指定的协议。
利用三元组【ip地址,协议,端口】可以进行网络间通信了,那我们应该怎么实现了,因此,我们socket应运而生,它就是利用三元组解决网络通信的一个中间件工具,就目前而言,几乎所有的应用程序都是采用socket,如UNIX BSD的套接字(socket)和UNIX System V的TLI(已经被淘汰)。
Docker 为什么比VM快
1.docker 有着较少的抽象层
2.docker 利用的是宿主机的内核,vm需要GuestOS
所以新建一个容器的时候,docker利用了主机的操作系统,不需要重新加载一个内核。所以vm启动是分钟级别的,而Docker容器是秒级别的。
docker常用命令
1、Docker容器信息
##查看docker容器版本
docker version
##查看docker容器信息
docker info
##查看docker容器帮助
docker --help
2、镜像操作
提示:对于镜像的操作可使用镜像名、镜像长ID和短ID。
2.1、镜像查看
##列出本地images
docker images
##含中间映像层
docker images -a
##只显示镜像ID
docker images -q
##含中间映像层
docker images -qa
##显示镜像摘要信息(DIGEST列)
docker images --digests
##显示镜像完整信息
docker images --no-trunc
##显示指定镜像的历史创建;参数:-H 镜像大小和日期,默认为true;--no-trunc 显示完整的提交记录;-q 仅列出提交记录ID
docker history -H redis
2.2、镜像搜索
##搜索仓库MySQL镜像
docker search mysql
## --filter=stars=600:只显示 starts>=600 的镜像
docker search --filter=stars=600 mysql
## --no-trunc 显示镜像完整 DESCRIPTION 描述
docker search --no-trunc mysql
## --automated :只列出 AUTOMATED=OK 的镜像
docker search --automated mysql
2.3、镜像下载