この記事はUnreal Engine (UE) Advent Calendar 2023 の12月22日の記事になりまーす(ΦωΦ)
またせたな。
「UE4にSentryを入れてエラー監視を楽にする」を書いて一年以上経っちゃいましたが、UE5での導入方法と
Sentry以外のクラッシュレポート収集ができるプラグインについても紹介します。
まずはSentryから!
ほとんどUE4のときと同じです~♪
Sentryって?
Sentryはエラー監視をやってくれるプラグインです。
UnityやWebアプリではよく使われてますがUEではなぜが記事がないのが不思議です。
Sentryの準備
Sentryのプラグインはマーケットプレイスから取得できます
以前はこちらのGithubから取ってくる形でしたが楽になりました。
その後プラグインが読み込まれたことを確認して
DSNを登録する箇所があるのでそこに必要なURLを入れます
クラッシュレポートのエンドポイントもここで設定できます。
URLに関してはこのあとのSentry側のプロジェクト作成で確認できます。
Sentry側のプロジェクト作成
Sentry側でレポートなど受け取るプロジェクトを作成しまう、
この登録をするとすぐ出てきます。
プロジェクトをUEを選んで
エンドポイントについては、"Client Keys" 設定ページの一番下にあります。
これ入れないとスタックトレース情報など受け取れないので注意してください
■クラッシュポイント設定
クラッシュレポータエンドポイントの設定
クラッシュ レポーターとデバッグ ファイルが含まれるようになったので、UE5はクラッシュをどこに送信するかを知る必要があります。
UE5.2以降だとSentry側の機能でクラッシュ情報を通知してくれる用になってます。
エンドポイントの登録などはプロジェクト設定の方でできるので以前より簡単になりました。
下記の用にクラッシュレポート側の.iniを変えなくてもいいですが
気になる人は変えておくといいかもです。
Sentry側の設定はちょっと見づらいので「Crash」で検索してみてください
一般のところにある「Override Windows default crash capturing mechanism」のところにチェックを入れるとSentry側のクラッシュ通知機能を使います
ですが、筆者としてはこれは使わないほうがいいです。
UE5側後の実際にクラッシュさせたときにも書いてますが
UE5側のクラッシュレポート機能に出てくるトレース情報がないのは困るのときがあるので
古いやり方ですが、直接iniを書き換える場合はここです
engine-dir\Engine\Programs\CrashReportClient\Config\DefaultEngine.ini
下記を追加する感じです
[CrashReportClient]
CrashReportClientVersion=1.0
DataRouterUrl="--------------------------これ-----------------------"
それではそのへんの対応ができた
ってところでいきなりやると大変なので
サンプルプロジェクトがあるのでそれを使ってから
移植していくのが良いと思います。
サンプルプロジェクトを使う場合はプロジェクトの中のPluginsの中にReleaseから持ってきた
UE5のバージョンに合わせてあプラグインを持ってきて入れておかないと起動時にプラグインがないぞと怒られて起動しません
注意しましょう。
それでは、サンプルプロジェクトからイベントとクラッシュをさせてみましょう
起動するとこんな画面になりメッセージやイベント、クラッシュが出ます
では
イベントの押してみますー
Sentyの管理画面のissuesにイベントやクラッシュ報告が出ます
イベント通知が来てま~す。
イベントの中身を見るとどこで呼ばれたのかやそのイベントを呼び出した
PCや端末の情報を見ることができます。
この辺はUE4のころと変わらず
どのような環境のユーザーから飛んできたイベントなのかが確認できます。
次はクラッシュさせてみます。
クラッシュのボタンを押すと
Sentry側の
クラッシュレポートが出てきてー
と思ったけど、「Override Windows default crash capturing mechanism」をチェック入れてると何もでません
なのでこれ切っておいたほうがいいと思うの開発中だとなんでエラーなのか出ないので困るからです。
まず、クラッシュした端末の情報とどんなクラッシュなのか
GPUの情報も飛んできます
こんな感じでエンドポイントがちゃんと設定されてるとコールスタック情報も入ってます。
これはあとで「どこで起きたエラーだ?」ってなったときでも助かりますね。
自分のプロジェクトにイベント通知を追加する
それでは、自分のプロジェクトにメッセージを飛ばすイベントを通知してみようと思います。
BPの場合はこれだけです。 日本語入れると化けちゃうかもなので非推奨ですー。
C++の場合
#include "SentrySubsystem.h"
void EventMessage()
{
// Capture message
USentrySubsystem* SentrySubsystem = GEngine->GetEngineSubsystem<USentrySubsystem>();
SentrySubsystem->CaptureMessage(TEXT("test"));
}
こんな感じです。
おまけ
Sentry以外のクラッシュ監視でUE5対応のものを紹介します。
BugSplat
エラーモニタリングや、安定性管理のサービスです。
Sentryに似てますが、パッと見ドキュメントが最近のUEに対応してるのはこちらです
動作確認用の利用ぐらいなら無料でできそうなので次回はこちらのサービスを調査してみようと思います。
BugSnag
こちらもエラーモニタリングのサービスなのですが
30日間のみ無料であとは有料みたいかな?それか機能制限みたいです。
あまり情報がないので、こちらはまとまった時間をとって調査してみようと思います。
最後に
またUE5に関して記事書くときは、もう少しエンジン側の内容を書こうかと思います(ΦωΦ)
一緒に開発してくれる方も絶賛募集中です!興味あったらいつでも僕に声かけてください!
会社へのエントリーもお待ちしてます!
https://www.blastedge-games.co.jp/recruit
一緒にUnreal Engineでゲームを作りましょー!