1.Docker概述
一款产品:开发--上线 ;两套环境:应用环境和应用配置;
环境配置是十分麻烦,每一个机器要部署环境(集群Redis、ES、Hadoop)!
发布一个项目(jar+(Redis、MySQL、jdk、ES)),项目能不能带上环境安装打包!
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程做完!
Docker的思想就来自于集装箱
JRE--多个应用(端口冲突)--原来都是交叉的!
隔离:Docker核心思想!打包集装箱!每个箱子是相互隔离的。
Docker通过隔离机制,可以将服务器利用到极致!
2.Docker历史
2010年,美国公司dotCloud,做一些pass的云计算服务!LXC有关的容器技术!
将自己的容器化技术命名Docker!
2013年,Docker开源!
2014年,Docker1.0发布!
Docker十分轻巧
Docker:隔离、镜像(最核心的环境4m+jdk+MySQL)十分小巧,运行镜像就可以了!
Docker基于Go语言开发的!开源项目!
3.Docker和虚拟技术
传统虚拟机,虚拟出一套硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
容器内的应用直接运行在宿主机的内容,容器没有自己的内核,也没有虚拟我们的硬件,所以轻便
每个容器间是相互隔离,每个容器内都有一个属于自己的文件系统,互不影响
DevOps(开发、运维)
应用更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用Docker后,部署应用和搭积木一样
更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的
更高效的计算资源利用
Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例!服务器的性能可以被压榨到极致。
4.Docker安装
镜像(image):好比是一个模块,可以通过这个模板来创建容器服务,tomcat镜像--->run--->tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目就是在容器中的)
容器(container):Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。启动,停止,删除,基本命令!目前就可以把这个容器理解为就是一个简易的linux系统
仓库(repository):仓库就是存放镜像的地方!仓库分为公有仓库和私有仓库。
安装过程
1.卸载旧的版本
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
It’s OK if yum reports that none of thes
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
4.安装docker相关的 ce 社区版 ee 企业版
sudo yum install docker-ce docker-ce-cli containerd.io
5.启动docker
systemctl start docker
6.使用docker version 是否安装成功
7.docker run hello-world
8.查看下载的hello-world镜像
卸载docker
sudo yum remove docker-ce docker-ce-cli containerd.io
sudo rm -rf /var/lib/docker
sudo rm -rf /var/lib/containerd
5.回顾run hello-world流程
6.底层原理
Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问!
DockerServer接收到Docker-Client的指令,就会执行这个命令。
新建一个容器的时候,docker不需要像虚拟机一样重新加载一个操作系统内核,避免引导。虚拟机是加载Guest OS,而docker是利用宿主机的操作系统,省略了这个复杂的过程。
7.Docker常用命令
帮助命令
docker version #显示docker的版本信息
docker info #显示docker的系统信息,镜像和容器数量
docker 命令 --help #万能命令
镜像命令
docker images 查看所有本地主机的镜像
-a, --all 列出所有镜像
-q, --quiet 只显示镜像的id
docker search 搜索镜像
-f, --filter=STARS=3000 搜索出来的镜像就是STARS大于3000的
docker pull 下载镜像
[root@localhost ~]# docker pull mysql
Using default tag: latest #如果不写tag,默认就是latest
latest: Pulling from library/mysql
b4d181a07f80: Pull complete #分层下载,docker image的核心 联合文件系统
a462b60610f5: Pull complete
578fafb77ab8: Pull complete
524046006037: Pull complete
d0cbe54c8855: Pull complete
aa18e05cc46d: Pull complete
32ca814c833f: Pull complete
9ecc8abdb7f5: Pull complete
ad042b682e0f: Pull complete
71d327c6bb78: Pull complete
165d1d10a3fa: Pull complete
2f40c47d0626: Pull complete
Digest: sha256:52b8406e4c32b8cf0557f1b74517e14c5393aff5cf0384eff62d9e81f4985d4b #签名
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest #真实地址
#指定版本
docker pull mysql:5.7
docker rmi -f 镜像id #删除镜像
docker rmi -f $(docker images -aq) #删除全部容器
容器命令
有了镜像才可以创建容器
新建容器并启动
docker run [可选参数] image
--name="Name" 容器名字
-d 后台方式运行
-it 使用交互方式运行,进入容器查看内容
-p 指定容器的端口 -p 8080:8080
-p ip:主机端口:容器端口
-p 主机端口:容器端口
-p 容器端口
-P 随机指定端口
启动并进入容器
docker run -it centos /bin/bash
退出容器
exit 容器停止并退出
Ctrl+P+Q 容器不停止退出
列出所有的运行的容器
docker ps
-a 列出当前运行的容器+带出历史运行的容器
-n=? 显示最近创建的容器
-q 只显示容器的编号
删除容器
docker rm 容器id 删除指定容器,不能删除正在运行的容器
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 centos
问题 docker ps 发现centos停止了
常见的坑,docker容器使用后台运行,就必须要有一个前台进程,docker发现没有应用,就会自动停止
查看日志
显示日志和指定条数
docker logs -tf --tail 10 id
查看容器中进程信息
docker top 容器id
查看镜像的元数据
docker inspect id
进入当前正在运行的容器
docker exec -it 容器id /bin/bash 进入容器后开启一个新的终端
docker attach 容器id 进入容器正在执行的终端
从容器内拷贝文件到主机上
docker cp 容器id:容器内路径 目的的主机路径
attach # 当前shell下attach连接指定运行镜像
build # 通过Dockerfile定制镜像
commit # 提交当前容器为新的镜像
cp # 从容器中拷贝指定文件或目录到宿主机中
create # 创建一个新的容器,同 run 但不启动容器
diff # 查看 docker 容器变化
events # 从docker服务器获取容器实时事件
exec # 在已存在的容器上运行命令
export # 导出容器的内容流作为一个 tar 归档文件【对应 import】
history # 展示一个镜像形成历史
images # 列出系统当前镜像
import # 从tar包中的内容创建一个新的文件系统映像【对应 export】
info # 显示系统相关信息
inspect # 查看容器详细信息
kill # kill 指定的容器
load # 从一个 tar 包中加载一个镜像【对应 save】
login # 注册或者登录一个 docker 源服务器
logout # 从当前 Docekr registry 退出
logs # 输出当前容器日志信息