我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Docker部署单页应用的详细操作

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Docker部署单页应用的详细操作

1. Docker 介绍

Docker 是一个基于 GO 语言和 Linux 内核的虚拟化容器技术,遵从 Apache2.0 协议开源。

Docker 与虚拟机给人的感觉比较相似,但是两者的实现原理不同:Docker 是虚拟化操作系统,而虚拟机则是虚拟化硬件设备。Docker 可利用 Linux 内核来创建独立的 Linux 容器,只占用一组与操作系统隔离的进程,就可以创建一个内部环境保持不变的容器。这种方式也更加利于项目迁移和运行,并且相比虚拟机,也省去了大量的系统配置和资源占用。

2. Docker 安装

windows 环境下安装 Docker 需要安装桌面端,直接在 Docker - Get Started 页面下载对应的 Docker Desktop 安装包安装即可。

3. Docker 基本操作

因为 Docker 是一种虚拟化容器技术,所以最常用的操作就是“容器”「Container」的操作;另外容器的创建也需要一个基础的创建模板,这个模板就是“镜像”「Image」。

这里简单介绍一下与镜像和容器相关的几个基本操作:

# docker拉取镜像,例如 docker pull nginx:1.21.6
docker pull 镜像别名:版本号
# 删除镜像,例如 docker rmi nginx:1.21.6
docker rmi 镜像id/镜像name
# 查看镜像列表
docker images

# 查看容器列表, 不加-a查看正在运行的,加上-a查看所有容器
docker ps -a
# 启动容器
#(-d 后台运行, --name 容器别名, -p 宿主机端口:容器端口, --network 桥接网络别名, 最后是镜像名称:镜像版本)
docker run -d  --restart always --name vue-app-container -p 3006:3006 vue-app:1.0.0
# 关闭一个已启动容器,例如 docker stop vue-app-container
docker stop 容器ID/容器别名
# 启动一个关闭的容器 ,例如 docker start vue-app-container
docker start 容器ID/容器别名
# 删除容器,例如 docker rm vue-app-container
docker rm 容器ID/容器名
# 查看一个容器的详情 ,例如 docker inspect vue-app-container
docker inspect 容器ID/容器别名
# 进入容器内部,例如 docker exec -it vue-app-container /bin/bash
docker exec -it 容器ID/容器别名 /bin/bash

4. Vue 应用镜像

这里不论是 Vue 应用还是 React 之类的应用,都可以用这样的方式发布;Vite 和 Webpack 也可以不做区分

首先,Vue 之类的单页应用,不论是用 Vite 还是 Webpack,都需要将对应的项目代码打包成普通的 js、css 等文件,最后通过 Nginx 等进行发布。

所以,创建单页应用镜像的第一步就是打包。

Docker 创建镜像的方式有:

  • 基于远程 pull 的镜像创建
  • 本地导入镜像(也可以看做是直接使用)
  • 基于 Dockerfile 创建(最常用的创建方式)

4.1 Dockerfile 配置文件

什么是 Dockerfile?

Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。

---摘自“菜鸟教程”

Dockerfile 文件的第一行命令,都是 FROM 命令,表示依赖的镜像。因为我们创建的镜像基本上都不会从0开始,最低都会依赖一个系统镜像。

文件内每条执行命令都以一个关键词作为开始,常用命令有:

  • FROM: 依赖镜像
  • RUN:需要执行的 shell 命令
  • COPY:文件复制命令
  • CMD:镜像容器运行时执行的命令
  • ENV:环境变量,一般会在 Dockerfile 文件内部预先定义
  • ARG:构建参数,类似环境变量,仅在 build 镜像时定义
  • VOLUME:需要挂载的数据卷,将容器内的某个数据卷映射为宿主机的磁盘位置,可以避免容易过大或者数据丢失
  • EXPOSE:仅声明使用端口,只有在运行容器时没有指定端口的时候自动映射到这里指定的端口

4.2 编写 Nginx 配置文件

在构建 Docker 镜像时,虽然可以执行一些命令,但是基本上不会通过命令来创建一个 nginx 配置文件。所以,我们需要在项目目录中创建一个 nginx.conf 文件。

### :::
### 服务器 nginx 配置,请勿改变 listen 端口
### :::
server {
    listen       80;
    server_name  localhost;

    root   /usr/share/nginx/vue-app;

    location / {
        try_files $uri $uri/ /index.html;
        index  index.html index.htm;
    }

    # 接口转发
    location ~* ^\/(sys|app)\/ {
       proxy_pass                 http://app-server:8080;
       proxy_redirect             off;
       proxy_set_header           Host $host;
       proxy_set_header           X-Real-IP $remote_addr;
       proxy_set_header           X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

这个 nginx.conf 文件仅作为示例,需要根据实际情况修改。

4.3 构建镜像

在执行镜像构建命令之前,我们需要在根目录下创建一个 Docker 配置文件 Dockerfile

# 配置 nginx 资源转发, alpine 为纯净版本
FROM nginx:1.21.6

# 服务器环境
COPY dist/ /usr/share/nginx/hwiot-web/

COPY nginx.conf /etc/nginx/conf.d/default.conf

这个文件仅仅是将外部打包后的 dist 文件夹里面的内容,复制到容器内的 /usr/share/nginx/vue-app/ 内,在复制 nginc.conf 文件到 /etc/nginx/conf.d/default.conf 作为默认 Nginx 配置。

之后执行构建命令:

docker build -t vue-app:1.0.0 .

注意后面的 .

这一步会默认在当前目录查找 Dockerfile 文件并进行镜像构建,并且用 -t 指定镜像名和镜像版本号。

5. 创建容器与启动

在上一步镜像创建完成之后,就可以根据该镜像创建容器了。

docker run -p 80:80 -d -name vue-app-container vue-app

这里指定了将容器的 80 端口映射到宿主机的80,端口,这样我们直接在本地打开浏览器访问 http://localhost 即可。

总结

到此这篇关于Docker部署单页应用的文章就介绍到这了,更多相关Docker部署单页应用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Docker部署单页应用的详细操作

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Docker部署单页应用的详细操作

Docker现在越来越流行,但是真正在生产环境部署Docker还是个比较新的概念,还没有一个标准的流程,下面这篇文章主要给大家介绍了关于Docker部署单页应用的相关资料,需要的朋友可以参考下
2022-11-13

在Docker快速部署Node.js应用的详细步骤

一、前言 可能还有一些同学不了解docker这个项目,docker是由go语言编写的,一个快速部署的轻量级虚拟技术项目,他允许开发人员将自己的程序和运行环境一起打包,制作成一个docker的image(镜像),这样部署到服务器上,也只需要下
2022-06-04

vue单页面应用部署配置详解

本文主要介绍了vue单页面应用部署配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-16

centos8使用Docker部署Django项目的详细教程

引言 在本文中将介绍在docker中通过django + uwsgi + nginx部署方式部署Django项目, 由于记录的是学习过程,使用的都是目前较高的版本。python 版本为3.8.3 django 版本为3.0.6 ngin
2022-06-04

Docker部署java项目的详细步骤(利用Dockerfile方式)

docker可以利用简单的编写程序构建出任何你想要的环境,同时可以跟业务代码相结合,快速构建和生成所需要的应用,下面这篇文章主要给大家介绍了关于Docker部署java项目的详细步骤,本文主要利用的是Dockerfile方式,需要的朋友可以参考下
2022-11-13

部署Node.js到阿里云服务器的详细操作步骤

Node.js是一种基于ChromeV8JavaScript引擎的、运行在服务端的JavaScript运行环境。阿里云服务器是阿里云推出的一种云计算产品,提供了丰富的云服务和强大的计算能力。本文将详细介绍如何将Node.js部署到阿里云服务器。一、准备工作在开始部署Node.js之前,首先需要准备一台阿里云服务器
部署Node.js到阿里云服务器的详细操作步骤
2023-11-17

云原生使用Docker部署mysql数据库的详细过程

目录一、检查系统版本二、检查docker状态1.检查docker版本2.检查docker状态三、在docker hub搜索mysql四、下载mysql镜像五、创建mysql容器1.创建数据目录2.运行mysql容器3.查看mysql容器状态
2023-03-23

Node项目部署到阿里云服务器的详细操作指南

本篇教程将详细说明如何将Node项目部署到阿里云服务器。我们将会首先创建阿里云服务器,然后安装Node.js和npm,最后将项目代码上传到服务器,实现项目的部署。一、创建阿里云服务器首先,你需要在阿里云的官网注册并登录你的账户,然后点击“产品与服务”->“服务器”->“ECS实例”来创建一个新的ECS实例。在实例
Node项目部署到阿里云服务器的详细操作指南
2023-11-22

Python操作Redis数据库的详细教程与应用实战

目录引言安装Redis-py库连接到Redis服务器连接到本地Redis服务器连接到远程Redis服务器数据操作键值对操作哈希表操作列表操作集合操作有序集合操作事务订阅与发布管道(Pipeline)持久化与备份总结引言Redis是一个高性
Python操作Redis数据库的详细教程与应用实战
2024-08-12

网络操作系统中的容器技术:轻量级应用部署的新天地

: 容器技术在网络操作系统中扮演着关键角色,通过隔离和打包应用程序,实现轻量级部署和可移植性。本文将深入探讨容器技术的优势,展示如何使用流行的容器引擎如 Docker 和 Kubernetes 部署应用程序。
网络操作系统中的容器技术:轻量级应用部署的新天地
2024-03-05

编程热搜

目录