Skip to main content

Helper script for installing shinnytech cdk

Project description

get-cdk: CDK环境安装工具

本工具旨在简化CDK环境的安装,提供基于服务的隔离运行环境,支持并行服务部署。

安装

堡垒机

无需任何操作,get-cdk已经安装在堡垒机上,直接使用即可。

本地开发机

使用pip安装get_cdk

pip install get-cdk

Usage

$ get-cdk --help
usage: get-cdk [-h] [--cdk-tag CDK_TAG] [--cdk-branch CDK_BRANCH] [--cdk-commit CDK_COMMIT] --service SERVICE args

安装cdk

options:
  -h, --help            show this help message and exit
  --cdk-tag CDK_TAG     cdk的tag
  --cdk-branch CDK_BRANCH
                        cdk的分支
  --cdk-commit CDK_COMMIT
                        cdk的commit
  --service SERVICE     要部署的服务名称, 跟服务所在的 github project 名称相同
  args                  run_cdk的参数

开发流程说明

开发服务

在本地开发机上使用 get-cdk, get-cdk 生成的 venv 放置在 $CDK_VENV_DIR 目录下, cdk 运行需要的临时文件放置在 $CDK_DIR 目录下。

  • 当没有设置 CDK_VENV_DIR 环境变量时默认值为 ~/.get_cdk/<service>/venv
  • 当没有设置 CDK_DIR 环境变量时默认值为 ~/.get_cdk/<service>/config

其中 <service> 为服务名

get-cdk --service=otg-sim
# 不添加 run_cdk 参数时仅创建 venv 并打印其路径

默认使用最新版的 cdk, 可以通过 --cdk-branch--cdk-commit 参数指定 cdk 的分支和 commit 创建 venv

venv创建完成后,可以在pycharm中添加 <venv_path>/bin/python3 为python解释器,然后在pycharm中开发cdk和服务。

如需开发cdk本身可以直接clone cdk后attach到项目中。

在 venv 中可以直接运行 deploy.py 部署服务。

本地打包

需将 deploy.py 以及对应的依赖打成 sdist 包, 如使用了 airflow dag 可以和 deploy.py 打到一个 sdist 包中或分开独立打包.

在本地开发机上使用本地的打包结果部署服务:

  • 需设置环境变量 CDK_LOCAL_DIST<service>=<dist_path>; 其中 <service> 为服务名, <dist_path> 为本地打包结果的目录
  • 在 venv 中运行 python3 -m cdk.run_cdk --service=<service> --tag=dummy-local 部署服务, 其中 dummy-local 表示使用本地打包结果

ci 打包

ci 打包完成后可以在开发机上部署,部署命令如下:

get-cdk --service=otg-sim --cdk-branch=master --cdk-commit=196c3de --branch=master --commit=4b5d056 --action apply
# 添加 run_cdk 的参数会直接传递给 run_cdk 进行服务部署

也可以在堡垒机上执行以上命令部署.

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

get_cdk-2024.10.0.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

get_cdk-2024.10.0-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file get_cdk-2024.10.0.tar.gz.

File metadata

  • Download URL: get_cdk-2024.10.0.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for get_cdk-2024.10.0.tar.gz
Algorithm Hash digest
SHA256 6f127bf0c3e067af168c0815734a9b1864dcff51f35d3af5225a3207fb43aa9e
MD5 013bf4074836c556e47a4c65c2618009
BLAKE2b-256 5760d42b455327d308533e874565eeb5abfc5e5e68171b6968739d7ebac69a4e

See more details on using hashes here.

File details

Details for the file get_cdk-2024.10.0-py3-none-any.whl.

File metadata

  • Download URL: get_cdk-2024.10.0-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for get_cdk-2024.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e52f6264416ffba3b4b51a28dc4551622b5bcaf3613ff3f52b103c0c667a079e
MD5 b6ba11c4c04696345df56589f04aec1c
BLAKE2b-256 ba7572bcd05678a9ad2fe80e0ef4cfe3d6c11632460edb2ac50897004b58042b

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