zoukankan      html  css  js  c++  java
  • 自动化部署到产线有这几种方法

    结论

    - 目前有13 种方法 支持 自动化部署

    一、Docker (Nginx)

    在 Docker 容器中使用 Nginx 部署你的应用。

    1. 安装 Docker

    2. 在项目根目录创建 Dockerfile 文件

      FROM node:10
      COPY ./ /app
      WORKDIR /app
      RUN npm install && npm run build
      
      FROM nginx
      RUN mkdir /app
      COPY --from=0 /app/dist /app
      COPY nginx.conf /etc/nginx/nginx.conf
      
    3. 在项目根目录创建 .dockerignore 文件

      设置 .dockerignore 文件能防止 node_modules 和其他中间构建产物被复制到镜像中导致构建问题。

      **/node_modules
      **/dist
      

        

    4. 在项目根目录创建 nginx.conf 文件

      Nginx 是一个能在 Docker 容器中运行的 HTTP(s) 服务器。它使用配置文件决定如何提供内容、要监听的端口等。参阅 Nginx 设置文档 以了解所有可能的设置选项。

      下面是一个简单的 Nginx 设置文件,它会在 80 端口上提供你的 Vue 项目。页面未找到 / 404 错误使用的是 index.html,这让我们可以使用基于 pushState() 的路由。

      user  nginx;
      worker_processes  1;
      error_log  /var/log/nginx/error.log warn;
      pid        /var/run/nginx.pid;
      events {
        worker_connections  1024;
      }
      http {
        include       /etc/nginx/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"';
        access_log  /var/log/nginx/access.log  main;
        sendfile        on;
        keepalive_timeout  65;
        server {
          listen       80;
          server_name  localhost;
          location / {
            root   /app;
            index  index.html;
            try_files $uri $uri/ /index.html;
          }
          error_page   500 502 503 504  /50x.html;
          location = /50x.html {
            root   /usr/share/nginx/html;
          }
        }
      }
      

        

    5. 构建你的 Docker 镜像
      docker build . -t my-app
      # Sending build context to Docker daemon  884.7kB
      # ...
      # Successfully built 4b00e5ee82ae
      # Successfully tagged my-app:latest
      

        

    6. 运行你的 Docker 镜像

      这个例子基于官方 Nginx 镜像,因此已经设置了日志重定向并关闭了自我守护进程。它也提供了其他有利于 Nginx 在 Docker 容器中运行的默认设置。更多信息参阅 Nginx Docker 仓库

      docker run -d -p 8080:80 my-app
      curl localhost:8080
      # <!DOCTYPE html><html lang=en>...</html>
      

        

    注:推荐此方案

    二、GitLab Pages

    根据 GitLab Pages 文档的描述,所有的配置都在根目录中的.gitlab-ci.yml 文件中。下面的范例是一个很好的入门:

    # .gitlab-ci.yml 文件应放在你仓库的根目录下 
    
    pages: # 必须定义一个名为 pages 的 job
      image: node:latest
      stage: deploy
      script:
        - npm ci
        - npm run build
        - mv public public-vue # GitLab Pages 的钩子设置在 public 文件夹
        - mv dist public # 重命名 dist 文件夹 (npm run build 之后的输出位置)
      artifacts:
        paths:
          - public # artifact path 一定要在 /public , 这样 GitLab Pages 才能获取
      only:
        - master
    

    通常, 你的静态页面将托管在 https://yourUserName.gitlab.io/yourProjectName 上, 所以你可以创建一个 initial vue.config.js 文件去 更新 BASE_URL 要匹配的值 :

    // vue.config.js 位于仓库的根目录下
    // 确保用 GitLab 项目的名称替换了 `YourProjectName`
    
    module.exports = {
      publicPath: process.env.NODE_ENV === 'production'
        ? '/yourProjectName/'
        : '/'
    }
    

    请阅读在 GitLab Pages domains 的文档来学习更多关于页面部署 URL 的信息。注意,你也可以使用自定义域名

    在推送到仓库之前提交 .gitlab-ci.yml 和 vue.config.js 文件。GitLab CI 的管道将会被触发: 当成功时候, 到 Settings > Pages 查看关于网站的链接。

    注:此方案支持公司内部代码存放

    三、GitHub Pages 

     

    使用 Travis CI 自动更新

    1. 仿照上面在 vue.config.js 中设置正确的 publicPath

    2. 安装 Travis CLI 客户端:gem install travis && travis --login

    3. 生成一个拥有“repo”权限的 GitHub 访问令牌

    4. 授予 Travis 访问仓库的权限:travis set GITHUB_TOKEN=xxx (xxx 是第三步中的个人访问令牌)

    5. 在项目根目录下创建一个 .travis.yml 文件。

      language: node_js
      node_js:
        - "node"
      
      cache: npm
      
      script: npm run build
      
      deploy:
      provider: pages
      skip_cleanup: true
      github_token: $GITHUB_TOKEN
      local_dir: dist
      on:
        branch: master
      

        

    6. 将 .travis.yml 文件推送到仓库来触发第一次构建

    使用 Nuxt 自动更新

       1. 链接

    注:此方法不用于存放商业代码,可以做类似 Demo 

    四、Vercel

    Vercel 是一个网站和无服务器 (Serverless) API 云平台,你可以使用你的个人域名 (或是免费的 .vercel.app URL) 部署你的 Vue 项目。

    方案一:

      步骤一:安装 Now CLI

    1. 要使用 npm 安装其命令行界面,运行以下命令:
      npm install -g vercel
      

          

    步骤二:部署

    1. 在项目根目录运行以下命令部署你的应用:
      vercel

    方案二:

       GitHub 或 GitLab 集成服务

    注:此方案需要谨慎选择

    五、其他

    我这边已经抽出我们会经常用到的方案给到大家,其他的案例请参考 VueCli 给出的其他方案

  • 相关阅读:
    【网络爬虫】【python】网络爬虫(五):scrapy爬虫初探——爬取网页及选择器
    AndroidStudio的transformDexArchiveWithExternalLibsDexMergerForDebug报错解决方案
    SQL笔记
    基尼系数
    搜索评价指标——NDCG
    Bayes' theorem (贝叶斯定理)
    itembase协同过滤的详细介绍
    线性回归

    指标、统计和分布
  • 原文地址:https://www.cnblogs.com/gqx-html/p/14677384.html
Copyright © 2011-2022 走看看