1.docker官网
2.docker仓库
Docker 仓库是用来存放镜像的,Docker提供一个注册服务器(Register)来保存多个仓库,每个仓库又可以包含多个具备不同tag的镜像。
Docker运行中使用的默认仓库是 Docker Hub 公共仓库。(Docker hub 官方网站如下)
Docker Hub
https://hub.docker.com/
3.Docker的基本组成
镜像(Image)
Docker 镜像(Image)就是一个只读的模板。镜像可以用来创建 Docker 容器,一个镜像可以创建很多容器。
容器(Container)
Docker 利用容器(Container)独立运行的一个或一组应用。容器是用镜像创建的运行实例。
它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。
可以把容器看做是一个简易版的 Linux 环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。
容器的定义和镜像几乎一模一样,也是一堆层的统一视角,唯一区别在于容器的最上面那一层是可读可写的。
仓库(Repository)
仓库(Repository)是集中存放镜像文件的场所。
仓库(Repository)和仓库注册服务器(Registry)是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签(tag)。
仓库分为公开仓库(Public)和私有仓库(Private)两种形式。
最大的公开仓库是 Docker Hub(https://hub.docker.com/),
存放了数量庞大的镜像供用户下载。国内的公开仓库包括阿里云 、网易云 等
4.docker的常用命令
4.1帮助启动类命令
启动docker: systemctl start docker
停止docker: systemctl stop docker
重启docker systemctl restart docker
查看docker状态 systemctl status docker
开机启动 systemctl enable docker
查看docker概要信息 docker info
查看docker总体帮助文档 docker --help
查看docker具体帮助文档 docker 具体命令 --help
4.2 镜像命令
docker images -a 列出本地所有的镜像
docker search 某个镜像的名字 (查询仓库的镜像 一般拉取查到的第一个,点赞数最高官方认证)
docker pull 镜像名字 拉取镜像
docker system df 查看镜像/容器/数据卷所占的空间
docker rmi -f 某个镜像的名字(或者镜像id) 删除镜像(多个,全部也可以删)
面试题例:谈一谈docker的虚悬镜像?
4.3容器命令
新建+启动容器
docker run [option] images [command]
option说明
--name=“容器的新名字” 为容器指定一个名字
-d 后台运行容器并返回容器id也即启动守护式容器(后台运行)
-i 以交互模式运行容器,通常与-t 同时使用
-t 为容器重新分配一个伪输入终端,通常与-i 同时使用
也即启动交互式容器(前台有伪终端,等待交互)
-p 指定端口映射 如 -p 8080:80 -p hostPort:containerPort
-P 随机端口映射
docker ps 列出正在运行的docker容器
退出容器 两种退出方式
exit run进去容器,exit退出,容器停止
ctrl+p+q ctrl+p+q退出,容器不停止
启动已经停止的容器 docker start 容器id或者容器名
重启容器 docker restart 容器id或者容器名
停止容器 docker stop 容器id或者容器名
强制停止容器 docker kill 容器id或者容器名
删除已经停止的容器 docker rm 容器ID 强制删除 docker rm -f 容器id
前台交互式启动 docker run -it redis
后台守护式启动 docker run -d redis
查看容器日志 docker logs 容器id
查看容器内运行的进程 docker top 容器id
查看容器内部细节 docker inspect 容器id
进入正在运行的容器并以命令行交互
docker exec -it 容器id /bin/bash
docker attach 容器id
区别 attach直接进入容器启动命令终端,不会启动新的进程,用exit退出,会导致容器的停止
exec是在容器种打开新的终端,并且可以启动新的进程,用exit退出,不会导致容器的停止
一般用-d后台启动的程序,再用exec进入对应容器实例
从容器内拷贝文件到主机 docker cp 容器ID:容器内路径 目的主机路径
docker commit 提交容器副本使之成为一个新的镜像
docker commit -m="提交的描述信息" -a=“作者” 容器ID 要创建的目标镜像名:[标签名]
docker内部安装vim命令
apt-get update
apt-get -y install vim
5.Docker镜像的理解
5.1什么是镜像
镜像是一种轻量级、可执行的独立软件包,它包含运行某个软件所需的所有内容,我们把应用程序和配置依赖打包好形成一个可交付的运行环境(包括代码、运行时所需的库、环境变量和配置文件等),这个打包好的运行环境就是镜像文件。 只有通过镜像才能生成Docker容器实例 镜像是分层的,
5.2Docker镜像采用分层结构原因
共享资源、方便复制迁移即复用;
*Docker镜像层是只读的,容器层才是可写的*
镜像层是只读的,新的镜像层是基于前一个镜像层的修改,只保留了增量修改的部分!
使用了联合文件系统,对文件系统的修改作为一次提交来一层层的叠加
!
比如我们拉取一个ubuntu镜像只有 72Mb 我们在这个基础上安装vim命令commit一个新的镜像,大小变为172Mb
。
这个新镜像就是从原来的ubuntu镜像叠加而来的,每安装一个软件,就在现有的镜像基础上增加一层
。
Docker镜像都是只读的,当容器启动时,一个新的可写层加载到镜像的顶部。这一层就是我们通常说的容器层,容器之下的都叫镜像层。
容器本质上也是在镜像的基础上加了一层可写层!
6.docker容器数据卷
将docker容器内的数据保存进宿主机的磁盘中。
容器数据卷的方式,完成数据的持久化重要资料的备份,有点类似redis的rdb和aof。
运行一个带有容器卷存储功能的容器实例
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
6.2 容器卷能干什么?
将运用与运行的环境打包镜像,run后形成容器实例运行 ,但是我们对数据的要求希望是持久化的
Docker容器产生的数据,如果不备份,那么当容器实例删除后,容器内的数据自然也就没有了。
为了能保存数据在docker中我们使用卷。
特点:
数据卷可在容器之间共享或重用数据。
卷的更改可以直接实时生效。
数据卷中的更改不会包含在镜像的更新中。
数据卷的生命周期一直持续到没有容器使用它为止。
7.docker常用软件的安装简介
7.1总体步骤
搜索镜像 拉取镜像 查看镜像 启动镜像 停止容器 移除容器
相关的命令在https://hub.docker.com 有
7.2例mysql的安装
docker pull 一下mysql的镜像
执行一下命令,大致步骤如下,具体看你自己的环境
docker run -d -p 3306:3306 --privileged=true
-v /smhuse/mysql/log:/var/log/mysql
-v /smhuse/mysql/data:/var/lib/mysql
-v /smhuse/mysql/conf:/etc/mysql/conf.d
-e MYSQL_ROOT_PASSWORD=123456
--name mysql mysql:5.7
说明:mysql需要备份数据,配置和日志,要使用容器卷功能,不然容器关了数据就没了。挂载了数据卷后,即使容器删了,数据和配置日志还会在宿主机上。下一次用同样的命令启动,数据还会恢复
在/smhuse/mysql/conf 路径下 新建my.cnf 解决docker上mysql的中文乱码
default_character_set=utf8
[mysqld]
collation_server = utf8_general_ci
character_set_server = utf8
修改完重启mysql容器实例
7.3例redis的安装
执行命令,大致如下,具体看你自己的环境。
docker run -p 6379:6379 --name myr3 --privileged=true
-v /app/redis/redis.conf:/etc/redis/redis.conf
-v /app/redis/data:/data
-d redis:6.0.8 redis-server /etc/redis/redis.conf