はじめに
ビルド速度を調べたいことがあったので、そのときに知ったことを記事にします。
ビルド速度を測る方法はいくつかありますが、それぞれ取得できる情報は違ったりするので、その違いなども説明しつつ、測定方法を解説します。
ビルドにかかった総時間だけを測りたいとき
ビルドログを見れば、ビルドにかかった総時間をみることができます。
以下手順で、Xcode でビルドログを確認できます。
1. Xcode の左の Navigator の上部タブの中から、ログのタブを選択する
過去〜現在のビルドログが一覧で表示されているので、測定したいビルドを選択する
DerivedData にビルドログが格納されているので、DerivedData の削除をしてしまうと過去のビルドログは見れなくなります。
2. ビルドログを開くと、ログの最下部にビルドの総時間を確認できる。
ビルドの各プロセス毎にどれぐらい時間かかかっているか測りたいとき
一言でビルドと言っても、その中でもいろんなことをやっています。
RunScript を実行したり、依存関係の検出、コンパイル、リンクなどいろんなプロセスを経て、ビルドが完了となっています。
ビルドで行われているプロセスの詳細は、こちらの記事で詳しく説明されていました。
それら各プロセスでどれぐらい時間がかかっているかを計測するには、以下の手順で確認できます。
1. Xcode の上部のタブから"Product"を選択する
2. "Perform Action" -> "Build with Timing Summary"を選択する。
これで、ビルドが開始されるので、ビルド完了までしばらく待ちます。
ビルド完了したら、ビルドにかかった総時間を測りたいときの確認手順と同様に、ビルドログを確認すると、最下部にビルド内の各プロセス毎の時間が確認できます。
使い所
この測定方法では、各ビルドプロセスの実行時間を、実行時間の降順で表示してくれるため、ビルド時間のボトルネックが直感的に確認することができます。
ビルド時間の高速化を検討しようとするときに、ボトルネックを探すための一次情報として優れていると思いました。
また、各リリースのタイミングなので、この情報を取得して、都度比較を行うことで、ビルド時間の悪化タイミングを早期に検知することもできそうです。
もっと細かい粒度でビルド時間を測りたいとき
上述した測定よりも、もっと細かい粒度でビルド時間を測定する方法もあります。
あるライブラリのコンパイル時間を見れたりもします。
以下手順で、確認していきます。
1. ビルドログを確認する
ビルドにかかった総時間を測りたいときの手順でビルドログを確認します。
2. タイムラインを表示
ビルドログを開いたら、ログの任意の箇所で右クリックして、"Show in Timeline"を選択します。
すると、以下のようにビルドのタイムラインが表示されます。
"Show in Timeline"を行った位置にズームしてタイムラインが表示されるので、全体を見たい場合は、ズームアウトしてください。
時々タイムラインが表示されなかったりするので、その際はXcodeの再起動で解消することがある。
それでもダメな場合は、ビルドしなおせば大体上手くタイムラインを表示できます。
以下のように、タイムラインの上部にカーソルを合わせると、その時間に何が行われているか確認することができます。
使い所
見てもらった通り、非常に大量のビルド時間に関わる情報を確認できます。
どのライブラリがビルドの遅延の原因なのかなどを知ることができるので、ビルドの各プロセス毎にどれぐらい時間かかかっているか測りたいときで解説した方法で、ボトルネックの箇所を確認した後、タイムラインでさらにボトルネックのプロセスの中でも、どのライブラリが悪さをしているのかなどを細かく確認するのに使用できそうです。
おわり
以上が、ビルド時間の測定方法です。
Xcodeにこんな機能があったのは、結構長い間知らなかったので驚きでした。
これを活用すると、ビルド時間の高速化も捗りそうです。
もっと良い方法あれば、コメントいただけると幸いです。