Skip to main content

安装指南

Octopus 支持两种不同的部署方式,一种是基于Helm chart部署,另一种是基于Kustomize部署。

基于 Helm chart 部署#

说明

此仓库中的 Chart 需要 Helm 3.x 或更高版本。请阅读并遵循Helm 安装指南

Octopus-Chart项目包含了Octopus的官方 Helm Chart。 这些 Chart 用于将 Octopus 部署到 Kubernetes 或 k3s 集群。

添加 Octopus Helm 仓库#

为了能够使用此存储库中的 Chart,请将下列名称和 URL 添加到您的 Helm 客户端:

helm repo add octopus http://charts.cnrancher.com/octopus
helm repo update

安装应用#

请运行以下命令,将 Octopus Chart 安装到 Kubernetes 或 k3s 集群中:

kubectl create ns octopus-system
helm install --namespace octopus-system myapp octopus/octopus

安装成功后,您可以获取应用状态:

helm status myapp -n octopus-system

如果要删除应用,请使用以下命令:

helm delete myapp -n octopus-system

该命令几乎删除了与应用关联的所有 Kubernetes 组件,并删除了 Helm。

Helm Chart 和 Octopus 支持#

请访问Octopus github issues以获得支持。

基于 Kustomize 部署#

Kustomize 是解决 Kubernetes 应用程序管理的另一种工具,它使用的概念与 Helm 不同,后者称为声明式应用程序管理

Octopus 使用 Kustomize生成其安装程序的清单文件,安装程序 YAML 文件位于以下目录中的deploy/e2e目录下 Github,用户可以使用它来安装 Octopus 及其适配器。

  1. 安装 Octopus

    kubectl apply -f https://raw.githubusercontent.com/cnrancher/octopus/master/deploy/e2e/all_in_one.yaml
  2. 安装 Octopus 官方的协议适配器(包含 Modbus、OPC-UA、BLE、MQTT 和 Dummy)

    kubectl apply -f https://raw.githubusercontent.com/cnrancher/octopus/master/adaptors/modbus/deploy/e2e/all_in_one.yaml
    kubectl apply -f https://raw.githubusercontent.com/cnrancher/octopus/master/adaptors/opcua/deploy/e2e/all_in_one.yaml
    kubectl apply -f https://raw.githubusercontent.com/cnrancher/octopus/master/adaptors/mqtt/deploy/e2e/all_in_one.yaml
    kubectl apply -f https://raw.githubusercontent.com/cnrancher/octopus/master/adaptors/ble/deploy/e2e/all_in_one.yaml
    kubectl apply -f https://raw.githubusercontent.com/cnrancher/octopus/master/adaptors/dummy/deploy/e2e/all_in_one.yaml

动画快速演示#

asciicast

process instruction# deploy octopus without webhook kubectl apply -f deploy/e2e/all_in_one.yaml # confirm the octopus deployment kubectl get all -n octopus-system kubectl get crd | grep devicelinks # deploy a devicelink cat adaptors/dummy/deploy/e2e/dl_specialdevice.yaml kubectl apply -f adaptors/dummy/deploy/e2e/dl_specialdevice.yaml # confirm the state of devicelink kubectl get dl living-room-fan -n default # deploy dummy adaptor and model kubectl apply -f adaptors/dummy/deploy/e2e/all_in_one.yaml # confirm the dummy adaptor deployment kubectl get daemonset octopus-adaptor-dummy-adaptor -n octopus-system kubectl get crd | grep dummyspecialdevice # confirm the state of devicelink kubectl get dl living-room-fan -n default # watch the device instance kubectl get dummyspecialdevice living-room-fan -n default -w
Last updated on by yzeng25