(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024022288
(43)【公開日】2024-02-16
(54)【発明の名称】RDBに関する処理を行うためのシステム、キャッシュサーバ、方法、及びプログラム
(51)【国際特許分類】
G06F 16/2455 20190101AFI20240208BHJP
【FI】
G06F16/2455
【審査請求】有
【請求項の数】12
【出願形態】OL
(21)【出願番号】P 2022125757
(22)【出願日】2022-08-05
(11)【特許番号】
(45)【特許公報発行日】2023-10-19
(71)【出願人】
【識別番号】511249637
【氏名又は名称】株式会社Cygames
(74)【代理人】
【識別番号】100094569
【弁理士】
【氏名又は名称】田中 伸一郎
(74)【代理人】
【識別番号】100109070
【弁理士】
【氏名又は名称】須田 洋之
(74)【代理人】
【識別番号】100067013
【弁理士】
【氏名又は名称】大塚 文昭
(74)【代理人】
【識別番号】100086771
【弁理士】
【氏名又は名称】西島 孝喜
(74)【代理人】
【識別番号】100120525
【弁理士】
【氏名又は名称】近藤 直樹
(74)【代理人】
【識別番号】100139712
【弁理士】
【氏名又は名称】那須 威夫
(74)【代理人】
【識別番号】100196612
【弁理士】
【氏名又は名称】鎌田 慎也
(72)【発明者】
【氏名】倉林 修一
【テーマコード(参考)】
5B175
【Fターム(参考)】
5B175EA03
5B175GC02
5B175HA04
(57)【要約】
【課題】RDBの検索や更新を行う特定のシステムにおいて、処理の高速化又は高効率化を実現することが可能なシステムを提供する。
【解決手段】本発明の一実施形態のシステムは、所定のRDBの1テーブルの1行に作用する事前に定義されたクエリを生成するクエリ生成部と、クエリ実行部と、オブジェクト管理部と、を備え、クエリ生成部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを生成し、オブジェクト管理部は、所定の場合に、キャッシュオブジェクトを所定のメモリに記憶又は所定のメモリから削除し、クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が所定のメモリに記憶されている場合、所定のRDBに対してクエリを実行せずに、所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、システムである。
【選択図】
図1
【特許請求の範囲】
【請求項1】
システムであって、
所定のリレーショナルデータベースの1テーブルの1行に作用する事前に定義されたクエリを生成するクエリ生成部であって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、クエリ生成部と、
クエリ生成部が生成したクエリを実行するクエリ実行部と、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理するオブジェクト管理部と、
を備え、
前記クエリ生成部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを生成し、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶し、クエリ実行部が削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除し、
前記クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、
システム。
【請求項2】
前記クエリ生成部は、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、請求項1に記載のシステム。
【請求項3】
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合において、与えられた引数が所定条件を満たす場合、該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶しない、請求項2に記載のシステム。
【請求項4】
前記クエリ生成部が生成するクエリは、SQLクエリであり、
前記クエリ生成部は、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のクエリを生成する、請求項1から3のいずれか1項に記載のシステム。
【請求項5】
前記オブジェクト管理部は、クエリ実行部がUPDATE命令のクエリを実行してクエリ実行結果を取得した場合、該クエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを前記所定のメモリから削除する、請求項4に記載のシステム。
【請求項6】
前記所定のメモリは、前記システムが含むキャッシュサーバのメモリ又はSSDストレージである、請求項1に記載のシステム。
【請求項7】
前記システムは、ゲームサーバを含み、
前記所定のリレーショナルデータベースは、ゲームに関する情報を記憶するリレーショナルデータベースである、請求項1に記載のシステム。
【請求項8】
キャッシュサーバであって、
サービス提供サーバから、所定のリレーショナルデータベースの1テーブルの1行に作用する事前に定義されたクエリを受け取るクエリ受取部であって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、クエリ受取部と、
クエリ受取部が受け取ったクエリを実行するクエリ実行部と、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理するオブジェクト管理部と、
を備え、
前記クエリ受取部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを受け取り、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶し、クエリ実行部が削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除し、
前記クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、
キャッシュサーバ。
【請求項9】
前記クエリ生成部は、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、請求項8に記載のキャッシュサーバ。
【請求項10】
方法であって、
所定のリレーショナルデータベースの1テーブルの1行に作用する事前に定義されたクエリを生成するステップであって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、生成するステップと、
前記生成するステップにおいて生成したクエリを実行するステップと、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを記憶又は削除するステップと、
を含み、
前記生成するステップで生成するクエリは、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含み、
前記記憶するステップは、前記実行するステップにおいて挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶することを含み、
前記削除するステップは、前記実行するステップにおいて削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除すること、を含み、
前記実行するステップは、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得することを含む、
方法。
【請求項11】
前記クエリを生成するステップでは、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、請求項10に記載の方法。
【請求項12】
請求項10又は11に記載の方法の各ステップをコンピュータに実行させるプログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、RDBに関する処理を行うためのシステム、キャッシュサーバ、方法、及びプログラムに関する。
【背景技術】
【0002】
リレーショナルデータベース(RDB)は、データベースマネジメントシステムとして、多くのサービスにおいて用いられている。一般的にRDBが提供するクエリ処理は、専用のプログラミング言語であるSQLを介したものであり、極めて汎用的かつ幅広いクエリ処理を記述可能であるため、その最適化には膨大な研究開発の努力が投じられてきた(非特許文献1)。
【0003】
近年、スマートフォン等に代表される通信機能を備える端末装置上で実行されるゲームが数多くリリースされており、このようなゲームサービスでは、極めて高い頻度でデータベース(RDB)の検索や更新が行われるものが多い。
【先行技術文献】
【特許文献】
【0004】
【非特許文献1】Daniel Abadi, Anastasia Ailamaki, David Andersen, Peter Bailis, Magdalena Balazinska, Philip Bernstein, Peter Boncz, Surajit Chaudhuri, Alvin Cheung, AnHai Doan, Luna Dong, Michael J. Franklin, Juliana Freire, Alon Halevy, Joseph M. Hellerstein, Stratos Idreos, Donald Kossmann, Tim Kraska, Sailesh Krishnamurthy, Volker Markl, Sergey Melnik, Tova Milo, C. Mohan, Thomas Neumann, Beng Chin Ooi, Fatma Ozcan, Jignesh Patel, Andrew Pavlo, Raluca Popa, Raghu Ramakrishnan, Christopher Re, Michael Stonebraker, and Dan Suciu. 2020. The Seattle Report on Database Research. SIGMOD Rec. 48, 4 (December 2019), 44-53.
【発明の概要】
【発明が解決しようとする課題】
【0005】
ゲームシステムは、高い頻度でRDBの検索や更新を要求し、データ操作言語(DML)(例えばSQLのDML)の一部の機能のみを用いるシステムである。一般的に、RDBに関する処理は高速化や高効率化が求められるが、ゲームサービスを提供するゲームシステムにおいても、RDBに関する処理の高速化や高効率化は重要な課題である。ゲームシステムのような、DMLの一部の機能のみを用いるシステムであって、高い頻度でRDBの検索や更新を要求する特定のシステムにおいては、RDBに関する処理の高速化や高効率化を実現する余地が大きいと考えられるが、それを実現する機構やシステムは実現されていない。
【0006】
本発明は、このような課題を解決するためになされたものであり、RDBの検索や更新を行う特定のシステムにおいて、処理の高速化又は高効率化を実現することが可能なシステム等を提供することを目的とする。
【課題を解決するための手段】
【0007】
〔1〕本発明の一実施形態のシステムは、
所定のリレーショナルデータベースの1テーブルの1行に作用する事前に定義されたクエリを生成するクエリ生成部であって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、クエリ生成部と、
クエリ生成部が生成したクエリを実行するクエリ実行部と、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理するオブジェクト管理部と、
を備え、
前記クエリ生成部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを生成し、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶し、クエリ実行部が削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除し、
前記クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、
システムである。
【0008】
〔2〕本発明の一実施形態では、
前記クエリ生成部は、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、〔1〕に記載のシステムである。
【0009】
〔3〕本発明の一実施形態では、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合において、与えられた引数が所定条件を満たす場合、該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶しない、〔2〕に記載のシステムである。
【0010】
〔4〕本発明の一実施形態では、
前記クエリ生成部が生成するクエリは、SQLクエリであり、
前記クエリ生成部は、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のクエリを生成する、〔1〕から〔3〕のいずれか1つに記載のシステムである。
【0011】
〔5〕本発明の一実施形態では、
前記オブジェクト管理部は、クエリ実行部がUPDATE命令のクエリを実行してクエリ実行結果を取得した場合、該クエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを前記所定のメモリから削除する、〔4〕に記載のシステムである。
【0012】
〔6〕本発明の一実施形態では、
前記所定のメモリは、前記システムが含むキャッシュサーバのメモリ又はSSDストレージである、〔1〕から〔5〕のいずれか1つに記載のシステムである。
【0013】
〔7〕本発明の一実施形態では、
前記システムは、ゲームサーバを含み、
前記所定のリレーショナルデータベースは、ゲームに関する情報を記憶するリレーショナルデータベースである、〔1〕から〔6〕のいずれか1つに記載のシステムである。
【0014】
〔8〕本発明の一実施形態のキャッシュサーバは、
サービス提供サーバから、所定のリレーショナルデータベースの1テーブルの1行に作用する事前に定義されたクエリを受け取るクエリ受取部であって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、クエリ受取部と、
クエリ受取部が受け取ったクエリを実行するクエリ実行部と、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理するオブジェクト管理部と、
を備え、
前記クエリ受取部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを受け取り、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶し、クエリ実行部が削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除し、
前記クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、
キャッシュサーバである。
【0015】
〔9〕本発明の一実施形態では、
前記クエリ生成部は、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、〔8〕に記載のキャッシュサーバである。
【0016】
〔10〕本発明の一実施形態の方法は、
所定のリレーショナルデータベースの1テーブルの1行に作用する事前に定義されたクエリを生成するステップであって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、生成するステップと、
前記生成するステップにおいて生成したクエリを実行するステップと、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを記憶又は削除するステップと、
を含み、
前記生成するステップで生成するクエリは、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含み、
前記記憶するステップは、前記実行するステップにおいて挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶することを含み、
前記削除するステップは、前記実行するステップにおいて削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除すること、を含み、
前記実行するステップは、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得することを含む、
方法である。
【0017】
〔11〕本発明の一実施形態では、
前記クエリを生成するステップでは、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、〔10〕に記載の方法である。
【0018】
〔12〕本発明の一実施形態のプログラムは、〔10〕又は〔11〕の方法の各ステップをコンピュータに実行させる、プログラムである。
【発明の効果】
【0019】
本発明によれば、RDBの検索や更新を行う特定のシステムにおいて、処理の高速化又は高効率化を実現することができる。
【図面の簡単な説明】
【0020】
【
図1】本発明の一実施形態の情報処理システムの全体構成図である。
【
図2】本発明の一実施形態のサービス提供システムのハードウェア構成を示すブロック図である。
【
図3】本発明の一実施形態のサービス提供システムの機能ブロック図である。
【
図4】本発明の一実施形態のサービス提供システムの処理のフローチャートを示す図である。
【発明を実施するための形態】
【0021】
以下、図面を参照して、本発明の実施形態の情報処理システム1について説明する。本明細書において、アプリは、スマートフォンやタブレット端末にインストールされるアプリを意味することができ、またアプリケーション全般を意味することもできる。本明細書においては、説明の便宜上、必要以上に詳細な説明は省略する場合がある。
【0022】
図1は、本発明の一実施形態の情報処理システム1の全体構成図である。
図1に示すように、情報処理システム1は、サービス提供システム10と、プレイヤ端末50と、を含み、サービス提供システム10とプレイヤ端末50とは、インターネットなどのネットワーク2に接続され、互いに通信可能である。本実施形態の情報処理システム1は、既知のクライアントサーバ型のシステムを想定して説明するが、これに限定されるものではない。
【0023】
サービス提供システム10は、1又は複数の装置を含んで構成されるシステムである。サービス提供システム10は、仮想マシン又はクラウドシステムにより実現されてもよい。サービス提供システム10は、サービス提供サーバ12と、キャッシュサーバ14と、データベースサーバ(DBサーバ)16と、を含む。サービス提供サーバ12は、ゲームサーバであるか、又はゲームサーバの機能を備える。サービス提供サーバ12は、プレイヤ端末50からのアクセスを受け付けて、ネットワーク2を介して、プレイヤに応じたゲームサービスを提供する。したがって、本実施形態では、サービス提供システム10又は情報処理システム1は、ゲームシステムである。キャッシュサーバ14は、一時的なデータを記憶する機能を備えるサーバである。DBサーバ16は、永続的なデータを記憶する機能を備えるサーバであり、ゲームに関する情報を記憶するリレーショナルデータベースである。1つの例では、DBサーバ16は、MySQLを実装したサーバである。以下では、説明の便宜上、サービス提供システム10は、1つの装置により実現されるものとして説明する。
【0024】
図2は本発明の一実施形態のサービス提供システム10のハードウェア構成を示すブロック図である。サービス提供システム10は、プロセッサ21、入力装置22、表示装置23、記憶装置24、及び通信装置25を備える。これらの各構成装置はバス26によって接続される。なお、バス26と各構成装置との間には必要に応じてインタフェースが介在しているものとする。
【0025】
プロセッサ21は、サービス提供システム10全体の動作を制御する。例えばプロセッサ21は、CPUである。プロセッサ21は、記憶装置24に格納されているプログラムやデータを読み込んで実行することにより、様々な処理を実行する。プロセッサ21は、複数のプロセッサから構成されてもよい。
【0026】
入力装置22は、サービス提供システム10に対するユーザからの入力を受け付けるユーザインタフェースであり、例えばキーボードやマウスである。表示装置23は、プロセッサ21の制御に従って、アプリケーション画面などをサービス提供システム10のユーザに表示するディスプレイである。
【0027】
記憶装置24は、キャッシュサーバ14又はキャッシュサーバ14の機能を実現するためのプログラム、データ、及び記憶領域を備える。記憶装置24は、DBサーバ16又はDBサーバ16の機能を実現するためのプログラム、データ、及び記憶領域を備える。記憶装置24は、既知の主記憶装置及び補助記憶装置を含むことができる。
【0028】
通信装置25は、ネットワークを介してユーザ端末又はサーバなどの他のコンピュータとの間でデータの授受を行うことが可能なモジュール、デバイス、又は装置である。通信装置25は、無線通信用のデバイスやモジュールなどとすることもできるし、有線通信用のデバイスやモジュールなどとすることもできる。
【0029】
プレイヤ端末50は、ゲームサービスを利用するプレイヤが使用するスマートフォンであり、一般的なスマートフォンが備える構成を備えることができる。ただし、プレイヤ端末50は、パーソナルコンピュータ、タブレット端末などの端末とすることができる。プレイヤ端末50は、各部を制御するCPU等の処理装置と、ROMやRAM等の記憶素子等の記憶装置と、タッチパネル等の入出力装置と、無線モジュール等の通信装置とを備える。これらの構成要素はバスを介して接続される。
【0030】
本実施形態では、プレイヤ端末50は、ゲームアプリAP1がインストールされ、サービス提供サーバ12は、ゲームアプリAP1に対応するサーバ用アプリケーションAP2がインストールされている。プレイヤ端末50上でゲームアプリAP1が起動されると、プレイヤ端末50は、サービス提供サーバ12と通信し、ゲームサービスを提供するために必要なデータをプレイヤ端末50と送受信する。1つの例では、サービス提供サーバ12は、プレイヤ端末50においてゲームアプリAP1が起動している間、該プレイヤ端末50と定期的又は断続的に通信し、該プレイヤ端末50でのゲーム操作入力に応じてゲームを実行し、その実行結果を該プレイヤ端末50に送信する。サービス提供サーバ12は、ゲームの進行に応じて、クエリを生成してDBサーバ16からゲーム情報などのデータを取得し、又は、ゲームの進行に応じて、クエリを生成してDBサーバ16にゲーム情報などのデータを記憶若しくは削除する。1つの例では、サービス提供サーバ12は、ゲームの進行に応じて、クエリを生成して、プレイヤIDと各種のゲーム情報とを関連付けてDBサーバ16に記憶する。
【0031】
図3は本発明の一実施形態のサービス提供システム10の機能ブロック図である。サービス提供システム10は、クエリ生成部31と、クエリ実行部32と、オブジェクト管理部33とを備える。本実施形態においては、記憶装置24に記憶されるプログラムがプロセッサ11により実行されることによりこれらの機能が実現される。このように、各種機能がプログラム読み込みにより実現されるため、1つのパート(機能)の一部又は全部を他のパートが有していてもよい。ただし、各機能の一部又は全部を実現するための電子回路等を構成することによりハードウェアによってもこれらの機能は実現してもよい。
【0032】
サービス提供サーバ12は、ゲームの進行に応じて、DBサーバ16のデータベース(RDB)に対してデータを挿入、選択、削除、又は更新するための命令文を送る。クエリ生成部31は、この命令文を生成するものであり、本実施形態では、事前に定義されたSQLクエリ(プリペアドステートメントを用いたクエリ)を生成する。クエリ生成部31が生成するクエリは、1つのクエリが1テーブルの1行のみに作用する事前に定義されたクエリ(Single-Table Row-level Locking (STRL) Prepared Statement)である。本実施形態では、クエリ生成部31は、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のいずれかのクエリ(命令文)であって1テーブルの1行のみに作用する事前に定義されたクエリを生成する。したがって、クエリ生成部31は、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のクエリであっても、1テーブルの複数行に作用するクエリを生成しない。クエリは、変数を含むものであるから、事前に定義されたクエリは、事前に定義されたタイプのクエリを意味することができる。
【0033】
クエリ実行部32は、クエリ生成部31が生成したクエリを実行する。クエリ実行部32は、クエリ生成部31が生成したクエリをDBサーバ16に対して送り、DBサーバ16からクエリ実行結果を取得することができる。クエリ実行結果は、クエリを実行し、エラーなどが発生せずにクエリが成功した場合に、取得されるクエリ実行結果であるものとする。
【0034】
オブジェクト管理部33は、クエリ実行部32がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理する。本実施形態では、オブジェクトはRDB内の1つのテーブルの1つの行のデータ(クエリ実行結果)を意味し、したがって、1つのテーブルには行の数のオブジェクトが存在する。キャッシュオブジェクトは、オブジェクトを一時的に記憶するためのものであり、オブジェクトのデータを所定の形式のデータ(シリアライズオブジェクト)に変換したものである。
【0035】
クエリ生成部31は、キャッシュオブジェクトを識別するためのキャッシュIDを含むクエリを生成する。キャッシュIDは、キャッシュオブジェクトを一意に識別可能なキャッシュオブジェクト識別情報の1つの例である。本実施形態では、クエリ生成部31は、ゲームの進行に応じて、1つのクエリが1テーブルの1行のみに作用するINSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のクエリ(プリペアドステートメントを用いたクエリ)であって、更に、このクエリが対象とするオブジェクトに対応するキャッシュオブジェクトに関する情報を含むクエリを生成する。
【0036】
本実施形態では、クエリ生成部31は、与えられた引数(変数)の一部又は全部に基づいて生成したキャッシュIDをコメントとして付与したクエリを生成する。例えば、ここでの引数は、サービス提供サーバ12が、ゲームの進行に応じて、DBサーバ16のRDBに対してデータを挿入、選択、削除、又は更新するための命令文を送る際にクエリに与えられる可変部分(要素)である。
【0037】
例えば、クエリ生成部31は、以下の例1に示すようなクエリ(プリペアドステートメントを用いたクエリ)を生成する。
(例1)INSERT INTO person(vid, name, param) VALUES ($1, $2, $3) -- CacheID="person_$1_$2"
例1のクエリは、「vid, name, param」の3つの列を有するテーブル「person」において、各列に対応する変数(要素)「$1, $2, $3」を有する行を追加する命令文である。例1のクエリにおいては、「CacheID="person_$1_$2"」がコメントの部分であり、「person_$1_$2」がキャッシュIDである。例1のクエリにおいては、命令文の「INSERT INTO…VALUES」の部分とコメントの「-- CacheID=」部分を含む、「INSERT INTO…VALUES…-- CacheID=」は、事前に定義されたクエリのうちの1つである。RDBが含むテーブル名と各テーブルに含まれる列に関する情報は予め定められており、例1のクエリにおいては、テーブル名「person」がキャッシュIDを構成する文字列として用いられている。「$1, $2, $3」は、各列に対応する要素(値又は文字列)を変数(可変部分)として表したものであって、例1のクエリにおいては、3つの要素「$1, $2, $3」のうちの2つの要素「$1, $2」がキャッシュIDを構成する文字列として用いられている。このような構成とすることにより、RDB内の1つのテーブルの1つの行のデータ(オブジェクト)を識別可能なキャッシュIDを自動的に生成することが可能となり、キャッシュIDを介してオブジェクトとキャッシュオブジェクトを紐づけることも可能となる。
【0038】
クエリ実行部32及びオブジェクト管理部33は、クエリ生成部31が生成したクエリのタイプに応じた処理を行う。本実施形態では、クエリは、基本機能(INSERT/SELECT /UPDATE/SELECT FOR UPDATE/DELETE)に応じた5つのタイプを想定している。ただし、同じ基本機能のクエリであっても、(変数の数が異なりうる)参照するテーブルごとに異なるタイプのクエリとして定めてもよい。
【0039】
クエリ実行部32は、クエリ生成部31が生成したクエリがINSERT命令のクエリQ1である場合、該クエリQ1をDBサーバ16に対して送り、DBサーバ16から結果を受け取る。オブジェクト管理部33は、クエリ実行部32がクエリQ1を実行してクエリ実行結果を取得した場合(INSERT命令が成功した場合)、該クエリ実行結果をキャッシュオブジェクトに変換し、実行されたクエリQ1に含まれるキャッシュIDに対応付けて、該キャッシュオブジェクトをキャッシュサーバ14の所定のメモリ(キャッシュ領域M)に記憶する。
【0040】
クエリ実行部32は、クエリ生成部31が生成したクエリがSELECT命令のクエリQ2である場合、該クエリQ2に含まれるキャッシュIDがキャッシュサーバ14のキャッシュ領域Mに記憶されているか否かを判定する。
【0041】
SELECT命令のクエリQ2に含まれるキャッシュIDがキャッシュ領域Mに記憶されていた場合、クエリ実行部32は、該所定のメモリから該キャッシュIDに対応付けられたキャッシュオブジェクトを取得する。この場合、クエリ実行部32は、DBサーバ16に対してクエリQ2を実行しない、すなわち、クエリ生成部31が生成したクエリQ2をDBサーバ16に対して送らない(問い合わせしない)。クエリ実行部32は、取得したキャッシュオブジェクトから、SELECT命令のクエリQ2を実行した場合に取得されるクエリ実行結果を取得することができる。該クエリQ2に含まれるキャッシュIDがキャッシュ領域Mに記憶されていなかった場合、クエリ実行部32は、該クエリQ2をDBサーバ16に対して送り、DBサーバ16から結果を受け取る。オブジェクト管理部33は、クエリ実行部32がクエリQ2を実行してクエリ実行結果を取得した場合(SELECT命令が成功した場合)、該クエリ実行結果をキャッシュオブジェクトに変換し、実行されたクエリQ2に含まれるキャッシュIDに対応付けて、該キャッシュオブジェクトをキャッシュ領域Mに記憶する。
【0042】
クエリ実行部32は、クエリ生成部31が生成したクエリがDELETE命令のクエリQ3である場合、該クエリQ3をDBサーバ16に対して送り、DBサーバ16から結果を受け取る。オブジェクト管理部33は、クエリ実行部32がDELETE命令のクエリQ3を実行してクエリ実行結果を取得した場合(DELETE命令が成功した場合)、キャッシュサーバ14のキャッシュ領域Mに記憶されている該クエリQ3に含まれるキャッシュIDに対応付けられたキャッシュオブジェクトを、キャッシュIDとともにキャッシュ領域Mから削除する。
【0043】
クエリ実行部32は、クエリ生成部31が生成したクエリがSELECT FOR UPDATE命令のクエリQ4である場合、該クエリQ4をDBサーバ16に対して送り、DBサーバ16から結果を受け取る。SELECT FOR UPDATE命令の実行時、該クエリQ4が対象とするオブジェクトは一時的にロックされ、オブジェクト管理部33は、該クエリQ4に含まれるキャッシュIDに対応付けられたキャッシュオブジェクトを一時的にロックする。なお、クエリQ4が対象とするオブジェクトがロックされているとき、当該オブジェクトに対する他のクエリからの書き込みとロックはブロックされる。また、クエリQ4の処理が完了したとき、該クエリQ4が対象とするオブジェクトのロックは解除され、該クエリQ4に含まれるキャッシュIDに対応付けられたキャッシュオブジェクトのロックも解除される。
【0044】
クエリ実行部32は、クエリ生成部31が生成したクエリがUPDATE命令のクエリQ5である場合、該クエリQ5をDBサーバ16に対して送り、DBサーバ16から結果を受け取る。UPDATE命令の実行時、該クエリQ5が対象とするオブジェクトは一時的にロックされ、オブジェクト管理部33は、該実行したクエリQ5に含まれるキャッシュIDに対応付けられたキャッシュオブジェクトを一時的にロックする。クエリ実行部32がUPDATE命令のクエリQ5を実行してクエリ実行結果を取得した場合(UPDATE命令が成功した場合)であって該クエリQ5に含まれるキャッシュIDがキャッシュサーバ14のキャッシュ領域Mに記憶されている場合、オブジェクト管理部33は、該キャッシュIDに対応付けられたキャッシュオブジェクトを、該キャッシュIDとともにキャッシュ領域Mから削除する。なお、クエリQ5が対象とするオブジェクトがロックされているとき、当該オブジェクトに対する他のクエリからの書き込みとロックはブロックされる。また、クエリQ5の処理が完了したとき、該クエリQ5が対象とするオブジェクトのロックは解除され、該クエリQ5に含まれるキャッシュIDに対応付けられたキャッシュオブジェクトのロックも解除される。
【0045】
本実施形態では、キャッシュサーバ14がクエリを要求するプロキシサーバとして機能し、サービス提供サーバ12がクエリ生成部31の機能を備え、キャッシュサーバ14がクエリ実行部32及びオブジェクト管理部33を備える。キャッシュサーバ14は、サービス提供サーバ12が生成したクエリを受け取るクエリ受取部を備える。キャッシュサーバ14(クエリ実行部32)は、受け取ったクエリの結果として、取得したクエリ実行結果をサービス提供サーバ12に受け渡す。ただし、サービス提供システム10の各機能部をどの構成要素(装置、システムなど)が備えるかについては、発明の要旨を逸脱しない限り、上記に限定されない。例えば、サービス提供サーバ12がクエリ生成部31、クエリ実行部32、及びオブジェクト管理部33を備え、キャッシュサーバ14が所定のメモリ上に一時的にデータを記憶する機能のみを備えるように構成してもよい。
【0046】
図4は、本発明の一実施形態のサービス提供システム10の処理のフローチャートの一例を説明する図である。
【0047】
ステップS1で、クエリ生成部31は、クエリを生成する。本実施形態では、クエリ生成部31は、DBサーバ16のRDBの1テーブルの1行のみに作用するINSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のクエリを生成する。以下のステップは、各タイプのクエリについて、それぞれ処理を説明する。
【0048】
クエリ生成部31が生成したクエリがINSERT命令であった場合、ステップS2で、クエリ実行部32は、該クエリをDBサーバ16に対して送ることで、クエリを実行する。ステップS3で、クエリ実行部32は、実行したクエリが成功したか否か、すなわち、DBサーバ16から正常にクエリ実行結果を取得したか否か(例えばエラーメッセージが発生していないか否か)を判定する。クエリが成功したとき、本フローチャートはステップS4へ進み、クエリが成功しなかったとき、本フローチャートは終了する。ステップS4で、オブジェクト管理部33は、クエリ実行部32が取得したクエリ実行結果をキャッシュオブジェクトに変換し、ステップS2で実行されたクエリに含まれるキャッシュIDに対応付けて、該キャッシュオブジェクトをキャッシュサーバ14の所定のメモリ(キャッシュ領域M)に記憶する。
【0049】
クエリ生成部31が生成したクエリがSELECT命令であった場合、ステップS2で、クエリ実行部32は、キャッシュサーバ14のキャッシュ領域Mが該クエリに含まれるキャッシュIDを記憶しているか否かを判定する。クエリ実行部32は、キャッシュ領域Mが当該クエリに含まれるキャッシュIDを記憶する場合、キャッシュ領域Mから該キャッシュIDに対応付けられたキャッシュオブジェクトを取得し、キャッシュ領域Mが該キャッシュIDを記憶していない場合、該クエリをDBサーバ16に対して送る。
【0050】
ステップS3で、クエリ実行部32は、クエリをDBサーバ16に送った場合に、実行したクエリが成功したか否かを判定する。クエリが成功したとき、本フローチャートはステップS4へ進み、クエリをDBサーバ16に送らなかった場合又はクエリが成功しなかったとき、本フローチャートは終了する。ステップS4で、オブジェクト管理部33は、クエリ実行部32が取得したクエリ実行結果をキャッシュオブジェクトに変換し、ステップS2で実行されたクエリに含まれるキャッシュIDに対応付けて、該キャッシュオブジェクトをキャッシュ領域Mに記憶する。
【0051】
クエリ生成部31が生成したクエリがDELETE命令であった場合、ステップS2で、クエリ実行部32は、該クエリをDBサーバ16に対して送ることで、クエリを実行する。ステップS3で、クエリ実行部32は、実行したクエリが成功したか否かを判定する。クエリが成功したとき、本フローチャートはステップS4へ進み、クエリが成功しなかったとき、本フローチャートは終了する。ステップS4で、オブジェクト管理部33は、ステップS2で実行されたクエリに含まれるキャッシュIDに対応付けられたキャッシュオブジェクトがキャッシュ領域Mに記憶されている場合、該キャッシュオブジェクトを、キャッシュIDとともにキャッシュ領域Mから削除する。
【0052】
クエリ生成部31が生成したクエリがUPDATE命令であった場合、ステップS2で、クエリ実行部32は、該クエリをDBサーバ16に対して送ることで、クエリを実行する。ステップS3で、クエリ実行部32は、実行したクエリが成功したか否かを判定する。クエリが成功したとき、本フローチャートはステップS4へ進み、クエリが成功しなかったとき、本フローチャートは終了する。ステップS4で、オブジェクト管理部33は、ステップS2で実行されたクエリに含まれるキャッシュIDに対応付けられたキャッシュオブジェクトがキャッシュ領域Mに記憶されている場合、該キャッシュオブジェクトをキャッシュIDとともにキャッシュ領域Mから削除する。
【0053】
クエリ生成部31が生成したクエリがSELECT FOR UPDATE命令であった場合、ステップS2で、クエリ実行部32は、該クエリをDBサーバ16に対して送ることで、クエリを実行する。SELECT FOR UPDATE命令は、オブジェクトを変更するものではないため、キャッシュオブジェクトを記憶するものでも削除するものでもないため、ステップS3で、ステップS2で実行したクエリがSELECT FOR UPDATE命令であった場合、本フローチャートは終了する。
【0054】
次に、本発明の実施形態のサービス提供システム10(情報処理システム1)の主な作用効果について説明する。
【0055】
従来、周辺ソフトウェアであるキャッシュやデータアクセスレイヤを含めて、既存のRDBの高速化、高効率化、さらには信頼性の向上を図ることは、ゲームシステムにおいて重要な課題である。特に、RDBのユースケースにおいて必要不可欠となっている、サーバサイドシステム全体のパフォーマンスを改善しうるクエリキャッシュ機構の改善は重要な課題である。クエリキャッシュとは、一度実行した問い合わせの結果をメモリ上に保存しておき、二度目の問合せの実行をRDB上で実行せずに、メモリ上に蓄積したデータを返却することにより、データベースの負荷を下げながら、システム全体の応答速度を向上させる仕組みを意味する。このクエリキャッシュは、ほぼ全てのアプリケーションに適用できるよう、汎用的に設計されており、特定のSQLのユースケースに適した最適化は行われていない。
【0056】
本発明の実施形態では、一般的なゲーム運用時のデータベース問い合わせは、1つのクエリが1テーブルの1行のみに作用するクエリのみを用いることに注目した。本実施形態では、クエリ生成部31が生成するクエリは、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のいずれかのクエリであって、1テーブルの1行のみに作用する、プリペアドステートメントを用いたクエリである。このように、ゲームサーバ(サービス提供サーバ12)のゲーム運用時のDBサーバ16のRDBへの問い合わせのすべてが上記のクエリとなるように構成されている。また本実施形態では、クエリ生成部31が、クエリを生成する際に、オブジェクトを特定可能なクエリのパラメータに基づいて、キャッシュオブジェクトを識別可能な文字列を自動生成し、該文字列をアノテーションコメントとして付与する。また本実施形態では、オブジェクト管理部33が、クエリのタイプ(INSERT/SELECT /UPDATE(SELECT FOR UPDATE)/DELETE)毎に、クエリを実行する際の、キャッシュオブジェクトのロックと寿命の管理を行う。
【0057】
このような構成とすることにより、ゲームシステムにおけるRDBのクエリキャッシュ機構を改善することができるとともに、キャッシュオブジェクトとRDBとの紐付けとキャッシュオブジェクトの寿命管理を、一元的、かつ、自動的に行うことができる。これにより、ゲームシステムにおいて処理の高速化や高効率化を実現することが可能となる。
【0058】
またこのような自動的なキャッシュオブジェクト管理を行うことにより、アプリケーションから独立したキャッシュオブジェクトの寿命の制御を可能にする。これにより、キャッシュサーバ14は、RDBのオブジェクトをキャッシュオブジェクトとして記憶し、分散型メモリキャッシュシステムを実現することが可能となる。また、RDBの全エントリー(全オブジェクト)を、プログラミング言語(例えば、PHP言語やC#言語)に固有のオブジェクトデータ表現に、透過的に変換する機能をキャッシュサーバ14上に実装することができるため、「分散オンメモリ・シリアライズオブジェクトキャッシュ(Distributed On-Memory Serialized Object Cache)」を実現することができる。これにより、複数のエンジニアがコーディングを行うサーバサイドプログラムにおいて、キャッシュ層の安全で効率的な実装が可能になる。なお、この場合、キャッシュサーバ14が記憶するキャッシュオブジェクトのデータ構造は、シリアライズオブジェクトであるが、シリアライズオブジェクトとは、プログラミング言語が採用するデータ構造を外部に保存するときのバイナリデータ表現のことである。
【0059】
上記のように、本発明の実施形態では、すべてのクエリは事前に定義されており、プリペアドステートメントとして実装することができる。そのため、本実施形態のキャッシュサーバ14は、キャッシュサーバ起動時に、そのキャッシュサーバが担当するプレイヤIDの範囲内のパラメータを用いて、全てのSELECT文のプリペアドステートメントを実行し、SELECT文に対応するRDBのテーブルの各行のデータ(オブジェクト)を、シリアライズオブジェクトとして保存することができる。このような技術は、従来のWebアプリやクラウドアプリには存在しなかったものである。
【0060】
上記の作用効果は、特に言及が無い限り、他の実施形態や変形例においても同様である。
【0061】
本発明の実施形態のシステムは、情報処理システム1とすることもできるし、サービス提供システム10とすることもできる。本発明の1又は複数の実施形態では、サービス提供システム10は、DBサーバ16を備えないものとすることができる。この実施形態では、DBサーバ16は、サービス提供システム10と通信可能に構成される。またキャッシュサーバ14が、プロキシサーバとして機能せず、キャッシュ領域に一時的に記憶する機能のみを備える実施形態においては、サービス提供システム10は、キャッシュサーバ14を備えないものとすることができる。この実施形態では、キャッシュサーバ14は、サービス提供システム10と通信可能に構成される。またこの実施形態では、サービス提供システム10は、サービス提供サーバ12により実現することができる。
【0062】
本発明の1又は複数の実施形態では、1つのクエリが1テーブルの1行のみに作用するプリペアドステートメントを用いたクエリを生成して実行するゲームシステム以外の所定のサービスを提供するシステムに適用することもできる。この実施形態では、サービス提供サーバ12は、ゲームサービス以外の所定のサービスを提供するアプリケーションサーバであるか、又はアプリケーションサーバの機能を備えることができる。この実施形態では、サービス提供サーバ12は、ゲームサーバではなく、ゲームサーバの機能を備えるものではない。
【0063】
本発明の1又は複数の実施形態では、上記で説明したサービス提供システム10の各機能部が同様の動作を実行できる場合、クエリ生成部31が生成し、クエリ実行部32が実行するクエリの言語はSQL以外であってもよい。例えば、クエリの言語は、INSERT命令に相当する挿入命令、SELECT命令に相当する選択命令、SELECT FOR UPDATE命令に相当する占有ロック命令、UPDATE命令に相当する更新命令、及びDELETE命令に相当する削除命令を有するものであればよい。
【0064】
本発明の1又は複数の実施形態では、クエリ生成部31は、INSERT命令、SELECT命令、又はDELETE命令のいずれかのクエリであって1テーブルの1行のみに作用する事前に定義されたクエリを生成するように構成されてもよい。本発明の1又は複数の実施形態では、クエリ生成部31は、INSERT命令、SELECT命令、UPDATE命令、又はDELETE命令のいずれかのクエリであって1テーブルの1行のみに作用する事前に定義されたクエリを生成するように構成されてもよい。本発明の1又は複数の実施形態では、クエリ生成部31は、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、又はDELETE命令のいずれかのクエリであって1テーブルの1行のみに作用する事前に定義されたクエリを生成するように構成されてもよい。
【0065】
本発明の1又は複数の実施形態では、与えられた引数が所定条件を満たす場合、オブジェクト管理部33は、クエリ実行部32がINSERT命令又はSELECT命令のクエリを実行してクエリ実行結果を取得した場合であっても、該クエリ実行結果をキャッシュオブジェクトに変換しないように構成することができる。したがって、この場合、オブジェクト管理部33は、キャッシュオブジェクトをキャッシュサーバ14のキャッシュ領域Mに記憶しない。1つの例では、クエリ生成部31は、所定条件をコメントとして付与したクエリを生成することができる。
例えば、クエリ生成部31は、以下の例1に示すようなクエリ(プリペアドステートメントを用いたクエリ)を生成する。
(例2)INSERT INTO person(vid, name, param) VALUES ($1, $2, $3) -- CacheID="person_$1_$2", Ignore = $1 lt 0
例2のクエリは、例1のクエリに所定条件「Ignore = $1 lt 0」が付与されたものである。この所定条件は「$1」が0より小さいというものであり、この場合、オブジェクト管理部33は、「$1」が0より小さい場合、キャッシュオブジェクトはキャッシュ領域Mに記憶されない。比較演算子としては、less-than(lt), greater-than(gt), equal(eq), partially equal(pe), AND, OR, NOTなど、さまざまな演算子を実装することができる。
【0066】
本発明の1又は複数の実施形態では、キャッシュサーバ14は、シリアライズオブジェクトを、キャッシュサーバ14の所定のメモリ又はSSDストレージに、1オブジェクト1ファイルとして保存することができる。1つの例では、ゲームロジックをサーバ側で実行するアプリケーションサーバ(サービス提供サーバ12)の実装にPHP言語を使用している場合は、キャッシュサーバ14は、PHPのシリアライズオブジェクトとして保存する。1つの例では、アプリケーションサーバ(サービス提供サーバ12)の実装にC#言語を使用している場合は、キャッシュサーバ14は、C#で最も扱いやすいProtocol Buffersフォーマットのシリアライズオブジェクトとして保存する。このように、アプリケーションを記述するプログラミング言語毎にシリアライズオブジェクトのフォーマットは異なるものとすることができる。
【0067】
本発明の1又は複数の実施形態では、キャッシュオブジェクトは、オブジェクトのデータそのものであってもよい。この実施形態では、キャッシュオブジェクトの取得は、クエリ実行結果の取得を意味する。
【0068】
本発明の実施形態では、プレイヤ端末50は、プレイヤがゲームをプレイする前に予めダウンロード可能なデータをサービス提供サーバ12から受信してゲームアプリAP1に関連するデータとして記憶するように構成されてもよい。この場合、プレイヤ端末50は、プレイヤに関連するデータの更新等のサービス提供サーバ12に実装される必要のある機能を除いたゲームサービスを実現するために必要な機能を備える。或いはプレイヤ端末50は、入出力用のシンクライアント端末として構成されてもよい。この場合、サービス提供サーバ12は、プレイヤ端末50における入出力機能を除いたゲームサービスを実現するために必要な機能を備える。
【0069】
上記で説明したように、本発明の実施形態は、情報処理システム1又はサービス提供システム10とすることができる。本発明の実施形態は、クエリ実行部32及びオブジェクト管理部33を備えるキャッシュサーバ14とすることもできる。本発明の実施形態は、上記で説明した本発明の実施形態の機能やフローチャートに示す情報処理を実現するプログラムや該プログラムを格納したコンピュータ読み取り可能な記憶媒体とすることもできる。また本発明の実施形態は、上記で説明した本発明の実施形態の機能やフローチャートに示す情報処理を実現する方法とすることもできる。また本発明の実施形態は、上記で説明した本発明の実施形態の機能やフローチャートに示す情報処理を実現するプログラムをコンピュータに供給することができるサーバとすることもできる。
【0070】
以上に説明した処理又は動作において、あるステップにおいて、そのステップではまだ利用することができないはずのデータを利用しているなどの処理又は動作上の矛盾が生じない限りにおいて、処理又は動作を自由に変更することができる。また以上に説明してきた各実施例は、本発明を説明するための例示であり、本発明はこれらの実施例に限定されるものではない。本発明は、その要旨を逸脱しない限り、種々の形態で実施することができる。
【符号の説明】
【0071】
1:情報処理システム、2:ネットワーク、10:サービス提供システム、12:サービス提供サーバ、14:キャッシュサーバ、16:データベースサーバ、21:プロセッサ、22:表示装置、23:入力装置、24:記憶装置、25:通信装置、26:バス、31:クエリ生成部、32:クエリ実行部、33:オブジェクト管理部、50:プレイヤ端末
【手続補正書】
【提出日】2023-05-30
【手続補正1】
【補正対象書類名】特許請求の範囲
【補正対象項目名】全文
【補正方法】変更
【補正の内容】
【特許請求の範囲】
【請求項1】
システムであって、
所定のリレーショナルデータベースの1テーブルの1行のみに作用する事前に定義されたクエリのみを生成するクエリ生成部であって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、クエリ生成部と、
クエリ生成部が生成したクエリを実行するクエリ実行部と、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理するオブジェクト管理部と、
を備え、
前記クエリ生成部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを生成し、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶し、クエリ実行部が削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除し、
前記クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、
システム。
【請求項2】
前記クエリ生成部は、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、請求項1に記載のシステム。
【請求項3】
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合において、与えられた引数が所定条件を満たす場合、該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶しない、請求項2に記載のシステム。
【請求項4】
前記クエリ生成部が生成するクエリは、SQLクエリであり、
前記クエリ生成部は、INSERT命令、SELECT命令、SELECT FOR UPDATE命令、UPDATE命令、又はDELETE命令のクエリを生成する、請求項1から3のいずれか1項に記載のシステム。
【請求項5】
前記オブジェクト管理部は、クエリ実行部がUPDATE命令のクエリを実行してクエリ実行結果を取得した場合、該クエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを前記所定のメモリから削除する、請求項4に記載のシステム。
【請求項6】
前記所定のメモリは、前記システムが含むキャッシュサーバのメモリ又はSSDストレージである、請求項1に記載のシステム。
【請求項7】
前記システムは、ゲームサーバを含み、
前記所定のリレーショナルデータベースは、ゲームに関する情報を記憶するリレーショナルデータベースである、請求項1に記載のシステム。
【請求項8】
キャッシュサーバであって、
サービス提供サーバから、所定のリレーショナルデータベースの1テーブルの1行のみに作用する事前に定義されたクエリのみを受け取るクエリ受取部であって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、クエリ受取部と、
クエリ受取部が受け取ったクエリを実行するクエリ実行部と、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを管理するオブジェクト管理部と、
を備え、
前記クエリ受取部は、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含むクエリを受け取り、
前記オブジェクト管理部は、クエリ実行部が挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶し、クエリ実行部が削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除し、
前記クエリ実行部は、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得する、
キャッシュサーバ。
【請求項9】
前記クエリ受取部は、与えられた引数に基づいて生成したクエリ識別情報がコメントとして付与されて生成されたクエリを受け取る、請求項8に記載のキャッシュサーバ。
【請求項10】
方法であって、
所定のリレーショナルデータベースの1テーブルの1行のみに作用する事前に定義されたクエリのみを生成するステップであって、事前に定義されたクエリは挿入命令、選択命令及び削除命令のクエリを含む、生成するステップと、
前記生成するステップにおいて生成したクエリをクエリ実行部が実行するステップと、
前記クエリ実行部がクエリを実行して取得したクエリ実行結果に基づくキャッシュオブジェクトを記憶又は削除するステップと、
を含み、
前記生成するステップで生成するクエリは、キャッシュオブジェクトを識別するためのキャッシュ識別情報を含み、
前記記憶するステップは、前記実行するステップにおいて挿入命令又は選択命令のクエリを実行してクエリ実行結果を取得した場合、実行されたクエリに含まれるキャッシュ識別情報に対応付けて該クエリ実行結果に基づくキャッシュオブジェクトを所定のメモリに記憶することを含み、
前記削除するステップは、前記実行するステップにおいて削除命令のクエリを実行してクエリ実行結果を取得した場合、該削除命令のクエリに含まれるキャッシュ識別情報に対応付けられたキャッシュオブジェクトを該所定のメモリから削除すること、を含み、
前記実行するステップは、選択命令のクエリを実行する場合において、該クエリに含まれるキャッシュ識別情報が前記所定のメモリに記憶されている場合、前記所定のリレーショナルデータベースに対してクエリを実行せずに、前記所定のメモリから該キャッシュ識別情報に対応付けられたキャッシュオブジェクトを取得することを含む、
方法。
【請求項11】
前記クエリを生成するステップでは、与えられた引数に基づいて生成したクエリ識別情報をコメントとして付与したクエリを生成する、請求項10に記載の方法。
【請求項12】
請求項10又は11に記載の方法の各ステップをコンピュータに実行させるプログラム。