ソースデータはメインの Web アーキテクチャとは別のサーバーにあり、頻繁に変更されないため、asp.net アプリケーションにキャッシュされた単純なルックアップ テーブルがたくさんあります。ここでの回答とさまざまなドキュメントをフォローしており、初期ロード関数で次のように呼び出しています。
HttpContext.Current.Cache.Insert("CheckLocations", GetAllCheckLocations(), _
Nothing, DateAdd(DateInterval.Day, 1, Now()), _
System.Web.Caching.Cache.NoSlidingExpiration, _
CacheItemPriority.Normal, _
New CacheItemRemovedCallback(AddressOf CheckLocationsExpired))
私のキャッシュ期限切れコールバックには、次のコードがあります。
Public Shared Sub CheckLocationsExpired(ByVal key As String, ByVal value As Object, ByVal reason As CacheItemRemovedReason)
Dim dtCheckLocation As New ReferenceSchema.CheckLocationDataTable
dtCheckLocation = GetAllCheckLocations()
HttpContext.Current.Cache.Insert("CheckLocations", dtCheckLocation, Nothing, _
DateAdd(DateInterval.Day, 1, Now()), _
System.Web.Caching.Cache.NoSlidingExpiration, _
CacheItemPriority.Normal, _
New CacheItemRemovedCallback(AddressOf CheckLocationsExpired))
End Sub
レコードの場合、GetAllCheckLocations メソッドは単純に Web サービスを呼び出し、結果を解析して格納されているデータ テーブルに入れます。
ローカル テスト用にアプリケーションを再コンパイルすると、すべて正常に機能しますが、ログ ファイルに次の例外メッセージが見つかります。
System.NullReferenceException: オブジェクト参照がオブジェクトのインスタンスに設定されていません。C:\Projects\HR\EAF 2.0\DAL\CacheMethods.vb:line 434 の EAF.CacheMethods.CheckLocationsExpired (文字列キー、オブジェクト値、CacheItemRemovedReason 理由) で System.Web.Caching.CacheEntry.CallCacheItemRemovedCallback (CacheItemRemovedCallback コールバック、CacheItemRemovedReason)理由)
データが実際にそこにあり、最新であることを確認します。デバッガーをステップ実行しても、コマンド引数に不自然な点はありません。
ここで何が欠けているか知っている人はいますか?これは、技術的に処理を終了するとスレッド中止例外がスローされる Reponse.Redirect の問題のような「ニュアンス」の 1 つですか?