みなさん、シーケンス図は何を使って書いていますか?
エクセルとかスプレッドシート、はたまた、draw.ioなど使っているかと思います。
私は、VSCode + PlantUMLで、シーケンス図を書いています。
ちなみに読み方は、「プラントユーエムエル」です。
PlantUMLであれば、テキストベースのため、git管理でき、履歴管理できます。
シーケンスは、実装次第で変わっていきますよね。
シーケンス図だけでなく、
- ユースケース図
- クラス図
- オブジェクト図
- コンポーネント図
- 配置図
- 状態遷移図
- タイミング図
等にも利用が可能です。
最近知ったのですが、システム構成図もかけるのですね。システム構成図を描く方は、以下を見てみてください。
直感的にシンプルに記述できるのですが、ちょっと凝ったことをやろうとするとその都度、調べないといけなく面倒だったので、こちらにまとめてみることにしました。
PlantUML以外では、最近GitHubで、「Mermaid」記法が使えるようになったので、こちらの利用者も増えていくことでしょう。
目次
VSCodeでPlantUMLを表示できるようにする
VSCodeがインストールされている事が前提になります。
まずは、ローカルマシンに、いくつか必要なパッケージをインストールします。
- Java
- Graphviz
- PlantUML
# brew install --cask temurin # brew install --cask adoptopenjdkはエラーになったため
# brew install graphviz
# brew install plantuml
久しぶりにbrewコマンドを実行したため、エラーだらけになりました。
以下を実行して、brew updateしました。
# git -C /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core fetch --unshallow
# brew update
adoptopenjdkは500エラーとなったため、後継であるtemurinをインストールしています。
VSCodeのインストールは、以下から可能です。
私の環境では、VSCodeのバージョンは、1.62になります。
赤枠のアイコンをクリックし、「PlantUML」を検索して、一番最初のものをインストールします。
data:image/s3,"s3://crabby-images/6bad9/6bad9676509edcd125acc84686a65bf3d4ad0472" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
installをクリックしてインストールします。
data:image/s3,"s3://crabby-images/bceb5/bceb5dad806a328211efb07db762babcf5603040" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
VSCodeのプラグインの動作確認をする
前項のインストールが完了したら、新規でファイルを作成します。
拡張子は、以下のいづれかにします。
- .wsd
- .pu
- .puml
- .plantuml
- .iuml
作成したら、以下のコードを貼り付けてみてください。
@startuml
自宅->会社:出社
会社-->自宅:退社
@enduml
この状態で、option + D(Mac) or Alt + D(Windows)を押してみてください。
すると右側に、プレビューのウィンドウが表示されます。
data:image/s3,"s3://crabby-images/918f2/918f2059286842318ecceb6a2d08a08ccdabd16b" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
こちらで動作確認としては、OKになります。
基本の書き方
以下の図では、自宅、会社が分類子になります。
シーケンスを->で記述して、分類子間をつなげていきます。
可読性という意味では、戻りのシーケンスは、”<–“で記述した方がよいかもしれません。(下のコードの上下どちらも同じ表示になります。)
@startuml
自宅->会社:出社
会社-->自宅: 退社
自宅->会社:出社
自宅<--会社:退社
@enduml
data:image/s3,"s3://crabby-images/c7156/c71561c3cbde200233a54492fcfb27ee2fa814d9" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
分類子の種類
分類子には、以下のようなものがあります。
- participant
- actor
- boundary
- control
- entity
- database
- collections
- queue
data:image/s3,"s3://crabby-images/60919/60919053f22953f34f320d34a1afa368310bba05" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
シーケンス図の色を変えてみる
こちらの配色のサンプルをよく見るかと思います。
data:image/s3,"s3://crabby-images/b9256/b92568e8b009e7cb18ba5c9de823bbd3f8db12ff" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
見やすいといえば見やすいのですが、ちょっと味気なさを感じます。
そこで、デフォルトで用意されているテーマを利用して、色を変えてみます。
個別に色を変えることもできます。
テーマによっては、文字が消えてしまうものもあるのでご注意ください。
テーマを利用する場合は、@startumlのあとに、!theme テーマ名と記述します。
@startuml
!theme united
自宅->会社:出社
会社-->自宅:退社
@enduml
_none_
!theme _none_
data:image/s3,"s3://crabby-images/c7156/c71561c3cbde200233a54492fcfb27ee2fa814d9" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
amiga
!theme amiga
data:image/s3,"s3://crabby-images/a0461/a0461b01a75689c57c7e42a321404a18ce972534" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
aws-orange
!theme aws-orange
data:image/s3,"s3://crabby-images/a8689/a868918d8bb46e5557ac80523605a37b379211b5" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
black-knight
!theme black-knight
data:image/s3,"s3://crabby-images/1d562/1d56219da5b3230842a35dcf2d308986b1b3bffd" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
bluegray
!theme bluegray
data:image/s3,"s3://crabby-images/a6ed8/a6ed83dd716362c00380935c25fc7a98f5b49a61" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
blueprint
!theme blueprint
cerulean
!theme cerulean
data:image/s3,"s3://crabby-images/8a6d9/8a6d9932e502da6315b2b1f405974091b8e014d9" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
cerulean-outline
!theme cerulean-outline
data:image/s3,"s3://crabby-images/ef9b2/ef9b227c26bd0426965157a8dc107975dab8a800" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
crt-amber
!theme crt-amber
data:image/s3,"s3://crabby-images/8f7ac/8f7ac4168a195833d259d4fd53c4ae48629a77dd" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
crt-green
!theme crt-green
data:image/s3,"s3://crabby-images/be5bf/be5bff84edb4e96f2dd444ff14a5b92760eb2190" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
cyborg
!theme cyborg
data:image/s3,"s3://crabby-images/c6eaf/c6eaf95244c25275f9b5dc0dda8ac422b66e3478" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
cyborg-outline
!theme cyborg-outline
data:image/s3,"s3://crabby-images/21b3c/21b3c22e4625813de9654ae5d5c43b4a38bc6134" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
hacker
!theme hacker
data:image/s3,"s3://crabby-images/f3620/f362076858d00a22f773865b4898f57b6308cff2" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
lightgray
!theme lightgray
data:image/s3,"s3://crabby-images/a0755/a0755bdad6cd3ef15d98bce6d54a6ab035b53f89" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
mars
!theme mars
materia
!theme materia
data:image/s3,"s3://crabby-images/70dd5/70dd5321326d0773f107fb89cecec34a2bb23e11" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
materia-outline
!theme materia-outline
data:image/s3,"s3://crabby-images/ad841/ad841b5fb6919f0c0f1aab637a9ef06b233c9a54" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
metal
!theme metal
data:image/s3,"s3://crabby-images/3d270/3d27049cf0de7ae9bdaa26e523c89a1fae7443fb" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
mimeograph
!theme mimeograph
data:image/s3,"s3://crabby-images/f0e45/f0e45f5dea52e048b958eb03fbcd1000ccd629be" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
minty
!theme minty
data:image/s3,"s3://crabby-images/cee80/cee80024f57a20109fec43daf82fbf26f6f946bd" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
plain
!theme plain
reddress-darkblue
!theme reddress-darkblue
reddress-darkgreen
!theme reddress-darkgreen
reddress-darkorange
!theme reddress-darkorange
reddress-darkred
!theme reddress-darkred
reddress-lightblue
!theme reddress-lightblue
reddress-lightgreen
!theme reddress-lightgreen
reddress-lightorange
!theme reddress-lightorange
reddress-lightred
!theme reddress-lightred
sandstone
!theme sandstone
data:image/s3,"s3://crabby-images/1f3ee/1f3ee5d2ff30a143efe697b813dbdabc2a6c1be8" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
silver
!theme silver
data:image/s3,"s3://crabby-images/a50df/a50df271271c86a3ee9d40926b6d9f0e18d4922b" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
sketchy
!theme sketchy
data:image/s3,"s3://crabby-images/eda2d/eda2def540c6ba0fb1f14221f8c81731c7ed2af0" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
sketchy-outline
!theme sketchy-outline
data:image/s3,"s3://crabby-images/4cf70/4cf7055c389230a324dc26fbdfad117e96a982fa" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
spacelab
!theme spacelab
data:image/s3,"s3://crabby-images/6d281/6d281729e50620c154a1990d8a81c2e56be0ce32" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
spacelab-white
!theme spacelab-white
data:image/s3,"s3://crabby-images/affb4/affb45034a0980783cd77a17dc92449e98644657" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
superhero
!theme superhero
data:image/s3,"s3://crabby-images/db39b/db39be573589d36dbffdfd962004b1b300414df6" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
superhero-outline
!theme superhero-outline
data:image/s3,"s3://crabby-images/d843f/d843fe193b10c8c06d7bc0c3a6ae0967cbc7d9a8" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
toy
!theme toy
united
!theme united
data:image/s3,"s3://crabby-images/052b8/052b8a8198138f0b676e6cdcfbd5ed50444b4846" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
vibrant
!theme vibrant
テーマによっては、出社・退社の文字が消えてしまっているものがあるのでその場合は、<color: 色></color>でくくることにより色を変更することができます。
@startuml
!theme united
自宅->会社:<color:blue>出社</color>
会社-->自宅:<color:blue>退社</color>
@enduml
data:image/s3,"s3://crabby-images/11c5e/11c5e63b370041acdef7ffa6a14a19a3a9c3886c" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
エイリアス機能
分類子の名前を毎回書くと可読性が悪くなります。
そこでキーワードasを使って分類子の別名をつけることができます。
@startuml
hide unlinked
participant Participant as Foo
actor Actor as Foo1
boundary Boundary as Foo2
control Control as Foo3
Foo->Foo1: Participant->Actor
Foo->Foo2: Participant->Boundary
@enduml
data:image/s3,"s3://crabby-images/4b6a7/4b6a7f41c893ec34a06bfe982b0e38c0e892a6e0" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
上記の例では、controlも定義していますが、”hide unlinked”を入れることで、未接続の分類子(定義したけど利用していない分類子)が非表示になります。
hideキーワードには以下があります。
記述方法 | 内容 |
---|---|
hide unlinked | 未接続の分類子は非表示にする |
hide footbox | 分類子の下のボックスを非表示にする |
ボックスで分けたい
シーケンス図をかいていると、ここからここまでは、サーバ側、ここからここまでは、ユーザ側等で分けたくなることがあるかと思います。
そんなときは、キーワードboxを利用します。
@startuml
hide unlinked
actor ユーザ as u
participant スマホ as s
box サーバサイド # box タイトル名で始める
participant サーバ as sv
database DB as d
end box # end boxでボックスを閉じる
u->s: スマホ利用
s->sv: アクセス
sv->d: 検索
d-->sv: 結果
sv-->s: 表示
s->u:確認
@enduml
data:image/s3,"s3://crabby-images/8bd4c/8bd4cf1f69b3266e5dbbc5697a70097ee2d7372b" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
グループ分けをする
いくつかの処理をグループで分けて表示したいときがあります。
そういう場合は、altを利用します。
alt 認証が必要
u->s: 認証処理を実行
else 認証不要
u->s: 通常アクセス
end
data:image/s3,"s3://crabby-images/bd6e3/bd6e39ad51a59534051fe7d76a42adc235f0bc46" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
alt以外にも以下が利用可能です。
opt
loop
par
ref over
break
critical
group 任意のラベル名
利用するとラベルの部分が変わります。
data:image/s3,"s3://crabby-images/2e12a/2e12a3db6c5b070eb21d7d435876c1b3171a6864" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
シーケンス図にタイトルをつける
なんのシーケン図なのかわかりやすくするために、タイトルをつけることができます。
title スマホでの検索について
data:image/s3,"s3://crabby-images/46c53/46c5341dccb2a611922fdff810c7e6bee2e86e82" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
title スマホでの検索について\n改行もできます
data:image/s3,"s3://crabby-images/3e91b/3e91b150ca4168d54580323aca7480e343c17f03" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
title 〜 endtitleで囲うと複数行の記入ができます。
title
スマホでの検索について
改行もできます
さらに改行
end title
data:image/s3,"s3://crabby-images/67df2/67df22f49debc81e6b662cedfb2c091b64fafba1" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
メッセージにノートをつける
note right, note left, note overでメッセージにノートをつけることができます。
なぜに、centerではなく、overなのかと。overの方がしっくりくるけど、left, rightとあったらcenterがよかった。overが思い出せないですw
@startuml
title メモ書き
A->B
note left of A
Aの左にメモ
end note
B->C
note over of B
Bの上にメモ
end note
C-->B
B-->A
note right of C
Cの右にメモ
end note
@enduml
data:image/s3,"s3://crabby-images/b29c0/b29c0d75fbbac9142ba5183acd6ccb58000c7395" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
ノートの形を変える
線上にボックスを配置したいこともあるかと思います。その際は、ボックスの形を変え、色を変えると
分類子の上に、ボックスを配置することができます。
キーワード hnote と rnote を使ってノートの形を変更できます。
@startuml
title メモ書き
A->B
hnote left of A
hnote: 六角形
end note
B->C
rnote over of B #red
rnote: 四角
end note
C-->B
B-->A
hnote right of C
hnote: 六角形
end note
@enduml
data:image/s3,"s3://crabby-images/c85f2/c85f2d30a46d89591073411eef37a43207861427" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
区切りをつける(境界線)
シーケンスを書いていると、上の部分は、XX、これより下は、YYとか区切りをつけたくなることがあるかと思います。
== を利用します。
== ここから下は、別 ==
@startuml
== 初期化処理 ==
ユーザ -> サーバ: 認証要求
サーバ --> ユーザ: 許可
== 通常処理 ==
ユーザ -> サーバ: APIリクエスト
ユーザ <-- サーバ: レスポンス
@enduml
data:image/s3,"s3://crabby-images/f76a0/f76a024919b54531913ed6d56ad5fb3e0b6fee59" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"
シーケンスに数字をつける
autonumberと宣言すると、シーケンスに添え字をつけることができます。
@startuml
autonumber # 添字開始
autonumber stop # 添字停止
autonumber 10 # 10から開始
autonumber resume # 再開
@startuml
autonumber
== 初期化処理 ==
ユーザ -> サーバ: 認証要求
サーバ --> ユーザ: 許可
autonumber stop
== 通常処理 ==
autonumber 10
ユーザ -> サーバ: APIリクエスト
ユーザ <-- サーバ: レスポンス
autonumber stop
@enduml
data:image/s3,"s3://crabby-images/8cce4/8cce409dcc8c440907059b7fb6030e2764f09115" alt="PlantUML(プラントユーエムエル)でシーケンス図を書くぞ!"