KCL
项目作者: 徐鹏飞
项目网址: https://kcl-lang.io
入驻时间: 2024-01-09
开源许可证: Apache

项目描述

KCL 是一个开源的用于配置和策略场景的记录及函数语言

项目介绍

KCL: 基于约束的记录及函数语言

English | 简体中文

介绍 | 特性 | 场景 | 安装 | 快速开始 | 文档 | 贡献 | 路线规划

介绍

KCL 是一个开源的基于约束的记录及函数语言并通过成熟的编程语言技术和实践来改进对大量繁杂配置比如云原生 Kubernetes 配置场景的编写,致力于构建围绕配置的更好的模块化、扩展性和稳定性,更简单的逻辑编写,以及更简单的自动化和生态工具集成。 image

场景

您可以将 KCL 用于

特性

  • 简单易用:源于 Python、Golang 等高级语言,采纳函数式编程语言特性,低副作用
  • 设计良好:独立的规范驱动的语法、语义、运行时和系统库设计
  • 快速建模开箱即用的模型库和以 Schema 为中心的配置类型及模块化抽象
  • 功能完备:基于 ConfigSchemaLambdaRule 的配置及其模型、逻辑和策略编写
  • 可靠稳定:依赖静态类型系统约束自定义规则的配置稳定性
  • 强可扩展:通过独立配置块自动合并机制保证配置编写的高可扩展性
  • 易自动化CRUD APIs多语言 SDK语言插件 构成的梯度自动化方案
  • 极致性能:使用 Rust & C,LLVM 实现,支持编译到本地代码和 WASM 的高性能编译时和运行时
  • API 亲和:原生支持 OpenAPI、 Kubernetes CRD, Kubernetes Resource Model (KRM) 等 API 生态规范
  • 开发友好语言工具 (Format,Lint,Test,Vet,Doc 等)、包管理工具IDE 插件 构建良好的研发体验
  • 安全可控:面向领域,不原生提供线程、IO 等系统级功能,低噪音,低安全风险,易维护,易治理
  • 多语言 SDKGoPythonJava SDK 满足不同场景和应用使用需求
  • 生态集成:通过 Kubectl KCL 插件Kustomize KCL 插件Helm KCL 插件 或者 KPT KCL SDK 直接编辑或校验资源

  • 生产可用:广泛应用在蚂蚁集团平台工程及自动化的生产环境实践中

如何选择

简单的答案:

  • 如果你需要编写结构化的静态的 K-V,或使用 Kubernetes 原生的技术工具,建议选择 YAML
  • 如果你希望引入编程语言便利性以消除文本(如 YAML、JSON) 模板,有良好的可读性,或者你已是 Terraform 的用户,建议选择 HCL
  • 如果你希望引入类型功能提升稳定性,维护可扩展的配置文件,建议选择 CUE
  • 如果你希望以现代语言方式编写复杂类型和建模,维护可扩展的配置文件,原生的纯函数和策略,和生产级的性能和自动化,建议选择 KCL

更详细的功能和场景对比参考这里

安装

有关安装的更多信息,请查看 KCL 官网的安装指南

快速开始

./samples/kubernetes.k 是一个生成 Kubernetes 资源的例子

apiVersion = "apps/v1"
kind = "Deployment"
metadata = {
    name = "nginx"
    labels.app = "nginx"
}
spec = {
    replicas = 3
    selector.matchLabels = metadata.labels
    template.metadata.labels = metadata.labels
    template.spec.containers = [
        {
            name = metadata.name
            image = "${metadata.name}:1.14.2"
            ports = [{ containerPort = 80 }]
        }
    ]
}

我们可以通过执行如下命令得到 YAML 输出

kcl ./samples/kubernetes.k

YAML 输出

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

更多例子可以在这里找到

文档

更多文档请访问KCL 网站

贡献

参考开发手册。您也可以直接在 GitHub Codespaces 中打开该项目开始贡献。

用 GitHub Codespaces 打开

路线规划

参考KCL 路线规划

社区

欢迎访问 社区 加入我们。

百度统计