Skip to main content

The Python SDK for blueking bscp project.

Project description

BSCP-PYTHON-SDK

license

EnglishDocs

Overview

bscp-python-sdk 是蓝鲸 BSCP 项目的 Python SDK,它能帮助你轻松访问项目保存在 BSCP 上的配置内容。

Features

  • kv 配置拉取
  • kv 配置 watch

使用示例

客户端对象 BscpClient

使用 BscpClient 来完成主要操作,其支持两种不同的调用风格。

普通风格:

from bk_bscp.client import BscpClient

client = BscpClient(server_addrs, token, biz_id)
try:
    pair = client.get("app1", "key1")
finally:
    client.close()
  • 普通风格要求你手动管理连接,适合复用长连接,在需要完成大量操作时使用

上下文管理器风格:

from bk_bscp.client import BscpClient

with BscpClient(server_addrs, token, biz_id) as client:
    pair = client.get("app1", "key1")
  • 在这种风格下,client 的连接会自动关闭,适合短连接,操作次数不多时的场景

示例文件

更多示例代码请参考 examples/ 目录。

开发指南

执行单元测试:

uv run pytest -s tests/

一些相关的环境变量配置项:

# 设置日志打印级别,默认为 INFO
BSCP_LOG_LEVEL=DEBUG

启用集成测试

为了更好地测试 SDK 的功能,本项目编写了一些会连接真实 BSCP 服务器的集成测试用例。这些测试默认处于未启用状态,你可以配置以下环境变量来启用:

BSCP_SERVER_ADDRS="your-bscp.example.com:9090"
BSCP_TOKEN="your_token"
BSCP_BIZ_ID="1"

# 启用 Get 功能测试
BSCP_EXISTENT_APP_KEY="your_app,your_key"

同步自动生成的 gRPC 源码文件

在项目的 bk_bscp/grpc_lib 目录里,存放着由 grpc 相关工具链自动生成的 Python 源码文件。需注意的是,这些源码所依赖的原始 proto 定义文件,并未保存在本 SDK 项目中,而是存放于 bscp 主项目里。当你需要更新这批文件时,请先将 bscp 项目克隆到本地,切换到项目根目录中,执行以下命令:

find ./pkg/protocol/core ./pkg/protocol/feed-server -name "*.proto" | \
    xargs python -m grpc_tools.protoc -I. -I ./pkg/thirdparty/protobuf/ --python_out=. --pyi_out=. --grpc_python_out=.

然后,回到本 SDK 项目的 scripts/ 子目录,执行以下脚本完成同步:

# 将 {bscp_project_path} 替换为真实的 bscp 项目目录
bash sync_grpc_generated.sh {bscp_project_path}

Support

BlueKing Community

  • BK-CI:蓝鲸持续集成平台是一个开源的持续集成和持续交付系统,可以轻松将你的研发流程呈现到你面前。
  • BK-BCS:蓝鲸容器管理平台是以容器技术为基础,为微服务业务提供编排管理的基础服务平台。
  • BK-PaaS:蓝鲸PaaS平台是一个开放式的开发平台,让开发者可以方便快捷地创建、开发、部署和管理SaaS应用。
  • BK-SOPS:标准运维(SOPS)是通过可视化的图形界面进行任务流程编排和执行的系统,是蓝鲸体系中一款轻量级的调度编排类SaaS产品。
  • BK-CMDB:蓝鲸配置平台是一个面向资产及应用的企业级配置管理平台。

Contributing

如果你有好的意见或建议,欢迎给我们提 Issues 或 Pull Requests,为蓝鲸开源社区贡献力量。

License

bscp-python-sdk 是基于MIT协议, 详细请参考LICENSE

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bk_bscp-0.2.2.tar.gz (44.0 kB view details)

Uploaded Source

Built Distribution

bk_bscp-0.2.2-py3-none-any.whl (86.2 kB view details)

Uploaded Python 3

File details

Details for the file bk_bscp-0.2.2.tar.gz.

File metadata

  • Download URL: bk_bscp-0.2.2.tar.gz
  • Upload date:
  • Size: 44.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.1

File hashes

Hashes for bk_bscp-0.2.2.tar.gz
Algorithm Hash digest
SHA256 891c7cbe74cb98c0dbfe655cd7daceba2324e9277c6d3c63386819148dab8a9d
MD5 107b42e7281c79170624335141ddc9a0
BLAKE2b-256 ba8ef6a5c3d3d388e88b1bbdd278392026cda1c0cd1fc09d096d3fd56111b728

See more details on using hashes here.

File details

Details for the file bk_bscp-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: bk_bscp-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 86.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.1

File hashes

Hashes for bk_bscp-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fd0580ae5629e5380e34b6f6e8d92983370ad362ea10fd3820bf85227083cc28
MD5 114f064fdfcda476b0de4684de65fc90
BLAKE2b-256 7e374c2fee6b471a49bf1f9fa3a17ef69ce0d9db3d8114438fbd88694ecc61ed

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page