如何使用 Python 通过代码创建图表

简介

Diagram as Code 工具允许您创建基础架构的架构图。您可以重复使用代码、测试、集成和自动化绘制图表的过程,这将使您能够将文档视为代码,并构建用于映射基础架构的流水线。您可以使用 diagrams 脚本与许多云提供商和自定义基础架构。

在本教程中,您将使用 Python 创建一个基本的图表,并将其上传到对象存储桶。完成后,您将了解 diagrams 脚本的工作原理,从而能够创建新的集成。

步骤 1 — 安装 Graphviz

在这一步中,您将安装 Graphviz 工具。Graphviz 是 diagrams 模块的引擎,它生成图表本身。

首先,更新服务器的软件包:

sudo apt update

然后,使用以下命令安装 Graphviz:

sudo apt install -y graphviz

-y 选项会自动回答安装过程中的任何额外提示。您也可以下载其他发行版的 Graphviz。

安装完成后,您将拥有安装的 Graphviz。

因为您将在本教程后面使用 Pip3 安装 Python 依赖项,您可以检查您是否有正确的版本:

pip3 --version

您应该会看到类似以下的内容:

pip 20.0.2 from /usr/lib/python3/dist-packages/pip (python 3.8)

在这一步中,您更新了服务器,安装了 Graphviz,并检查了 Pip 的版本。接下来,您将构建 diagrams 脚本。

步骤 2 — 构建 Python 脚本

在这一步中,您将在 Python 中编写一个示例图表脚本。

首先,创建一个工作文件夹:

mkdir ~/my-diagram

创建项目文件夹后,使用以下命令进入该文件夹:

cd ~/my-diagram

然后,创建一个 requirements.txt 文件以跟踪项目依赖项:

echo -e "diagrams==0.21.1\ngraphviz==0.16" | tee requirements.txt

此命令有两个关键字:echo 将打印字符串,-e 选项将使用 \n 插入来解析新行,以创建一个格式良好的 requirements 文件。

| 符号表示将 echo 语句的结果传递给管道。tee 命令接受管道输入,并根据列出的参数创建一个新文件:在本例中,是 requirements.txt

Python 中的 requirements.txt 文件提供了运行脚本所需的模块列表。目前,该项目有两个依赖项。
创建文件后,您将看到以下输出:

diagrams=0.21.1
graphviz=0.16

此显示指示了两个工具的版本号。

现在,您将编写 Python 脚本以创建图表图像。

确保您仍在创建的目录中:

cd ~/my-diagram

接下来,使用 nano 或您喜欢的文本编辑器打开一个新文件:

nano my-diagram.py

添加以下代码:

from diagrams import Diagram, Cluster, Edge

此行将导入创建通用图表元素所需的图表部件。

接下来,您必须导入绘制您将构建的 DigitalOcean 基础架构所需的内容。在本示例中,您将创建一个图表,显示两个 Droplets 连接到一个数据库,并且所有主机都将日志发送到一个 Logstash 实例。

添加以下行以导入 Droplet、DbaasPrimary 和 Logstash 图标:

...
from diagrams.digitalocean.compute import Droplet
from diagrams.digitalocean.database import DbaasPrimary
from diagrams.elastic.elasticsearch import Logstash

这些行导入了本教程所需的图标。您可以在 Mingrammer 文档中找到所有可用的 DigitalOcean 图标。

导入图标后,您可以开始构建图表。此代码部分将创建一个名为 My Diagram: Droplets 的图表:

...
with Diagram("My Diagram: Droplets", show=False, filename="my-diagram", direction="LR"):

show 参数可以在创建时打开它,但由于您正在使用 Linux 主机,它已设置为 False。生成的文件将被命名为分配给 filename 的任何字符串。direction 是您希望图表打印的方向。direction 的支持值为 TB(从上到下)和 LR(从左到右)。选择 direction 可以使图表更易于阅读。对于此图表,您将使用 LR

最后,将图标添加到图表中:

...
with Diagram("My Diagram: Droplets", show=False, filename="my-diagram", direction="LR"):with Cluster("DigitalOcean"):droplet1 = Droplet("My first Droplet")droplet2 = Droplet("My second Droplet")db = DbaasPrimary("My database")logstash = Logstash("Logstash service")

Cluster 在图表中为您的 Droplets 创建一个框,显示它们在名为 DigitalOcean 的空间中。DropletDbaasPrimaryLogstash 将创建以字符串提供的图标名称。

接下来,您将通过添加以下行来在图表中的各个项目之间创建依赖关系:

...[droplet1, droplet2] >> db >> [droplet1, droplet2][droplet1, droplet2, db] >> Edge(color="firebrick", style="dashed") >> logstash

您将您的 Droplets 连接到上面创建的 DbaasPrimary 数据库,既读又写。然后,您添加了一个颜色为 firebrick 的虚线,以指示从 Droplets 和主数据库到 Logstash 的连接。

您的最终 my-diagram.py 文件将如下所示:

from diagrams import Diagram, Cluster, Edge
from diagrams.digitalocean.compute import Droplet
from diagrams.digitalocean.database import DbaasPrimary
from diagrams.elastic.elasticsearch import Logstashwith Diagram("My Diagram: Droplets", show=False, filename="my-diagram", direction="LR"):with Cluster("DigitalOcean"):droplet1 = Droplet("My first droplet")droplet2 = Droplet("My second droplet")db = DbaasPrimary("My database")logstash = Logstash("Logstash service")[droplet1, droplet2] >> db >> [droplet1, droplet2][droplet1, droplet2, db] >> Edge(color="firebrick", style="dashed") >> logstash

保存并关闭文件。

现在,您在同一个文件夹中有一个名为 my-diagram.py 和一个名为 requirements.txt 的文件。

有了这两个文件,您可以安装所需的模块并创建图表。

步骤 3 — 创建图表

完成编写 Python 脚本后,您可以运行它以创建图表。

首先使用 Pip 安装所需的库:

pip3 install -r requirements.txt

您将看到以下输出:

Collecting diagrams==0.21.1Using cached diagrams-0.21.1-py3-none-any.whl (23.8 MB)
Collecting graphviz==0.16Using cached graphviz-0.16-py2.py3-none-any.whl (19 kB)
Requirement already satisfied: jinja2<4.0,>=2.10 in /usr/lib/python3/dist-packages (from diagrams==0.21.1->-r requirements.txt (line 1)) (2.10.1)
Installing collected packages: graphviz, diagrams
Successfully installed diagrams-0.21.1 graphviz-0.16

安装完成所需的库后,运行 Python 脚本:

python3 my-diagram.py

此脚本将生成一个名为 my-diagram.png 的图表,如下所示:

!The Droplets and Database diagram

有关不同类型图标和使用此模块的其他方法的更多信息,请参阅 Mingrammer 文档。

在这一步中,您已创建了图表。接下来,您将把它添加到对象存储中,以便可以访问 .png 文件。

步骤 4 — 将图表上传到对象存储

为了能够从不同位置查看您的图表,现在将图表上传到对象存储。在本教程中,您将使用 DigitalOcean Spaces 存储桶。

在先决条件中,您已设置了一个 Spaces 存储桶并创建了一组访问密钥。

接下来,安装 s3cmd,这是一个用于通过 CLI 与 s3 风格 API 进行交互的工具:

sudo apt install -y s3cmd

安装完成后,配置 s3cmd

s3cmd --configure

现在,您将使用 API 凭据和其他首选项设置配置。下面的每个提示将作为自己的行加载,因此请使用您的信息和选择更新下面的突出显示部分:

HTTP 代理服务器名称:新设置:
访问密钥:your-access-key
密钥:your-secret-key
默认区域:EU
S3 端点:ams3.digitaloceanspaces.com
用于访问存储桶的 DNS 样式主机名+端口模板:%(bucket)s.ams3.digitaloceanspaces.com
加密密码:your-encryption-password
GPG 程序路径:/usr/bin/gpg
使用 HTTPS 协议:True
HTTP 代理服务器名称:
HTTP 代理服务器端口:0

S3 端点 需要与 Spaces 设置中提供的端点匹配,并且 DNS 样式 需以类似格式的方式设置。上面的示例使用 ams3,因为此 Spaces 存储桶托管在阿姆斯特丹数据中心 3 上。请相应更新您的设置。

设置完首选项后,选择 Y 来测试凭据:

使用提供的凭据测试访问权限?[Y/n] Y

测试将运行。如果失败,您可以提供新的凭据进行配置并重试。一旦成功,您将看到以下显示:

请稍候,尝试列出所有存储桶...
成功。您的访问密钥和密钥工作正常 :-)现在验证加密是否有效...
成功。加密和解密工作正常 :-)

现在,您可以通过运行 s3cmd 命令上传文件:

s3cmd put my-diagram.png s3://your_space_name/my-diagram.png

上传完成后,您将看到以下显示:

upload: 'my-diagram.png' -> 's3://your-space-name/my-diagram.png'  [1 of 1]43672 of 43672   100% in    0s  1516.98 kB/s  done

如果您的存储桶是公开访问的,或者您已将图表设置为公开,您可以访问 https://your-space-name.ams3.digitaloceanspaces.com/my-diagram.png 查看您的图表。请确保使用您的存储桶名称和其数据中心更新 URL。

如果您的存储桶不是公开访问的,您可以更改文件权限使其公开,或者您可以从存储桶下载图像到本地计算机。

如果您不需要保留在本教程中创建的服务器和对象存储,您可以按照文档中有关删除 Droplets 和销毁 Spaces 的说明进行操作。

结论

您已使用 Python 创建了一个图表,您可以根据需要修改它以满足您未来的图表创建需求。您将不再需要手动拖动框来创建图表。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/683785.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt:自定义信号,信号emit,传参问题,信号槽与moc

一、自定义信号&#xff0c;信号emit 1、自定义信号 在头文件中 加入signals&#xff1a; 就可以编写信号 2、emit emit的作用是通知信号发生 二、跨UI控件传参 每次按Dialog添加按钮主控件数字会增长 // .h private slots:void on_btnAdd_clicked(); signals:void sign…

《区块链公链数据分析简易速速上手小册》第8章:实战案例研究(2024 最新版)

文章目录 8.1 案例分析&#xff1a;投资决策支持8.1.1 基础知识8.1.2 重点案例&#xff1a;股票市场趋势预测准备工作实现步骤步骤1: 加载和准备数据步骤2: 特征工程步骤3: 训练模型步骤4: 评估模型 结论 8.1.3 拓展案例 1&#xff1a;基于情感分析的投资策略准备工作实现步骤步…

C# winfrom中NPOI操作EXCEL

前言 1.整个Excel表格叫做工作表&#xff1a;WorkBook&#xff08;工作薄&#xff09;&#xff0c;包含的叫页&#xff08;工作表&#xff09;&#xff1a;Sheet&#xff1b;行&#xff1a;Row&#xff1b;单元格Cell。 2.忘了告诉大家npoi是做什么的了&#xff0c;npoi 能够读…

Node.js开发-fs模块

这里写目录标题 fs模块1) 文件写入2) 文件写入3) 文件移动与重命名4) 文件删除5) 文件夹操作6) 查看资源状态7) 相对路径问题8) __dirname fs模块 fs模块可以实现与硬盘的交互&#xff0c;例如文件的创建、删除、重命名、移动等&#xff0c;还有文件内容的写入、读取&#xff…

每日五道java面试题之java基础篇(八)

目录&#xff1a; 第一题.CopyOnWriteArrayList的底层原理是怎样的第二题.Java中有哪些类加载器第三题. 说说类加载器双亲委派模型第四题. GC如何判断对象可以被回收第五题.JVM中哪些是线程共享区 第一题.CopyOnWriteArrayList的底层原理是怎样的 ⾸先CopyOnWriteArrayList内部…

游戏开发的编程算不算是IT行业中难度最大的?

游戏开发的编程算不算是IT行业中难度最大的&#xff1f; 游戏作为当今数字娱乐领域中最引人入胜的产品之一&#xff0c;其背后所依托的程序开发能力也备受关注。作为游戏开发过程中的“幕后英雄”&#xff0c;编程工作的难易程度直接影响到游戏的质量体验和开发效率。 关于游…

如何在 Angular 中将特定按键绑定到 keyup 和 keydown 事件

简介 当在 Angular 2 模板中绑定 keyup 或 keydown 事件时&#xff0c;可以指定 键名。这将应用一个过滤器&#xff0c;只有在按下特定键时才会触发事件。 在本文中&#xff0c;您将学习如何在监听 keyup 和 keydown 事件时使用键名。 使用键名 首先&#xff0c;让我们看一…

Python 装饰器的学习笔记

Python 装饰器的学习笔记 0. Python 装饰器的说明1. 装饰器的基本结构2. 使用装饰器3. 带参数的装饰器4. 类装饰器 0. Python 装饰器的说明 装饰器是Python中一个非常强大的功能&#xff0c;它允许程序员扩展或修改函数的行为而不改变函数本身的代码。装饰器本质上是一个接受函…

Python dict函数

Python中的字典&#xff08;dict&#xff09;是一种非常重要且灵活的数据结构&#xff0c;它提供了键值对的存储和访问机制。字典函数&#xff08;dict()&#xff09;作为创建字典的工具之一&#xff0c;可以从多种数据结构中创建字典对象。在本文中&#xff0c;将深入探讨dict…

2.15数据结构与算法学习日记(分治,二分)

洛谷P1296 奶牛的耳语 题目描述 在你的养牛场&#xff0c;所有的奶牛都养在一排呈直线的牛栏中。一共有 &#xfffd;n 头奶牛&#xff0c;其中第 &#xfffd;i 头牛在直线上所处的位置可以用一个整数坐标 &#xfffd;&#xfffd;(0≤&#xfffd;&#xfffd;≤108)pi​(…

算法刷题:有效三角形个数

有效三角形个数 .题目链接题目详情算法原理补充知识点双指针:对撞指针 我的答案 . 题目链接 有效三角形个数 题目详情 算法原理 补充知识点 有效三角形需要满足的条件: ab>cac>bbc>a 其实在满足1的时候,c是最大的,那么2和3是显然成立的,因此我们可以这样解题: 对…

华为OD机试 - 分配土地( Python C C++ JavaGo JS PHP)

题目描述 从前有个村庄&#xff0c;村民们在各种田地上插上小旗子&#xff0c;每个旗子上都标识了一个数字。现在&#xff0c;村民们想要找出一个包含相同数字的最小矩形区域&#xff0c;并将这块土地分配给对村庄做出巨大贡献的村民。我们需要找出这个矩形区域的最大面积。 …

知识图谱简单介绍

知识图谱&#xff08;Knowledge Graph&#xff09;是一种用于表达实体、概念及其之间关系的图形数据结构。它通过将现实世界中的各种概念、实体和关系以图形的形式组织起来&#xff0c;实现对知识的表示、存储和推理。知识图谱在许多领域都有广泛的应用&#xff0c;如搜索引擎、…

分享个CSDN自定义模块模板

在开了会员或升级为博客专家后&#xff0c;才有这个自定义模块的权限 当然这也是为了有很多粉丝的博主更方便的推广一些业务场景展示的橱窗 自定义模块管理 下面就列下我使用的自定义模块相关的代码 <marquee><b><font color"#8A2BE2">不</…

[WinForm开源]概率计算器 - Genshin Impact(V1.0)

创作目的&#xff1a;为方便旅行者估算自己拥有的纠缠之缘能否达到自己的目的&#xff0c;作者使用C#开发了一款小型软件供旅行者参考使用。 创作说明&#xff1a;此软件所涉及到的一切概率与规则完全按照游戏《原神》(V4.4.0)内公示的概率与规则&#xff08;包括保底机制&…

代码随想录 -- 数组

文章目录 二分查找题目描述题解 移除元素题目描述题解&#xff1a;暴力解法题解&#xff1a;双指针法 有序数组的平方题目描述题解&#xff1a;暴力解法题解&#xff1a;双指针法 长度最小的子数组题目描述题解&#xff1a;暴力解法题解&#xff1a;滑动窗口&#xff08;双指针…

猫头虎分享已解决Bug || DNS解析问题(DNS Resolution Issue):DNSLookupFailure, DNSResolveError

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

学习Spring的第十八天

注解方式配值声明式事务控制 直接上源码配置类 package com.itheima.config;import com.alibaba.druid.pool.DruidDataSource; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.facto…

作业2.12

1.会出现段错误&#xff0c;因为p申请的堆区内存未返回给str&#xff0c;导致str仍然指向NULL&#xff0c;无法将"hello world"拷贝给str 2.会出现段错误&#xff0c;因为p是一个局部变量&#xff0c;函数结束时&#xff0c;p将被释放&#xff0c;不能返回它的地址&…

大学生必备搜题软件推荐?找题不再难!好用的大学搜题工具推荐 #媒体#职场发展

在快节奏的大学生活中&#xff0c;合理利用这些日常学习工具&#xff0c;能够让你事半功倍&#xff0c;提高学习效率。 1.茱莉亚公开课 茱莉亚公开课APP不是一款针对所有人的应用&#xff0c;是针对对艺术有特殊爱好和艺术领域的人 茱莉亚音乐学院里面都是世界著名的茱莉亚音…