关于 Docker 入门,这一篇就够了

关于 Docker 的一些概念和操作,我争取这一篇博客说完。 下面正文开始。

Docker 镜像与容器

说到 Docker ,你会常遇到两个内容: image 和 container (即镜像和容器) 关于镜像和容器,你可以这样来理解:镜像是构建 Docker 的基石,用户基于镜像来运行自己的容器。或者说,镜像是 Docker 生命周期中的构建或打包阶段,而容器则是启动或是执行阶段。 好吧,说的再明白点儿,就是有了镜像,才有的容器。容器是在镜像的基础上,才有的。

Docker 安装

以前写过,这里就不赘述了,直接上链接: 需要科学上网的安装方法:[Docker]CentOS7下Docker安装教程 不需要科学上网的安装方法:[Docker]CentOS7通过rpm包安装Docker

Docker 相关命令

Docker 操作相关命令:

1
2
3
4
5
6
systemctl start docker		启动 docker
systemctl status docker		查看 docker 状态
systemctl stop docker		停止 docker
systemctl enable docker		开机自启
docker info 			查看 docker 概要信息
docker --help			查看 docker 帮助文档

镜像相关命令:

查看镜像命令:

1
docker images

搜索镜像:

1
docker search 镜像名称

拉取镜像:[Docker]Docker拉取,上传镜像到Harbor仓库 删除镜像:[Docker]如何批量删除镜像

容器相关命令:

查看容器: 查看正在运行的容器:

1
docker ps

查看所有容器:

1
docker ps -a

查看最后一次运行的容器:

1
docker ps -l

查看停止的容器:

1
docker ps -f status=exited

创建容器:

1
docker run

可以在 run 后面加参数。其中:

1
2
3
4
5
6
-i   表示运行容器
-t   表示容器启动后进入其命令行
--name  为创建的容器命名
-v     表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录)
-d     在 run 后面加上 -d 参数,则会创建一个守护式容器在后台运行
-p     表示端口映射,前者是宿主机端口,后者是容器内的映射端口

交互式方式创建容器

1
docker run -it --name=容器名称 镜像名称:标签 /bin/bash

守护式方式创建容器

1
docker run -di --name=容器名称 镜像名称:标签

登录守护式容器方式

1
docker exec -it 容器名称(或容器 ID) /bin/bash

启动容器:

1
docker start 容器名称(或容器 ID)

停止容器:

1
docker stop 容器名称(或容器 ID)

文件拷贝:

将文件拷贝到容器内

1
docker cp 需要拷贝的文件或目录  容器名称:容器目录

将文件从容器内拷贝出来

1
docker cp 容器名称:容器目录	需要拷贝的文件或目录

目录挂载:

在创建容器时,将宿主机的目录与容器内的目录进行映射,这样可以通过修改宿主机某个目录的文件从而去影响容器 创建容器 添加 -v 参数 后边为 宿主机目录:容器目录,完整命令:

1
2
3

docker run  -v 宿主机目录:容器目录

如果共享的是多级目录,可能会出现权限不足的情况 可以通过添加参数 –privileged=true 来解决,因为 CentOS7 中安全模块将 selinux 权限禁掉了,添加此参数,可以将问题解决。

查看容器 IP:

1
docker inspect 容器名称(容器 ID )

也可以直接输出 IP 地址:

1
2
3

docker inspect --format='\{\{NetworkSetting。IPAddress\}\}' 容器名称(容器 ID)

删除容器

1
docker rm 容器名称(容器 ID)

常见的应用部署

MySQL 部署:

1 ,拉取镜像:

1
docker pull centos/mysql-57-centos7

2 ,创建容器:

1
docker run -di --name=mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root centos/mysql-57-centos7

其中: -p 代表端口映射,格式为 宿主机映射端口:容器运行端口 -e 代表添加环境变量 MYSQL_ROOT_PASSWORD 是 root 用户的登录密码 3 ,进入 mysql 容器:

1
docker exec -it mysql /bin/bash

4 ,登录 mysql :

1
mysql -u root -p

tomcat 部署:

1 ,拉取镜像

1
docker pull tomcat:7-jre7

2 ,创建容器

1
docker run -di --name=mytomcat -p 9000:8080 -v /usr/local/webapps:/usr/local/webapps tomcat:7-jre7

Nginx 部署:

1 ,拉取镜像

1
docker pull nginx

2 ,创建 nginx 容器

1
docker run -di --name=mynginx -p 80:80 nginx

Redis 部署:

1 ,拉取镜像

1
docker pull redis

2 ,创建 redis 容器

1
docker run -di --name=myredis -p 6379:6379 redis

迁移与备份

容器保存为镜像:

1
docker commit 容器名称 镜像名称

例:

1
docker commit mynginx mynginx_i

将镜像保存为 tar 文件,例:

1
docker save -o mynginx。tar mynginx_i

镜像恢复与迁移: -i 输入的文件,例:

1
docker load -i mynginx。tar

Dockerfile

Dockerfile 是由一系列命令和参数构成的脚本,基于基础镜像,最终创建一个新的镜像,常用命令有:

1
2
3
4
5
6
7
FROM image_name:tag  定义了使用哪儿个基础镜像启动构建流程
MAINTAINER user_name	声明镜像的创建者
ENV key value		设置环境变量(可以写多条)
RUN command 		是 Dockerfile 的核心部分(可以写多条)
ADD source_dir/file dest_dir/file  将宿主机的文件复制到容器内,如果是一个压缩文件,将会在复制后自动解压
COPY source_dir/file dest_dir/file   和 ADD 相似,但是如果有压缩文件并不能解压
WORDIR path_dir 设置工作目录

需要注意一下,如果要使用 Dockerfile 文件,名字必须为「Dockerfile」,否则里面的命令不会有效。

镜像上传下载到镜像仓库

以前写过博客,感觉还是比较详细的:[Docker]Docker拉取,上传镜像到Harbor仓库(在上面应该也看到过了,再放一次)

关于 Docker 入门,我只能帮你到这儿了~

Java Geek Tech wechat
欢迎订阅 Java 极客技术,这里分享关于 Java 的一切。