跳转至

离线升级可观测性模块

本页说明下载可观测性模块后,应该如何安装或升级。

Info

下述命令或脚本内出现的 insight 字样是可观测性模块的内部开发代号。

解压下载的包得到bundle包

  tar -xvf insight_v0.25.3_amd64.tar

解压后可得到insight和insight-agent对应2个bundle.tar包

  # ll insight_v0.25.3_amd64
  总用量 2899996
  -rw-r--r-- 1 root root 2367463936 4月   2 18:36 insight_0.25.3.bundle.tar
  -rw-r--r-- 1 root root  602125824 4月   2 18:35 insight-agent_0.25.3.bundle.tar

从安装包中加载镜像

您可以根据下面两种方式之一加载镜像,当环境中存在镜像仓库时,建议选择 chart-syncer 同步镜像到镜像仓库,该方法更加高效便捷。需注意,charts-syncer版本需大于等于 0.0.22

chart-syncer 同步镜像到镜像仓库

  1. 创建 load-image.yaml

    Note

    该 YAML 文件中的各项参数均为必填项。您需要一个私有的镜像仓库,并修改相关配置。

    若当前环境已安装 HARBOR chart repo,chart-syncer 也支持将 chart 导出为 tgz 文件。

    load-image.yaml
    source:
      intermediateBundlesPath: insight-offline # 到执行 charts-syncer 命令的相对路径,而不是此 YAML 文件和离线bundle包之间的相对路径
    target:
      containerPrefixRegistry: 10.16.10.111 # 需更改为你的镜像仓库 url
      appendOriginRegistry: true
      repo:
        kind: HARBOR # 也可以是任何其他支持的 Helm Chart 仓库类别
        url: http://10.16.10.111/chartrepo/release.daocloud.io # 需更改为 chart repo project url
        auth:
          username: "admin" # 你的镜像仓库用户名
          password: "Harbor12345" # 你的镜像仓库密码
      containers:
        auth:
          username: "admin" # 你的镜像仓库用户名
          password: "Harbor12345" # 你的镜像仓库密码
    

    若当前环境已安装 CHARTMUSEUM chart repo,chart-syncer 也支持将 chart 导出为 tgz 文件。

    load-image.yaml
    source:
      intermediateBundlesPath: insight-offline # 到执行 charts-syncer 命令的相对路径,而不是此 YAML 文件和离线bundle包之间的相对路径
    target:
      containerPrefixRegistry: 10.16.10.111 # 需更改为你的镜像仓库 url
      appendOriginRegistry: true
      repo:
        kind: CHARTMUSEUM # 也可以是任何其他支持的 Helm Chart 仓库类别
        url: http://10.16.10.111 # 需更改为 chart repo url
        auth:
          username: "rootuser" # 你的镜像仓库用户名, 如果 chartmuseum 没有开启登录验证,就不需要填写 auth
          password: "rootpass123" # 你的镜像仓库密码
      containers:
        auth:
          username: "rootuser" # 你的镜像仓库用户名
          password: "rootpass123" # 你的镜像仓库密码
    

    若当前环境未安装 chart repo,chart-syncer 也支持将 chart 导出为 tgz 文件,并存放在指定路径。

    load-image.yaml
    source:
      intermediateBundlesPath: insight-offline # (1)
    target:
      containerPrefixRegistry: 10.16.10.111 # (2)
      repo:
        kind: LOCAL
        path: ./local-repo # (3)
      containers:
        auth:
          username: "admin" # (4)
          password: "Harbor12345" # (5)
    
    1. 到执行 charts-syncer 命令的相对路径,而不是此 YAML 文件和离线包之间的相对路径
    2. 需更改为你的镜像仓库 url
    3. chart 本地路径
    4. 你的镜像仓库用户名
    5. 你的镜像仓库密码
  2. 执行同步镜像命令。

    charts-syncer sync --config load-image.yaml --insecure
    

Docker 或 containerd 直接加载

解压并加载镜像文件。

  1. 解压 tar 压缩包。

    tar -xvf insight_0.25.3.bundle.tar
    

    解压成功后会得到 3 个文件:

    • hints.yaml
    • images.tar
    • original-chart
  2. 从本地加载镜像到 Docker 或 containerd。

    docker load -i images.tar
    
    ctr -n k8s.io image import images.tar
    

Note

每个 node 都需要做 Docker 或 containerd 加载镜像操作。 加载完成后需要 tag 镜像,保持 Registry、Repository 与安装时一致。

升级

有两种升级方式。您可以根据前置操作,选择对应的升级方案。升级前,请关注「升级注意事项」

  1. 检查 Insight helm 仓库是否存在。

    helm repo list | grep insight
    

    若返回结果为空或如下提示,则进行下一步;反之则跳过下一步。

    Error: no repositories to show
    
  2. 添加 Insight的 helm 仓库。

    helm repo add insight http://{harbor url}/chartrepo/{project} --insecure-skip-tls-verify
    
  3. 更新 Insight 的 helm 仓库。

    helm repo update insight # (1)
    
    1. helm 版本过低会导致失败,若失败,请尝试执行 helm update repo
  4. 选择您想安装的 Insight 版本(建议安装最新版本)。

    helm search repo insight/insight --versions
    helm search repo insight/insight-agent --versions
    
    [root@master ~]# helm search repo insight/insight --versions
    NAME                   CHART VERSION  APP VERSION  DESCRIPTION
    insight/insight        0.25.3          0.25.3       A Helm chart for Insight
    insight/insight-agent  0.25.3          0.25.3       A Helm chart for Insight Agent
    ...
    
  5. 备份 --set 参数。

    在升级 Insight 版本之前,建议您执行如下命令,备份老版本的 --set 参数。

    helm get values insight -n insight-system -o yaml > insight.yaml
    helm get values insight-agent -n insight-system -o yaml > insight-agent.yaml
    
  6. 执行 helm upgrade

    helm upgrade insight insight/insight \
      -n insight-system \
      -f ./insight.yaml \
      --version 0.25.3
    

    以及

    helm upgrade insight-agent insight/insight-agent \
      -n insight-system \
      -f ./insight-agent.yaml \
      --version 0.25.3
    
  1. 备份 --set 参数。

    在升级 Insight 版本之前,建议您执行如下命令,备份老版本的 --set 参数。

    helm get values insight -n insight-system -o yaml > insight.yaml
    
  2. 执行 helm upgrade

    升级前建议您覆盖 bak.yaml 中的 global.imageRegistry 为当前使用的镜像仓库地址。

    export imageRegistry={你的镜像仓库}
    
    helm upgrade insight . \
      -n insight-system \
      -f ./insight.yaml \
      --set global.imageRegistry=$imageRegistry
    

    以及

    helm upgrade insight-agent . \
      -n insight-system \
      -f ./insight-agent.yaml \
      --set global.imageRegistry=$imageRegistry
    

评论