百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 博客教程 > 正文

helm kong yaml ternary

connygpt 2024-09-09 03:08 12 浏览

  • summary
  • 首先根据这段代码抛砖引玉 学习下?helm 以及?helm 语法?和?用法?
Bash
这段代码是一个 Kubernetes 的 YAML 配置文件模板,
用于创建一个 HorizontalPodAutoscaler 对象,
用于自动调整 Kubernetes 集群中 Pod 的数量,
以适应负载的变化。具体来说,
这个 YAML 文件模板将根据配置文件中的值来创建一个
HorizontalPodAutoscaler 对象,
并根据不同版本的 Kubernetes API 来设置不同的属性。
下面是这段代码的详细解释:
  • yaml
Bash
{{- if .Values.autoscaling.enabled }}
apiVersion: {{ .Capabilities.APIVersions.Has "autoscaling/v2beta2" | ternary "autoscaling/v2beta2" "autoscaling/v1" }}
kind: HorizontalPodAutoscaler
metadata:
  name: "{{ template "kong.fullname" . }}"
  namespace:  {{ template "kong.namespace" . }}
  labels:
    {{- include "kong.metaLabels" . | nindent 4 }}
spec:
  scaleTargetRef:
    apiVersion: apps/v1
    kind: Deployment
    name: "{{ template "kong.fullname" . }}"
  minReplicas: {{ .Values.autoscaling.minReplicas }}
  maxReplicas: {{ .Values.autoscaling.maxReplicas }}
  {{- if not (.Capabilities.APIVersions.Has "autoscaling/v2beta2") }}
  targetCPUUtilizationPercentage: {{ .Values.autoscaling.targetCPUUtilizationPercentage | default 80 }}
  {{- else }}
  metrics:
    {{- toYaml .Values.autoscaling.metrics | nindent 4 }}
  {{- end }}
{{- end }}
  • explain
它使用了 ternary 操作符来动态设置 apiVersion 的值:
{{ .Capabilities.APIVersions.Has "autoscaling/v2beta2" | ternary "autoscaling/v2beta2" "autoscaling/v1" }}
ternary 的语法是:
条件表达式 ? 值1 : 值2
如果条件表达式为真,返回值1,否则返回值2。
在这里:
- .Capabilities.APIVersions.Has "autoscaling/v2beta2" 检查是否支持 autoscaling/v2beta2 版本
- 如果支持,ternary 返回 "autoscaling/v2beta2"
- 如果不支持,返回 "autoscaling/v1"
这样可以根据集群环境动态采用合适的 autoscaling apiVersion。
另外,它还使用了 Helm 的 template 和 include 功能:
- {{ template "kong.fullname" . }} 渲染一个名为 kong.fullname 的模板
- {{- include "kong.metaLabels" . | nindent 4 }} 渲染 kong.metaLabels 模板,并缩进 4 个空格
- {{- toYaml .Values.autoscaling.metrics | nindent 4 }} 渲染 metrics 并缩进 4 个空格


首先,使用条件语句 if 判断 .Values.autoscaling.enabled 的值是否为真。.Values 是一个 Helm Chart 中定义的变量,这个变量用于存储用户在安装 Chart 时指定的值。如果 .Values.autoscaling.enabled 为真,那么这个模板文件会继续执行,否则会跳过整个文件。

如果 .Values.autoscaling.enabled 为真,那么这个模板文件会根据 Kubernetes API 的版本来设置 apiVersion 属性。具体来说,使用 {{ .Capabilities.APIVersions.Has "autoscaling/v2beta2" | ternary "autoscaling/v2beta2" "autoscaling/v1" }} 来判断 Kubernetes 集群是否支持 autoscaling/v2beta2 版本的 API。如果支持,那么设置 apiVersion 为 autoscaling/v2beta2,否则设置为 autoscaling/v1。这里使用了 ternary 函数,它的作用是根据第一个参数的值来返回第二个参数或第三个参数。如果第一个参数为真,那么返回第二个参数,否则返回第三个参数。

接下来,设置 kind 为 HorizontalPodAutoscaler,metadata.name 为 {{ template "kong.fullname" . }}(其中 {{ template "kong.fullname" . }} 是一个 Helm 模板函数,用于生成名称),metadata.namespace 为 {{ template "kong.namespace" . }}(其中 {{ template "kong.namespace" . }} 是另一个 Helm 模板函数,用于生成命名空间)。设置 spec.scaleTargetRef 为 Deployment 对象的引用,spec.minReplicas 和 spec.maxReplicas 分别为 .Values.autoscaling.minReplicas 和 .Values.autoscaling.maxReplicas(这些都是用户在安装 Chart 时配置的变量)。

最后,如果 Kubernetes 集群不支持 autoscaling/v2beta2 版本的 API,那么设置 spec.targetCPUUtilizationPercentage 为 .Values.autoscaling.targetCPUUtilizationPercentage 的值(如果未指定,则默认为 80)。否则,设置 spec.metrics 为 .Values.autoscaling.metrics 的值。.Values.autoscaling.metrics 是用户在安装 Chart 时配置的一个列表,用于指定要监控的指标。这里使用了 toYaml 函数将列表转换为 YAML 格式。

综上所述,这段代码的作用是根据用户在安装 Helm Chart 时的配置,生成一个 HorizontalPodAutoscaler 对象,并根据 Kubernetes API 的版本来设置不同的属性。

安装Helm

要安装Helm,请按照以下步骤操作:

  1. 下载并安装Helm二进制文件,可以从Helm的官方GitHub存储库下载适用于你的操作系统的最新版本。
  2. 将Helm二进制文件解压缩,并将可执行文件添加到系统的PATH环境变量中。
  3. 验证Helm安装是否成功,运行以下命令:
   helm version

创建和管理Chart

要创建和管理Helm Charts,请遵循以下步骤:

  1. 创建一个新的Chart,使用以下命令:
   helm create mychart
  1. 进入Chart目录,你可以编辑Chart的配置文件和模板文件来定义应用程序的配置和部署要求。
  2. 打包Chart为可分发的tar文件,使用以下命令:
   helm package mychart
  1. 将Chart安装到Kubernetes集群,使用以下命令:
   helm install <release_name> mychart-0.1.0.tgz
   helm install my-release stable/mysql
   这个命令会安装名为 my-release 的 Release,并使用 stable/mysql Chart。
   如果你想指定 Chart 的版本或使用其他自定义值,可以使用 --version 和 --set 参数
  1. 查询 Chart
要查询已经安装的 Helm Charts,你可以使用 helm list 命令。下面是一个例子:
helm list
这个命令会显示所有已安装的 Release 的名称、Chart 的名称、版本、命名空间和状态。
  1. 要查看特定 Release 的详细信息,可以使用 helm status 命令。下面是一个例子:
helm status my-release
这个命令会显示名为 my-release 的 Release 的详细信息,包括 Chart 的名称、版本、命名空间、状态和配置信息。

更新和升级Chart

要更新和升级已部署的Helm Chart,请按照以下步骤操作:

  1. 更新Chart文件或值文件中的配置。你可以修改Chart的values.yaml文件或使用—set参数来覆盖默认值。
  2. 更新Chart的发布,使用以下命令:
   helm upgrade <release_name> <chart_directory>

确保将<release_name>替换为你的发布名称,<chart_directory>替换为Chart所在的目录。

  1. 回滚到先前的版本,使用以下命令: helm rollback 将<revision_number>替换为要回滚到的版本号。
在使用 Helm 管理 Kubernetes 应用程序时,可能需要对已安装的 Chart 进行回滚操作,以恢复到之前的版本。下面是使用 Helm 进行回滚操作的步骤:
首先,使用 helm list 命令查找要回滚的 Release 的名称和版本。例如,假设我们要回滚名为 my-release 的 Release 到上一个版本,可以使用以下命令:
helm list
这个命令会显示所有已安装的 Release 的名称、Chart 的名称、版本、命名空间和状态。找到名为 `my-release` 的 Release,并记录当前版本号和上一个版本号。
接下来,使用 helm rollback 命令回滚到上一个版本。例如,假设我们要回滚名为 my-release 的 Release 到上一个版本,可以使用以下命令:
helm rollback my-release <previous_version>
其中 <previous_version> 是上一个版本的版本号。例如,如果当前版本号是 2,上一个版本号是 1,则命令应该是:
helm rollback my-release 1
等待 Helm 回滚操作完成并验证应用程序的状态。可以使用 helm status 命令检查应用程序的状态,以确保回滚操作已成功完成。
  1. 如何查看 Helm 回滚操作的进度
在使用 Helm 进行回滚操作时,可能需要查看回滚操作的进度,以了解回滚操作的状态和任何错误或警告消息。下面是查看 Helm 回滚操作进度的步骤:
首先,使用 helm rollback 命令启动回滚操作。例如,假设我们要将名为 my-release 的 Release 回滚到上一个版本,可以使用以下命令:
helm rollback my-release <previous_version>
其中 `<previous_version>` 是上一个版本的版本号。
在回滚操作进行期间,可以使用 helm status 命令查看应用程序的状态并监视回滚操作的进度。例如,可以使用以下命令:
helm status my-release
这个命令会显示名为 my-release 的 Release 的详细信息,包括 Chart 的名称、版本、命名空间、状态和配置信息。
在回滚操作完成后,可以再次运行 helm status 命令来验证应用程序的状态,并确保回滚操作已成功完成。

需要注意的是,回滚操作可能需要一些时间才能完成,具体取决于应用程序的规模和复杂性。如果回滚操作失败或出现问题,请检查 Helm 的日志文件和错误消息,以找出问题所在。可以使用 helm history 命令查看 Release 的历史记录,并确定是否需要执行其他操作才能解决问题
在使用 Helm 进行回滚操作时,可能需要查看回滚操作的进度,以了解回滚操作的状态和任何错误或警告消息。下面是查看 Helm 回滚操作进度的步骤:
首先,使用 helm rollback 命令启动回滚操作。例如,假设我们要将名为 my-release 的 Release 回滚到上一个版本,可以使用以下命令:
helm rollback my-release <previous_version>
其中 `<previous_version>` 是上一个版本的版本号。
在回滚操作进行期间,可以使用 helm status 命令查看应用程序的状态并监视回滚操作的进度。例如,可以使用以下命令:
helm status my-release
这个命令会显示名为 my-release 的 Release 的详细信息,包括 Chart 的名称、版本、命名空间、状态和配置信息。
在回滚操作完成后,可以再次运行 helm status 命令来验证应用程序的状态,并确保回滚操作已成功完成。
需要注意的是,回滚操作可能需要一些时间才能完成,具体取决于应用程序的规模和复杂性。如果回滚操作失败或出现问题,请检查 Helm 的日志文件和错误消息,以找出问题所在。可以使用 helm history 命令查看 Release 的历史记录,并确定是否需要执行其他操作才能解决问题
  1. 卸载 Chart 要卸载一个 Helm Chart,你可以使用 helm uninstall 命令。下面是一个例子:
helm uninstall my-release
这个命令会卸载名为 my-release 的 Release。

管理依赖关系

如果你的Chart依赖于其他Charts,可以使用以下命令来管理依赖关系:

  • 安装依赖:
  helm dependency update
  • 更新依赖:
  helm dependency build
  • 清理依赖:
  helm dependency list

这是关于Helm的一些详细用法说明,

当使用Helm来管理Kubernetes应用程序时,你可以通过编写Helm Charts来定义应用程序的配置和部署要求。下面是关于如何使用Helm的一些常见操作,以Markdown文件格式输出:

更新镜像 (images)

要更新Helm Chart中的镜像,你需要修改Chart中的values.yaml文件或使用—set参数来覆盖默认值。首先,找到Chart所在的目录,并打开values.yaml文件。在该文件中,你可以找到与镜像相关的配置项,如:

image:
  repository: myapp
  tag: 1.0.0

要更新镜像,修改repositorytag的值即可。保存并关闭文件后,使用以下命令来更新Chart的发布:

helm upgrade <release_name> <chart_directory>

确保将<release_name>替换为你的发布名称,<chart_directory>替换为Chart所在的目录。

更新注解 (annotations)

要更新Helm Chart中的注解,你可以在Chart模板文件中使用Kubernetes注解语法来设置或更新注解。打开相应的模板文件(如Deployment.yaml),找到需要更新的对象,并添加或修改注解。以下是一个示例:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp
  annotations:
    app.example.com/annotation-key: annotation-value

在上述示例中,你可以在metadata下的annotations部分添加或修改注解。保存文件后,使用helm upgrade命令来更新发布,就会更新注解。

以Markdown格式输出的Helm使用指南到此结束,希望对你有所帮助!如果你还有其他问题,请随时提问。

您说得对,在 Markdown 中,YAML 代码块最好使用 来引用。我更新后的 Markdown 内容如下:

Helm 管理 Deployment

安装 Deployment

可以在 Helm Chart 中定义 Deployment 资源,例如:

apiVersion: apps/v1  
kind: Deployment  
metadata:  
  name: nginx-deployment  
spec:  
  replicas: 3  
  selector:    
    matchLabels:      
      app: nginx  
  template:    
    metadata:      
      labels:        
        app: nginx    
    spec:      
      containers:      
      - name: nginx        
          image: nginx:1.14.2        
          ports:        
          - containerPort: 80

设置replicas 扩缩容

可以通过 replicas 字段设置 Pod 的复制数,实现 Deployment 的扩缩容。

更新Deployment

可以通过 helm upgrade 命令更新 Deployment,例如:

  • 更新镜像版本:
apiVersion: apps/v1  
kind: Deployment  
metadata:  
  name: nginx-deployment  
spec:  
  replicas: 3  
  selector:    
    matchLabels:      
      app: nginx  
  template:    
    metadata:      
      labels:        
        app: nginx    
    spec:      
      containers:      
      - name: nginx        
          image: nginx:1.15.2  # 修改镜像版本        
          ports:        
          - containerPort: 80  

然后执行helm upgrade

  • 更新注解(Annotations):

yaml apiVersion: apps/v1 kind: Deployment metadata:
name: nginx-deployment annotations:
some-annotation: "new value" # 新增或修改注解

然后执行helm upgrade

回滚Deployment

可以通过 helm rollback 命令回滚 Deployment 到之前的版本。

删除Deployment

可以通过 helm delete 和 helm uninstall 命令删除 Deployment。

所以总体来说,Helm 可以很好的配合 Kubernetes Deployment 资源进行管理,具有版本控制、扩缩容、回滚等能力。

Here is a markdown summary of using Helm to manage Deployments:

Helm 管理 Deployment

安装 Deployment

可以在 Helm Chart 中定义 Deployment 资源,例如:

apiVersion: apps/v1  
kind: Deployment  
metadata:  
  name: nginx-deployment  
spec:  
  replicas: 3  
  selector:    
    matchLabels:      
      app: nginx  
  template:    
    metadata:      
      labels:        
        app: nginx    
    spec:      
      containers:      
      - name: nginx        
          image: nginx:1.14.2        
          ports:        
          - containerPort: 80

设置replicas 扩缩容

可以通过 replicas 字段设置 Pod 的复制数,实现 Deployment 的扩缩容。

更新Deployment

可以通过 helm upgrade 命令更新 Deployment,例如:

  • 更新镜像版本:
apiVersion: apps/v1  
kind: Deployment  
metadata:  
  name: nginx-deployment
spec:  
  replicas: 3  
  selector:    
    matchLabels:      
      app: nginx  
  template:    
    metadata:      
      labels:        
        app: nginx    
    spec:      
      containers:      
      - name: nginx        
          image: nginx:1.15.2  # 修改镜像版本        
          ports:        
          - containerPort: 80 

然后执行helm upgrade

  • 更新注解(Annotations):
  • yaml
apiVersion: apps/v1
kind: Deployment
metadata:  
  name: nginx-deployment
  annotations:  
    some-annotation: "new value"  # 新增或修改注解

然后执行helm upgrade

回滚Deployment

可以通过 helm rollback 命令回滚 Deployment 到之前的版本。

删除Deployment

可以通过 helm delete 和 helm uninstall 命令删除 Deployment。

所以总体来说,Helm 可以很好的配合 Kubernetes Deployment 资源进行管理,具有版本控制、扩缩容、回滚等能力。

Helm 可以很方便的安装和管理 Kubernetes 的应用。对于 Deployment,主要有以下几个方面:

  1. 创建 Deployment 资源:在 Helm Chart 中可以定义 Deployment 资源,例如:
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80
  1. 设置 Deployment 的复制数:可以通过 replicas 字段设置 Pod 的复制数,实现 Deployment 的扩缩容。
  2. 更新 Deployment:可以通过 helm upgrade 命令更新 Deployment,例如更新镜像版本,这将触发 Deployment 进行滚动更新。
  3. 回滚 Deployment:可以通过 helm rollback 命令回滚 Deployment 到之前的版本,实现快速恢复。
  4. 扩缩容 Deployment:可以通过 helm upgrade --set replicas=5 这样的命令来扩展 Deployment 的 Pod 数量。缩容同理。
  5. 查看 Deployment 状态:可以通过 kubectl get deploy 和 helm status 命令查看 Deployment 的状态,如有异常可以及时处理。
  6. 删除 Deployment:可以通过 helm delete 和 helm uninstall 命令删除 Deployment,这将删除 Deployment 和相关的 Pod。

所以总体来说,Helm 可以很好的配合 Kubernetes Deployment 资源进行部署与管理,具有版本控制、回滚、扩缩容等能力。

对 Deployment 中的镜像版本或注解(Annotation)进行更新,可以通过 Helm Upgrade 来实现。具体步骤如下:

  1. 修改 Chart 中 Deployment 的镜像版本或注解。例如:
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  annotations:
    some-annotation: "new value"  # 新增或修改注解
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.15.2  # 修改镜像版本
  1. 执行 helm upgrade 命令进行升级:

bash helm upgrade my-release .

  1. 此时 Deployment 将进行滚动更新,将镜像版本更新到 1.15.2,并应用新的注解。
  2. 可以通过 kubectl get deploy 和 helm status 查看 Deployment 的更新进度。
  3. 如果更新出现问题,可以使用 helm rollback 命令快速回滚到上一版本。

所以通过 Helm Upgrade,可以很方便的对 Deployment 进行配置更新,并享受到版本控制、回滚等功能。需要注意的是,如果只修改了注解、标签等非核心配置,Deployment 不会触发重新创建 Pod,只会直接更新现有 Pod,这点需要注意。

除了 Deployment,Helm 同样可以很好的管理 Kubernetes 的其他资源对象,如 Service、Ingress 等。Helm 作为 Kubernetes 的包管理工具,可以说是运维 Kubernetes 应用的必备工具之一。

Helm 的模版语法

Helm 使用 Go 模板语言来为 Charts 中的 Kubernetes 资源文件提供动态值和逻辑。下面是一些 Helm 模板语法的常见用法和示例:

变量和函数 Helm 模板语言支持变量和函数,可以在模板中使用这些变量和函数来引用值或执行操作。以下是一些常用的变量和函数:

.Values: 用于访问 Chart 的 values.yaml 文件中定义的值。例如,可以使用 .Values.image.tag 引用 values.yaml 文件中定义的 image.tag 值。

tpl: 用于在模板中生成文本。例如,可以使用 {{ tpl "name: {{ .Chart.Name }}" . }} 生成包含 Chart 名称的文本。

include: 用于包含其他模板文件。例如,可以使用 {{ include "common.labels" . }} 包含名为 common.labels 的模板文件。

以下是一个使用变量和函数的示例:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: {{ .Chart.Name }}-deployment
spec:
  replicas: {{ .Values.replicaCount }}
  selector:
    matchLabels:
      app: {{ .Chart.Name }}
  template:
    metadata:
      labels:
        app: {{ .Chart.Name }}
    spec:
      containers:
        - name: {{ .Chart.Name }}
          image: {{ .Values.image.repository }}:{{ .Values.image.tag }}
          ports:
            - containerPort: {{ .Values.service.port }}

在这个示例中,我们使用 .Chart.Name、.Values.replicaCount、.Values.image.repository 和 .Values.image.tag 等变量来引用 Chart 中定义的值,并使用 tpl 函数生成文本。例如,使用 {{ tpl "name: {{ .Chart.Name }}" . }} 生成 name: my-chart 的文本。

条件语句 Helm 模板语言支持条件语句,可以根据条件来渲染资源文件中的值。以下是一个使用条件语句的示例:

apiVersion: v1
kind: Service
metadata:
  name: {{ .Chart.Name }}-service
spec:
  type: {{ if eq .Values.service.type "LoadBalancer" }}LoadBalancer{{ else }}ClusterIP{{ end }}
  ports:
  - port: {{ .Values.service.port }}
    targetPort: {{ .Values.service.targetPort }}
  selector:
    app: {{ .Chart.Name }}

在这个示例中,我们使用 if 语句根据 .Values.service.type 的值来确定 Service 的类型。如果 .Values.service.type 的值为 LoadBalancer,那么 Service 的类型为 LoadBalancer,否则为 ClusterIP。

迭代器 Helm 模板语言支持迭代器,可以在模板中迭代列表或映射中的值。以下是一个使用迭代器的示例:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: {{ .Chart.Name }}-deployment
spec:
  replicas: {{ .Values.replicaCount }}
  selector:
    matchLabels:
      app: {{ .Chart.Name }}
  template:
    metadata:
      labels:
        app: {{ .Chart.Name }}
    spec:
      containers:
      {{- range .Values.containers }}
        - name: {{ .name }}
          image: {{ .image }}
          ports:
            - containerPort: {{ .port }}
      {{- end }}

在这个示例中,我们使用 range 函数迭代 .Values.containers 列表中的值,并为每个容器生成一个 Deployment。每个容器都有一个名称、一个镜像和一个端口号。使用 {{- 和 -}} 语法可以去除迭代器生成的空格和换行符,使生成的 YAML 文件更加紧凑。

以上是一些常用的 Helm 模板语法,还有其他更高级的用法,例如模板继承和模板函数等。你可以参考官方文档来了解更多信息

相关推荐

Golang报表项目的Java重构过程

最近,完成了从原先使用Golang生成报表的工程项目,到Java项目来重构。【背景内容】最初使用Golang,主要是由于语言自身的精简性。不管是搭建HTTP服务端,还是对传统数据库的数据获取,都有...

不懂代码也能做出酷炫可视化大屏

最近在做一个数据可视化大屏项目,从指标设计、视觉设计、可视化动效到大屏硬件、开发工具整个流程,总结了一些经验和观点,想和大家分享。大屏制作工具大屏的制作,可以用代码开发或现成的可视化工具来实现。用的比...

爬虫界的启蒙老师,python超爽爬取入门案例分享

爬虫,就是授权的或公开数据的自动采集。百度,就是一只爬虫,一条百足之虫。学会爬虫,会让你以为自己离超越百度指日可待。人有多大胆,地有多大产,梦想还是要有的,万一实现了呢。人不怕有梦想,就怕不知道,不敢...

多亏这几个工具,我终于搞懂了数据分析怎么做

说起来,数据分析这东西之前真是让我头疼不已,感觉就像是个无解的迷宫。但多亏这几个工具,竟然帮我打开了这扇大门,让我终于搞明白了数据分析是怎么一回事。数据分析可不仅仅是个简单的任务,它涉及数据收集、处理...

主流富文本编辑器推荐,网站编辑器排名不分先后及特点

富文本编辑器(RichTextEditor,简称RTE)是一种提供类似于MicrosoftWord编辑功能的工具,在后台处理文章编辑时,深受不会编写HTML但又需要设置各种文本格式的用户喜爱,但...

文库系统开发全攻略:技术要点与实战案例

在信息爆炸的时代,文库系统作为知识管理的基石,正面临着前所未有的挑战。随着人工智能技术的崛起,我们有机会重新定义文档的存储、检索和交互方式。本文将深入探讨AI技术如何赋能文库系统,提升其智能化水平,从...

Apache ECharts:基于JavaScript的数据可视化图表库

#挑战30天在头条写日记#ApacheECharts是一个由百度开源的数据可视化,凭借着良好的交互性,精巧的图表设计,得到了众多开发者的认可。而Python是一门富有表达力的语言,很适合用于数...

某个网站打不开,其它网站都正常怎么办?

前两天学echarts,结果官网打不开,其它网站都能正常打开,自己家里的网络打不开echarts官网,把echarts官网地址发给朋友都能打开,然后综合网上查看的资料,确定是dns的问题,有两种方法...

ECharts 水球图

水球图是一种适合于展现单个百分比数据的图表类型,ECharts的水球图插件使你能够通过非常简单的配置,实现酷炫的数据展示效果。那么,今天我们就一起来学习一下,如何使用ECharts水球图。第一步...

用echarts画图表好,还是dhtmlxGantt画图表好?实战验结果

事情是这样的早些时候,我接到了一个需求,说要将项目里程碑用甘特图展示,一脸懵逼的我先是搜一下什么是“甘特图”:From百度百科:甘特图(Ganttchart)又称为横道图、条状图(Barch...

轻量级 Markdown 写作工具:One Markdown

大家好,我是oulvhai,MWeb的作者,MWeb是macOS和iOS/iPadOS下的Markdown写作/记笔记/静态博客生成软件。所以简单地来说我就是专门做ma...

【大屏可视化组态编辑器】图表

大屏中的图表大使用的是开源可视化图表库Echarts在线编辑:https://v.le5le.com/使用1.在html中引入echarts资源包<scriptsrc="ech...

20多个好用的 Vue 组件库,请查收!

每日一荐:Freemen,程序员自己的求职招聘软件,赶紧下载收藏一波,留着下次跳槽用。在本文中,我们将探讨一些最常见的vuejs组件。你可以收藏一波。VueTables-2地址:https://g...

弃用 Echarts,推荐选择Vue Data UI!

各位网友大家好,今天,我要向大家隆重推荐一款令人惊艳的可视化图表库——VueDataUI,一个赋予用户权力的数据可视化Vue3组件库。前言VueDataUI诞生于一个问题:如果你的仪表板...

Echarts仿电梯运行图

本文适合有一定Echarts基础的人员,至少可以面向API编程。场景假设我们有这样一个需求:实现一个柱状图,柱状图中间有一个小块表示电梯,柱状图本身作为建筑物。而且电梯需要上下运行动画。实现工具优先选...