最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    正文概述 掘金(果冻丨小布丁)   2021-02-02   929

    GitHub 篇

    1. 配置工作流程

    • 在仓库的根目录,创建 .github/workflows 目录

    • 在 .github/workflows 目录下 添加 xxx.yml 或 xxx.yaml 文件 (注意保持缩进, 文件名 xxx 随意,语法:参考资料 3. )

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    2. 配置服务器密钥:(密钥在文件在 ~/.ssh/ 目录下)

    • 生成密钥:ssh-keygen -m PEM -t rsa -b 4096 -C "jserhub@icloud.com"(注意邮箱更换成自己 GitHub 上的邮箱, 一路回车就行)
    • 将公钥保存到 authorized_keys 文件中:cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys

    3. 配置 GitHub SSH、Secrets

    • 配置路径:当前仓库 -> Settings -> Secrets (这里配置的变量是 xxx.yml 文件中 ${{secrets.你配置的名称}} 需要用到的。请看参考资料 4. )

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    • 配置 SSH 公钥 (将服务器公钥添加到 GitHub 账户的 SSH)

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    工作流程文件示例:

    name: Tser CI
    
    on:
      push:
        branches:
          - master
    
    jobs:
      # 发布到 GitHub Pages
      # build-and-deploy-to-github-pages:
      #   runs-on: ubuntu-latest
      #   steps:
      #     - name: Checkout
      #       uses: actions/checkout@master
    
      #     - name: Build and Deploy to GitHub Pages
      #       uses: JamesIves/github-pages-deploy-action@master
      #       env:
      #         ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}
      #         BRANCH: gh-pages
      #         FOLDER: build
      #         BUILD_SCRIPT: npm install && npm run build
    
      # 发布到服务器
      build-and-deploy-to-server:
        runs-on: ubuntu-latest
        steps:
          - name: Checkout
            uses: actions/checkout@master
    
          - name: Setup Node.js environment
            uses: actions/setup-node@v1
            with:
              node-version: 12.x
    
          - name: Install Dependencies
            run: npm install
            env:
              CI: true
    
          - name: Build Project
            run: npm run build
            env:
              CI: true
    
          - name: Deploy to Server
            uses: easingthemes/ssh-deploy@v2.1.2
            env:
              SSH_PRIVATE_KEY: ${{ secrets.SERVER_SSH_KEY }}
              ARGS: '-rltgoDzvO --delete'
              SOURCE: 'build/'
              REMOTE_HOST: ${{ secrets.REMOTE_HOST }}
              REMOTE_USER: ${{ secrets.REMOTE_USER }}
              TARGET: ${{ secrets.REMOTE_TARGET }}
    

    提交代码,在 仓库 -> Actions 下查看执行记录

    前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器




    GitLab 篇

    以 windows 为例

    1. 安装 GitLab Runner

    • 按 win + q 键,输入 powershell ,以管理员身份运行

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    • 安装 GitLab Runner (请看参考资料 1.)

      1. 在打开的 powershell 中 创建 C:\GitLab-Runner 目录 mkdir C:\GitLab-Runner
      2. 把下载的 gitlab-runner 安装包重命名成:gitlab-runner.exe 然后放到 C:\GitLab-Runner 目录下
      3. 在 powershell 中执行命令:cd C:\GitLab-Runner && .\gitlab-runner.exe install && .\gitlab-runner.exe start

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    • 注册 runners (同样以管理员身份在 powershell 中执行命令。请看参考资料 3.)

      注册所需 URL 和 token:(仓库 -> Settings -> CI/CD Pipelines)

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

      注册步骤:

      前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    2. 项目根目录下配置 .gitlab-ci.yml 文件 (不要随意起名,语法:请看参考资料 2.)

    .gitlab-ci.yml 文件内容示例:

    Deploy To Server:
      stage: deploy
      script:
        - ls
        - whoami
        - rm -r C:\inetpub\wwwroot\*
        - cp -r ./dist/* C:\inetpub\wwwroot\
      only:
        - master
      tags:
        - IFSDeploy
    

    注意: 我这里把打包之后的文件(dist 目录)也提交到仓库了,也可以把打包的步骤放到自动化部署中执行,需要去探索。


    起源地下载网 » 前端 CI/CD 自动化部署 GitHub / GitLab 项目到服务器

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元