.NET TIPS

[ASP.NET]SQL Serverモードのセッション管理で情報を永続化するには?

山田 祥寛
2004/11/19

 「TIPS:[ASP.NET]セッション情報をSQL Server上で管理するには?」では、SQL Serverを利用して、IISサーバ・プロセスからセッション管理を分離する方法について紹介した。セッション管理をASP.NETアプリケーションから分離することで、メモリ負荷の軽減などの効果を得ることができる。

 しかし、前述のTIPSで紹介した方法では、セッションを管理するSQL Serverが何らかの事情で再起動したときにセッション情報を維持することができない。これは、セッション情報を保持するtempdbデータベースが、SQL Server再起動のタイミングで必ず初期化されるためだ。そのため、たとえ障害に対する耐久性を向上する目的で、SQL Serverをクラスタ構成にしていたとしても、フェイルオーバーによってセッション状態は破棄されてしまうことになる。これでは、せっかくセッション管理のプロセスをASP.NETアプリケーションから分離しても、その効果は半減してしまう。

 そこで本稿では、SQL Serverが再起動してもセッション状態を維持させる方法について紹介する。もっとも、その方法はすでに先のTIPSでSQL Serverモードのセッションを実現された方ならば、ごく簡単だ。

 先述のTIPSでは、セッション管理用のデータベースを作成するためにInstallSqlState.sqlを使用したが、これを同一のフォルダ(「<Windowsルート>\Microsoft.NET\Framework\<バージョン番号>」フォルダ)に含まれるInstallPersistSqlState.sqlに置き換えればよい。ただし、InstallPersistSqlState.sqlは.NET Framework 1.1から同梱されるようになったスクリプトであり、.NET Framework 1.0には含まれていないので注意すること。.NET Framework 1.0を使用している方は、以下のサイトからPersistSqlState.exeをダウンローしていただきたい。

 InstallPersistSqlState.sqlの実行方法は、前述のTIPSの手順1でも紹介したとおりである。インストールに際しては、MSSQLServer、およびSQLServerAgentのサービスを起動しておく必要がある。また、それ以降のweb.configの設定についても、別稿の手順に従えばよい。

 正しくInstallPersistSqlState.sqlが実行され、セッション管理用のデータベースが生成されているかどうかを確認するとき、MSDEのようにGUIのデータベース管理ツールがない場合には、Microsoft Access上から行うとよい。AccessからSQL Server(MSDE)に接続する手順については、「Windows TIPS:AccessをMSDEのフロントエンドとして利用する」にて紹介しているので、併せて参照してほしい。

 以下は、ASPStateデータベースのテーブル・リストだ。InstallSqlState.sqlを実行した時にはtempdbデータベース上に展開されたテーブルが、今度はASPStateデータベース上に展開されたことが確認できるはずだ。もちろんこのデータベースは、tempdbデータベースと異なり、SQL Serverが再起動しても、その情報が自動的に削除されることはない。

ASPStateデータベース
InstallPersistSqlState.sqlによって生成されたASPStateデータベースには、セッション操作用のストアドプロシージャに加え、セッション情報を保存するためのテーブルが含まれる。

 なお、InstallPersistSqlState.sqlによって生成されたASPStateデータベースは、UninstallPersistSqlState.sqlによって破棄することができる。End of Article

カテゴリ:Webフォーム 処理対象:セッション管理
使用キーワード:<sessionState>要素
関連TIPS:[ASP.NET]セッション情報をSQL Server上で管理するには?
 
この記事と関連性の高い別の.NET TIPS
[ASP.NET]セッション情報をSQL Server上で管理するには?
手軽にSQL Serverのデータベースをコピーするには?
[ASP.NET]Express Edition以外のSQL Serverでフォーム認証を利用するには?
[ASP.NET]セッション情報を外部プロセスで管理するには?
アプリケーション内でデータベースをアタッチするには?
このリストは、(株)デジタルアドバンテージが開発した
自動関連記事探索システム Jigsaw(ジグソー) により自動抽出したものです。
generated by

「.NET TIPS」


Insider.NET フォーラム 新着記事
  • 第2回 簡潔なコーディングのために (2017/7/26)
     ラムダ式で記述できるメンバの増加、throw式、out変数、タプルなど、C# 7には以前よりもコードを簡潔に記述できるような機能が導入されている
  • 第1回 Visual Studio Codeデバッグの基礎知識 (2017/7/21)
     Node.jsプログラムをデバッグしながら、Visual Studio Codeに統合されているデバッグ機能の基本の「キ」をマスターしよう
  • 第1回 明瞭なコーディングのために (2017/7/19)
     C# 7で追加された新機能の中から、「数値リテラル構文の改善」と「ローカル関数」を紹介する。これらは分かりやすいコードを記述するのに使える
  • Presentation Translator (2017/7/18)
     Presentation TranslatorはPowerPoint用のアドイン。プレゼンテーション時の字幕の付加や、多言語での質疑応答、スライドの翻訳を行える
@ITメールマガジン 新着情報やスタッフのコラムがメールで届きます(無料)

注目のテーマ

Insider.NET 記事ランキング

本日 月間