Redis
作者 | Salvatore Sanfilippo(2020年6月30日まで)[1][2] |
---|---|
開発元 | Redis Ltd.(2015年7月15日から) |
初版 | 2009年2月26日[3] |
最新版 | 7.2.4 - 2024年1月9日[4] [±] |
リポジトリ | |
プログラミング 言語 | C |
対応OS | クロスプラットフォーム |
対応言語 | 英語 |
サポート状況 | 活動中 |
種別 | データストア |
ライセンス |
7.2までは三条項BSDライセンス。 7.4以降は Redis Source Available License v2 と Server Side Public License v1 のデュアルライセンス。[5] |
公式サイト |
redis |
Redisは、Redis Ltd.が開発している、ネットワーク接続された永続化可能なインメモリデータベース。連想配列(キー・バリュー)、リスト、セットなどのデータ構造を扱える。いわゆるNoSQLデータベースの一つ。バージョン7.2まではオープンソースソフトウェアで、7.4以降はソースアベイラブル・ソフトウェア[6]。
概要
[編集]Redisの名称はREmote DIctionary Serverを意味している[7][8]。
DB-Engines.comの月間ランキングでは、Redisはしばしば最もポピュラーなキー・バリュー型データベースとして評されている[9]。また、Redisは2015年のユーザーレビューによる満足度と市場でのプレゼンスの評価でNoSQLデータベースで4位を[10]、Docker等の各種コンテナ上で使われているNoSQLデータベースとして1位を[11]、さらに上位50デベロッパーツール&サービスにおけるNoSQLデータベースとしても1位を獲得している[12]。
沿革
[編集]- 2009年2月4日、RedisのプロトタイプをSalvatore SanfilippoがTclで実装して、Fabio Pitrolaにメールした。[13]
- 2009年2月26日、Salvatore Sanfilippo(ハンドルネームantirez)がC言語で実装し直して、最初のβ版をリリースした。[3]
- 2010年3月15日、Salvatore SanfilippoがVMwareに入社し、VMwareがスポンサーとなった[14][15][16][8]。
- 2013年5月からは、RedisはVMwareをスピンオフしたPivotal Softwareにスポンサーされるようになった[17]。
- 2013年11月4日、Garantia DataがGarantiaをRedisDBに改名した。この変更は、Redisの開発者であるSalvatore SanfilippoやPivotal Softwareに事前通告はなく、その後Garantiaに戻した。[18]
- 2014年1月29日、Garantia DataがRedis Labsに社名変更した[19]。
- 2015年7月15日、Redisの開発者のSalvatore SanfilippoがRedis Labsに入社し、Redis Labsがスポンサーとなった[20][21][22]。
- 2017年2月7日、Redis Enterpriseを発表。[23]
- 2018年、Salvatore SanfilippoがRedisの知的財産と商標をRedis Labsに譲渡した。[24]
- 2020年6月30日、Redisの開発者のSalvatore SanfilippoがRedis Labsを退職した。[25][26][27]
- 2021年8月11日、Redis LabsはRedis Ltd.に社名変更した[28]。
- 2024年3月20日、バージョン7.4よりBSDライセンスからソースアベイラブルである「Redis Source Available License v2」と「Server Side Public License v1」のデュアルライセンスに変更した[6][29]。その結果、Linux Foundationは「Valkey」という名前でフォークを作成した[30]。これにより、コミュニティのメンテナ、コントリビュータ、ユーザーがRedisデータベースのオープンソース版の開発を継続できるようになった。
リリース
[編集]- 2009年03月 - Redis 1.0がリリース。[31]
- 2010年09月 - Redis 2.0がリリース。[32]
- 2015年04月 - Redis 3.0がリリース。[33]
- 2017年04月 - Redis 4.0がリリース。[34]
- 2017年09月 - Redis EnterpriseがRedis 4.0をサポート開始[35]。
- 2017年11月 - Redis Enterprise 5.0を提供開始[36]。
- 2018年10月 - Redis 5.0がリリース。Redis Streamが導入される[37]。
- 2020年04月 - Redis 6.0がリリース。ACLのサポートを拡大[38]。
- 2020年04月 - Redis Enterprise 6.0を提供開始[39]。
- 2022年04月 - Redis 7.0がリリース。新コマンド、オプションを追加[40]。
対応するプログラミング言語
[編集]以下のような数多くのプログラミング言語からの使用が可能である[41]。
ActionScript, Bash, C, C++, Chicken Scheme, Clojure, Common Lisp, C#, Crystal, D, Dart, Delphi, Deno, Elixir, Emacs Lisp, Erlang, gawk, GNU Prolog, Go, Haskell, Haxe, Io, Java, JavaScript (Node.js), Julia, Lua, Nim, Objective-C, OCaml, Perl, PHP, Pure Data, Python, R,[42] Racket, Ruby, Rust, Scala, Smalltalk, Tcl
データタイプ
[編集]Redisではキーと値を紐づけて保存する。しかしRedisと他の構造型ストレージの重要な違いとして、Redisはバイナリ列(文字列, string)だけでなく以下のようなデータタイプをサポートする。Redis ではバイナリ列のことを string と呼んでいるが、特に文字の使用だけに限った物ではない。
- バイナリ列(string)のリスト(両端キューとして利用可能)
- バイナリ列(string)の集合(ソートされない重複のないコレクション)
- バイナリ列(string)のソートされた集合(浮動小数点数のスコアによりソートされた重複のないコレクション)
- バイナリ列(string)のキーと値からなるハッシュテーブル
- ビットマップ
- 集合の濃度(元の個数)。分布を表現。
値のデータタイプは、各タイプごとに用意された操作(コマンド)で決定される。RedisはINTERSECTIONやUNION、セットやリストの差分抽出といったサーバーサイド操作をアトミックにサポートする。
永続性
[編集]Redisでは一般的に全てのデータはメモリ上に格納される。バージョン2.4よりバーチャルメモリと名付けられたデータをディスク上に格納する機構が使用可能となったが[43]、これは後に非推奨となっている。永続性を実現するための方法としては、3.2現在では2つの手段が用意されている。1つ目はスナップショットと呼ばれるもので、スナップショットではメモリ上のデータは非同期で時折RDBダンプの形式でディスク上に書きこまれる。もう1つの手段が、1.1から存在するAOF (append-only file) と呼ばれるもので、こちらはメモリ上のデータが変更されるごとにトランザクションログが書きこまれる安全な方式となっている。Redisはトランザクションログの肥大化防止のためにバックグラウンドでこれを再生成することができる。
デフォルトでは、Redisは2秒間隔でデータをファイルシステムに書きこむようになっているが、必要であればより安全なオプションを使用することもできる。デフォルト設定でシステムが完全に失敗した場合でも、失われるデータは数秒間分に限られる。
レプリケーション(複製)
[編集]Redisはマスター・レプリカ・レプリケーションをサポートする。Redisサーバーのデータは、複数台のレプリカに複製できます。レプリカは、他のレプリカのマスターになることができます。これにより、Redisは単一ルートのレプリケーションツリーを実装できます。Redisのレプリカには書き込みを許可する設定も可能で、その場合インスタンス間の不整合を許容する形になる。Redisは出版-購読型モデル (Publish/Subscribe) を完全に実装しており、マスターで出版 (Publish) されたメッセージは、レプリカに接続して購読 (Subscribe) しているクライアントにも到達する。レプリケーションは、読込みの拡張性(書込みは除く)とデータの冗長性向上に有効である。[44]
性能
[編集]データの永続性が必要ない場合において、Redisはメモリ上のみで動作することが可能であり、トランザクションのコミットごとにディスクへの書き込みが発生するデータベースと比べて性能的に優位である[7]。Redisの操作はシングルスレッド上のシングルプロセスとして動作する。そのため、1つのRedisインスタンスでは例えばストアドプロシージャのように並列に処理を実行することはできない。
クラスタリング
[編集]Redisプロジェクトはクラスター仕様を持っており[45]、開発者のSanfilippoはRedis clusterの製品版ではキー空間の自動パーティショニングとホットリシャーディングをサポート、ただしシングルキー操作のみに対応、という投稿を行っている[46](β版が2013年末にリリース予定[47])。将来のバージョンでは、1000以上のノードをサポートし、ハートビートと障害検知によりフォールトトレランスを実現、スレーブのマスターへの昇格、全ノードへの出版-購読モデルなどが構想されている[45][48]。
Redis Stack
[編集]Redis に加えて下記の物を加えた物を Redis Stack として配布している[49]。これらのソフトウェアはオープンソースではなく、ソースアベイラブルで配布されている[50]。
- RedisInsight - Redis のデータ内容を見られたりする管理ツール[51]
- RedisJSON - JSONデータベース[52]
- RediSearch - 全文検索、緯度経度検索、ベクトルデータベースによる類似文章検索など[53]
- RedisTimeSeries - 時系列データベース[54]
- RedisBloom - 確率分布の扱い[55]
以下はかつて Redis Stack に含まれていた物。
Redis Stack には含まれていない関連プロジェクトとして以下のものがある。
- RedisGears - Python, Java などの関数を Redis 上で実行する[57]
- RedisAI - 深層学習を Redis 上で実行する。TensorFlow, PyTorch, ONNX Runtime 等に対応。[58]
関連項目
[編集]脚注
[編集]- ^ 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
- ^ a b “Page 7 of 7 - Redis - Google Code Archive - Long-term storage for Google Code Project Hosting.”. code.google.com. 22 March 2024閲覧。
- ^ “Releases”. GitHub. 2023年4月17日閲覧。
- ^ “Redis Licensing Overview | Redis”. Redis. 22 March 2024閲覧。
- ^ a b Trollope, Rowan. “Redis Adopts Dual Source-Available Licensing | Redis”. Redis. 22 March 2024閲覧。
- ^ a b “FAQ, Redis”. 2017年3月16日閲覧。
- ^ a b Redis - AWS、2020年6月10日閲覧
- ^ 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
- ^ LMDB -- First version of Redis written in Tcl
- ^ Gwen Shapira (March 17, 2010). “VMware Hires Redis Key Developer – But Why?”. Blog. September 25, 2016閲覧。
- ^ Salvatore Sanfilippo (March 15, 2010). “VMware: the new Redis home”. Blog. September 25, 2016閲覧。
- ^ Derek Collison (March 15, 2010). “VMware: The Console: VMware hires key developer for Redis”. Blog. March 22, 2010時点のオリジナルよりアーカイブ。September 25, 2016閲覧。
- ^ Salvatore Sanfilippo. “Redis Sponsors”. Redis Labs. September 25, 2016閲覧。
- ^ Kepes, Ben (4 November 2013). “UPDATED - Was Garantia, Is Now RedisDB. Either Way NoSQL Is Hot. But Open Source Firestorm Ensues” (auto). Forbes. 22 March 2024閲覧。
- ^ “Database Provider Garantia Data Makes Another Name Change, This Time To Redis Labs | TechCrunch”. TechCrunch. 22 March 2024閲覧。
- ^ Thanks Pivotal, Hello Redis Labs, July 15, 2015, By Salvatore Sanfilippo, Redis Labs
- ^ “Redis Creator, Salvatore Sanfilippo (Antirez), Joins Redis”. Redis. 22 March 2024閲覧。
- ^ Haber, Itamar. “Salvatore Sanfilippo - Welcome to Redis | Redis”. Redis. 22 March 2024閲覧。
- ^ Gupta, Manish. “Introducing Redis Enterprise | Redis”. Redis. 22 March 2024閲覧。
- ^ “Redis Labs Becomes, Simply, Redis | Redis”. Redis. 22 March 2024閲覧。
- ^ “The end of the Redis adventure - <antirez>”. antirez.com. 22 March 2024閲覧。
- ^ Gottlieb, Yossi. “New Governance for Redis | Redis”. Redis. 22 March 2024閲覧。
- ^ Bengal, Ofer. “Thank You, Salvatore Sanfilippo | Redis”. Redis. 22 March 2024閲覧。
- ^ Kreisman, Dylan. “From Our Founders: Becoming One Redis | Redis”. Redis. 22 March 2024閲覧。
- ^ “LICENSE.txt” (英語). GitHub. 2024年4月28日閲覧。
- ^ “Linux Foundation Launches Open Source Valkey Community”. 2024年4月29日閲覧。
- ^ “Page 6 of 7 - Redis - Google Code Archive - Long-term storage for Google Code Project Hosting.”. code.google.com. 22 March 2024閲覧。
- ^ “Page 4 of 7 - Redis - Google Code Archive - Long-term storage for Google Code Project Hosting.”. code.google.com. 22 March 2024閲覧。
- ^ Redis 3.0 release notes
- ^ Redis 4.0 release notes
- ^ Abutbul, Aviad (2017年9月26日). “Redis 4.0 Now Available on Redis Enterprise”. Redis. 2022年7月23日閲覧。
- ^ B, Cihan (2017年11月27日). “Announcing Redis Enterprise Pack 5.0 GA”. Redis. 2022年7月23日閲覧。
- ^ Redis (2018年10月22日). “Redis 5.0 is here!”. Redis. 2022年7月23日閲覧。
- ^ Redis (2020年4月30日). “Diving Into Redis 6.0”. Redis. 2022年7月23日閲覧。
- ^ Magrafta, Alon (2020年4月30日). “Rediscover Redis Security with Redis Enterprise 6.0”. Redis. 2022年7月23日閲覧。
- ^ Haber, Itamar (2022年4月27日). “Redis 7.0 Is Out!”. Redis. 2022年7月23日閲覧。
- ^ “Clients”. Redis. 19 May 2023閲覧。
- ^ 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.
- ^ “About Redis Stack”. Redis. 19 May 2023閲覧。
- ^ “Redis Licensing Overview | Redis”. Redis. 4 September 2023閲覧。
- ^ “RedisInsight | The Best Redis GUI”. Redis. 21 May 2023閲覧。
- ^ “RedisJSON | NoSQL Document Database”. Redis. 21 May 2023閲覧。
- ^ “RediSearch | Full-Text Search Engine for NoSQL Database”. Redis. 21 May 2023閲覧。
- ^ “RedisTimeSeries | A NoSQL Time Series Database”. Redis. 21 May 2023閲覧。
- ^ “RedisBloom | Bloom & Cuckoo Filtering for Redis”. Redis. 21 May 2023閲覧。
- ^ Kogan, Lior. “RedisGraph End-of-Life Announcement”. Redis. 4 September 2023閲覧。
- ^ “RedisGears | Python Scripting in Redis”. Redis. 21 May 2023閲覧。
- ^ “RedisAI - A Server for Machine and Deep Learning Models”. oss.redis.com. 4 September 2023閲覧。