複数のアプリケーションからのエラーを保存するための単一のSQLログがあります。各アプリケーションのelmah.axdページを無効にし、エラーを共通のSQLログに報告するすべてのアプリからのエラーを具体的に表示する新しいアプリケーションが必要です。
現在のところ、すべてのエラーのアプリケーションは共通のSQLログを使用していますが、現在のアプリケーションからのエラーのみが表示されます。誰かがこれを以前にやったことがありますか?elmahコード内で微調整が必要なものは何ですか?
複数のアプリケーションからのエラーを保存するための単一のSQLログがあります。各アプリケーションのelmah.axdページを無効にし、エラーを共通のSQLログに報告するすべてのアプリからのエラーを具体的に表示する新しいアプリケーションが必要です。
現在のところ、すべてのエラーのアプリケーションは共通のSQLログを使用していますが、現在のアプリケーションからのエラーのみが表示されます。誰かがこれを以前にやったことがありますか?elmahコード内で微調整が必要なものは何ですか?
「SQLログ」とはMSSQLServerを意味すると思います...もしそうなら、おそらくあなたが望むことを達成する最も簡単な方法は、エラーを保持するSQLServerデータベースに作成されたストアドプロシージャを編集することでしょう。
エラーリストを取得するために、ELMAH dllはELMAH_GetErrorsXML
、アプリケーション名をパラメーターとしてprocを呼び出し、procはWHERE [Application] = @Application
句を使用して戻り値をフィルター処理します。
プロシージャからWHERE句を削除するだけELMAH_GetErrorsXML
で、アプリケーションに関係なくすべてのエラーが返されます。
単一のエラーレコードを適切に取得するには、ELMAH_GetErrorXML
procでも同じことを行う必要があります。これは、アプリケーションによってもフィルタリングされるためです。
もちろん、これはこの特定のデータベースからエラーを取得するアプリケーションに影響しますが、あなたの場合は1つしかないと思いますので、これは良いことです。
警告:私はこれを試したことがないので、結果を保証することはできません...
デフォルトのElmahハンドラーファクトリをオーバーライドして、アプリケーションによってElmahログをフィルター処理することは問題ありません。MySqlでそれを行う方法を示すサンプルアプリを作成しました:http://diagnettoolkit.codeplex.com/releases/view/103931。それがどのように機能するかを説明している私のブログの投稿をチェックするのもよいでしょう。
はい、簡単に動作します。ただし、Elmah/Default.aspxにアプリ名を表示することはできません。わかりやすいかどうかはわかりません。もう1列だけ表示してください。