JavaScript

    您只需在 pipeline.yml 中配置部分参数即可使用该插件。根据运行时容器的类型可分为:

    • Herd:使用 Erda 提供的 Node.js 运行
    • Single-Page Application(SPA):使用 Nginx 作为容器运行

    当前支持 12.13.1 LTS 版本。

    安装依赖

    插件需使用 安装依赖。

    相较于传统的 npm install,npm ci 的优势在于:

    • 依赖版本锁定
    • 更快的依赖安装速度

    npm ci 需在应用目录下提供 package.json 和 package-lock.json 两个文件。

    使用该插件构建镜像时,需明确以下几点:

    • 打包工具是什么? 平台不限制打包工具,Webpack、Rollup 等工具均可。

    • 在哪个路径执行打包工具? 代码根目录,即 所在目录。

    • 依赖下载命令 npm ci

    ::: tip 提示 明确以上问题,有助于您更好地理解在 Erda 上构建 JavaScript 应用时需填写的配置,以及 Erda 如何执行 JavaScript。 :::

    JavaScript 构建分为两部分:

    • 通过指明的打包方式和上下文参数,将源代码编译为打包产物。
    • 按照指明的运行环境和版本,选择基础镜像,将构建产物制作成运行镜像。

    pipeline.yml 示例如下:

    • 依赖npm ci
    • 编译npm run build,编译后,编译目录下的所有文件都将被放入镜像中
    • 运行npm run start,可使用编译后的所有文件

    pipeline.yml 示例如下:

    1. version: 1.1
    2. stages:
    3. - stage:
    4. - stage:
    5. - js:
    6. params:
    7. workdir: ${git-checkout}
    8. build_cmd: npm run build
    9. container_type: herd

    SPA

    • 依赖npm ci
    • 编译npm run build,编译后,编译目录下的 public 文件夹(可在 params 中通过 dest_dir 调整)将被放入镜像中
    • 运行:启动 Nginx

    应用需在编译目录下提供一个 Nginx 配置模板文件,文件名为固定的 nginx.conf.template。该模板文件可使用环境变量,Erda 在运行时将动态替换环境变量的值,随后启动 Nginx。

    模板文件参考如下:

    1. listen 80;
    2. server_name localhost;
    3. root /usr/share/nginx/html;
    4. # compression
    5. gzip on;
    6. gzip_min_length 2k;
    7. gzip_buffers 4 16k;
    8. gzip_http_version 1.0;
    9. gzip_comp_level 3;
    10. gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
    11. gzip_vary on;
    12. client_max_body_size 0;
    13. set $OPENAPI_ADDR ${API_ADDR}; # 需要在 dice.yml 的 envs 字段或 Erda 平台的应用设置-部署变量中配置变量名 API_ADDR
    14. location /api {
    15. proxy_pass $OPENAPI_ADDR;
    16. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    17. }
    18. }

    pipeline.yml 示例如下:

    打包加速

    相比 npm install,使用 可加速打包。

    后续将在 Erda 集群内提供企业级 npm 代理仓库,用于缓存 npm package 并加速打包。

    1. - stage:
    2. - js:
    3. caches:
    4. - path: ${git-checkout}/node_modules
    5. params:
    6. workdir: ${git-checkout}
    7. build_cmd: npm run build
    8. container_type: spa

    ${git-checkout}/node_modules:${git-checkout} 为项目路径,node_modules 则是 npm 构建后生成的包路径,缓存后下一次将会加速。

    • Herd
    • SPA
    • Node.js

    接入平台监控

    通过接入监控,可统计页面加载性能、报错和用户相关信息,更好地了解性能、质量问题和分析用户。

    无侵入式监控,插件在制作镜像时,将自动安装对应 Erda 版本的 @terminus/spot-agent@~${ERDA_VERSION}

    SPA 接入监控

    SPA 暂不支持无侵入式浏览器监控接入,需手动接入。接入方式如下:

    • 在模板页的 head 中添加 ta.js

      1. <script src="/ta"></script>
      2. <script>
      3. var _taConfig = window._taConfig;
      4. if (_taConfig && _taConfig.enabled) {
      5. !function(e,n,r,t,a,o,c){e[a]=e[a]||function(){(e[a].q=e[a].q||[]).push(arguments)},e.onerror=function(n,r,t,o,c){e[a]("sendExecError",n,r,t,o,c)},n.addEventListener("error",function(n){e[a]("sendError",n)},!0),o=n.createElement(r),c=n.getElementsByTagName(r)[0],o.async=1,o.src=t,c.parentNode.insertBefore(o,c)}(window,document,"script",_taConfig.url,"$ta");
      6. $ta('start', { udata: { uid: 0 }, ak: _taConfig.ak, url: _taConfig.collectorUrl });
      7. }
      8. </script>
    • nginx.conf.template 中添加 /ta 请求处理。

    • 在项目目录安装 spot-agent 依赖。

      1. ## npm config set registry https://registry.npm.terminus.io
      2. npm i @terminus/spot-agent@~3.20
    • 在 Node 应用的启动类(通常为 index.js)第一行添加 Agent 的启动代码。

      自定义镜像接入监控