スキップしてメイン コンテンツに移動

plantuml node procedure アーキテクチャ図の部品化


 最近よくアーキテクチャ図を描くようになりました。

一々Node名とリンクやIP、データベースの設定するのもいいのですが、

Node数が多すぎると大変な作業になります。そこで、plantumlのprocedureを作れました。

他の部品も同じ方法で作れますので、興味ある方はご参考ください。

SVG画像

@startuml

!procedure $node($alias, $name="mynode",$ip="", $database="", $namelink="", $dbtype="", $dblink="", $fontsize=14, $color="#bafcc8")
!include
skinparam node {
backgroundColor $color
FontSize $size
}
!if ($namelink != "")
!$name = "[[" + $namelink + " " + $name + "]]"
!endif
!if ($ip != "")
!$name = $name + "\n(" + $ip + ")"
!endif


node "$name" <<$archimate/technology-node>> as $alias {
!if ($database != "")
!$dbalias = $alias + "DB"
!if ($dblink != "")
!$database = "[[" + $dblink + " " + $database + "]]"
!endif
!if ($dbtype != "")
!$database = $database + "\n(" + $dbtype + ")"
!endif
database "$database" as $dbalias
!endif
}

!endprocedure

$node($alias="SpotfireServer", $name="Spotfireサーバ", $ip="192.168.1.20", $database="Spotfire", $namelink="http://localhost", $dbtype="PostgreSQL", $dblink="http://localhost")

$node($alias="DWHDb", $name="DWH DBサーバ",$ip="192.168.1.21", $database="Spotfire", $namelink="http://localhost", $dbtype="PostgreSQL", $dblink="http://localhost")

SpotfireServerDB <-> DWHDbDB

@enduml

コメント

このブログの人気の投稿

余裕ですかね。

  いまの自分はやることが多いが、意外と慌てず一歩一歩現場と歩んでいき、地道にデータ入力から可視化までの利便性、完全性と正確性を追求する余裕が出ております。SpotfireというBIツールにハマり、人に使い方を教えながらもまたその恩恵を受けているといういい循環も大きいですね。大体自分のようなポストにいる人たちはあまりプログラムを書く余裕もないだが、自分は幸せのほうと思います。

自己流思い付き

 長年契約してきたさくらインターネットのVPSに稼働しているWordpressが何らかのものに削除されました。幸い残したいものはこのブログに移したので、あまり困ったことはありませんでした。もうVPSを解約しようと思いますが、今年の11月までの契約なので、正直って迷っております。  職場のホームページサーバがMacmini上のピュアDebianなので、実験台としてVPSを契約したのですが、もう実験しないし、解約してもよいだと思います。   このブログもこれをきっかけにタイトルを変えました。

Excel Power Query 英数字の全角から半角への変換

最近仕事上でExcelのPower Queryを始めました。しかし、英数字の全角から半角への変換関数がないため、下記のサイトを参考して、 作っちゃいました。  https://qiita.com/baku2san/items/8041d0259fe0db680e7e https://www.yoheim.net/blog.php?q=20191101 (original as text) as text =&gt; let    originalText = Text.Combine({original, ""}),    replaceResult =  Web.Page("<script>var originalText="&"'"&originalText&"'"&";var result=originalText.replace(/[A-Za-z0-9]/g, function(s) {return String.fromCharCode(s.charCodeAt(0) - 0xFEE0);});document.write(result);</script>")       [Data]{0}[Children]{0}[Children],    result = if (List.Count(replaceResult) &lt;= 1) then    {        "" as text // 変換して何も残らない場合    } else if (replaceResult{1}[Text]{0} = null) then    {       originalText   as text// 何も見つからない場合    }  else {       replaceResult{1}[Text]{0} as text    } in     result{0}