title: Docker学习笔记2
date: 2020-08-21 16:05:07
tags: /学习
categories: /学习
第一章 可视化面板Portainer
Portainer是Docker图形化界面管理工具
安装命令:
docker run -d -p 8088:9000 --restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer
安装之后,访问测试:http://123.56.24.126:8088 (个人IP地址不一样,这里是我个人的阿里云服务器)
进入之后界面
第二章 Docker镜像
2.1 镜像是什么
镜像是一种轻量级、 可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时、库、环境变量和配置文件。
所有的应用,直接打包docker镜像,就可以直接运行。
2.2 Docker镜像加载原理
UnionFS (联合文件系统) : Union文件系统( UnionFS )是一种分层、 轻量级并且高性能的文件系统,它支持对文件系统的修改作为-次提交来层层的叠加,同时可以将不同目录挂载到同-个虚拟文件系统下(unite several directories into a single virtual filesystem)。Union 文件系统是Docker镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像) ,可以制作各
种具体的应用镜像。
特性: 一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录
(就是之前下载镜像的时候看到的一层层)
2.3 commit镜像
docker commit 提交容器成为一个新的副本
docker commit -m=“提交的描述信息” -a=“作者” 容器id 目标镜像名:[TAG]
测试:
启动默认的tomcat,没有webapps应用,因为官网的镜像默认webapps没有文件,需要自己拷贝,非常不方便
通过命令提交自己修改过的镜像,使用自己的镜像
docker commit -a=“xtt” -m=“add webapps” a16b47bdcb9a tomcat02:1.0
以上是Docker入门内容
第三章 容器数据卷
3.1 容器数据卷是什么
容器之间数据共享的技术,Docker容器中产生的数据同步到本地,就是卷技术(目录的挂载),将容器的目录挂载到Linux上。
卷的使用就是为了容器的持久化和同步操作。容器间也可以数据共享。
3.2 使用数据卷
3.2.1 直接使用命令来挂载 -v
docker run -it -v 主机目录:容器内目录
3.2.2 测试mysql的数据持久化
docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
–name 容器名字
启动成功之后,利用navicat连接测试,可以使用,连接正常。
利用navicat在本地创建数据库,同步成功
删除容器之后,数据依然存在
3.3 具名挂载和匿名挂载
3.3.1 匿名挂载
docker run -d -P --name nginx01 -v /etc/nginx nginx
3.3.2 具名挂载
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
3.3.3 区分
-v 容器内路径 匿名挂载
-v 卷名:容器内路径 具名挂载
-v /宿主机路径:容器内路径 指定路径挂载
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx
(ro,rw改变读写权限 ro readonly只读 rw readwrite可读可写)
3.3.4 Dockerfile
Dockerfile是用来构建docker镜像的构建文件
通过脚本来生成镜像
创建一个dockerfile文件
FROM centos
VOLUME [“volume01”,“volume02”]
CMD echo “…end…”
CMD /bin/bash
docker build -f dockerfile1 -t xtt/centos:1.0 .
构建镜像的时候实现挂载卷的方式比较常见
3.3.5 数据卷容器
多个容器同步数据
docker run -it --name docker02 --volumes-from docker01 8fdf395a999e
docker run -it --name docker03 --volumes-from docker01 xtt/centos:1.0
测试删除了docker01容器,docker02和docker03依然存在,数据都挂载在本地。
多个mysql数据共享
docker run -d -p 3310:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql
docker run -d -p 3310:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 --volume-from mysql01 mysql