Docker学习
网上介绍Docker优点的大多很官方,我这里就用自己的理解描述一下docker。
介绍:Docker是使用GO语言编写的虚拟化技术(和虚拟机的虚拟化是两个概念,虚拟机的虚拟化是硬件层面的),它主要解决的是程序运行所需环境的问题。Docker对进程进行了隔离,让进程独立出来成为一个容器。容器和容器之间是完全隔离的,他们之间没有任何接口。
那么什么是镜像?什么又是容器?镜像就是一个特殊的文件系统,提供了运行程序时所需要的配置、环境、资源、程序等。镜像是不会改变的,不论创建多少次。而容器是通过镜像创建的,并且和镜像类似,但不同的是容器是可读可写的。也可以这么理解,镜像是一个类,而容器是一个对象。
Docker流行不是没有原因的,下面列举一下Docker的优点:
- 部署方便:在有镜像的情况下我们只需要拉取镜像并运行即可,在没有镜像的情况下我们也只需要将DockerFile和可执行文件放在服务器上即可运行。
- 环境一致:我们应该都有经历过线上有bug,而本地却是正常的,很多时候这都是环境不一致引起的,而docker可以将环境不一致导致的问题降到最低。
- 隔离性:端口冲突,版本冲突,依赖冲突这些应该时我们跑微服务项目时最头疼的问题,而docker的隔离性就能很好的解决这个问题,对于容器来说,一个容器就是一个运行环境,不用担心这些冲突问题。
- 回滚:当一个新版出现问题时,我们不需要在对代码进行回滚然后重新部署。我们只需要吧对应版本的镜像运行起一个容器即可完成。
- 低成本:在以前我们可能发布一个应用就需要一台服务器或者虚拟机,而现在我们只需要启动一个容器即可,省去了一部分资源。
安装docker
Linux上Docker的安装其实很简单,下载启动即可。Windows的Docker安装需要WSL2,大部分情况下都要手动
# 安装
yum install docker-ce
# 启动
systemctl start docker
# 开机启动
systemctl enable docker
Docker File
dockerfile用于构建镜像文件,dockerfile中包含了所需的基础镜像,指令,端口号等等。
常用指令讲解
- FROM:定义基础镜像
- RUN:执行命令行命令,有两种格式,shell(java -jar app.jar)和exec([“java”, “-jar”, “app.jar”])
- 尽可能少的使用RUN,因为RUN会导致创建一层新的镜像,造成镜像过大。可以使用连接符
\
&&
进行多条命令的连接
- 尽可能少的使用RUN,因为RUN会导致创建一层新的镜像,造成镜像过大。可以使用连接符
- COPY:复制指令,从上下文目录中复制文件或者目录到容器里指定路径。
- ADD:也是复制指令,官方推荐使用COPY,大同小异。
- CMD:类似RUN,但作用时间不同,RUN在构建镜像时执行,CMD在启动容器时执行。若有多个CMD,仅最后一个生效。
- ENTRYPOINT:类似于CMD,但CMD会被docker run -c 参数覆盖,而ENTRYPOINT不会。
- ENV:环境变量,定义过的环境变量可在指令中使用。如:
ENV VERSION 2.0
则可在RUN中使用RUN curl -SLO "https://nodejs.org/dist/v$VERSION/node-v$VERSION-linux-x64.tar.xz"
- EXPOSE:声明端口,定义了这个指令后,若在运行容器时未指定端口映射,则会随机映射该端口。
实例:
FROM openjdk:8
MAINTAINER caizhiyuan
# 定义时区
ENV TZ=Asia/Shanghai
# 创建软连接更改时间,更改时间
RUN ln -sf /usr/share/zoneinfo/$TZ \
&& echo $TZ > /etc/timezone
# 创建目录
WORKDIR /www/server/springboot/store
# 复制到docker
ADD store.jar /www/server/springboot/store/app.jar
ADD images /www/server/springboot/store/images
# 声明端口
EXPOSE 81
# 运行jar
ENTRYPOINT ["nohup","java","-jar","/www/server/springboot/store/app.jar","&"]
Docker常用命令
镜像操作
- build:根据DockerFile创建镜像。必传参数:docker的路径。例:
docker build /www/server
- images:列出本地所有镜像
docker images
- pull:从远程仓库拉取镜像
docker pull etcd
容器操作
- run:创建并运行一个容器 -P:随机端口映射;-p:指定端口;-d:后台运行;–name:指定名称
docker run -p 3307:3306 mysql
- create:和run一致,但只创建不运行
- start/stop/restart:启动,停止,重启。
docker restart nginx
- kill:终止容器
- rm:移除容器
- rename:修改容器名称
- ps:查询容器列表,默认只查询运行中的容器。-a:查询所有容器,不论运行与否。
- exec:在容器中执行命令。-d:后台执行;-i:保持STDIN打开;-t:分配一个伪终端。(-i -t一般一起使用)例:
docker exec -it mysql bash