JP4860779B1 - Distributed data storage system - Google Patents

Distributed data storage system Download PDF

Info

Publication number
JP4860779B1
JP4860779B1 JP2011151337A JP2011151337A JP4860779B1 JP 4860779 B1 JP4860779 B1 JP 4860779B1 JP 2011151337 A JP2011151337 A JP 2011151337A JP 2011151337 A JP2011151337 A JP 2011151337A JP 4860779 B1 JP4860779 B1 JP 4860779B1
Authority
JP
Japan
Prior art keywords
data
server
user
partial data
client terminal
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.)
Expired - Fee Related
Application number
JP2011151337A
Other languages
Japanese (ja)
Other versions
JP2013020313A (en
Inventor
敏文 新谷
壮一 最首
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nomura Research Institute Ltd
Original Assignee
Nomura Research Institute Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Nomura Research Institute Ltd filed Critical Nomura Research Institute Ltd
Priority to JP2011151337A priority Critical patent/JP4860779B1/en
Priority to PCT/JP2011/079837 priority patent/WO2013008351A1/en
Application granted granted Critical
Publication of JP4860779B1 publication Critical patent/JP4860779B1/en
Publication of JP2013020313A publication Critical patent/JP2013020313A/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0823Network architectures or network communication protocols for network security for authentication of entities using certificates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/41User authentication where a single sign-on provides access to a plurality of computers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6218Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Computer Security & Cryptography (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • General Health & Medical Sciences (AREA)
  • Bioethics (AREA)
  • Health & Medical Sciences (AREA)
  • Databases & Information Systems (AREA)
  • Computing Systems (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Storage Device Security (AREA)

Abstract

【課題】重要データから秘密分散技術により生成された複数の部分データを複数のデータセンターに分散保管し、各データセンター間での部分データの不正取得を防止するためのセキュリティを確保するデータ分散保管システムを提供する。
【解決手段】各サーバ100はそれぞれクライアント端末300から受信した部分データを保管するデータ保管部110を有し、クライアント端末300は、重要データから秘密分散技術によりk個以上集めなければ重要データを復元できないn個(k≦n)の部分データを生成する分割処理部310と、n個の部分データをn個のサーバ100に保管し、重要データを復元するためのm個(k≦m≦n)の部分データをm個のサーバ100から収集する分散管理部320と、m個の部分データから秘密分散技術により重要データを復元する復元処理部330とを有する。
【選択図】図1
Distributed data storage that secures security to prevent unauthorized acquisition of partial data between each data center by distributing and storing a plurality of partial data generated from important data by secret sharing technology to a plurality of data centers Provide a system.
Each server has a data storage unit for storing partial data received from a client terminal, and the client terminal restores important data unless k or more are collected from the important data by a secret sharing technique. A division processing unit 310 that generates n (k ≦ n) partial data that cannot be performed, and m pieces (k ≦ m ≦ n) for storing n pieces of partial data in n servers 100 and restoring important data ) From the m servers 100 and a restoration processing unit 330 that restores the important data from the m partial data by the secret sharing technique.
[Selection] Figure 1

Description

本発明は、電子データの保管技術に関し、特に、重要データから秘密分散技術により複数の非重要データを生成して複数の拠点に分散保管するデータ分散保管システムに適用して有効な技術に関するものである。   The present invention relates to electronic data storage technology, and more particularly to a technology effective when applied to a data distributed storage system that generates a plurality of non-critical data from important data by secret sharing technology and distributes and stores the data at a plurality of locations. is there.

情報システムを有する企業等においては、情報漏洩などの情報セキュリティ事故を防止するため、機密性の高いデータなどの重要なデータを保護する手段を講じる必要がある。一方でこれらを実現するための様々な手段も提案されている。   A company having an information system needs to take measures to protect important data such as highly confidential data in order to prevent an information security accident such as information leakage. On the other hand, various means for realizing these have been proposed.

重要データを保護するための手段として、例えば、企業等が重要データをセキュリティ対策が多重に施されたデータセンターに保管することが考えられる。しかしながら、外部からアクセス可能なプライベートなデータセンターを独自に構築・運用するのは技術面・コスト面等で多大な負荷を要し、容易に実現できるものではない。   As a means for protecting important data, for example, it is conceivable that a company or the like stores important data in a data center where multiple security measures are taken. However, the construction and operation of a private data center that can be accessed from the outside requires a great load in terms of technology and cost, and cannot be easily realized.

これに対して第三者が運用してサービスとして外部に提供しているデータセンターを利用することも考えられる。しかし、第三者が運用管理するデータセンターに自社の重要データを保管することはセキュリティ面で高いリスクが伴う。ましてや近年利用が拡大しているクラウドコンピューティング環境における仮想データセンターや仮想サーバに重要データを保管することは非常にリスクが高いことから、重要データを取り扱う業務を行う情報システムをクラウドコンピューティング環境を利用して構築するということがなかなか普及しない一因ともなっている。   On the other hand, it is also possible to use a data center that is operated by a third party and provided as a service to the outside. However, storing important company data in a data center operated and managed by a third party involves a high security risk. In addition, storing important data in virtual data centers and virtual servers in cloud computing environments that have been increasingly used in recent years is extremely risky. Using it for construction is also one of the reasons why it is not popular.

一方、重要データを保管する際に、データを秘匿化したり改竄を防止したりする手段を講じて保管することも行われている。一般的には、暗号鍵を用いて重要データを暗号化して保管することが行われているが、この場合、暗号化されたデータには重要データの情報が全て含まれている。従って、例えば暗号化データが第三者に取得されたような場合、何らかの理由で当該第三者に暗号鍵も取得、解読された場合は容易に重要データが復元されてしまう。また、暗号鍵を取得されなくとも、暗号鍵が有限長であることから、理論上は有限回数の試行によって暗号化されたデータから重要データが復元されてしまう可能性を有する。   On the other hand, when important data is stored, the data is concealed or stored by taking measures to prevent tampering. In general, important data is encrypted and stored using an encryption key. In this case, the encrypted data includes all important data information. Therefore, for example, when encrypted data is acquired by a third party, important data is easily restored when the encryption key is also acquired and decrypted by the third party for some reason. Even if the encryption key is not acquired, since the encryption key has a finite length, theoretically, there is a possibility that important data may be restored from the encrypted data after a finite number of trials.

これに対し、重要データを強固に秘匿化する手法として、いわゆる秘密分散の技術も用いられている。秘密分散では、重要データを、それだけでは意味のない(重要データを復元・推測できない)非重要データに分割・分散することで、一部の非重要データが第三者に取得された場合でも、第三者による重要データの復元を理論上も不可能とすることができる。   On the other hand, a so-called secret sharing technique is also used as a method for strongly concealing important data. In secret sharing, important data is divided into non-important data that cannot be used by itself (important data cannot be recovered or guessed). Even if some non-important data is obtained by a third party, It is theoretically impossible to restore important data by a third party.

秘密分散の手法としては種々のものが提案されている。例えば、特許第4039810号明細書(特許文献1)には、電子情報ファイルを複数の情報エレメントに分割し、分割された情報エレメントを選択し順序を変えて組み合わせることにより、2個以上の情報ブロックであって全ての情報ブロックを統合しなければ全ての情報エレメントを含むことにならないような情報ブロックを生成し、情報エレメントに分割した方法に係る分割情報と情報ブロックを生成した方法に係る形成情報を記録した分割抽出データを生成し、各情報ブロックと分割抽出データとのうち、少なくとも1つを証明局に保管し、他を分離して別々に保管することで電子情報の安全を確保する技術が開示されている。   Various secret sharing techniques have been proposed. For example, in Japanese Patent No. 4039810 (Patent Document 1), two or more information blocks are obtained by dividing an electronic information file into a plurality of information elements, selecting the divided information elements, and combining them in a different order. In this case, an information block that does not include all information elements unless all the information blocks are integrated is generated, and division information relating to the method divided into information elements and formation information relating to the method generating the information block A technology that secures the security of electronic information by generating divided extracted data that records information, storing at least one of each information block and divided extracted data in a certification authority, and separately storing the other separately Is disclosed.

一方、重要データに対応する非重要データや情報ブロック(以下では“部分データ”と記載する場合がある)を全て集めなくとも所定の個数以上集めれば重要データを復元可能な秘密分散の手法として、例えば、非特許文献1に記載されたような多項式補間を用いた(k,n)閾値秘密分散法が従来から用いられている。この手法によれば、n個に分散した部分データのうち少なくともk個(k≦n)を集めれば重要データを復元することができる。また、この手法をさらに改良した種々の閾値秘密分散法も提案されている。   On the other hand, as a secret sharing technique that can restore important data if you collect more than a predetermined number of non-important data and information blocks corresponding to important data (sometimes referred to as “partial data” below) For example, a (k, n) threshold secret sharing method using polynomial interpolation as described in Non-Patent Document 1 has been conventionally used. According to this method, important data can be restored by collecting at least k pieces (k ≦ n) of n pieces of partial data. Various threshold secret sharing methods that further improve this method have also been proposed.

これに関連して、例えば、特開2009−139990号公報(特許文献2)には、記憶装置に格納されたデータを、復元の際に基準個数の部分データが必要となる秘密分散法により、基準個数以上の所定の個数の部分データに分割する分割部と、部分データを他の情報処理装置に送信するとともに記憶装置から削除する送信部と、記憶装置へデータを復元する場合に、他の情報処理装置から部分データを取得して記憶装置に格納する取得部と、基準個数の部分データが記憶装置に格納されたことを条件にデータを復元する復元部とを備える情報処理装置が開示されている。   In relation to this, for example, in JP 2009-139990 A (Patent Document 2), the data stored in the storage device is converted into a secret sharing method that requires a reference number of partial data at the time of restoration. When dividing data into a predetermined number of partial data equal to or greater than the reference number, a transmission unit that transmits partial data to another information processing device and deletes the partial data from the storage device, An information processing apparatus including an acquisition unit that acquires partial data from an information processing device and stores the partial data in a storage device, and a restoration unit that restores data on condition that a reference number of partial data is stored in the storage device is disclosed. ing.

特許第4039810号明細書Patent No. 4039810 特開2009−139990号公報JP 2009-139990 A

A.Shamir、"How to Share a Secret"、Communications of the ACM、vol.22 no.11 pp.612-613、1979.A. Shamir, "How to Share a Secret", Communications of the ACM, vol.22 no.11 pp.612-613, 1979.

近年、ノート型PC(Personal Computer)などの携帯可能な情報処理端末が広く利用されるに従って、これらの端末自体の盗難や紛失等に伴う情報漏洩のリスクが高まっている。例えば、個人情報等を取り扱う企業などにおいては、従業員等がこれらの端末を紛失したような場合には、監督官庁への届出や報告等が必要となる場合がある。しかし、従来は実際の情報漏洩範囲については特定することができない場合がほとんどであり、紛失した時点で全てのデータが漏洩もしくはその可能性があると報告せざるを得なかった。   In recent years, as portable information processing terminals such as notebook PCs (Personal Computers) are widely used, there is an increased risk of information leakage due to theft or loss of these terminals themselves. For example, in a company that handles personal information or the like, if an employee or the like loses these terminals, a report or report to a supervisory authority may be required. However, in the past, the actual information leakage range could not be specified in most cases, and when it was lost, all data had to be reported as leaked or possibly.

これに対して、端末内の重要データを含むデータを外部のサーバ等に保管することで端末の紛失等に伴う情報漏洩のリスクを低減することが考えられる。このとき、重要データをそのまま外部のサーバ等に保管するのではなく、例えば、上述した秘密分散の技術を利用して重要データを非重要データに分割・分散して部分データとし、これを外部のサーバ等に分散保管するようにすることで、例えば、クラウドコンピューティング環境における仮想データセンターや仮想サーバなどに保管するような場合においても情報漏洩のリスクを低減させることが可能である。   On the other hand, it is conceivable to reduce the risk of information leakage due to loss of the terminal by storing data including important data in the terminal in an external server or the like. At this time, the important data is not stored in an external server or the like as it is, for example, using the secret sharing technique described above, the important data is divided / distributed into non-important data to obtain partial data, which is By storing in a distributed manner on a server or the like, for example, the risk of information leakage can be reduced even when storing in a virtual data center or a virtual server in a cloud computing environment.

すなわち、各データセンター等に分散保管される部分データは、それ自体では意味をなさず、当該部分データのみからは重要データの内容を復元したり推測したりすることができない。従って、当該データセンターやサーバ等に不正に侵入し、当該部分データを取得した第三者はもちろん、例えば、各データセンターの管理者等の内部の者が悪意を持って当該部分データを取得した場合でも、取得された部分データから重要データの内容が漏洩する事態を防ぐことができる。   In other words, partial data distributed and stored in each data center or the like does not make sense by itself, and the contents of important data cannot be restored or estimated from only the partial data. Therefore, not only the third party who illegally invaded the data center or server and acquired the partial data, but also, for example, an insider such as an administrator of each data center acquired the partial data maliciously. Even in this case, it is possible to prevent a situation in which the content of important data is leaked from the acquired partial data.

ここで、複数のデータセンター等に部分データを分散保管するシステム構成を考えた場合、通常は、ユーザが各データセンター等に対してそれぞれ個別にユーザ認証を行う必要があるが、この場合ユーザ認証の処理が煩雑となり、業務効率が低下することが懸念される。これに対して、通常は、ユーザが一度の認証を行うことで、ユーザ認証が必要な複数のデータセンターやサーバ等に対して個別の認証手続きを行わずにアクセスすることを可能とするいわゆるシングルサインオンの技術が用いられる。   Here, when considering a system configuration in which partial data is distributed and stored in a plurality of data centers, etc., it is usually necessary for a user to perform user authentication individually for each data center. This process is complicated, and there is a concern that the business efficiency is lowered. On the other hand, a so-called single that enables a user to access a plurality of data centers or servers that require user authentication without performing individual authentication procedures by performing authentication once. Sign-on technology is used.

シングルサインオンの環境を実現する手法としては、例えば、各サーバやシステムがSAML(Security Assertion Markup Language)プロトコル等を用いてサーバ間で通信を行って、認証サーバ等の特定のサーバで行った認証結果の情報を自動的に引き継ぐことで、各サーバ等でのユーザによる再度の認証手続きを不要とする手法などがある。   As a technique for realizing a single sign-on environment, for example, each server or system communicates between servers using the SAML (Security Assertion Markup Language) protocol, and authentication performed by a specific server such as an authentication server. There is a technique that eliminates the need for re-authentication by the user at each server or the like by automatically taking over the result information.

しかしながら、このような手法によるシングルサインオンの環境は、例えば、イントラネット上の社内システムなど、サーバやシステム間で認証情報の引き継ぎ・受け入れを許容する信頼関係が成立していることが前提となる。従って、各データセンターやサーバ等が異なる事業者等によって運用されている場合などでは、セキュリティ上の関係等からこのような信頼関係が成立しない場合もある。   However, a single sign-on environment based on such a method is premised on the establishment of a trust relationship that allows authentication information to be taken over and accepted between servers and systems, such as an in-house system on an intranet. Therefore, when each data center, server, etc. is operated by a different business operator, such a trust relationship may not be established due to a security relationship or the like.

また、このような環境で上述したようなシングルサインオンの手法を用いると、例えば、あるデータセンター等において、ユーザの認証処理のために認証サーバ等から取得した認証情報を、悪意を持った内部の者が利用して他のデータセンター等に対して不正にアクセスを行い、当該他のデータセンターに保管されている部分データを取得してしまうということも考えられる。従って、上述したような、重要データから秘密分散技術により生成された複数の部分データを各データセンター等に分散保管する仕組みにおいては、各データセンター間での部分データの不正取得を防止するためのセキュリティについても考慮する必要がある。   In addition, if the single sign-on method described above is used in such an environment, for example, in a certain data center, authentication information acquired from an authentication server or the like for user authentication processing is It is also conceivable that an unauthorized person accesses the other data center or the like illegally and acquires partial data stored in the other data center. Therefore, in the mechanism for distributing and storing a plurality of partial data generated from important data by secret sharing technology in each data center as described above, in order to prevent unauthorized acquisition of partial data between the data centers. Security also needs to be considered.

ここで、例えば特許文献1に記載された技術では、秘密分散された部分データ(情報ブロック)のうちの1つをいわゆる“信頼できる第三者機関(Trusted Third Party)”である証明局に供託しておくことで、重要データの復元の際に必ず証明局を介在させることができ、悪意を持った内部の者からの不正なアクセスに対しても対応することが可能である。しかしながら、システム構成として“信頼できる第三者機関”を設置する必要があり、コストや運用負荷の面で負担が大きくなってしまうことが考えられる。   Here, for example, in the technique described in Patent Document 1, one of the secret-distributed partial data (information blocks) is deposited with a certification authority which is a so-called “Trusted Third Party”. By doing so, a certification authority can always be interposed in the restoration of important data, and it is possible to cope with unauthorized access from insiders with malicious intent. However, it is necessary to install a “reliable third-party organization” as a system configuration, which may increase the burden in terms of cost and operational load.

一方、特許文献2に記載された技術では、主に、部分データをサーバや地理的に離れた他のクライアント端末などに分散保管することで、第三者によるクライアント端末の盗難やネットワークを介した不正侵入に対する情報漏洩のリスクを低下させることが目的とされているが、悪意を持った内部の者(例えば、他のクライアント端末の所有者など)からの不正なアクセスに対する考慮はされていない。   On the other hand, in the technique described in Patent Document 2, the partial data is mainly stored in a distributed manner on a server or other geographically distant client terminals, so that the client terminal is stolen by a third party or via a network. Although the purpose is to reduce the risk of information leakage due to unauthorized intrusion, no consideration is given to unauthorized access from a malicious insider (for example, the owner of another client terminal).

そこで本発明の目的は、重要データから秘密分散技術により生成された複数の部分データを複数のデータセンターに分散保管し、各データセンター間での部分データの不正取得を防止するためのセキュリティを確保することが可能なデータ分散保管システムを提供することにある。   Therefore, an object of the present invention is to secure a security for preventing unauthorized acquisition of partial data between each data center by distributing and storing a plurality of partial data generated from important data by secret sharing technology in a plurality of data centers. It is an object of the present invention to provide a distributed data storage system that can do this.

本発明の前記ならびにその他の目的と新規な特徴は、本明細書の記述および添付図面から明らかになるであろう。   The above and other objects and novel features of the present invention will be apparent from the description of this specification and the accompanying drawings.

本願において開示される発明のうち、代表的なものの概要を簡単に説明すれば、以下のとおりである。   Of the inventions disclosed in this application, the outline of typical ones will be briefly described as follows.

本発明の代表的な実施の形態によるデータ分散保管システムは、クライアント端末において、重要データから秘密分散技術により複数の非重要データである部分データを生成し、前記各部分データを、ネットワークを介して接続された複数のサーバに分散保管するデータ分散保管システムであって、以下の特徴を有するものである。   A data distributed storage system according to a representative embodiment of the present invention generates partial data that is a plurality of non-important data from important data by secret sharing technology at a client terminal, and the partial data is transmitted via a network. A distributed data storage system that stores data in a plurality of connected servers, and has the following characteristics.

すなわち、前記各サーバは、それぞれ、前記クライアント端末から受信した前記部分データを保管するデータ保管部を有し、前記クライアント端末は、ユーザから保管を指示された前記重要データから前記秘密分散技術によりk個以上集めなければ前記重要データを復元できないn個(k≦n)の前記部分データを生成する分割処理部と、前記分割処理部によって生成されたn個の前記部分データを、それぞれ異なる前記サーバの前記データ保管部に保管し、また、前記重要データを復元するためのm個(k≦m≦n)の前記部分データを前記サーバからそれぞれ収集する分散管理部と、前記ユーザから利用を指示された前記重要データについて、前記分散管理部から取得したm個の前記部分データから前記秘密分散技術により前記重要データを復元する復元処理部とを有することを特徴とする。   That is, each of the servers has a data storage unit that stores the partial data received from the client terminal, and the client terminal uses the secret sharing technique to generate k data from the important data instructed to be stored by the user. The division processing unit that generates n (k ≦ n) partial data that cannot restore the important data unless it is collected, and the n pieces of partial data generated by the division processing unit are different from each other. A distribution management unit for collecting m pieces of partial data (k ≦ m ≦ n) for restoring the important data from the server, and instructing the use from the user The important data obtained from the m pieces of partial data acquired from the distributed management unit is processed by the secret sharing technique. And having a restoring unit for restoring the.

本願において開示される発明のうち、代表的なものによって得られる効果を簡単に説明すれば以下のとおりである。   Among the inventions disclosed in the present application, effects obtained by typical ones will be briefly described as follows.

本発明の代表的な実施の形態によれば、重要データから秘密分散技術により生成された複数の部分データを複数のデータセンターに分散保管し、各データセンター間での部分データの不正取得を防止するためのセキュリティを確保することが可能となる。   According to a typical embodiment of the present invention, a plurality of partial data generated from important data by a secret sharing technique is distributed and stored in a plurality of data centers to prevent unauthorized acquisition of partial data between the data centers. Security can be ensured.

本発明の一実施の形態であるデータ分散保管システムの構成例について概要を示した図である。It is the figure which showed the outline | summary about the structural example of the data distribution storage system which is one embodiment of this invention. 本発明の一実施の形態におけるデータの保管の概念について説明した図である。It is the figure explaining the concept of the storage of the data in one embodiment of this invention. 本発明の一実施の形態における部分データを保管するサーバの選択の例について示した図であるIt is the figure shown about the example of selection of the server which stores the partial data in one embodiment of this invention 本発明の一実施の形態における認証処理の流れの例について概要を示した図である。It is the figure which showed the outline | summary about the example of the flow of the authentication process in one embodiment of this invention.

以下、本発明の実施の形態を図面に基づいて詳細に説明する。なお、実施の形態を説明するための全図において、同一部には原則として同一の符号を付し、その繰り返しの説明は省略する。   Hereinafter, embodiments of the present invention will be described in detail with reference to the drawings. Note that components having the same function are denoted by the same reference symbols throughout the drawings for describing the embodiment, and the repetitive description thereof will be omitted.

<概要>
本発明の一実施の形態であるデータ分散保管システムは、ユーザがクライアント端末上で、ユーザの重要データを保管する際に、当該重要データから秘密分散技術により複数の部分データを生成し、これらを複数のデータセンターのサーバに送信して分散保管する。また、各データセンターに対するシングルサインオンの仕組みを実装し、認証の際に、各データセンターで異なる固有情報(鍵)を用いて認証処理を行うことで、各データセンターへのアクセスを独立して安全に行えるようにし、各データセンター間でのセキュリティを確保する。これらにより、各データセンターの管理者等の内部の者であっても1つの部分データしか得ることができず、当該部分データから重要データを復元・推測することはできないため、ユーザは安全に重要データを保管することができる。
<Overview>
The data distributed storage system according to an embodiment of the present invention generates a plurality of partial data from the important data by secret sharing technology when the user stores the user's important data on the client terminal. Send to multiple data center servers for distributed storage. In addition, by implementing a single sign-on mechanism for each data center and performing authentication processing using different unique information (key) at each data center during authentication, access to each data center can be made independent. Ensure safety and ensure security between data centers. As a result, even insiders such as managers of each data center can obtain only one partial data, and important data cannot be restored / inferred from the partial data. Data can be stored.

図2は、本実施の形態のデータ分散保管システムにおけるデータの保管の概念について説明した図である。データ分散保管システム1は、インターネット等のネットワーク400に、クライアント端末300と、複数のデータセンター10(図2の例では10a〜10dの4つ)が接続された構成を有している。ここで、クライアント端末300は、ユーザが業務等で通常使用し、重要データ500の入力や参照などの処理を行う情報処理端末であり、例えば、PCや、タブレット型端末、スマートフォン、携帯電話などの携帯端末などが該当する。   FIG. 2 is a diagram for explaining the concept of data storage in the data distributed storage system of the present embodiment. The data distributed storage system 1 has a configuration in which a client terminal 300 and a plurality of data centers 10 (four in the example of FIG. 2, 10a to 10d) are connected to a network 400 such as the Internet. Here, the client terminal 300 is an information processing terminal that is normally used by a user for business or the like and performs processing such as input and reference of important data 500. For example, the client terminal 300 is a PC, a tablet terminal, a smartphone, a mobile phone, or the like. This applies to mobile terminals.

また、データセンター10は、サーバ機器を保管して運用管理を行う拠点であり、例えば、多数のサーバ機器等を保管して高度な運用管理を行うことができる専用のデータセンター施設や、いわゆるコンテナ型やモジュール型などの可搬型のデータセンターなどであってもよいし、オフィスビル内のマシンルームなど専用ではない施設であってもよい。また、クラウドコンピューティング環境における仮想データセンターであってもよい。本実施の形態での各データセンター10は、それぞれ、データを保持・記憶するためのストレージ機器等からなるデータ保管部110(図2の例では110a〜110d)を有するサーバ100(図2の例では100a〜100d)を1台以上有している。   The data center 10 is a base for storing and managing server devices. For example, a dedicated data center facility that can store a large number of server devices and perform advanced operations management, or a so-called container. It may be a portable data center such as a mold or module, or may be a non-dedicated facility such as a machine room in an office building. Further, it may be a virtual data center in a cloud computing environment. Each data center 10 according to the present embodiment has a server 100 (example in FIG. 2) having a data storage unit 110 (110a to 110d in the example in FIG. 2) composed of storage devices and the like for holding and storing data. Then, it has one or more of 100a to 100d).

なお、これらの各データセンター10は、地理的にも組織的にも相互に関連のないものとするのが望ましい。すなわち、例えば同一の敷地内や隣接する敷地に存在したり、同一もしくは関連する事業者等により運用されていたりなど、データセンター10間で、管理者等が相互に物理的もしくは電子的にアクセスすることが可能な構成とはなっていないものとするのが望ましい。   Each of these data centers 10 is preferably not related to each other geographically and organizationally. In other words, managers and the like access each other physically or electronically between the data centers 10 such as being in the same site or adjacent sites, or being operated by the same or related business operators, etc. It is desirable that the configuration is not possible.

上記のような環境で、ユーザからの指示に基づいて、クライアント端末300に存在する重要データ500についてセキュアな保管を行う場合、まず、クライアント端末300において、重要データ500から秘密分散技術を利用して複数の部分データ510(図2の例では510a〜510dの4つ)を生成する。それぞれの部分データ510は、上述したように、単独では意味をなさない非重要データである。なお、重要データ500は漏洩を防止するために削除する。   In the environment as described above, when the important data 500 existing in the client terminal 300 is securely stored based on an instruction from the user, first, the client terminal 300 uses the secret sharing technique from the important data 500. A plurality of partial data 510 (four items 510a to 510d in the example of FIG. 2) are generated. As described above, each partial data 510 is non-important data that does not make sense alone. The important data 500 is deleted to prevent leakage.

利用する秘密分散技術(秘密分散のアルゴリズム)については特に限定されず、例えば、n個の部分データ510うちk個以上集めれば重要データ500を復元することができるが、k個未満では原則として重要データ500を復元することができない、いわゆる(k,n)閾値型(1<k≦n)の秘密分散の手法を用いることができる。また、k、nの値も特に限定されず、セキュリティの強度や処理速度等の要件などに応じて適宜決定することができる。なお、nの値(生成する部分データ510の数)はデータセンター10の数以下であるものとする。換言すれば、n個の部分データ510に対してn個以上のデータセンター10を用意するものとする。   The secret sharing technique (secret sharing algorithm) to be used is not particularly limited. For example, if k or more of n partial data 510 are collected, the important data 500 can be restored. A so-called (k, n) threshold type (1 <k ≦ n) secret sharing technique that cannot restore the data 500 can be used. Also, the values of k and n are not particularly limited, and can be appropriately determined according to requirements such as security strength and processing speed. Note that the value of n (the number of partial data 510 to be generated) is equal to or less than the number of data centers 10. In other words, n or more data centers 10 are prepared for n partial data 510.

生成した部分データ510は、それぞれ重複しないように各データセンター10に振り分けて送信し、データ保管部110に分散保管する。すなわち、同一の重要データ500から生成した部分データ510は、それぞれ別個に異なるデータセンター10に保管するものとし、いずれか2つ以上の部分データ510が同一のデータセンター10に保管されることがないようにする。なお、クライアント端末300上の各部分データ510は漏洩を防止するために削除する。   The generated partial data 510 is distributed and transmitted to each data center 10 so as not to overlap each other, and is distributed and stored in the data storage unit 110. That is, the partial data 510 generated from the same important data 500 is stored separately in different data centers 10, and any two or more partial data 510 are not stored in the same data center 10. Like that. Each partial data 510 on the client terminal 300 is deleted to prevent leakage.

以上のように、重要データ500から秘密分散技術により部分データ510を生成して各データセンター10に分散保管することで、クライアント端末300の盗難や紛失等による重要データ500の漏洩を防止することができる。また、各データセンター10は重要データ500につき部分データ510を1つしか有していないため、データセンター10に対して第三者が侵入して不正に部分データ510を取得したり、データセンター10の管理者等の内部の者が部分データ510を取得したりした場合でも、部分データ510を1つしか得ることができない。当該部分データ510だけでは重要データ500を復元・推測することはできないため、重要データ500の内容が漏洩することはない。   As described above, the partial data 510 is generated from the important data 500 by the secret sharing technique and stored in each data center 10 to prevent leakage of the important data 500 due to theft or loss of the client terminal 300. it can. Since each data center 10 has only one partial data 510 for the important data 500, a third party enters the data center 10 to obtain the partial data 510 illegally, Even if an internal person such as an administrator of the system acquires partial data 510, only one partial data 510 can be obtained. Since the important data 500 cannot be restored / estimated only by the partial data 510, the contents of the important data 500 are not leaked.

また、各データセンター10が地理的にも組織的にも相互に関連のないものとなっている場合には、データセンター10の管理者等の内部の者が、他のデータセンター10にアクセスすることも、後述する認証処理と合わせて、困難である。従って、例えば、データセンター10の管理者等の内部の者が悪意を持った場合でも、他のデータセンター10から部分データ510を不正に取得し、k個以上集めて重要データ500を復元してしまうという事態を防止することができる。   Further, when the data centers 10 are not related to each other geographically or organizationally, an internal person such as an administrator of the data center 10 accesses the other data center 10. This is also difficult together with the authentication processing described later. Therefore, for example, even if an insider such as an administrator of the data center 10 has malicious intent, the partial data 510 is illegally acquired from other data centers 10, and k or more pieces are collected to restore the important data 500. Can be prevented.

<システム構成>
以下では、本実施の形態のデータ分散保管システム1のシステム構成について説明する。図1は、本発明の一実施の形態であるデータ分散保管システム1の構成例について概要を示した図である。データ分散保管システム1は、ネットワーク400に対して、複数のサーバ100、マスタサーバ200、およびクライアント端末300が接続する構成を有する。なお、各サーバ100は、上述の図2に示したとおり、地理的にも組織的にも相互に関連のないデータセンター10内においてそれぞれ運用管理されているものとする。
<System configuration>
Below, the system configuration | structure of the data distribution storage system 1 of this Embodiment is demonstrated. FIG. 1 is a diagram showing an outline of a configuration example of a data distributed storage system 1 according to an embodiment of the present invention. The data distributed storage system 1 has a configuration in which a plurality of servers 100, a master server 200, and client terminals 300 are connected to a network 400. Each server 100 is assumed to be operated and managed in the data center 10 which is not related to each other geographically and organizationally as shown in FIG.

サーバ100は、サーバ機器によって構成されるコンピュータシステムであり、ファイルサーバもしくはストレージサーバ等として、ユーザ認証を経た後にクライアント端末300等からのアクセスを受け付けてデータ(部分データ510)の保管サービスを提供する機能を有する。サーバ100は、例えば、磁気ディスク等のストレージ機器からなるデータ保管部110およびソフトウェアプログラムにより実装される認証処理部120を有する。データ保管部110は、OS(Operating System)などの指示に基づいて、指定されたデータについての読み書きを行う。   The server 100 is a computer system composed of server devices. As a file server or a storage server, the server 100 accepts access from the client terminal 300 after user authentication and provides a data (partial data 510) storage service. It has a function. The server 100 includes, for example, a data storage unit 110 including a storage device such as a magnetic disk and an authentication processing unit 120 implemented by a software program. The data storage unit 110 reads and writes specified data based on an instruction from an OS (Operating System) or the like.

認証処理部120は、サーバ100へのアクセスに対しての認証処理を行う。認証処理部120は、認証処理を行う際に利用する情報として、ユーザ毎のアカウント情報からなるユーザ情報130を有する。ユーザ情報130は、例えば、データベースやファイルテーブル等によって構成され、例えば、登録されたユーザのユーザID毎に、ユーザ毎に異なる固有情報としてのユーザシーズ131、およびパスワードを所定の手順によりハッシュ化したハッシュ化パスワード132などのアカウント情報を有する。また、認証処理部120は、サーバ毎に異なる固有情報としてのサーバシーズ140を有する。   The authentication processing unit 120 performs an authentication process for access to the server 100. The authentication processing unit 120 includes user information 130 including account information for each user as information used when performing authentication processing. The user information 130 is configured by, for example, a database, a file table, or the like. For example, for each registered user ID of the registered user, the user seed 131 as unique information that is different for each user and the password are hashed by a predetermined procedure. Account information such as hashed password 132 is included. In addition, the authentication processing unit 120 has a server seed 140 as unique information that is different for each server.

本実施の形態では、認証処理部120は、後述するように、クライアント端末300との間でチャレンジ/レスポンス方式により認証処理を行う。すなわち、ユーザからの認証要求に対して、サーバシーズ140、ユーザシーズ131、およびチャレンジとしての乱数等を送信する。さらに、これらによってハッシュ化されたパスワード(ハッシュ値)をクライアント端末300からレスポンスとして受信して、受信したハッシュ値と、ハッシュ化パスワード132を上記乱数によってハッシュ化したものとを比較して認証を行う。従って、認証処理部120は、乱数生成の機能やハッシュアルゴリズムを実装している。なお、これらの実装には公知の各種技術やアルゴリズムを利用することができる。サーバ100とクライアント端末300との間の通信経路のセキュリティが確保されるなどの場合には、チャレンジ/レスポンス方式以外の他の方式を採用するなどしてもよい。   In the present embodiment, as will be described later, the authentication processing unit 120 performs authentication processing with the client terminal 300 by a challenge / response method. That is, in response to the authentication request from the user, the server seeds 140, the user seeds 131, and a random number as a challenge are transmitted. Further, the hashed hash value is received as a response from the client terminal 300, and authentication is performed by comparing the received hash value with the hashed password 132 hashed by the random number. . Therefore, the authentication processing unit 120 has a random number generation function and a hash algorithm. In addition, various known techniques and algorithms can be used for these implementations. When security of the communication path between the server 100 and the client terminal 300 is secured, a method other than the challenge / response method may be adopted.

マスタサーバ200は、サーバ機器やPC等によって構成されるコンピュータシステムであり、各サーバ100に保持するユーザシーズ131およびサーバシーズ140を生成して提供する。各サーバ100を代表して認証を行ういわゆる認証サーバではないため、ユーザ認証の機能は有さない。マスタサーバ200は、例えば、ソフトウェアプログラムにより実装されるシーズ生成部210を有する。シーズ生成部210は、管理者等からの指示もしくは各サーバ100からの要求等に基づいてシーズを生成し、ユーザシーズ131もしくはサーバシーズ140として、対象のサーバ100にネットワーク400を介して提供する。   The master server 200 is a computer system composed of server devices, PCs, and the like, and generates and provides user seeds 131 and server seeds 140 held in each server 100. Since it is not a so-called authentication server that performs authentication on behalf of each server 100, it does not have a user authentication function. The master server 200 includes, for example, a seed generation unit 210 that is implemented by a software program. The seeds generation unit 210 generates seeds based on an instruction from an administrator or the like or a request from each server 100, and provides the seeds as user seeds 131 or server seeds 140 to the target server 100 via the network 400.

シーズの生成方法やシーズのフォーマット等については特に限定されないが、例えば、所定の長さのユニークな文字列やバイナリデータを生成してシーズとすることができる。なお、マスタサーバ200は、他のサーバ100とは独立したデータセンター10に設置されていてもよいし、いずれかのサーバ100と同一のデータセンター10に、外部からアクセス可能な構成により設置されていてもよい。   The seed generation method and the seed format are not particularly limited. For example, a unique character string or binary data having a predetermined length can be generated and used as a seed. Note that the master server 200 may be installed in the data center 10 independent of the other servers 100, or installed in the same data center 10 as any one of the servers 100 with a configuration accessible from the outside. May be.

クライアント端末300は、重要データ500から秘密分散技術を利用して部分データ510を複数生成し、これらをそれぞれ重複しないように各サーバ100(各データセンター10)に振り分けて送信し、データ保管部110に分散保管する機能を有する。クライアント端末300は、例えば、ソフトウェアプログラムにより実装される分割処理部310、分散管理部320、復元処理部330、認証要求部340およびインタフェース部350の各部と、データベースもしくはファイルテーブル等からなる分散状況321および設定情報301の各テーブルを有する。   The client terminal 300 generates a plurality of partial data 510 using the secret sharing technique from the important data 500, distributes and transmits the partial data 510 to each server 100 (each data center 10) so as not to overlap each other, and the data storage unit 110 It has a function to store distributedly. The client terminal 300 includes, for example, a distribution processing unit 321 implemented by a software program, a distribution management unit 320, a restoration processing unit 330, an authentication request unit 340, an interface unit 350, and a distribution status 321 including a database or a file table. And each table of setting information 301.

分割処理部310は、後述するインタフェース部350を介してユーザからセキュアな保管を指示された重要データ500から、設定情報301の設定内容等に従って秘密分散により各サーバ100に分散保管する複数の部分データ510を生成する。上述したように、秘密分散の手法は特に限定されず、公知の(k,n)閾値型の秘密分散の手法を用いることができる。設定情報301には、例えば、利用する秘密分散のアルゴリズムを特定する情報や、k、nなどのパラメータを予め設定しておくことができる。   The division processing unit 310 performs a plurality of partial data to be distributed and stored in each server 100 by secret sharing according to the setting contents of the setting information 301 from the important data 500 instructed to be securely stored by the user via the interface unit 350 described later 510 is generated. As described above, the secret sharing technique is not particularly limited, and a known (k, n) threshold type secret sharing technique can be used. In the setting information 301, for example, information for specifying the secret sharing algorithm to be used and parameters such as k and n can be set in advance.

分散管理部320は、重要データ500の分散保管の際に、分割処理部310によって生成された部分データ510を、設定情報301の設定内容に基づく所定の条件に従って各サーバ100に送信して分散保管するとともに、各部分データ510がいずれのサーバ100に保管されているかの対応に係る情報を分散状況321に記録して管理する。   The distributed management unit 320 transmits the partial data 510 generated by the division processing unit 310 to each server 100 according to a predetermined condition based on the setting contents of the setting information 301 when the important data 500 is distributed and stored. At the same time, information relating to which server 100 stores each partial data 510 is recorded in the distribution status 321 and managed.

n個より多数のサーバ100が存在する場合、n個のサーバ100を選択し、各部分データ510をそれぞれどのサーバ100に保管するかを決定する手法については種々のものが考えられる。   When there are more than n servers 100, various methods can be considered for selecting n servers 100 and determining which server 100 to store each partial data 510.

図3は、部分データ510を保管するサーバ100の選択の例について示した図である。図3の例では、各重要データ500(“重要データα”、“重要データβ”、“重要データγ”、…)から(3,4)閾値型の秘密分散により生成した4つの部分データ510(“A”、“B”、“C”、“D”)に対して、6つのサーバ100(“サーバ#1”〜“サーバ#6”)から保管先となるサーバ100を4つ選択して割り当てた場合を示している。   FIG. 3 is a diagram illustrating an example of selection of the server 100 that stores the partial data 510. In the example of FIG. 3, four partial data 510 generated by (3,4) threshold type secret sharing from each important data 500 (“important data α”, “important data β”, “important data γ”,...). For four ("A", "B", "C", "D"), four servers 100 as storage destinations are selected from the six servers 100 ("Server # 1" to "Server # 6"). It shows the case of assigning.

例えば、各サーバ100(“サーバ#1”〜“サーバ#6”)をランダムあるいはスペック等に基づく優先順位等に従って順序付けしておき、そこからその時点で障害等により稼動していないサーバ100(図3の例では、“重要データγ”を保管する際の“サーバ#6”)を除外した上で、リストの順序に従ってn個のサーバ100を順に選択するようにしてもよい。このとき、毎回リストの先頭(例えば“サーバ#1”)からn個のサーバ100を選択するようにしてもよいし、図3の例に示すように、選択する際の始点を保管する重要データ500毎にずらして、選択するサーバ100をローテーションするようにしてもよい。   For example, the servers 100 ("server # 1" to "server # 6") are ordered in accordance with a priority or the like based on random or specs, etc., and the server 100 that is not operating at that time due to a failure or the like (see FIG. In the example of 3, the “server # 6” when storing “important data γ”) may be excluded, and n servers 100 may be sequentially selected according to the order of the list. At this time, n servers 100 may be selected from the top of the list (for example, “server # 1”) each time, or as shown in the example of FIG. 3, important data for storing the starting point for selection The server 100 to be selected may be rotated by shifting every 500.

選択するサーバ100をローテーションすることで、複数の重要データ500について、部分データ510の分散保管のされ方がそれぞれ異なるようにすることができる。これにより、例えば、複数のサーバ100(図3の例では、網掛けされた“サーバ#1”、“サーバ#2”の2つ)で障害等により部分データ510の取得が不能となった場合に、復元できなくなる重要データ500の範囲を一部に抑え(図3の例では“重要データα”のみ)、全ての重要データ500が復元不能となるような事態を防止することができる。   By rotating the server 100 to be selected, the partial data 510 can be distributed and stored differently for a plurality of important data 500. As a result, for example, when acquisition of the partial data 510 becomes impossible due to a failure or the like in a plurality of servers 100 (in the example of FIG. 3, two shaded “server # 1” and “server # 2”). In addition, the range of the important data 500 that cannot be restored is limited to a part (only “important data α” in the example of FIG. 3), and a situation in which all the important data 500 cannot be restored can be prevented.

選択したn個のサーバ100に対して部分データ510を割り当てる手法についても種々のものが考えられる。例えば、図3の例に示すように、n個のサーバ100のリストに対して、n個の部分データ510を順次割り当てるようにしてもよいし、各部分データ510をランダムに割り当てるようにしてもよい。   Various methods for assigning the partial data 510 to the selected n servers 100 can be considered. For example, as shown in the example of FIG. 3, n partial data 510 may be sequentially assigned to a list of n servers 100, or each partial data 510 may be randomly assigned. Good.

設定情報301には、例えば、分散保管先となる各サーバ100に対するアクセス情報(IPアドレスやホスト名等)、n個より多数のサーバ100が存在する場合にn個のサーバ100を選択するための基準や条件(例えばサーバ100の優先順位や順序付けされたリスト、ローテーションの際の方法等)などを予め設定しておくことができる。   The setting information 301 includes, for example, access information (IP address, host name, etc.) for each server 100 serving as a distributed storage destination, and for selecting n servers 100 when more than n servers 100 exist. Criteria and conditions (for example, the priority order of the server 100, an ordered list, a rotation method, etc.) can be set in advance.

また、分散管理部320は、後述する復元処理部330による重要データ500の復元の際に、復元処理部330からの要求に基づいて、分散状況321の内容、および設定情報301の設定内容に基づく所定の条件に従って、各サーバ100から、重要データ500を復元するためのm個の部分データ510を収集して復元処理部330に受け渡す。   Also, the distribution management unit 320 is based on the contents of the distribution status 321 and the setting contents of the setting information 301 based on a request from the restoration processing unit 330 when the important data 500 is restored by the restoration processing unit 330 described later. According to a predetermined condition, m partial data 510 for restoring the important data 500 are collected from each server 100 and transferred to the restoration processing unit 330.

なお、収集する部分データ510の個数mの値は、重要データ500を復元するために必要な部分データ510の数k以上である必要があり、また、n個全ての部分データ510を収集するものとしてもよい(k≦m≦n)。設定情報301には、例えば、mの値や、m<nである場合に、対象となるm個のサーバ100を選択するための基準や条件、障害等により対象のサーバ100から部分データ510を取得できなかった場合の代替となるサーバ100の決定方法などを予め設定しておくことができる。   The number m of partial data 510 to be collected must be equal to or greater than the number k of partial data 510 necessary for restoring the important data 500, and all n partial data 510 are collected. (K ≦ m ≦ n). The setting information 301 includes, for example, partial data 510 from the target server 100 depending on criteria, conditions, failures, and the like for selecting the target m servers 100 when m is m or n <n. It is possible to set in advance a method for determining the server 100 as an alternative in the case where it cannot be acquired.

なお、サーバ100の障害等により、部分データ510の分散保管時にn個の部分データ510のうちいずれかを各サーバ100に保管できなかった場合や、部分データ510の収集時にk個以上収集できなかった場合は、ユーザに対してエラーを応答するようにしてもよい。また、各サーバ100との間で部分データ510の送受信を行う際に、クライアント端末300および各サーバ100がそれぞれ部分データ510に対して所定の暗号化を施した上で送受信することで、情報漏洩のリスクをさらに低減させるようにしてもよい。   If any of the n partial data 510 cannot be stored in each server 100 when the partial data 510 is distributed and stored due to a failure of the server 100, or more than k cannot be collected when the partial data 510 is collected. In such a case, an error may be returned to the user. Further, when the partial data 510 is transmitted / received to / from each server 100, the client terminal 300 and each server 100 perform predetermined encryption on the partial data 510 to transmit / receive information, thereby leaking information. This risk may be further reduced.

復元処理部330は、インタフェース部350を介してユーザから参照や編集等の利用を指示された重要データ500について、これを復元するために必要な数以上の部分データ510を分散管理部320に要求して取得し、取得した部分データ510から秘密分散の手法により重要データ500を復元する。   The restoration processing unit 330 requests the distributed management unit 320 for more than the number of partial data 510 necessary for restoring important data 500 that is instructed to be used for reference or editing by the user via the interface unit 350. The important data 500 is restored from the acquired partial data 510 by a secret sharing technique.

認証要求部340は、分散管理部320が各サーバ100に対して部分データ510を分散保管する際、および各サーバ100から部分データ510を収集する際の、各サーバ100に対する認証の要求を行う。例えば、ログイン画面を介してユーザからユーザIDおよびパスワードの入力を受け付け、後述するように、チャレンジ/レスポンス方式等により、各サーバ100の認証処理部120との間で順次もしくは並行的にそれぞれ個別に認証処理を行うことで、シングルサインオンの機能を実現する。   The authentication request unit 340 requests authentication of each server 100 when the distributed management unit 320 stores the partial data 510 in a distributed manner for each server 100 and collects the partial data 510 from each server 100. For example, an input of a user ID and a password is accepted from a user via a login screen, and individually or in parallel with the authentication processing unit 120 of each server 100 by a challenge / response method or the like, as will be described later. Implementing the authentication process realizes the single sign-on function.

ここでは、後述するように、認証要求の送信に対してサーバ100の認証処理部120から送信されたサーバシーズ140、ユーザシーズ131、および乱数に基づいて、ユーザから指定されたパスワードを所定の手順によりハッシュ化し、これをサーバ100の認証処理部120に送信することで認証処理を行う。従って、認証要求部340は、サーバ100の認証処理部120が実装しているものと同一のハッシュアルゴリズムを実装している。   Here, as will be described later, based on the server seeds 140, the user seeds 131, and the random numbers transmitted from the authentication processing unit 120 of the server 100 in response to the transmission of the authentication request, the password designated by the user is set in a predetermined procedure. Is hashed and transmitted to the authentication processing unit 120 of the server 100 for authentication processing. Accordingly, the authentication request unit 340 is implemented with the same hash algorithm as that implemented by the authentication processing unit 120 of the server 100.

インタフェース部350は、クライアント端末300における画面表示等のユーザインタフェースやデータの送受信などの入出力機能を有する。ユーザは、例えば、一般的なOSが有するファイル管理用の画面等を利用して、データ分散保管システム1の機能を利用することができる。   The interface unit 350 has a user interface such as a screen display in the client terminal 300 and an input / output function such as data transmission / reception. The user can use the function of the data distributed storage system 1 by using, for example, a file management screen of a general OS.

例えば、ファイル管理用の画面において重要データを特定のフォルダ等にドラッグ&ドロップなどの簡易な操作により移動する。これをトリガとして、分割処理部310および分散管理部320によって、自動的に当該重要データ500から(k,n)閾値型の秘密分散によりn個の部分データ510を生成し、各部分データ510をユーザに意識させずに各サーバ100に分散保管することができる。なお、上述したように、このとき重要データ500はクライアント端末300から削除するが、ファイル管理用の画面上では、ユーザに意識させないよう、例えば、重要データ500に対応するダミーファイル等を作成して残しておく。   For example, on the file management screen, important data is moved to a specific folder or the like by a simple operation such as drag and drop. With this as a trigger, the division processing unit 310 and the distribution management unit 320 automatically generate n pieces of partial data 510 from the important data 500 by (k, n) threshold type secret sharing, It can be distributed and stored in each server 100 without making the user aware of it. As described above, the important data 500 is deleted from the client terminal 300 at this time. However, for example, a dummy file corresponding to the important data 500 is created on the file management screen so as not to make the user aware of it. Leave it.

また、例えば、ユーザは、ファイル管理用の画面において特定のフォルダにて管理されている重要データ500のダミーファイル等に対して操作を行うことで、重要データ500に対する参照や編集等の操作を行うことができる。すなわち、ダミーファイル等に対する操作をトリガとして、分散管理部320および復元処理部330によって、ダミーファイル等に対応する重要データ500について、自動的に各サーバ100からm個(k≦m≦n)の部分データ510を収集し、重要データ500を復元してユーザに利用可能とすることができる。   Further, for example, the user performs operations such as reference and editing on the important data 500 by performing operations on the dummy file or the like of the important data 500 managed in a specific folder on the file management screen. be able to. That is, using the operation on the dummy file as a trigger, the distribution management unit 320 and the restoration processing unit 330 automatically generate m (k ≦ m ≦ n) important data 500 corresponding to the dummy file from each server 100. Partial data 510 can be collected and important data 500 can be recovered and made available to the user.

<認証処理>
以下では、本実施の形態のデータ分散保管システム1における認証処理の内容について説明する。本実施の形態のデータ分散保管システム1では、上述したように、複数のサーバ100に対して部分データ510を分散保管する際、および複数のサーバ100から部分データ510を収集する際に、ユーザによる各サーバ100に対する個別の認証処理に伴う煩雑さを回避するため、シングルサインオンの仕組みを有する。
<Authentication process>
Below, the content of the authentication process in the data distribution storage system 1 of this Embodiment is demonstrated. In the data distributed storage system 1 according to the present embodiment, as described above, when the partial data 510 is distributed and stored in the plurality of servers 100 and when the partial data 510 is collected from the plurality of servers 100, In order to avoid the complexity associated with individual authentication processing for each server 100, a single sign-on mechanism is provided.

本実施の形態では、各データセンター10が地理的にも組織的にも関連のないものであることから、例えば代表となる認証サーバ等での認証結果を、SAMLプロトコル等によって各サーバ100間で引き継ぐような認証手法ではなく、各データセンター10間で異なる固有情報(鍵)を用いて個別に認証処理を行うことで、各データセンター10へのアクセスを独立して安全に行える仕組みを有し、各データセンター10間でのセキュリティを確保する。   In the present embodiment, since each data center 10 is not related geographically or organizationally, for example, the authentication result of a representative authentication server or the like is sent between the servers 100 using the SAML protocol or the like. It has a mechanism that allows independent and secure access to each data center 10 by performing authentication processing individually using unique information (key) that is different between each data center 10 instead of taking over the authentication method. , Ensuring security between the data centers 10.

認証処理を行うに当たっての初期状態として、各サーバ100では、予め、マスタサーバ200のシーズ生成部210によって生成されたシーズをそれぞれサーバシーズ140として保持しているものとする。さらに、各ユーザによって、ユーザID、パスワード等を含むアカウント情報の初期登録が事前に行われているものとする。このとき、アカウント情報として、ユーザID毎にそれぞれマスタサーバ200のシーズ生成部210によって生成されたシーズをユーザシーズ131として保持しておく。さらに、パスワードについては、当該ユーザシーズ131およびサーバシーズ140をシード値として、所定のハッシュアルゴリズムによりハッシュ化したハッシュ化パスワード132として保持しておく。   As an initial state for performing the authentication process, it is assumed that each server 100 holds a seed generated by the seed generation unit 210 of the master server 200 as a server seed 140 in advance. Furthermore, initial registration of account information including a user ID, a password, and the like is performed in advance by each user. At this time, as account information, the seeds generated by the seed generation unit 210 of the master server 200 are stored as user seeds 131 for each user ID. Further, the password is stored as a hashed password 132 hashed by a predetermined hash algorithm using the user seeds 131 and the server seeds 140 as seed values.

パスワードを直接保持しないことで、パスワードの漏洩を防止することができる。また、ユーザ毎にユニークなユーザシーズ131をシード値としてハッシュ化を行うことで、例えば、複数のユーザによって偶然同一のパスワードが指定された場合でも、ユーザ毎にハッシュ値が異なるようにすることができる。   By not holding the password directly, the leakage of the password can be prevented. In addition, hashing is performed by using a unique user seed 131 for each user as a seed value, so that, for example, even when the same password is accidentally specified by a plurality of users, the hash value may be different for each user. it can.

図4は、本実施の形態における認証処理の流れの例について概要を示した図である。まず、ユーザはクライアント端末300の認証要求部340を介して、認証(ログイン)の要求を行う。このとき、例えば、ユーザIDおよびパスワードの情報をログイン画面等を介して指定する。認証要求部340は、指定されたユーザIDを含む認証の要求をサーバ100へ送信する(S01)。   FIG. 4 is a diagram showing an overview of an example of the flow of authentication processing in the present embodiment. First, the user requests authentication (login) via the authentication request unit 340 of the client terminal 300. At this time, for example, user ID and password information are specified via a login screen or the like. The authentication request unit 340 transmits an authentication request including the designated user ID to the server 100 (S01).

ユーザIDを受信したサーバ100の認証処理部120は、チャレンジ/レスポンス方式におけるチャレンジとしての乱数を生成し、さらにシーズを取得して、これらをクライアント端末300に送信する(S02)。ここでは、乱数に加えて、サーバシーズ140と、ユーザ情報130に保持されたユーザIDに対応するユーザシーズ131を取得する。   Upon receiving the user ID, the authentication processing unit 120 of the server 100 generates a random number as a challenge in the challenge / response method, acquires seeds, and transmits them to the client terminal 300 (S02). Here, in addition to the random number, the server seed 140 and the user seed 131 corresponding to the user ID held in the user information 130 are acquired.

サーバシーズ140とユーザシーズ131、および乱数を受信したクライアント端末300の認証要求部340では、ステップS01において指定されたパスワードを所定のハッシュアルゴリズムによりハッシュ化する(S03)。さらに、ステップS03で得られたハッシュ値を、ユーザシーズ131をシード値としてハッシュ化する(S04)。さらに、ステップS04で得られたハッシュ値を、サーバシーズ140をシード値としてハッシュ化する(S05)。さらに、ステップS05で得られたハッシュ値を、乱数をシード値としてハッシュ化することでワンタイム化し、得られたハッシュ値をサーバ100へ送信する(S06)。   The server seed 140, the user seed 131, and the authentication request unit 340 of the client terminal 300 that has received the random number hash the password specified in step S01 with a predetermined hash algorithm (S03). Further, the hash value obtained in step S03 is hashed using the user seeds 131 as a seed value (S04). Furthermore, the hash value obtained in step S04 is hashed using the server seeds 140 as a seed value (S05). Further, the hash value obtained in step S05 is made one-time by hashing using a random number as a seed value, and the obtained hash value is transmitted to the server 100 (S06).

なお、上記のステップS03〜S05の一連のハッシュ化処理手順は、一例であり、同等の結果が得られる他の手順とすることも当然可能であるが、事前のユーザ登録の際にパスワードをハッシュ化してハッシュ化パスワード132を取得する際のハッシュ化処理と同一の手順である必要がある。また、例えば、ステップS02において、サーバ100からパスワードの有効期限が経過しているためパスワードを更新する旨の指示を受信した場合など、必要に応じて、ステップS03を実行する前にパスワード(およびハッシュ化パスワード132)の更新を行えるようにしてもよい。   Note that the series of hashing procedures in steps S03 to S05 described above is merely an example, and other procedures that can obtain equivalent results are naturally possible. However, the password is hashed in advance during user registration. It is necessary to use the same procedure as the hashing process when the hashed password 132 is acquired. Further, for example, when an instruction to update the password is received from the server 100 in step S02, the password (and hash) is executed before executing step S03 as necessary. Update password 132) may be updated.

ハッシュ値を受信したサーバ100の認証処理部120は、ユーザ情報130から対象のユーザIDに対応するハッシュ化パスワード132を取得し(S07)、取得したハッシュ化パスワード132を、ステップS02で生成した乱数をシード値としてハッシュ化する(S08)。その後、得られたハッシュ値と、ステップS07でクライアント端末300から受信したハッシュ値とを比較することで認証処理を行い、認証結果をクライアント端末300に送信する(S09)。すなわち、比較の結果両者が一致すれば認証は成立し、不一致であれば認証は不成立となる。なお、このとき例えば、クライアント端末300からの要求電文からIPアドレス等の発信元の所在に係る情報を取得し、当該情報が所定の範囲内にあるか否か等の他の条件を認証の成否の判断に加えてもよい。   Upon receiving the hash value, the authentication processing unit 120 of the server 100 acquires the hashed password 132 corresponding to the target user ID from the user information 130 (S07), and the random number generated in step S02 is the acquired hashed password 132. Is hashed as a seed value (S08). Thereafter, authentication processing is performed by comparing the obtained hash value with the hash value received from the client terminal 300 in step S07, and the authentication result is transmitted to the client terminal 300 (S09). That is, if the two match as a result of the comparison, the authentication is established, and if the two do not match, the authentication is not established. At this time, for example, information related to the location of the transmission source such as the IP address is acquired from the request message from the client terminal 300, and other conditions such as whether or not the information is within a predetermined range are successful or unsuccessful. It may be added to the judgment.

クライアント端末300の認証要求部340は、認証結果を受領し(S10)、その後、必要に応じて他のサーバ100に対しても順次上記の一連の処理を自動的に行い、各サーバ100に対する認証処理を行う。各サーバ100での認証処理は独立していることから、必要な複数のサーバ100に対して上記の一連の処理を同時並行的に行うことも可能である。なお、必要なサーバ100の情報については、例えば、クライアント端末300の設定情報301等に予め設定しておいてもよいし、分散管理部320が、部分データ510の分散保管時や収集時に選択したサーバ100を対象としてもよい。   The authentication request unit 340 of the client terminal 300 receives the authentication result (S10), and then automatically performs the above-described series of processes sequentially for the other servers 100 as necessary, and authenticates each server 100. Process. Since the authentication processing in each server 100 is independent, the above-described series of processing can be performed simultaneously on a plurality of necessary servers 100 in parallel. The necessary server 100 information may be set in advance in the setting information 301 of the client terminal 300, for example, or selected by the distribution management unit 320 at the time of distributed storage or collection of the partial data 510. The server 100 may be the target.

以上の処理により、ユーザは、ユーザIDおよびパスワードの指定を1回行うだけで、必要な各サーバ100に対して認証処理を行うことができる。   With the above processing, the user can perform authentication processing for each necessary server 100 only by specifying the user ID and password once.

上述したような手法をとることにより、例えば、あるサーバ100やデータセンター10の管理者等が、対象のユーザのユーザシーズ131やハッシュ化パスワード132などのアカウント情報を自身のユーザ情報130から取得したとしても、これらの情報を利用して他のサーバ100(データセンター10)に対してなりすましによる認証を行うことはできず、サーバ100間でのセキュリティは確保される。   By taking the above-described method, for example, an administrator of a certain server 100 or data center 10 acquires account information such as the user's seed 131 or hashed password 132 of the target user from his / her user information 130. However, it is not possible to authenticate other servers 100 (data center 10) by impersonation using these pieces of information, and security between the servers 100 is ensured.

これは、あるサーバ100でのユーザのハッシュ化パスワード132の値は、自身のサーバシーズ140によってハッシュ化されたものであり、他のサーバ100における当該ユーザのハッシュ化パスワード132は、当該他のサーバ100のサーバシーズ140によってハッシュ化されたものであるため値が異なるからである。従って、両者を同じ乱数をシード値としてハッシュ化しても同一のハッシュ値とはならず、図4のステップS09において認証は不成立となる。また、当該他のサーバ100のサーバシーズ140を何らかの手段で取得してきたとしても、対象のユーザのパスワードを知らない限り、当該他のサーバ100におけるハッシュ化パスワード132と同じ値のハッシュ値を生成することはできない。   This is because the value of the user's hashed password 132 in a certain server 100 is hashed by its own server seeds 140, and the user's hashed password 132 in the other server 100 is stored in the other server 100. This is because the value is different because it is hashed by 100 server seeds 140. Therefore, even if both are hashed using the same random number as a seed value, the same hash value is not obtained, and authentication is not established in step S09 in FIG. Further, even if the server seeds 140 of the other server 100 are acquired by some means, a hash value having the same value as the hashed password 132 in the other server 100 is generated unless the password of the target user is known. It is not possible.

以上に説明したように、本発明の一実施の形態であるデータ分散保管システム1によれば、重要データ500から秘密分散技術により部分データ510を生成して各データセンター10に分散保管することで、クライアント端末300の盗難や紛失等による重要データ500の漏洩を防止することができる。また、各データセンター10は重要データ500につき部分データ510を1つしか有していないため、データセンター10に対して第三者が侵入して不正に部分データ510を取得したり、データセンター10の管理者等の内部の者が部分データ510を取得したりした場合でも、部分データ510を1つしか得ることができない。当該部分データ510だけでは重要データ500を復元・推測することはできないため、重要データ500の内容が漏洩することはない。   As described above, according to the data distributed storage system 1 according to an embodiment of the present invention, the partial data 510 is generated from the important data 500 by the secret sharing technique and is distributed and stored in each data center 10. The leakage of the important data 500 due to theft or loss of the client terminal 300 can be prevented. Since each data center 10 has only one partial data 510 for the important data 500, a third party enters the data center 10 to obtain the partial data 510 illegally, Even if an internal person such as an administrator of the system acquires partial data 510, only one partial data 510 can be obtained. Since the important data 500 cannot be restored / estimated only by the partial data 510, the contents of the important data 500 are not leaked.

また、サーバ100毎に異なる固有情報(サーバシーズ140)を用いて認証を行うことで、データセンター10の管理者等の内部の者が、悪意を持って他のデータセンター10にアクセスすることも困難であることから、各データセンター10間での部分データ510の不正取得を防止するためのセキュリティを確保することが可能となる。   In addition, by performing authentication using unique information (server seeds 140) that is different for each server 100, an internal person such as an administrator of the data center 10 may access other data centers 10 with malicious intent. Since this is difficult, it is possible to ensure security for preventing unauthorized acquisition of the partial data 510 between the data centers 10.

また、ユーザによるクライアント端末300からの一度の認証処理によって複数のサーバ100に対するシングルサインオンを実現することができ、また、各サーバ100での認証を同時並行的に行うことが可能である。従って、重要データ500から生成された部分データ510の分散保管、および重要データ500を復元するために必要な数以上の部分データ510の収集において、認証に要する時間を削減してレスポンスの低下を抑止することが可能となる。   In addition, single sign-on for a plurality of servers 100 can be realized by a single authentication process from the client terminal 300 by a user, and authentication on each server 100 can be performed simultaneously in parallel. Therefore, in the distributed storage of the partial data 510 generated from the important data 500 and the collection of the partial data 510 exceeding the number necessary for restoring the important data 500, the time required for authentication is reduced and the deterioration of the response is suppressed. It becomes possible to do.

以上、本発明者によってなされた発明を実施の形態に基づき具体的に説明したが、本発明は前記実施の形態に限定されるものではなく、その要旨を逸脱しない範囲で種々変更可能であることはいうまでもない。   As mentioned above, the invention made by the present inventor has been specifically described based on the embodiment. However, the present invention is not limited to the embodiment, and various modifications can be made without departing from the scope of the invention. Needless to say.

本発明は、重要データから秘密分散技術により複数の非重要データを生成して複数の拠点に分散保管するデータ分散保管システムに利用可能である。   INDUSTRIAL APPLICABILITY The present invention can be used in a data distributed storage system that generates a plurality of non-important data from important data using a secret sharing technique and distributes and stores the data at a plurality of locations.

1…データ分散保管システム、
10、10a〜d…データセンター、
100、100a〜d…サーバ、110、110a〜d…データ保管部、120…認証処理部、130…ユーザ情報、131…ユーザシーズ、132…ハッシュ化パスワード、140…サーバシーズ、
200…マスタサーバ、210…シーズ生成部、
300…クライアント端末、301…設定情報、310…分割処理部、320…分散管理部、321…分散状況、330…復元処理部、340…認証要求部、350…インタフェース部、
400…ネットワーク、
500…重要データ、510a〜d…部分データ。
1 ... Data distributed storage system,
10, 10a-d ... data center,
100, 100a to d ... server, 110, 110a to d ... data storage unit, 120 ... authentication processing unit, 130 ... user information, 131 ... user seed, 132 ... hashed password, 140 ... server seed,
200: Master server, 210: Seeds generation unit,
300 ... Client terminal 301 ... Setting information 310 ... Division processing unit 320 ... Distribution management unit 321 ... Distribution status 330 ... Restore processing unit 340 ... Authentication request unit 350 ... Interface unit
400 ... Network,
500: important data, 510a to d: partial data.

Claims (7)

クライアント端末において、重要データから秘密分散技術により複数の非重要データである部分データを生成し、前記各部分データを、ネットワークを介して接続された複数のサーバに分散保管するデータ分散保管システムであって、
前記各サーバは、それぞれ、前記クライアント端末から受信した前記部分データを保管するデータ保管部を有し、
前記クライアント端末は、ユーザから保管を指示された前記重要データから前記秘密分散技術によりk個以上集めなければ前記重要データを復元できないn個(k≦n)の前記部分データを生成する分割処理部と、
前記分割処理部によって生成されたn個の前記部分データを、n個以上の前記サーバの中から、保管する前記重要データ毎に順次ローテーションさせて選択したn個の前記サーバの前記データ保管部にそれぞれ保管し、また、前記重要データを復元するためのm個(k≦m≦n)の前記部分データをm個の前記サーバからそれぞれ収集する分散管理部と、
前記ユーザから利用を指示された前記重要データについて、前記分散管理部から取得したm個の前記部分データから前記秘密分散技術により前記重要データを復元する復元処理部とを有することを特徴とするデータ分散保管システム。
A data distributed storage system that generates a plurality of partial data, which are non-critical data, from secret data using a secret sharing technique at a client terminal, and distributes and stores each partial data on a plurality of servers connected via a network. And
Each of the servers has a data storage unit that stores the partial data received from the client terminal,
The client terminal generates n pieces (k ≦ n) of partial data that cannot be restored unless the k is collected from the important data instructed to be stored by the user by the secret sharing technique. When,
The n pieces of partial data generated by the division processing unit are sequentially rotated for each of the important data to be stored from the n or more servers, and the data storage units of the n servers selected. A distributed management unit that stores each of the m pieces of partial data (k ≦ m ≦ n) for restoring the important data from each of the m servers;
Data having a restoration processing unit that restores the important data from the m pieces of partial data acquired from the distribution management unit using the secret sharing technique for the important data instructed to be used by the user Distributed storage system.
請求項1に記載のデータ分散保管システムにおいて、
前記各サーバは、さらに、前記サーバへのアクセスに対しての認証処理を行う認証処理部を有し、
前記クライアント端末は、さらに、前記分散管理部が前記各サーバに対して前記部分データを保管する際、および前記各サーバから前記部分データを収集する際に、前記ユーザからユーザIDおよびパスワードの指定を受けて前記各サーバに対して順次もしくは並行的に認証の要求を送信する認証要求部を有し、
前記サーバの前記認証処理部は、前記サーバ毎に固有情報であるサーバシーズと、登録されたユーザのユーザID毎に、前記ユーザ毎に固有情報であるユーザシーズと、前記ユーザのパスワードを前記サーバシーズおよび前記ユーザシーズを用いて所定の手順でハッシュ化したハッシュ化パスワードとを含むアカウント情報を保持するユーザ情報とを有し、前記クライアント端末から受信した前記認証の要求に対して、前記サーバシーズと対象の前記ユーザに係る前記ユーザシーズ、および生成した乱数を前記クライアント端末に対して送信し、
前記クライアント端末の前記認証要求部は、前記ユーザから指定されたパスワードを、前記サーバから受信した前記サーバシーズおよび前記ユーザシーズを用いて所定の手順でハッシュ化し、さらに前記乱数を用いてハッシュ化したハッシュ値を前記サーバに送信し、
前記サーバの前記認証処理部は、前記クライアント端末から受信した前記ハッシュ値と、対象の前記ユーザに係る前記ハッシュ化パスワードを前記乱数を用いてハッシュ化した値とを比較して認証を行い、認証結果を前記クライアント端末に送信することを特徴とするデータ分散保管システム。
The data distributed storage system according to claim 1 ,
Each of the servers further includes an authentication processing unit that performs an authentication process for access to the server,
The client terminal further specifies a user ID and a password from the user when the distributed management unit stores the partial data in each server and collects the partial data from each server. Receiving an authentication requesting unit that transmits authentication requests to each of the servers sequentially or in parallel,
The authentication processing unit of the server includes a server seed that is unique information for each server, a user seed that is unique information for each user for each registered user ID, and a password of the user for the server. And user information holding account information including a hashed password hashed in a predetermined procedure using the user seeds, and the server seeds in response to the authentication request received from the client terminal And the user seed related to the target user and the generated random number to the client terminal,
The authentication request unit of the client terminal hashes the password designated by the user using a predetermined procedure using the server seeds and the user seeds received from the server, and further hashed using the random numbers. Sending a hash value to the server;
The authentication processing unit of the server performs authentication by comparing the hash value received from the client terminal with a value obtained by hashing the hashed password relating to the target user using the random number, and performing authentication. A data distributed storage system, wherein a result is transmitted to the client terminal.
請求項2に記載のデータ分散保管システムにおいて、
さらに、前記ネットワークに接続され、前記各サーバからの要求に基づいて、前記各サーバに対して前記シーズとなるシード値を生成して提供するマスタサーバを有することを特徴とするデータ分散保管システム。
The data distributed storage system according to claim 2 ,
The data distributed storage system further comprising a master server connected to the network and generating and providing a seed value serving as the seed for each server based on a request from each server.
請求項1〜のいずれか1項に記載のデータ分散保管システムにおいて、
前記クライアント端末の前記分散管理部は、n個の前記部分データをn個の前記サーバにそれぞれ保管した際に、前記各部分データがいずれの前記サーバに保管されているかの対応に係る情報を分散状況記録部に記録することを特徴とするデータ分散保管システム。
In the data distribution storage system of any one of Claims 1-3 ,
The distribution management unit of the client terminal distributes information related to which server each partial data is stored in when the n pieces of partial data are stored in the n servers. A data distributed storage system characterized by recording in a status recording unit.
請求項1〜のいずれか1項に記載のデータ分散保管システムにおいて、
前記クライアント端末は、前記秘密分散技術に係るk、m、nの値、前記各サーバに対するアクセス情報、前記分散管理部がn個の前記部分データを保管する対象となるn個の前記サーバを選択する条件、前記分散管理部がm個の前記部分データを収集する対象となるm個の前記サーバを選択する条件、および前記分散管理部が前記サーバから前記部分データを取得できなかった場合の代替となる前記サーバの決定方法のうち、少なくとも1つ以上の情報が予め設定された設定情報を有することを特徴とするデータ分散保管システム。
In the data distribution storage system of any one of Claims 1-4 ,
The client terminal selects k, m, n values related to the secret sharing technique, access information for each server, and n servers for which the distribution management unit stores n partial data. A condition for selecting the m servers for which the distributed management unit collects the partial data, and an alternative when the distributed management unit cannot acquire the partial data from the server Among the server determination methods, at least one piece of information has setting information set in advance.
請求項1〜のいずれか1項に記載のデータ分散保管システムにおいて、
前記クライアント端末の前記分散管理部は、n個の前記部分データをn個の前記サーバにそれぞれ保管する際に、n個の前記部分データのいずれかを前記サーバに保管できなかった場合、もしくはm個の前記部分データをm個の前記サーバからそれぞれ収集する際に、k個以上収集できなかった場合は、前記ユーザに対してエラーを応答することを特徴とするデータ分散保管システム。
In the data distribution storage system of any one of Claims 1-5 ,
When the distribution management unit of the client terminal stores n pieces of partial data in each of the n servers, if the n pieces of partial data cannot be stored in the server, or m When collecting k pieces of partial data from m pieces of the servers, if k or more pieces cannot be collected, an error response is returned to the user.
請求項1〜のいずれか1項に記載のデータ分散保管システムにおいて、
前記クライアント端末および前記各サーバは、前記部分データを送受信する際に、送信する前記部分データを所定の手段で暗号化することを特徴とするデータ分散保管システム。
In the data distribution storage system of any one of Claims 1-6 ,
The client terminal and each server encrypt the partial data to be transmitted by a predetermined means when transmitting and receiving the partial data.
JP2011151337A 2011-07-08 2011-07-08 Distributed data storage system Expired - Fee Related JP4860779B1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2011151337A JP4860779B1 (en) 2011-07-08 2011-07-08 Distributed data storage system
PCT/JP2011/079837 WO2013008351A1 (en) 2011-07-08 2011-12-22 Data distributed storage system

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2011151337A JP4860779B1 (en) 2011-07-08 2011-07-08 Distributed data storage system

Publications (2)

Publication Number Publication Date
JP4860779B1 true JP4860779B1 (en) 2012-01-25
JP2013020313A JP2013020313A (en) 2013-01-31

Family

ID=45604562

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2011151337A Expired - Fee Related JP4860779B1 (en) 2011-07-08 2011-07-08 Distributed data storage system

Country Status (2)

Country Link
JP (1) JP4860779B1 (en)
WO (1) WO2013008351A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10348490B2 (en) 2015-12-10 2019-07-09 Ns Solutions Corporation Information processing device, authorization system, information processing method, and recording medium

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5850974B2 (en) * 2014-04-21 2016-02-03 日本電信電話株式会社 File distribution system, file distribution method, and program
WO2016152601A1 (en) 2015-03-23 2016-09-29 富士フイルム株式会社 Image file distribution device, image file restoration device, method and program therefor, and recording medium in which program is stored
WO2017033442A1 (en) 2015-08-26 2017-03-02 日本電気株式会社 Information processing device, authentication system, authentication method, and recording medium for recording computer program
CN108475483B (en) * 2016-01-18 2021-07-13 日本电信电话株式会社 Hidden decision tree calculation system, device, method and recording medium
JP6493885B2 (en) 2016-03-15 2019-04-03 富士フイルム株式会社 Image alignment apparatus, method of operating image alignment apparatus, and image alignment program
JP7099305B2 (en) 2018-12-20 2022-07-12 富士通株式会社 Communication equipment, communication methods, and communication programs

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005209118A (en) * 2004-01-26 2005-08-04 Nippon Telegr & Teleph Corp <Ntt> Information distributed storage system, overall authentication server device used therefor, authentication server device, distributed storage server device, and information distributed storage method
JP2007102672A (en) * 2005-10-07 2007-04-19 Toppan Nsw:Kk Data backup device, data backup method and program
JP2009010531A (en) * 2007-06-26 2009-01-15 Toshiba Corp Security distribution device, method, and program

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005209118A (en) * 2004-01-26 2005-08-04 Nippon Telegr & Teleph Corp <Ntt> Information distributed storage system, overall authentication server device used therefor, authentication server device, distributed storage server device, and information distributed storage method
JP2007102672A (en) * 2005-10-07 2007-04-19 Toppan Nsw:Kk Data backup device, data backup method and program
JP2009010531A (en) * 2007-06-26 2009-01-15 Toshiba Corp Security distribution device, method, and program

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10348490B2 (en) 2015-12-10 2019-07-09 Ns Solutions Corporation Information processing device, authorization system, information processing method, and recording medium

Also Published As

Publication number Publication date
JP2013020313A (en) 2013-01-31
WO2013008351A1 (en) 2013-01-17

Similar Documents

Publication Publication Date Title
US11108753B2 (en) Securing files using per-file key encryption
CN111488598B (en) Access control method, device, computer equipment and storage medium
US9667416B1 (en) Protecting master encryption keys in a distributed computing environment
CN105027493B (en) Safety moving application connection bus
EP3216188B1 (en) Roaming content wipe actions across devices
US9584316B1 (en) Digital security bubble
JP4860779B1 (en) Distributed data storage system
CN103731395B (en) The processing method and system of file
JP4875781B1 (en) Distributed data storage system
CN104145446B (en) Operate method, computing device and the computer program of computing device
US20120254622A1 (en) Secure Access to Electronic Devices
JP2017507629A (en) Security and data privacy for lighting sensor networks
JP2016535476A (en) Systems and methods for encryption key management, collaboration, and distribution
GB2489676A (en) Overlay network comprising management node controlling access of subordinate nodes
JP3215882U (en) Cloud storage based file access control system
CN108494724B (en) Cloud storage encryption system based on multi-authority attribute encryption algorithm
CN105518696B (en) Operation is executed to data storage
JP5485452B1 (en) Key management system, key management method, user terminal, key generation management device, and program
US11032708B2 (en) Securing public WLAN hotspot network access
CN117879819B (en) Key management method, device, storage medium, equipment and computing power service system
JP6293617B2 (en) Authentication control system, control server, authentication control method, program
JP5778018B2 (en) Electronic data management system and electronic data management method
JP2013120515A (en) Electronic data management system, information processing device, electronic data management program and electronic data management method
Paul et al. 5G-enabled decentralised services
CN118709166A (en) Document information safety management system based on full period management

Legal Events

Date Code Title Description
TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20111102

R150 Certificate of patent or registration of utility model

Ref document number: 4860779

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20141111

Year of fee payment: 3

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

LAPS Cancellation because of no payment of annual fees