Ubuntu下安装Docker及其基本使用
Docker的安装
使用命令安装
安装命令如下:
`curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun`
也可以使用国内 daocloud 一键安装命令:
curl -sSL https://get.daocloud.io/docker | sh
手动安装
若已安装旧版本,须先卸载,命令如下:
sudo apt-get remove docker docker-engine docker.io containerd runc
更新apt包:
sudo apt-get update
添加 Docker 的官方 GPG 密钥:
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
安装:
sudo apt-get install docker-ce docker-ce-cli containerd.io
安装成功后,输入docker --version
查看是否成功
若出现以下信息,则安装成功,且版本为20.10.2
配置镜像加速
当您下载安装的Docker Version不低于1.10时,建议直接通过daemon config进行配置。使用配置文件/etc/docker/daemon.json(没有时新建该文件)。
加入以下信息:
{
"registry-mirrors": ["<your accelerate address>"]
}
Docker的卸载
输入以下命令,卸载Docker
systemctl stop docker
yum -y remove docker-ce
rm -rf /var/lib/docker
Docker的常用命令
帮助命令
- docker info:查看docker相关信息
- docker --help 帮助命令,查看docker相关操作指令
镜像命令
-
docker images 查看本机所有镜像
-
docker search xxx 查找某个镜像
-
–filter filter 筛选指令
如docker searchmysql --filter stars=30
筛选出点赞数大于30的mysql镜像
-
–limit int 搜索结果最大展示数(默认为25)
-
–no-trunc 列出详细信息
-
-
docker pull xxx:TAG 下载/拉取镜像
若不加TAG则表示为latest版本
-
docker rmi xxx 删除镜像
-
docker rmi -f 镜像名1:TAG 镜像名2:TAG 删除多个
-
docker rmi -f $(docker images -qa) 删除所有
容器命令
- docker run 启动容器
–name=“容器新名字”: 为容器指定一个名称;
-d: 后台运行容器,并返回容器ID,也即启动守护式容器;
-i:以交互模式运行容器,通常与 -t 同时使用;
-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;
-P: 随机端口映射;
-p: 指定端口映射;
docker run -d --name nginx -p 80:80 nginx
-d与-it的区别就是-d可以后台启动,而-it是交互界面,若启动了tomcat这种类型的容器则终端不能进行其他操作,若停止交互,则容器也停止。
-
docker ps 查看容器进程,不加参数代表正在运行的容器
-a :列出当前所有正在运行的容器+历史上运行过的
-l :显示最近创建的容器。
-n:显示最近n个创建的容器。
-q :静默模式,只显示容器编号。
–no-trunc :不截断输出。
-
exit/ctrl+P+Q 容器停止再退出/容器不停止退出
-
docker stop 容器ID 容器停止
-
docker start 启动容器
-
docker restart 重启容器
-
docker kill 强制停止容器
-
docker rm 删除容器
-
docker rm -f $(docker ps -a -q)/docker ps -a -q | xargs docker rm
-
docker logs -f -t --tail 容器ID
-t 是加入时间戳
-f 跟随最新的日志打印
–tail 数字 显示最后多少条
docker logs 容器ID -f -t -tail 8
表示显示后面八条日志 -
docker exec -it 容器ID /bin/bash进入容器并进行交互
-
重新进入docker attach 容器ID
-
区别:
attach 直接进入容器启动命令的终端,不会启动新的进程
exec 是在容器中打开新的终端,并且可以启动新的进程 -
docker inspect 容器ID 查看容器的内部信息
-
docker top 容器ID 查看容器内部运行的进程
Docker镜像
- docker commit -m=“提交的描述信息” -a=“作者” 容器ID 要创建的目标镜像名:[标签名]
docker commit -m="complete" -a="hfz" 8979 hfz/tomcat:1.0
Docker容器数据卷
- ** docker run -it/-d -v /宿主机绝对路径目录:/容器内目录 镜像名**
容器和宿主机之间可以实现数据共享
DockerFile文件
DockerFile保留字指令
FROM 基础镜像,当前新镜像是基于哪个镜像的
MAINTAINER 镜像维护者的姓名和邮箱地址
RUN 容器构建时需要运行的命令
EXPOSE 当前容器对外暴露出的端口
WORKDIR 指定在创建容器后,终端默认登陆的进来工作目录,一个落脚点
ENV 用来在构建镜像过程中设置环境变量
ADD 将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包
COPY 类似ADD,拷贝文件和目录到镜像中。
将从构建上下文目录中 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路径> 位置
VOLUME 容器数据卷,用于数据保存和持久化工作
CMD 指定一个容器启动时要运行的命令(只有一个CMD生效)
**ENTRYPOINT ** 指定一个容器启动时要运行的命令(和CMD功能一样但是可以多个生效)
ONBUILD 当构建一个被继承的Dockerfile时运行命令,父镜像在被子继承后父镜像的onbuild被触发
Dockerfile内容基础知识
- 每条保留字指令都必须为大写字母且后面要跟随至少一个参数
- 指令按照从上到下,顺序执行
- #表示注释
- 每条指令都会创建一个新的镜像层,并对镜像进行提交
Docker执行Dockerfile的大致流程
- docker从基础镜像运行一个容器
- 执行一条指令并对容器作出修改
- 执行类似docker commit的操作提交一个新的镜像层
- docker再基于刚提交的镜像运行一个新容器
- 执行dockerfile中的下一条指令直到所有指令都执行完成