Redis
ファイル:Redis Logo.svg | |
開発元 | Salvatore Sanfilippo[1][2] |
---|---|
初版 | 2009年5月10日 |
最新版 | 7.2.4 - 2024年1月9日[3] [±] |
リポジトリ | |
プログラミング 言語 | C |
対応OS | クロスプラットフォーム |
対応言語 | 英語 |
サポート状況 | 活動中 |
種別 | データストア |
ライセンス | BSD |
公式サイト |
redis |
Redisは、ネットワーク接続された永続化可能なインメモリデータベース。連想配列(キー・バリュー)、リスト、セットなどのデータ構造を扱える。いわゆるNoSQLデータベースの一つ。オープンソースソフトウェアプロジェクトであり、Redis Labsがスポンサーとなって開発されている[4]。
歴史
Redisの名称はREmote DIctionary Serverを意味している[5][6]。元々の開発者はVMware所属(2010年3月当時)のエンジニアSalvatore Sanfilippoである[7][8][9][6]。2013年5月からは、RedisはVMwareをスピンオフしたPivotal Softwareにスポンサーされるようになった[10]。2015年6月からは、Redis Labsがスポンサーとなっている[11]。
DB-Engines.comの月間ランキングでは、Redisはしばしば最もポピュラーなキー・バリュー型データベースとして評されている[12]。また、Redisは2015年のユーザーレビューによる満足度と市場でのプレゼンスの評価でNoSQLデータベースで4位を[13]、Docker等の各種コンテナ上で使われているNoSQLデータベースとして1位を[14]、さらに上位50デベロッパーツール&サービスにおけるNoSQLデータベースとしても1位を獲得している[15]。
対応するプログラミング言語
以下のような数多くのプログラミング言語からの使用が可能である[16]。
ActionScript, C, C++, C#, Chicken Scheme, Clojure, Common Lisp, D, Dart, Erlang, Go, Haskell, Haxe, Io, Java, JavaScript (Node.js), Julia, Lua, Nim, Objective-C, OCaml, Perl, PHP, Pure Data, Python, R,[17] Racket, Ruby, Rust, Scala, Smalltalk, Tcl
データタイプ
Redisではキーと値を紐づけて保存する。しかしRedisと他の構造型ストレージの重要な違いとして、Redisはバイナリ列(文字列, string)だけでなく以下のようなデータタイプをサポートする。Redis ではバイナリ列のことを string と呼んでいるが、特に文字の使用だけに限った物ではない。
- バイナリ列(string)のリスト(両端キューとして利用可能)
- バイナリ列(string)の集合(ソートされない重複のないコレクション)
- バイナリ列(string)のソートされた集合(浮動小数点数のスコアによりソートされた重複のないコレクション)
- バイナリ列(string)のキーと値からなるハッシュテーブル
- ビットマップ
- 集合の濃度(元の個数)。分布を表現。
値のデータタイプは、各タイプごとに用意された操作(コマンド)で決定される。RedisはINTERSECTIONやUNION、セットやリストの差分抽出といったサーバーサイド操作をアトミックにサポートする。
永続性
Redisでは一般的に全てのデータはメモリ上に格納される。バージョン2.4よりバーチャルメモリと名付けられたデータをディスク上に格納する機構が使用可能となったが[18]、これは後に非推奨となっている。永続性を実現するための方法としては、3.2現在では2つの手段が用意されている。1つ目はスナップショットと呼ばれるもので、スナップショットではメモリ上のデータは非同期で時折RDBダンプの形式でディスク上に書きこまれる。もう1つの手段が、1.1から存在するAOF (append-only file) と呼ばれるもので、こちらはメモリ上のデータが変更されるごとにトランザクションログが書きこまれる安全な方式となっている。Redisはトランザクションログの肥大化防止のためにバックグラウンドでこれを再生成することができる。
デフォルトでは、Redisは2秒間隔でデータをファイルシステムに書きこむようになっているが、必要であればより安全なオプションを使用することもできる。デフォルト設定でシステムが完全に失敗した場合でも、失われるデータは数秒間分に限られる。
レプリケーション
Redisはマスタースレーブ型のレプリケーションをサポートする。Redisサーバーのデータは複数台のスレーブにレプリケーションすることができる。スレーブはまた別のスレーブのマスターとなることもできる。Redisはシングルルートレプリケーションツリーをサポートする。Redisのスレーブには書き込みを許可する設定も可能で、その場合インスタンス間の不整合を許容する形になる。Redisは出版-購読型モデル (Publish/Subscribe) を完全に実装しており、マスターで出版 (Publish) されたメッセージは、スレーブに接続して購読 (Subscribe) しているクライアントにも到達する。レプリケーションは、読み込みのスケーラビリティ(書き込みは除く)とデータの冗長性向上に有効である。[19]
性能
データの永続性が必要ない場合において、Redisはメモリ上のみで動作することが可能であり、トランザクションのコミットごとにディスクへの書き込みが発生するデータベースと比べて性能的に優位である[5]。Redisの操作はシングルスレッド上のシングルプロセスとして動作する。そのため、1つのRedisインスタンスでは例えばストアドプロシージャのように並列に処理を実行することはできない。
クラスタリング
Redisプロジェクトはクラスター仕様を持っており[20]、開発者のSanfilippoはRedis clusterの製品版ではキー空間の自動パーティショニングとホットリシャーディングをサポート、ただしシングルキー操作のみに対応、という投稿を行っている[21](β版が2013年末にリリース予定[22])。将来のバージョンでは、1000以上のノードをサポートし、ハートビートと障害検知によりフォールトトレランスを実現、スレーブのマスターへの昇格、全ノードへの出版-購読モデルなどが構想されている[20][23]。
関連項目
脚注
- ^ An interview with Salvatore Sanfilippo, creator of Redis, working out of Sicily, January 4, 2011, by Stefano Bernardi, EU-Startups
- ^ Salvatore Sanfilippo – Welcome to Redis Labs, July 15, 2015, By Itamar Haber, Redis Labs
- ^ “Releases”. GitHub. 2023年4月17日閲覧。
- ^ Kepes, Ben (July 15, 2015),"Redis Labs hires the creator of Redis, Salvatore Sanfilippo", Network World, Retrieved August 30, 2015.
- ^ a b “FAQ, Redis”. 2017年3月16日閲覧。
- ^ a b Redis - AWS、2020年6月10日閲覧
- ^ Gwen Shapira (2010年3月17日). “VMware Hires Redis Key Developer – But Why?”. Blog. 2016年9月25日閲覧。
- ^ Salvatore Sanfilippo (2010年3月15日). “VMware: the new Redis home”. Blog. 2016年9月25日閲覧。
- ^ Derek Collison (2010年3月15日). “VMware: The Console: VMware hires key developer for Redis”. Blog. 2010年3月22日時点のオリジナルよりアーカイブ。2016年9月25日閲覧。
- ^ Salvatore Sanfilippo. “Redis Sponsors”. Redis Labs. 2016年9月25日閲覧。
- ^ Thanks Pivotal, Hello Redis Labs, July 15, 2015, By Salvatore Sanfilippo, Redis Labs
- ^ DB-Engines Ranking of Key-value Stores
- ^ Best NoSQL Databases: Fall 2015 Report from G2 Crowd
- ^ The Current State of Container Usage
- ^ Top 50 Developer Tools and Services of 2015
- ^ Redis language bindings
- ^ CRAN – Package rredis
- ^ Redis documentation "Virtual Memory", redis.io, accessed January 18, 2011.
- ^ ReplicationHowto – redis – A persistent key-value database with built-in net interface written in ANSI-C for Posix systems – Google Project Hosting
- ^ a b Redis Cluster Specification, Redis.io, Retrieved 2013-12-25.
- ^ News about Redis: 2.8 is shaping, I'm back on Cluster, Antirez Weblog - Salvatore Sanfilippo, Retrieved 2013-12-25.
- ^ Redis Download Page, Redis.io, Retrieved 2013-12-25.
- ^ Redis Cluster - a Pragmatic Approach to Distribution, Redis.io, Retrieved 2013-12-25.