docker自动部署前端

2020-11-12  本文已影响0人  沉默固执老阿姨

Dockerfile

# node镜像

FROM node:latest as build-stage

RUN echo "-------------------- web环境配置 --------------------"

# 指定接下来的工作路径为/app  - 类似于cd命令

WORKDIR /app

# 拷贝前端项目到app目录下

COPY ./package*.json ./

COPY ./package-lock.json ./

# 安装依赖

RUN npm install

COPY . .

# 打包 - 目的:丢到nginx下跑

RUN npm run build:prod

# ======================== 上:npm打包  下:nginx运行 ========================

# nginx镜像

FROM nginx:1.15.3-alpine as production-stage

# 移除nginx容器的default.conf文件、nginx配置文件

RUN rm /etc/nginx/conf.d/default.conf

RUN rm /etc/nginx/nginx.conf

# 把主机的nginx.conf文件复制到nginx容器的/etc/nginx文件夹下

COPY nginx.conf /etc/nginx/nginx.conf

# 拷贝前端vue项目打包后生成的文件到nginx下运行

COPY --from=build-stage /app/dist /usr/share/nginx/html

# 暴露8000端口

EXPOSE 8080

# 注:CMD不同于RUN,CMD用于指定在容器启动时所要执行的命令,而RUN用于指定镜像构建时所要执行的命令。

#  RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定--no-cache参数,如:docker build --no-cache

# 使用daemon off的方式将nginx运行在前台保证镜像不至于退出

CMD ["nginx", "-g", "daemon off;"]

nginx.conf

worker_processes 1;

master_process off;

events {

  worker_connections 1024;

}

http {

  include mime.types;

  default_type application/octet-stream;

  log_format main '$remote_addr - $remote_user [$time_local] "$request" '

  '$status $body_bytes_sent "$http_referer" '

  '"$http_user_agent" "$http_x_forwarded_for"';

  sendfile on;

  keepalive_timeout 65;

  server {

    listen 8080;

    server_name localhost;

    location / {

      root /usr/share/nginx/html;

      index index.html index.htm;

    }

  }

}

docker-compose.yml

version: '2'

services:

  myweb:

    build:

      context: .

      dockerfile: Dockerfile

    image: koi/test:1.0.13

    ports:

      - 8080:8080

    restart: always

    container_name: 'myweb'

命令:

docker build -t koi/test:1.0.13 .

docker images

docker rmi

docker run -p 8080:8080 -d koi/test:1.0.12

docker ps

docker ps -a 

docker rm

docker-compose up --force-recreate --build -d

一、Docker 删除镜像

1.1 通过标签删除镜像

通过如下两个都可以删除镜像:

docker rmi [image]

复制代码

或者:

docker image rm [image]

复制代码

支持的子命令如下:

-f, -force: 强制删除镜像,即便有容器引用该镜像;

-no-prune: 不要删除未带标签的父镜像;

Docker 查看镜像信息

例如,我们想删除上章节创建的 allen_mysql:5.7 镜像,命令如下:

docker rmi allen_mysql:5.7

复制代码

Docker 删除镜像

从上面章节中,我们知道 allen_mysql:5.7 和 docker.io/mysql:5.7 实际上指向的是同一个镜像,那么,您可以能会有疑问,我删除了 allen_mysql:5.7, 会不会将 docker.io/mysql:5.7 镜像也给删除了?

实际上,当同一个镜像拥有多个标签时,执行 docker rmi 命令,只是会删除了该镜像众多标签中,您指定的标签而已,并不会影响原始的那个镜像文件。

不信的话,我们可以执行 docker images 命令,来看下 docker.io/mysql:5.7 镜像还在不在:

Docker 查看镜像信息

可以看到,docker.io/mysql:5.7 镜像依然存在!

那么,如果某个镜像不存在多个标签,当且仅当只有一个标签时,执行删除命令时,您就要小心了,这会彻底删除镜像。

例如,这个时候,我们再执行 docker rmi docker.io/mysql:5.7 命令:

Docker 删除镜像

从上图可以看到,我们已经删除了 docker.io/mysql:5.7 镜像的所有文件层。该镜像在本地已不复存在了!

1.2 通过 ID 删除镜像

除了通过标签名称来删除镜像,我们还可以通过制定镜像 ID, 来删除镜像,如:

dockerrmi ee7cbd482336

复制代码

一旦制定了通过 ID 来删除镜像,它会先尝试删除所有指向该镜像的标签,然后在删除镜像本身。

1.3 删除镜像的限制

删除镜像很简单,但也不是我们何时何地都能删除的,它存在一些限制条件。

当通过该镜像创建的容器未被销毁时,镜像是无法被删除的。为了验证这一点,我们来做个试验。首先,我们通过 docker pull alpine 命令,拉取一个最新的 alpine 镜像, 然后启动镜像,让其输出 hello, docker!:

Docker run alpine

接下来,我们来删除这个镜像试试:

Docker 删除镜像

可以看到提示信息,无法删除该镜像,因为有容器正在引用他!同时,这段信息还告诉我们,除非通过添加 -f 子命令,也就是强制删除,才能移除掉该镜像!

docker rmi-fdocker.io/alpine

复制代码

但是,我们一般不推荐这样暴力的做法,正确的做法应该是:

先删除引用这个镜像的容器;

再删除这个镜像;

也就是,根据上图中提示的,引用该镜像的容器 ID (9d59e2278553), 执行删除命令:

docker rm 9d59e2278553

复制代码

然后,再执行删除镜像的命令:

docker rmi 5cb3aa00f899

复制代码

Docker 删除镜像

这个时候,就能正常删除了!

1.4 清理镜像

我们在使用 Docker 一段时间后,系统一般都会残存一些临时的、没有被使用的镜像文件,可以通过以下命令进行清理:

docker image prune

复制代码

它支持的子命令有:

-a, --all: 删除所有没有用的镜像,而不仅仅是临时文件;

-f, --force:强制删除镜像文件,无需弹出提示确认;

另外,执行完 docker image prune 命令后,还是告诉我们释放了多少存储空间!

二、Docker 创建镜像

此小节中,您将学习 Docker 如何创建镜像?Docker 创建镜像主要有三种:

基于已有的镜像创建;

基于 Dockerfile 来创建;

基于本地模板来导入;

我们将主要介绍常用的 1,2 两种。

2.1 基于已有的镜像创建

通过如下命令来创建:

docker container commit

复制代码

支持的子命令如下:

-a, --author="": 作者信息;

-c, --change=[]: 可以在提交的时候执行 Dockerfile 指令,如 CMD、ENTRYPOINT、ENV、EXPOSE、LABEL、ONBUILD、USER、VOLUME、WORIR 等;

-m, --message="": 提交信息;

-p, --pause=true: 提交时,暂停容器运行。

接下来,基于本地已有的 Ubuntu 镜像,创建一个新的镜像:

Docker 创建镜像

首先,让我将它运行起来,并在其中创建一个 test.txt 文件:

Docker 创建镜像

命令如下:

docker run -it docker.io/ubuntu:latest /bin/bash

root@a0a0c8cfec3a:/# touch test.txt

root@a0a0c8cfec3a:/# exit

复制代码

创建完 test.txt 文件后,需要记住标注的容器 ID: a0a0c8cfec3a, 用它来提交一个新的镜像(PS: 你也可以通过名称来提交镜像,这里只演示通过 ID 的方式)。

执行命令:

docker containercommit-m"Added test.txt file"-a"Allen"a0a0c8cfec3atest:0.1

复制代码

提交成功后,会返回新创建的镜像 ID 信息,如下图所示:

Docker 提交新创建的镜像

再次查看本地镜像信息,可以看到新创建的 test:0.1 镜像了:

Docker 查看镜像信息

3.1 导出镜像

查看本地镜像如下:

Docker 查看镜像信息

例如,我们想要将 python:3 镜像导出来,执行命令:

dockersave-opython_3.tarpython:3

复制代码

执行成功后,查看当前目录:

Docker 导出文件

可以看到 python_3.tar 镜像文件已经生成。接下来,你可以将它通过复制的方式,分享给别人了!

3.2 加载镜像

别人拿到了这个 tar 包后,要如何导入到本地的镜像库呢?

通过执行如下命令:

dockerload-i python_3.tar

复制代码

或者:

dockerload< python_3.tar

复制代码

4.3 上传镜像

进入命令行,用我们刚刚获取的 Docker ID 以及密码登录,执行命令:

dockerlogin

复制代码

命令行登录 Docker ID

登录成功后,我们开始准备上传本地的 python:3 镜像:

python:3 镜像

首先,我们对其打一个新的标签,前缀与我们新创建的 Docker ID 、仓库名保持一致:

docker tagpython:3weiwosuoai1991/python:3

复制代码

python:3 镜像打标签

查看本地信息,可以看到,标签打成功了。接下开,开始上传!执行命令:

docker push weiwosuoai1991/python:3

复制代码

上传 python:3 镜像

上传成功!去 Docker Hub 官网,新创建的仓库的信息页面验证一下,是否真的成功了:

仓库镜像展示页

上一篇 下一篇

猜你喜欢

热点阅读