plantuml-绘制状态图和活动图和部署图​

2024-04-02 18:08

本文主要是介绍plantuml-绘制状态图和活动图和部署图​,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

状态图:对象的所有状态,以及基于事件发生的状态改变的过程;

活动图:用例的工作流程;

部署图:系统的软硬件物理体系结构;

状态图

基本语法

元素语法说明
开始和结束状态[*]标识开始和结束状态
箭头-->添加箭头
隐藏描述区域hide empty description隐藏描述区域
合成状态state 合成状态名字{ 增城的状态定义语法}可以嵌套状态图
状态声明state 状态名字 : 备注声明状态
fork,joinstate state名字 分开,合并状态
并发状态-- or 或者双竖线状态是并发改变的
箭头方向top down left right可以控制箭头的方向
单行注释note 方位 of 状态名 : 单行注释单行注释
多行注释note 方位 of 状态名 换行 单行注释 换行 end note
多行注释

登录状态图

@startuml
hide empty description
left to right direction[*]-->NotLogin:首次打开appstate  NotLogin: 没有登录
state  LoginSuccess: 登录成功
state  LoginFail: 登录失败NotLogin -->LoginSuccess: 登录
NotLogin -->LoginFail:登录state LoginFail {state 用户不存在: ta校验state saas注册失败:注册saasstate 登记用户信息失败: 登记到tiananUserstate 参数校验失败 :校验参数
}state join_state  <<join>>
LoginSuccess-->join_state:组装响应参数
LoginFail-->join_state:组装响应参数join_state -->[*]:返回JSON数据到客户端@enduml

file

积分状态图

@startuml
scale 350 width
left to right direction
hide empty descriptionstate noPointRecord : 没有积分记录
state pointZero : 积分为0
state pointOk : 有积分[*] -->  noPointRecord: 增加积分
noPointRecord --> pointZero: 初始化
pointZero --> pointOk: 增加/消耗积分pointOk --> [*]@enduml

file

活动图

基本语法

元素语法说明
开始 结束start stop开始结束活动
活动:活动名称;定义活动
条件语句if (条件 ?) then (yes) 换行 下一个活动 else(no) endif条件分支
循环语句repeat 换行 活动 换行 repeatwhile(条件 ?)先执行再判断
循环语句while ( 成立的条件?) 换行 活动 换行 endwhile(不成立的条件描叙)先判断条件在循环
改变活动的形状:活动> < ] } / 竖线分别得到不同的形状
并行处理fork fork again end fork并行处理
组合partition group名称 { 活动图语法}对活动进行分组
泳道两根竖线包围泳道
分离detach移除箭头

登录活动图

@startuml
header 登录接口活动图
footer 登录接口活动图
|tomcat|
start
:参数校验]if (参数校验通过 ?) then (yes)
elseif (字符串为空) then (no)
stop
else (其它校验错误)stop
endif|TA服务端|
:用户code远程校验;
|LX Saas|
:saas注册登录;
|mysql|
:登记到saasUser;
|redis|
:保存令牌到Redis;
|tomcat|
:组装响应参数;
stop@enduml

file

增加积分活动图

@startumlheader 改变用户积分接口活动图
footer 改变用户积分接口活动图|tomcat|
start :登录态检查;if(令牌非法 ?) then (yes)
:返回未登录;
stop
else (合法)
endif:接受参数,point , event ;if(参数检查 ?) then(合法)
else(非法)
:返回参数错误;
stop
endif|mysql|
:插入积分增加详细纪录;
|tomcat|
:得到记录Id;
|redis|
:按照userId查询得到用户积分的表记录Id;
|tomcat|if(记录id不存在 ?)then(yes)
|mysql|
:插入用户的积分记录得到id;
:更新用户的总积分;else(id存在)
:更新用户的总积分;endif|redis|
:删除用户总积分的缓存;
:删除用户积分总条数的缓存;
:删除用户积分明细分页记录的缓存;|tomcat|
:得到明细记录的id,返回;:返回客户端;stop@enduml

file

查询积分活动图

@startuml|tomcat|
start#gold:接受参数,pageNum,pageSize|:参数校验;
if (参数校验通过 ?) then(通过)
else (不通过)
#red:报错 401 X 参数校验不通过;
stop
endif|redis|
:从Redis缓存中查询得到记录的总数]
|tomcat|
if(总数不存在)then (不存在)
|mysql|:从数据库中查询得到积分详细纪录的总数;|redis|:设置到redis缓存中;
elseendif|tomcat|
:得到纪录的总条数;if(总数是否大于0 ?)then-[#red]->总数大于0;fork|redis|:从Redis缓存分页查询得到列表;|tomcat|if (redis中获取不到数据 ?) then( 获取不到)|mysql|:从数据库中获取得到列表;|redis|:设置到redis缓存中;else (获取到了)endif|tomcat|:得到分页查询的列表;fork again|redis|:从Redis缓存中查询得到用户总积分;|tomcat|if (redis中获取不到数据 ?) then( 获取不到)|mysql|:从数据库中获取得到用户总积分;|redis|:设置到redis缓存中;else (获取到了)endif|tomcat|:得到用户总积分;end fork
else|tomcat|-[#green]->总数等于0;#green:分页列表为空;#green:总积分为0;
endif|tomcat|
:组装响应参数\n分页列表数据\n用户总积分;
stop;@enduml

file

部署图

部署图显示了系统的硬件和安装在硬件上的软件,以及用于连接异构计算机之间的中间件。部署图通常被认为是一个网络图或者物理架构图。

语法

系统部署图

@startumlheader TA项目物理架构图
footer TA项目物理架构图left to right directionactor TaUser as taUser
node TaApp as taApp {agent LxSDK as lxsdkagent TaClient as taClient
}folder tiananuser_folder{
cloud tiananuserCluster
node tomcat1_tiananuser
node tomcat2_tiananuser
node tomcat3_tiananusertiananuserCluster -down-> tomcat1_tiananuser
tiananuserCluster -down-> tomcat2_tiananuser
tiananuserCluster -down-> tomcat3_tiananuser}folder tianansp_folder{
cloud tiananspCluster
node tomcat1_tianansp
node tomcat2_tianansp
node tomcat3_tianansptiananspCluster -down-> tomcat1_tianansp
tiananspCluster -down-> tomcat2_tianansp
tiananspCluster -down-> tomcat3_tianansp}node Nginx as nginxnginx --> tiananuserCluster:负载均衡/路由
nginx --> tiananspCluster:负载均衡/路由taUser -->  taApp : 访问
taApp --> nginx:http/httpsdatabase tiananuser_database[用户登录数据库]
database tianansp_database[运营活动数据库
]database redis[redis缓存
]tiananuser_folder -down-> tiananuser_database
tianansp_folder -right-> tianansp_databasetiananuser_folder -down-> redis
tianansp_folder -up-> redisnode zk [zookeeper注册中心dubbo的消费者跟生产者通信中间件定时任务elasticjob的配置中间件
]tiananuser_folder -down-> zk
tianansp_folder -up-> zknode apollo [apollo配置中心
]queue kafka[kafka集群
]tiananuser_folder -down-> apollo
tianansp_folder -up-> apollotiananuser_folder -down-> kafka
tianansp_folder -up-> kafkafile fileCDN [七牛云或者阿里云存储
]tiananuser_folder -down-> fileCDN
tianansp_folder -up-> fileCDNcloud ELK {node elsticSearchnode filebeatnode kibana
}node kubernetes{node healmcharts[交付服务]node harbor[harbor监控管理kubernetes对象]
}tiananuser_folder -down-> ELK:日志写入
tianansp_folder -up-> ELK:日志写入tiananuser_folder -down-> kubernetes:发布和管控docker节点
tianansp_folder -up-> kubernetes:发布和管控docker节点@enduml

file

小结

1. 活动图(泳道图)实际上是代码流程的一个梳理,建议编码前,先画活动图;

2. 状态图 可以列举出所有状态发生改变的事件,防止遗漏掉某些发生改变的情况;

3. 部署图实际上是物理架构图,画的不太好看,但是却可以在上线的时候有效的指导运维;

原创不易,转载请注明出处,欢迎多沟通交流

这篇关于plantuml-绘制状态图和活动图和部署图​的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/870693

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

QT6中绘制UI的两种方法详解与示例代码

《QT6中绘制UI的两种方法详解与示例代码》Qt6提供了两种主要的UI绘制技术:​​QML(QtMeta-ObjectLanguage)​​和​​C++Widgets​​,这两种技术各有优势,适用于不... 目录一、QML 技术详解1.1 QML 简介1.2 QML 的核心概念1.3 QML 示例:简单按钮

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

ubuntu如何部署Dify以及安装Docker? Dify安装部署指南

《ubuntu如何部署Dify以及安装Docker?Dify安装部署指南》Dify是一个开源的大模型应用开发平台,允许用户快速构建和部署基于大语言模型的应用,ubuntu如何部署Dify呢?详细请... Dify是个不错的开源LLM应用开发平台,提供从 Agent 构建到 AI workflow 编排、RA

ubuntu16.04如何部署dify? 在Linux上安装部署Dify的技巧

《ubuntu16.04如何部署dify?在Linux上安装部署Dify的技巧》随着云计算和容器技术的快速发展,Docker已经成为现代软件开发和部署的重要工具之一,Dify作为一款优秀的云原生应用... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib