JPH0793205A - 分散ファイルシステム - Google Patents
分散ファイルシステムInfo
- Publication number
- JPH0793205A JPH0793205A JP5241534A JP24153493A JPH0793205A JP H0793205 A JPH0793205 A JP H0793205A JP 5241534 A JP5241534 A JP 5241534A JP 24153493 A JP24153493 A JP 24153493A JP H0793205 A JPH0793205 A JP H0793205A
- Authority
- JP
- Japan
- Prior art keywords
- file
- user
- priority
- cache
- client
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
- G06F12/122—Replacement control using replacement algorithms of the least frequently used [LFU] type, e.g. with individual count value
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0866—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches for peripheral storage systems, e.g. disk cache
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Computer And Data Communications (AREA)
- Information Transfer Between Computers (AREA)
Abstract
し、ファイルアクセスを高速化する分散ファイルシステ
ムを提供する。 【構成】 ファイルサーバ200は、ユーザ名とそのユ
ーザが頻繁にアクセスするファイル名を対応づけて記録
するアクセス頻度データベース250を持つ。クライア
ント100は、ログイン中のユーザ名を記録するログイ
ンユーザテーブル130と、キャッシュ優先度制御モジ
ュール142を持つ。キャッシュ優先度制御モジュール
142は、アクセス頻度データベース250とログイン
ユーザテーブル130の内容に基づき、キャッシュ領域
170内の各ファイルのコピーに優先度を設定する。 【効果】 クライアントにログインするユーザごとに、
使用頻度の高いファイルを優先的にキャッシングするこ
とにより、キャッシュのヒット率を向上させ、ファイル
アクセスを高速化できる。
Description
ァイルサーバとファイルにアクセスするクライアントと
がネットワークで接続された分散ファイルシステムに係
り、特に使用頻度の高いファイルをクライアントにキャ
ッシングする分散ファイルシステムに関する。
イルサーバが保管するファイルをクライアントにキャッ
シングすることで、ファイルアクセスを高速化してい
る。すなわち、ファイルサーバが保管するファイルのコ
ピーをクライアント側で保持しておくことにより、次回
そのファイルに対するアクセス要求が発生した場合に
は、ファイルサーバへアクセスすることなく自クライア
ント内で処理することができる。キャッシングしたファ
イルを保管する領域をキャッシュ領域と呼び、通常キャ
ッシュ領域は、クライアントの主記憶やディスク装置内
に確保される。
り、アクセスするすべてのファイルを保持することがで
きない。キャッシュのヒット率は、ファイルアクセス性
能に大きく影響するので、限られたキャッシュ領域を有
効活用して、高いキャッシュヒット率を達成することは
非常に重要である。
ァイルのコピーを保管する空間をキャッシュ領域内に確
保する必要がある。すでに多数のファイルをキャッシン
グしていて、十分な空間を確保できない場合には、キャ
ッシング中のファイルをキャッシュ領域から追い出す必
要がある。
いる各ファイルに優先度をつけており、キャッシュ領域
から追い出すファイルを優先度の低い順に選択する。キ
ャッシュのヒット率を向上させるためには、使用頻度の
高いファイルに高い優先度を設定し、高い確率でキャッ
シュ領域に残すようなキャッシュ制御が望ましい。
クセスしたファイルに高い優先度をつける方法によれ
ば、ファイルの使用頻度を反映したキャッシュ制御があ
る程度可能である。しかし、あらかじめファイルの使用
頻度が分かっている場合には、頻繁にアクセスするファ
イルに高い優先度を設定し、そのファイルはなるべくキ
ャッシュ領域から追い出さないようにするキャッシュ制
御が有効である。例えば、プログラム開発者はソースフ
ァイルを頻繁にアクセスする。プログラム開発者が利用
するクライアントマシンでは、ソースファイルに高い優
先度を設定することで、キャッシュのヒット率を向上さ
せファイルアクセスを高速化できる。
散ファイルシステムがある。Coda分散ファイルシス
テムでは、クライアント毎にファイルの優先度を設定す
る。頻繁にアクセスするファイルを高い優先度に設定
し、高い確率でキャッシュ領域に残すことで、キャッシ
ュのヒット率を向上させることができる。Coda分散
ファイルシステムについては、J. Kistler and M. Saty
anarayananによる「ディスコネクテッド・オペレーショ
ン・イン・ザ・コーダ・ファイル・システム(Disconne
cted Operation in the Coda File System)」 ACM Tra
nsactions on Computer Systems Vol. 10, No. 1, pp.
3-25 (1992). に記載されている。
を利用するユーザは、クライアントの1つにログインし
てファイルサーバが保管するファイルにアクセスする。
ユーザ毎にアクセスするファイルは異なるので、あるク
ライアントがどのファイルに頻繁にアクセスするかは、
そのクライアントにログインするユーザによって大きく
変化する。
の優先度を決定する上記従来技術では、ログインしてい
るユーザにあわせて、ファイルの優先度を変更するのが
困難である。その結果、ユーザが頻繁にアクセスするフ
ァイルに高い優先度を設定できず、キャッシュ領域から
追い出してしまう可能性がある。これはキャッシュのヒ
ット率の低下につながる。
向上し、ファイルアクセスを高速化する分散ファイルシ
ステムを提供することである。
に、本発明によるキャッシュ優先度制御方法は、複数の
ファイルを保管するファイルサーバと、該ファイルサー
バに保管されたファイルにアクセスするクライアントと
がネットワークで接続され、前記クライアントは、前記
ファイルのコピーを保管するキャッシュ記憶装置を有す
る分散ファイルシステムにおけるキャッシュ優先度制御
方法であって、前記ファイルサーバ内に、前記クライア
ントからログインを行なうユーザ毎に、そのユーザ名と
そのユーザが頻繁にアクセスするファイルのファイル名
とを対応付けて記憶するアクセス頻度データベースを設
け、前記クライアント内に、そのクライアントから前記
ファイルサーバに対してアクセスして自己のキャッシュ
記憶装置内に取り込んだいずれかのファイルの追い出し
時に当該キャッシュ記憶装置内に残すか否かの判断の基
準となる優先度を定める優先度テーブルを設け、前記ク
ライアントにおいて、あるユーザがログインした際、そ
のユーザのユーザ名を認識し、前記クライアントにおい
て、前記ユーザが前記ファイルサーバからあるファイル
名のファイルを取りだして前記キャッシュ記憶装置に格
納したとき、前記アクセス頻度データベースの内容に基
づいて、当該ファイルが当該ユーザが頻繁にアクセスす
るファイルであるか否かを調べ、その結果に応じて前記
優先度テーブルにおける当該ファイルの優先度を定め、
前記キャッシュ装置からいずれかのファイルを追い出す
べきとき、前記優先度テーブルの内容に基づいて、優先
度の低いファイルを当該追い出すべきファイルとして決
定するようにしたものである。
は、複数のファイルを保管する少なくとも1個のファイ
ルサーバと、該ファイルサーバに保管されたファイルに
アクセスするクライアントとがネットワークで接続され
た分散ファイルシステムにおいて、前記ファイルサーバ
は、ユーザ名とそのユーザが頻繁にアクセスするファイ
ル名とを対応づけて記録するアクセス頻度データベース
を有し、前記クライアントは、ログイン中のユーザ名を
記録するログインユーザテーブルと、前記ファイルサー
バ内のファイルのコピーを保管するキャッシュ記憶装置
と、前記キャッシュ記憶装置に保管する各ファイルのコ
ピーに優先度を設定し、別のファイルのコピーを前記キ
ャッシュ記憶装置に保管するにあたり、前記キャッシュ
記憶装置に十分な空き領域を確保できない場合、優先度
の低いコピーをキャッシュ記憶装置から追い出す制御を
行なうキャッシュ管理手段を有し、各クライアントのキ
ャッシュ管理手段は、前記ログインユーザテーブルと、
前記アクセス頻度データベースの内容に基づいて、自己
のキャッシュ記憶装置内のファイルの追い出し時に当該
キャッシュ記憶装置内に残すか否かの判断の基準となる
優先度を各ファイルに対して設定するようにしたもので
ある。
ユーザが頻繁にアクセスするファイル名とを対応づけて
記録している。アクセス頻度データベースを参照するこ
とで、ユーザ名あるいはファイル名をキーとして、ユー
ザが頻繁にアクセスするファイル名あるいはファイルを
頻繁にアクセスするユーザ名を検索できる。また、アク
セス頻度データベースはファイルサーバに存在するの
で、すべてのクライアントから参照できる。
にログイン中のユーザ名を記録している。キャッシュ管
理手段は、ログイン中のユーザが頻繁にアクセスするフ
ァイルを、ログインユーザテーブルとアクセス頻度デー
タベースを参照することで特定する。そして、ログイン
中のユーザが頻繁にアクセスするファイルに対して高い
優先度を設定することにより、それらのファイルのコピ
ーを高い確率でキャッシュ記憶装置内に保管できる。
イアントであっても、そこにログインするユーザに対応
して、キャッシュ記憶装置のヒット率を向上させ、ファ
イルアクセスを高速化する分散ファイルシステムを提供
できる。
より詳細に説明する。
る分散ファイルシステムのシステム構成を示す。このシ
ステムでは、ネットワーク300に、ファイルサーバ2
00とn台のクライアント100が接続している。ネッ
トワーク300としては、ローカルエリアネットワーク
を採用する。ファイルサーバ200には高性能ワークス
テーションを、クライアント100には安価なワークス
テーション或はパーソナルコンピュータを採用する。n
台のクライアント100は、ファイルサーバとは離れた
端末室に設置されており、ユーザはどれか1つのクライ
アント100にログインし、ファイルアクセスを行な
う。
スク装置230が接続している。ディスク装置230に
は、F1、F2、F3、F4をはじめとする多数のファ
イル240と、アクセス頻度データベース250が保管
されている。
ザ名欄251とファイル名リスト欄252とから構成さ
れ、分散ファイルシステムを利用するユーザ毎に、その
ユーザが頻繁にアクセスするファイル名を登録するもの
である。図示の例では、ユーザAに対してはF1、F3
が、ユーザBに対してはF2、F4が、ユーザCに対し
てはF1が、それぞれのユーザの頻繁にアクセスするフ
ァイルとして登録されている。アクセス頻度データベー
ス250に登録するファイル名は、実際のファイルアク
セス統計をもとに、システム管理者或は各ユーザが登録
する。
ディスク装置150と、端末160が接続している。デ
ィスク装置150は、ファイル240のコピーを保管す
るキャッシュ領域170として利用される。クライアン
ト100は、現在このクライアントにログインしている
ユーザ名を格納するログインユーザテーブル130およ
びキャッシュの管理を行なうキャッシュ管理部140を
有する。キャッシュ管理部140は、キャッシュ優先度
の制御を行なうキャッシュ優先度制御モジュール142
を内包する。ユーザは、端末160を通してクライアン
ト100にログインし、ファイル240にアクセスす
る。現在、クライアント100−1には、ユーザAがロ
グインしている。
ルに対して最初にファイルアクセスを要求した場合、ク
ライアント100は、ファイルサーバ200のディスク
装置250に保管されている当該ファイルを、ネットワ
ーク300を通して読み込む。キャッシュ管理部140
は、ファイルサーバ100から読み込んだファイルをキ
ャッシュ領域170に保管する。同じファイルに再度ア
クセスする場合には、キャッシュ領域170中のコピー
にアクセスすることにより、ファイルアクセスを高速化
できる。
制限があり、アクセスするすべてのファイルをキャッシ
ングできない。ファイルをキャッシングするにあたり、
キャッシュ領域170に十分な空き領域を確保できない
場合には、キャッシング中に存在するファイルをキャッ
シュ領域170から元のファイルサーバ200へ追い出
す必要がある。
度制御モジュール142は、キャッシュ領域170中の
各ファイルに対して優先度を設定する。キャッシュ管理
部140は、優先度の低い順に追い出すファイルを選択
する。具体的には、キャッシュ優先度制御モジュール1
42は、ログイン中のユーザ名131を記録するログイ
ンユーザテーブル130とアクセス頻度データベース2
50を参照して、ログイン中のユーザが頻繁にアクセス
するファイルを認識する。そして、それらのファイルの
コピーに対して高い優先度を設定する。クライアント1
00−1では、現在ユーザAがログインしているので、
アクセス頻度データベース250の内容に基づきユーザ
Aに対応してファイルF1とF3に高い優先度を設定す
る。
動作を詳細に説明する。
している。クライアント100は、セッション管理プロ
グラム110、ファイルアクセスプログラム120、ロ
グインユーザテーブル130、ファイルキャッシングプ
ログラム141、キャッシュ優先度制御モジュール14
2、ローカル頻度データベース144、通信制御プログ
ラム180を持つ。
ータベース250を管理するアクセス頻度データベース
管理プログラム210、ファイル管理プログラム22
0、通信制御プログラム280を持つ。
に協調して、OSIモデルのトランスポート層レベルの
ネットワーク通信を実現する。
7に示すように、アクセス頻度データベース250の登
録内容のうち、ログイン中のユーザに関する項のみを記
録するデータベースであり、ユーザ名欄1001とファ
イル名リスト欄1002とからなる。後述するように、
1つのクライアントに同時に複数のユーザがログインす
る場合を考慮して、図のデータベース144では複数の
エントリを用意してある。
ール142は、優先度テーブル143と、それぞれ優先
度テーブル143を操作するインサート処理ルーチン
1、削除処理ルーチン2、タイムスタンプルーチン3、
追いだし決定ルーチン4とからなる。
す。優先度テーブル143は、高優先度ヘッダ412、
低優先度ヘッダ422と、キャッシュ領域170中の各
ファイルに対して作成される優先度構造体400から構
成される。1つのファイルに対して1つの優先度構造体
400が割り当てられる。優先度構造体400は、タイ
ムスタンプ欄401、ファイル名欄402、レベル欄4
03、ポインタ欄404から構成される。タイムスタン
プ欄401は、ファイル402に最後にアクセスした時
刻を記録する。レベル欄403は、本実施例では、高い
優先度を表すH、低い優先度を表すLのどちらか一方を
記録する。
00は、高優先度ヘッダ412をヘッダとする高優先度
リスト410につながれる。レベル欄403の値がLの
優先度構造体400は、低優先度ヘッダ422をヘッダ
とする低優先度リスト420につながれる。リスト41
0、420の各々内の優先度構造体400は、タイムス
タンプ欄401の値が古い順に整列される。追いだしの
対象となるファイルとしては、低優先度ヘッダ422に
接続されたものから順に選択される。
トを用いて説明する。
ザが入力したコマンドを解釈し、実行する。図4のフロ
ーチャートを使って、セッション管理プログラム110
の処理520を説明する。
を実行する。次にステップ524でコマンド入力を受け
付け、ステップ526で入力コマンドを解釈する。ステ
ップ528で、ユーザがログアウトすると判定されたた
場合には、ステップ532でログアウト処理550を実
行する。ログアウト以外の場合は、ステップ530で入
力コマンドを実行し、ステップ524に戻る。
処理540とログアウト処理550を説明する。
1でユーザの認証を行ない、ステップ542で、ログイ
ンユーザテーブル130にユーザ名を登録する。次にス
テップ543で、ユーザが頻繁にアクセスするファイル
名をファイルサーバ200のアクセス頻度データベース
管理プログラム210に問い合わせ、ステップ544で
ローカル頻度データベース144に登録する。
51で、ログインユーザテーブル130からユーザ名を
削除し、ステップ552で、ローカル頻度データベース
144から、そのユーザの項を削除する。
ウト処理550によって、現在ログイン中のユーザ名を
ログインユーザテーブル130に記録できる。更に、ロ
グイン中のユーザが頻繁にアクセスするファイル名をロ
ーカル頻度データベース144に記録できる。
ドの幾つかは、ファイルサーバ200のファイル240
にアクセスするために、ファイルアクセスプログラム1
20を実行する。図6のフローチャートを使って、ファ
イルアクセスプログラム120の処理560を説明す
る。
イルがキャッシュ領域170に存在するかチェックす
る。キャッシュ領域170に無い場合には、ステップ5
64でファイルキャッシングプログラム141を実行
し、ファイルをキャッシングする。
70中のファイルにアクセスし、ステップ568でタイ
ムスタンプ更新ルーチン3を実行する。タイムスタンプ
更新ルーチン3は、アクセスしたファイルに対応する優
先度構造体400のタイムスタンプ欄401に現時刻を
記録し、リスト内でのそのファイルの優先度構造体の順
番を変更する。
理564に対応する、ファイルキャッシングプログラム
141の処理580を説明する。
ファイルのサイズを、ファイルサーバ200のファイル
管理プログラム220に問い合わせる。次に、ステップ
584で、キャッシュ領域170にファイルをキャッシ
ングできる空間があるかチェックする。空間がある場合
には、ステップ592に進む。
ステップ586で、追い出し決定ルーチン4を実行し、
キャッシュ領域170から追い出すファイルを決定し、
ステップ588で、そのファイルをキャッシュ領域から
追い出す。ステップ590で、削除処理ルーチン2を実
行し、追い出したファイルに対応する優先度構造体40
0を削除した後、ステップ584に戻る。
のファイル管理プログラム220にファイルの転送を依
頼し、キャッシュ領域170にファイルを保管する。最
後にステップ594で、インサート処理ルーチン1を実
行して、優先度テーブル143にファイルを登録する。
出し決定ルーチン4を説明する。
チン1の処理内容を示している。まずステップ602で
優先度構造体400を作成する。ステップ604で、フ
ァイル名欄402にキャッシングするファイル名を登録
し、ステップ606で、タイムスタンプ欄401に現時
刻を記録する。ステップ608で、ログインユーザテー
ブル130を参照して、現在ログイン中のユーザ名を得
て、ステップ610でローカル頻度データベース144
を検索する。
頻繁にアクセスするファイルか否かを判断する。頻繁に
アクセスするファイルの場合は、ステップ614でレベ
ル欄403にHを代入し、ステップ615で高優先度リ
スト410につなぐ。頻繁にアクセスするファイルでは
無い場合は、ステップ616でレベル欄403にLを代
入し、ステップ617で低優先度リスト420につな
ぐ。例えばクライアント100−1では、ファイルF1
とF3を高優先度リスト410につなぎ、その他のファ
イルは低優先度リスト420につなぐ。
100を示す。追い出し決定ルーチン4は、まず、ステ
ップ1102で、優先度テーブル143の低優先度リス
ト420が空であるか否かを確認する。空であれば、ス
テップ1104で、高優先度リスト410の先頭に位置
する優先度構造体400を選択する。空でなければ、ス
テップ1106に進み、低優先度リスト420の先頭に
位置する優先度構造体400を選択する。
にアクセスするファイルを高優先度リスト410に接続
するので、その他のファイルよりも高い確率でキャッシ
ュ領域170に残すことができる。例えば、ユーザAが
多数のファイルをバースト的にアクセスした場合でも、
ファイルF1とF3は必ずキャッシュ領域170に残す
ことができる。この結果、キャッシュのヒット率が向上
し、ファイルアクセスを高速化できる。
が、常にクライアント100−1にログインするわけで
はない。n台あるクライアント100のうちで、誰も使
っていないクライアント100にログインする。従っ
て、アクセス頻度データベース250をファイルサーバ
200に保管し、n台のクライアント100間で共有す
ることは有効である。
グするようにした。しかし、ファイルを固定長ブロック
に分割し、ブロック単位にキャッシングする実施例も考
えられる。その場合には、ブロック毎に優先度構造体4
00を作成する。ファイル名欄402には、そのブロッ
クが属するファイルの名前を設定し、レベル欄403の
値は、ファイル名402によって決定する。これによ
り、本実施例と同様の効果を達成できる。
末1台が接続しており、同時に1人のユーザしかログイ
ンできない。しかし、複数の端末を接続したり、遠隔ロ
グイン機能をサポートすることで、複数のユーザが同時
にログインすることも可能である。図2以下で説明した
ソフトウェアは、複数ユーザが同時にログインする環境
にも適用できる。
する。第1の実施例では、ファイルの優先度をキャッシ
ング時に決定した。本実施例は、ユーザのログイン、ロ
グアウト時に、キャッシュ領域170中の各ファイルの
優先度を再評価するものである。
している。本実施例では、キャッシュ優先度制御モジュ
ール142に優先度再評価ルーチン5が追加される。そ
して、ログイン処理540とログアウト処理550が優
先度再評価ルーチン5を実行する。
540とログアウト処理550を示している。共に、ロ
グインユーザテーブル130とローカル頻度データベー
ス144を変更した後で、優先度再評価ルーチン5を実
行する(ステップ545、553)。
ル143中のすべての優先度構造体400に対して、レ
ベル欄403の値を再評価し、その結果に従って優先度
構造体400を接続しなおす。図19に、優先度再評価
ルーチン5の具体的な処理1200を示す。まず、ログ
イン中のユーザを調べる(1208)。ログアウトによ
り、ログイン中のユーザが存在しない場合には、ユーザ
なしと認識する。次に、優先度テーブル143内の1つ
の優先度構造体400を取り出す(1209)。ログイ
ン中のユーザ名に基づいてローカル頻度データベース1
44を検索する(1210)。ステップ1209で取り
だした構造体400のファイルが、ログイン中のユーザ
が頻繁にアクセスするファイルか否かを調べる(121
2)。そうであれば、その優先度構造体400のレベル
欄403にHを代入し(1214)、これを高優先度リ
スト410の所定の位置につなぐ(1215)。ユーザ
が頻繁にアクセスするファイルでなければ、その優先度
構造体400のレベル欄403にLを代入し(121
6)、これを低優先度リスト420の所定の位置につな
ぐ(1217)。優先度テーブル143内のすべての優
先度構造体400について上記処理を繰り返す(121
9)。これにより、ユーザのログインの場合には、優先
度テーブル143がそのユーザに対応して再構成され
る。すなわち、そのユーザが頻繁にアクセスするファイ
ルがその時点で低優先度リスト420につながれていれ
ば、それが高優先度リスト410につなぎなおされる。
逆に、あるユーザがログオフした場合には、高優先度リ
スト410につながれている、そのユーザが頻繁にアク
セスするファイルの優先度構造体400が低優先度リス
ト410につなぎなおされる(但し、未だ別のユーザが
ログインしている場合にその別のユーザが頻繁にアクセ
スするファイルについてはそのままとされる)。
る分散ファイルシステムのシステム構成を示す。
ァイル260を持つ。アクセス頻度ファイル260は、
ユーザが頻繁にアクセスするファイル名を記録する。各
ユーザは、自分のアクセス頻度ファイル260の内容を
自由に設定できる。
1)にアクセス頻度ファイルの名前を指定する。ログイ
ン処理540は、ユーザが指定したアクセス頻度ファイ
ル260に登録されているファイル名をローカル頻度デ
ータベース144に登録する。
m台のファイルサーバ200に分散することで、信頼性
向上および負荷の分散を図ることができる。
散ファイルシステムのシステム構成を示す。
ァイル240のデータ241を、そのファイルを頻繁に
アクセスするユーザ名(ユーザ名リスト部242)と対
応づけて保管する。
示している。
ス144は、図14に示すように、ファイル名欄253
とユーザ名リスト欄254からなる。キャッシュ領域1
70中の各ファイルに対して、ファイル名とユーザ名リ
ストを記録する。
540とログアウト処理550を示している。本実施例
では、図5の処理と比較して、そのステップ543、5
44、552が不要となる。
ッシングプログラム141の処理580を示している。
ステップ592でファイルをキャッシングした後、ファ
イル名とユーザ名リスト部242をローカル頻度データ
ベース144に登録する(ステップ593)。ステップ
588で、ファイルをキャッシュ領域170から追い出
した後、ローカル頻度データベース144から追い出し
たファイルの項を削除する(ステップ589)。
260を保管するファイルサーバ200がダウンする
と、ファイルの優先度を決定できない。しかし、本実施
例では、ファイル毎にアクセス頻度情報を持つので必ず
優先度を決定できるという利点を有する。
ャッシュ優先度制御モジュールは、ログインユーザテー
ブルとアクセス頻度データベースを参照することで、ロ
グイン中のユーザが頻繁にアクセスするファイルを特定
できる。ログイン中のユーザが頻繁にアクセスするファ
イルに対して高い優先度を設定することにより、それら
のファイルを高い確率でキャッシュ領域に残すことがで
きる。この結果、位ANDにログインするユーザごと
に、キャッシュのヒット率を向上させ、ファイルアクセ
スを高速化できる。
である。
る。
を示すフローチャートである。
ト処理550を示すフローチャートである。
0を示すフローチャートである。
ム141の処理580を示すフローチャートである。
フローチャートである。
る。
ウト処理550を示すフローチャートである。
る。
る。
ある。
44の構造を示す図である。
ウト処理550を示すフローチャートである。
ラム141の処理580を示すフローチャートである。
44の構造を示す図である。
理1100を示すフローチャートである。
理1200を示すフローチャートである。
0…ネットワーク、130…ログインユーザテーブル、
140…キャッシュ管理部、142…キャッシュ優先度
制御モジュール、144…ローカル頻度データベース、
150…ディスク装置、160…端末、170…キャッ
シュ領域、230…ディスク装置、240…ファイル、
250…アクセス頻度データベース。
Claims (8)
- 【請求項1】複数のファイルを保管するファイルサーバ
と、該ファイルサーバに保管されたファイルにアクセス
するクライアントとがネットワークで接続され、前記ク
ライアントは、前記ファイルのコピーを保管するキャッ
シュ記憶装置を有する分散ファイルシステムにおけるキ
ャッシュ優先度制御方法であって、 前記ファイルサーバ内に、前記クライアントからログイ
ンを行なうユーザ毎に、そのユーザ名とそのユーザが頻
繁にアクセスするファイルのファイル名とを対応付けて
記憶するアクセス頻度データベースを設け、 前記クライアント内に、そのクライアントから前記ファ
イルサーバに対してアクセスして自己のキャッシュ記憶
装置内に取り込んだいずれかのファイルの追い出し時に
当該キャッシュ記憶装置内に残すか否かの判断の基準と
なる優先度を定める優先度テーブルを設け、 前記クライアントにおいて、あるユーザがログインした
際、そのユーザのユーザ名を認識し、 前記クライアントにおいて、前記ユーザが前記ファイル
サーバからあるファイル名のファイルを取りだして前記
キャッシュ記憶装置に格納したとき、前記アクセス頻度
データベースの内容に基づいて、当該ファイルが当該ユ
ーザが頻繁にアクセスするファイルであるか否かを調
べ、その結果に応じて前記優先度テーブルにおける当該
ファイルの優先度を定め、 前記キャッシュ装置からいずれかのファイルを追い出す
べきとき、前記優先度テーブルの内容に基づいて、優先
度の低いファイルを当該追い出すべきファイルとして決
定することを特徴とするキャッシュ優先度制御方法。 - 【請求項2】前記優先度テーブル内では、アクセス頻度
の高いファイルを高優先度リストに接続し、アクセス頻
度の低いファイルを低優先度リストに接続することを特
徴とする請求項1記載のキャッシュ優先度制御方法。 - 【請求項3】前記キャッシュ記憶装置にファイルを格納
したとき、およびそのファイルをアクセスしたとき、当
該時点の時刻をそのファイルに対応付けて記録し、前記
優先度テーブルの高優先度リストおよび低優先度リスト
の各々において、該時刻の新しいものの優先度を高くす
るよう更新を行なうことを特徴とする請求項2記載のキ
ャッシュ優先度制御方法。 - 【請求項4】ユーザのログインおよびログアウト時に、
前記キャッシュ記憶装置内に既に存在するファイルにつ
いて、対応する前記優先度テーブル内の当該ファイルの
優先度を、当該ログインまたはログアウトしたユーザの
各ファイルに対するアクセス頻度情報に基づいて更新す
ることを特徴とする請求項1、2または3記載のキャッ
シュ優先度制御方法。 - 【請求項5】複数のファイルを保管する少なくとも1個
のファイルサーバと、該ファイルサーバに保管されたフ
ァイルにアクセスするクライアントとがネットワークで
接続された分散ファイルシステムにおいて、 前記ファイルサーバは、ユーザ名とそのユーザが頻繁に
アクセスするファイル名とを対応づけて記録するアクセ
ス頻度データベースを有し、 前記クライアントは、 ログイン中のユーザ名を記録するログインユーザテーブ
ルと、 前記ファイルサーバ内のファイルのコピーを保管するキ
ャッシュ記憶装置と、 前記キャッシュ記憶装置に保管する各ファイルのコピー
に優先度を設定し、別のファイルのコピーを前記キャッ
シュ記憶装置に保管するにあたり、前記キャッシュ記憶
装置に十分な空き領域を確保できない場合、優先度の低
いコピーをキャッシュ記憶装置から追い出す制御を行な
うキャッシュ管理手段を有し、 各クライアントのキャッシュ管理手段は、前記ログイン
ユーザテーブルと、前記アクセス頻度データベースの内
容に基づいて、自己のキャッシュ記憶装置内のファイル
の追い出し時に当該キャッシュ記憶装置内に残すか否か
の判断の基準となる優先度を各ファイルに対して設定す
ることを特徴とする分散ファイルシステム。 - 【請求項6】前記キャッシュ管理手段が、ログイン中の
各ユーザに対して、前記アクセス頻度データベース内の
当該ユーザに対応する内容のコピーを保持するローカル
頻度データベースを有し、前記ログインユーザテーブル
と、前記ローカル頻度データベースの内容に基づいて、
前記優先度の設定を行なうことを特徴とする請求項5記
載の分散ファイルシステム。 - 【請求項7】前記アクセス頻度データベースには、ユー
ザ毎にそのユーザが頻繁にアクセスするファイル名を記
録したアクセス頻度ファイルを格納しておくことを特徴
とする請求項5または6記載の分散ファイルシステム。 - 【請求項8】前記アクセス頻度データベースとして、各
ファイルサーバが、自己の保管する各ファイルに対し
て、そのファイルを頻繁にアクセスするユーザ名を記録
することを特徴とする請求項5、6または7記載の分散
ファイルシステム。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP05241534A JP3140621B2 (ja) | 1993-09-28 | 1993-09-28 | 分散ファイルシステム |
US08/313,844 US5559984A (en) | 1993-09-28 | 1994-09-28 | Distributed file system permitting each user to enhance cache hit ratio in file access mode |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP05241534A JP3140621B2 (ja) | 1993-09-28 | 1993-09-28 | 分散ファイルシステム |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH0793205A true JPH0793205A (ja) | 1995-04-07 |
JP3140621B2 JP3140621B2 (ja) | 2001-03-05 |
Family
ID=17075784
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP05241534A Expired - Lifetime JP3140621B2 (ja) | 1993-09-28 | 1993-09-28 | 分散ファイルシステム |
Country Status (2)
Country | Link |
---|---|
US (1) | US5559984A (ja) |
JP (1) | JP3140621B2 (ja) |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH09160857A (ja) * | 1995-12-08 | 1997-06-20 | Matsushita Electric Ind Co Ltd | 分散型コンピュータ装置及びそのデータアクセス方式 |
JPH1031639A (ja) * | 1996-07-16 | 1998-02-03 | Nippon Telegr & Teleph Corp <Ntt> | クライアント状態管理方法およびその装置 |
JPH10149310A (ja) * | 1996-09-30 | 1998-06-02 | Internatl Business Mach Corp <Ibm> | モバイル・ユーザ・ファイル・システムにおけるキャッシュ管理のためのシステムおよび方法 |
JPH1165916A (ja) * | 1997-08-19 | 1999-03-09 | Hitachi Ltd | ネットワーク用キャッシュ管理方法 |
JPH11212886A (ja) * | 1998-01-27 | 1999-08-06 | Sharp Corp | ファイルオブジェクト中継方法、分散ファイルシステム、ファイルオブジェクト中継方法のプログラムを記録したコンピュータで読取り可能な記録媒体、およびゲートウェイ計算機 |
JP2002251312A (ja) * | 2001-02-23 | 2002-09-06 | Hitachi Ltd | 通信プロキシ装置 |
US7454653B2 (en) | 2002-11-26 | 2008-11-18 | Microsoft Corporation | Reliability of diskless network-bootable computers using non-volatile memory cache |
JP2015022735A (ja) * | 2013-07-24 | 2015-02-02 | 株式会社リコー | 情報処理装置 |
JP2015135690A (ja) * | 2010-10-04 | 2015-07-27 | クアルコム,インコーポレイテッド | ワイヤレスハンドヘルドコンピューティングデバイスのメモリリソースを管理するためのシステムおよび方法 |
US10049049B2 (en) | 2013-03-27 | 2018-08-14 | Fujitsu Limited | Method and system for caching data managed by plural information processing apparatuses |
Families Citing this family (50)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5675782A (en) * | 1995-06-06 | 1997-10-07 | Microsoft Corporation | Controlling access to objects on multiple operating systems |
US6122637A (en) * | 1995-11-30 | 2000-09-19 | Yohe; Thomas Patrick | Apparatus and method for increased data access in an object oriented caching system |
US5864854A (en) * | 1996-01-05 | 1999-01-26 | Lsi Logic Corporation | System and method for maintaining a shared cache look-up table |
JPH09212397A (ja) * | 1996-01-31 | 1997-08-15 | Toshiba Corp | ファイル読み出し方法 |
US5740370A (en) * | 1996-03-27 | 1998-04-14 | Clinton Battersby | System for opening cache file associated with designated file of file server only if the file is not subject to being modified by different program |
US6032224A (en) * | 1996-12-03 | 2000-02-29 | Emc Corporation | Hierarchical performance system for managing a plurality of storage units with different access speeds |
US5978842A (en) * | 1997-01-14 | 1999-11-02 | Netmind Technologies, Inc. | Distributed-client change-detection tool with change-detection augmented by multiple clients |
JP2000512048A (ja) * | 1997-03-05 | 2000-09-12 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | 訪問履歴の頻度が低いノードを優先するマルチメディアタイトルの提示 |
WO1999023571A1 (en) * | 1997-11-03 | 1999-05-14 | Inca Technology, Inc. | Automatically configuring network-name-services |
US6014692A (en) * | 1997-11-25 | 2000-01-11 | International Business Machines Corporation | Web browser file system attachment |
US6415373B1 (en) | 1997-12-24 | 2002-07-02 | Avid Technology, Inc. | Computer system and process for transferring multiple high bandwidth streams of data between multiple storage units and multiple applications in a scalable and reliable manner |
US6374336B1 (en) | 1997-12-24 | 2002-04-16 | Avid Technology, Inc. | Computer system and process for transferring multiple high bandwidth streams of data between multiple storage units and multiple applications in a scalable and reliable manner |
US6195622B1 (en) * | 1998-01-15 | 2001-02-27 | Microsoft Corporation | Methods and apparatus for building attribute transition probability models for use in pre-fetching resources |
US6425057B1 (en) | 1998-08-27 | 2002-07-23 | Hewlett-Packard Company | Caching protocol method and system based on request frequency and relative storage duration |
US6353833B1 (en) * | 1998-09-29 | 2002-03-05 | International Business Machines Corporation | Caching of distributed dynamic SQL statements in a multiple node RDBMS |
US6321235B1 (en) | 1998-09-29 | 2001-11-20 | International Business Machines Corporation | Global caching and sharing of SQL statements in a heterogeneous application environment |
US7634453B1 (en) * | 1999-08-13 | 2009-12-15 | Storage Technology Corporation | Distributed file data location |
JP2001222491A (ja) * | 2000-02-09 | 2001-08-17 | Nec Corp | 情報提供システム、情報提供方法およびクライアント |
US7278153B1 (en) * | 2000-04-12 | 2007-10-02 | Seachange International | Content propagation in interactive television |
ATE464603T1 (de) | 2000-05-25 | 2010-04-15 | Exent Technologies Inc | Plattencachespeicherung |
US20050091511A1 (en) * | 2000-05-25 | 2005-04-28 | Itay Nave | Useability features in on-line delivery of applications |
JP2002207620A (ja) * | 2001-01-10 | 2002-07-26 | Toshiba Corp | ファイルシステム及び該システムにおけるデータキャッシング方法 |
US7512940B2 (en) * | 2001-03-29 | 2009-03-31 | Microsoft Corporation | Methods and apparatus for downloading and/or distributing information and/or software resources based on expected utility |
AUPR428701A0 (en) * | 2001-04-06 | 2001-05-17 | Platypus Technology International Holdings Limited | Computer system performance improvements by relocation of files on devices |
US20030220948A1 (en) * | 2002-01-22 | 2003-11-27 | Columbia Data Products, Inc. | Managing snapshot/backup collections in finite data storage |
US7237075B2 (en) * | 2002-01-22 | 2007-06-26 | Columbia Data Products, Inc. | Persistent snapshot methods |
US6769785B1 (en) * | 2002-03-14 | 2004-08-03 | Acuity Brands, Inc. | Edge connectable lighting fixture assembly |
US7114156B2 (en) * | 2002-03-29 | 2006-09-26 | International Business Machines Corporation | System and method for processing multiple work flow requests from multiple users in a queuing system |
US8028077B1 (en) * | 2002-07-12 | 2011-09-27 | Apple Inc. | Managing distributed computers |
US8224964B1 (en) | 2004-06-30 | 2012-07-17 | Google Inc. | System and method of accessing a document efficiently through multi-tier web caching |
US8676922B1 (en) | 2004-06-30 | 2014-03-18 | Google Inc. | Automatic proxy setting modification |
US7437364B1 (en) * | 2004-06-30 | 2008-10-14 | Google Inc. | System and method of accessing a document efficiently through multi-tier web caching |
US7610296B2 (en) * | 2004-12-17 | 2009-10-27 | Microsoft Corporation | Prioritized files |
US8924441B2 (en) * | 2005-09-06 | 2014-12-30 | Teradata Us, Inc. | Method of performing snap imaging using data temperature for making anticipatory copies |
WO2008064934A1 (en) * | 2006-11-30 | 2008-06-05 | International Business Machines Corporation | Method, system and computer program for downloading information based on a snapshot approach |
US9015342B2 (en) * | 2007-01-22 | 2015-04-21 | Xerox Corporation | Two-level structured overlay design for cluster management in a peer-to-peer network |
US8812651B1 (en) | 2007-02-15 | 2014-08-19 | Google Inc. | Systems and methods for client cache awareness |
US9485322B2 (en) | 2007-07-07 | 2016-11-01 | Qualcomm Incorporated | Method and system for providing targeted information using profile attributes with variable confidence levels in a mobile environment |
US9392074B2 (en) | 2007-07-07 | 2016-07-12 | Qualcomm Incorporated | User profile generation architecture for mobile content-message targeting |
US20090124241A1 (en) | 2007-11-14 | 2009-05-14 | Qualcomm Incorporated | Method and system for user profile match indication in a mobile environment |
US9391789B2 (en) * | 2007-12-14 | 2016-07-12 | Qualcomm Incorporated | Method and system for multi-level distribution information cache management in a mobile environment |
JP2009187376A (ja) * | 2008-02-07 | 2009-08-20 | Canon Inc | ファイル管理装置、ファイル管理方法、及びプログラム |
US8429346B1 (en) * | 2009-12-28 | 2013-04-23 | Emc Corporation | Automated data relocation among storage tiers based on storage load |
US8612423B2 (en) * | 2010-10-29 | 2013-12-17 | Microsoft Corporation | Search cache for document search |
US10133797B1 (en) * | 2013-08-16 | 2018-11-20 | Amazon Technologies, Inc. | Distributed heterogeneous system for data warehouse management |
US9444905B2 (en) * | 2014-03-20 | 2016-09-13 | International Business Machines Corporation | Allocating network bandwidth to prefetch requests to prefetch data from a remote storage to cache in a local storage |
WO2015177505A1 (en) * | 2014-05-21 | 2015-11-26 | British Telecommunications Public Limited Company | Methods and apparatus for storing electronic documents |
EP3497705B1 (en) | 2016-08-15 | 2020-03-25 | Koninklijke Philips N.V. | Magnet system with thermal radiation screen |
CN113688338A (zh) * | 2020-05-19 | 2021-11-23 | 上海惠芽信息技术有限公司 | 用户数据的处理方法、处理装置及计算机存储介质 |
CN112491963B (zh) * | 2020-11-03 | 2023-11-24 | 泰康保险集团股份有限公司 | 数据传输方法、装置、设备及可读存储介质 |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4897781A (en) * | 1987-02-13 | 1990-01-30 | International Business Machines Corporation | System and method for using cached data at a local node after re-opening a file at a remote node in a distributed networking environment |
CA1337132C (en) * | 1988-07-15 | 1995-09-26 | Robert Filepp | Reception system for an interactive computer network and method of operation |
US5305440A (en) * | 1989-05-15 | 1994-04-19 | International Business Machines Corporation | File extension by clients in a distributed data processing system |
US5452447A (en) * | 1992-12-21 | 1995-09-19 | Sun Microsystems, Inc. | Method and apparatus for a caching file server |
US5491820A (en) * | 1994-11-10 | 1996-02-13 | At&T Corporation | Distributed, intermittently connected, object-oriented database and management system |
-
1993
- 1993-09-28 JP JP05241534A patent/JP3140621B2/ja not_active Expired - Lifetime
-
1994
- 1994-09-28 US US08/313,844 patent/US5559984A/en not_active Expired - Lifetime
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH09160857A (ja) * | 1995-12-08 | 1997-06-20 | Matsushita Electric Ind Co Ltd | 分散型コンピュータ装置及びそのデータアクセス方式 |
JPH1031639A (ja) * | 1996-07-16 | 1998-02-03 | Nippon Telegr & Teleph Corp <Ntt> | クライアント状態管理方法およびその装置 |
JPH10149310A (ja) * | 1996-09-30 | 1998-06-02 | Internatl Business Mach Corp <Ibm> | モバイル・ユーザ・ファイル・システムにおけるキャッシュ管理のためのシステムおよび方法 |
JPH1165916A (ja) * | 1997-08-19 | 1999-03-09 | Hitachi Ltd | ネットワーク用キャッシュ管理方法 |
JPH11212886A (ja) * | 1998-01-27 | 1999-08-06 | Sharp Corp | ファイルオブジェクト中継方法、分散ファイルシステム、ファイルオブジェクト中継方法のプログラムを記録したコンピュータで読取り可能な記録媒体、およびゲートウェイ計算機 |
US6389422B1 (en) | 1998-01-27 | 2002-05-14 | Sharp Kabushiki Kaisha | Method of relaying file object, distributed file system, computer readable medium recording a program of file object relay method and gateway computer, allowing reference of one same file object among networks |
JP2002251312A (ja) * | 2001-02-23 | 2002-09-06 | Hitachi Ltd | 通信プロキシ装置 |
JP4688312B2 (ja) * | 2001-02-23 | 2011-05-25 | 株式会社日立製作所 | 通信プロキシ装置 |
US7454653B2 (en) | 2002-11-26 | 2008-11-18 | Microsoft Corporation | Reliability of diskless network-bootable computers using non-volatile memory cache |
JP2015135690A (ja) * | 2010-10-04 | 2015-07-27 | クアルコム,インコーポレイテッド | ワイヤレスハンドヘルドコンピューティングデバイスのメモリリソースを管理するためのシステムおよび方法 |
US10049049B2 (en) | 2013-03-27 | 2018-08-14 | Fujitsu Limited | Method and system for caching data managed by plural information processing apparatuses |
JP2015022735A (ja) * | 2013-07-24 | 2015-02-02 | 株式会社リコー | 情報処理装置 |
Also Published As
Publication number | Publication date |
---|---|
JP3140621B2 (ja) | 2001-03-05 |
US5559984A (en) | 1996-09-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3140621B2 (ja) | 分散ファイルシステム | |
CN111124301B (zh) | 一种对象存储设备的数据一致性存储方法及系统 | |
US8621119B2 (en) | Storage system | |
EP2478442B1 (en) | Caching data between a database server and a storage system | |
US6745295B2 (en) | Designing a cache with adaptive reconfiguration | |
US6493810B1 (en) | Method and system for allocating cache memory for a network database service | |
US7146389B2 (en) | Method for rebalancing free disk space among network storages virtualized into a single file system view | |
US7191195B2 (en) | Distributed file sharing system and a file access control method of efficiently searching for access rights | |
US20070022122A1 (en) | Asynchronous file replication and migration in a storage network | |
US7783737B2 (en) | System and method for managing supply of digital content | |
US6606651B1 (en) | Apparatus and method for providing direct local access to file level data in client disk images within storage area networks | |
US20030009484A1 (en) | File management system and program therefor | |
EP2175383A1 (en) | Method and apparatus for improving file access performance of distributed storage system | |
US20080215836A1 (en) | Method of managing time-based differential snapshot | |
JP2008181243A (ja) | ストレージシステムのキャッシュパーティション領域の設定を制御するデータベース管理システム | |
EP1438653A2 (en) | Outboard data storage management system and method | |
US20020194432A1 (en) | Designing a cache using an LRU-LFU array | |
JP2002108662A (ja) | 情報管理方法 | |
JP2010079468A (ja) | ファイルサーバリソース分割方法、システム、装置及びプログラム | |
US20050262150A1 (en) | Object-based storage | |
JP3117003B2 (ja) | 広域分散ファイルシステム | |
JP2002082775A (ja) | 計算機システム | |
US7240150B1 (en) | Methods and apparatus for processing access requests in a content addressable computer system | |
JP2001027967A (ja) | 外部記憶装置及び情報処理システム | |
US7284014B2 (en) | Pre-fetch computer system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20071215 Year of fee payment: 7 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20081215 Year of fee payment: 8 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20081215 Year of fee payment: 8 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20091215 Year of fee payment: 9 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20101215 Year of fee payment: 10 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20101215 Year of fee payment: 10 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20111215 Year of fee payment: 11 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20111215 Year of fee payment: 11 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20121215 Year of fee payment: 12 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20131215 Year of fee payment: 13 |
|
EXPY | Cancellation because of completion of term |