Redis

Redis
作者 Salvatore Sanfilippo(2020年6月30日まで)[1][2]
開発元 Redis Ltd.(2015年7月15日から)
初版 2009年2月26日 (15年前) (2009-02-26)[3]
最新版 7.2.4 - 2024年1月9日 (3か月前) (2024-01-09)[4] [±]
リポジトリ ウィキデータを編集
プログラミング
言語
C
対応OS クロスプラットフォーム
対応言語 英語
サポート状況 活動中
種別 データストア
ライセンス 7.2までは三条項BSDライセンス
7.4以降は Redis Source Available License v2 と Server Side Public License v1 のデュアルライセンス。[5]
公式サイト redis.io ウィキデータを編集
テンプレートを表示

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はINTERSECTIONUNION、セットやリストの差分抽出といったサーバーサイド操作をアトミックにサポートする。

永続性[編集]

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 に含まれていた物。

  • RedisGraph - グラフデータベース。Cypherをクエリ言語として採用している。2023年7月5日にサポート終了が発表された。[56]

Redis Stack には含まれていない関連プロジェクトとして以下のものがある。

関連項目[編集]

脚注[編集]

  1. ^ An interview with Salvatore Sanfilippo, creator of Redis, working out of Sicily, January 4, 2011, by Stefano Bernardi, EU-Startups
  2. ^ Salvatore Sanfilippo – Welcome to Redis Labs, July 15, 2015, By Itamar Haber, Redis Labs
  3. ^ a b Page 7 of 7 - Redis - Google Code Archive - Long-term storage for Google Code Project Hosting.”. code.google.com. 2024年3月22日閲覧。
  4. ^ Releases”. GitHub. 2023年4月17日閲覧。
  5. ^ Redis Licensing Overview | Redis”. Redis. 2024年3月22日閲覧。
  6. ^ a b Trollope, Rowan. “Redis Adopts Dual Source-Available Licensing | Redis”. Redis. 2024年3月22日閲覧。
  7. ^ a b FAQ, Redis”. 2017年3月16日閲覧。
  8. ^ a b Redis - AWS、2020年6月10日閲覧
  9. ^ DB-Engines Ranking of Key-value Stores
  10. ^ Best NoSQL Databases: Fall 2015 Report from G2 Crowd
  11. ^ The Current State of Container Usage
  12. ^ Top 50 Developer Tools and Services of 2015
  13. ^ LMDB -- First version of Redis written in Tcl
  14. ^ Gwen Shapira (2010年3月17日). “VMware Hires Redis Key Developer – But Why?”. Blog. 2016年9月25日閲覧。
  15. ^ Salvatore Sanfilippo (2010年3月15日). “VMware: the new Redis home”. Blog. 2016年9月25日閲覧。
  16. ^ Derek Collison (2010年3月15日). “VMware: The Console: VMware hires key developer for Redis”. Blog. 2010年3月22日時点のオリジナルよりアーカイブ。2016年9月25日閲覧。
  17. ^ Salvatore Sanfilippo. “Redis Sponsors”. Redis Labs. 2016年9月25日閲覧。
  18. ^ Kepes, Ben (2013年11月4日). “UPDATED - Was Garantia, Is Now RedisDB. Either Way NoSQL Is Hot. But Open Source Firestorm Ensues” (auto). Forbes. 2024年3月22日閲覧。
  19. ^ Database Provider Garantia Data Makes Another Name Change, This Time To Redis Labs | TechCrunch”. TechCrunch. 2024年3月22日閲覧。
  20. ^ Thanks Pivotal, Hello Redis Labs, July 15, 2015, By Salvatore Sanfilippo, Redis Labs
  21. ^ Redis Creator, Salvatore Sanfilippo (Antirez), Joins Redis”. Redis. 2024年3月22日閲覧。
  22. ^ Haber, Itamar. “Salvatore Sanfilippo - Welcome to Redis | Redis”. Redis. 2024年3月22日閲覧。
  23. ^ Gupta, Manish. “Introducing Redis Enterprise | Redis”. Redis. 2024年3月22日閲覧。
  24. ^ Redis Labs Becomes, Simply, Redis | Redis”. Redis. 2024年3月22日閲覧。
  25. ^ The end of the Redis adventure - <antirez>”. antirez.com. 2024年3月22日閲覧。
  26. ^ Gottlieb, Yossi. “New Governance for Redis | Redis”. Redis. 2024年3月22日閲覧。
  27. ^ Bengal, Ofer. “Thank You, Salvatore Sanfilippo | Redis”. Redis. 2024年3月22日閲覧。
  28. ^ Kreisman, Dylan. “From Our Founders: Becoming One Redis | Redis”. Redis. 2024年3月22日閲覧。
  29. ^ LICENSE.txt” (英語). GitHub. 2024年4月28日閲覧。
  30. ^ Linux Foundation Launches Open Source Valkey Community”. 2024年4月29日閲覧。
  31. ^ Page 6 of 7 - Redis - Google Code Archive - Long-term storage for Google Code Project Hosting.”. code.google.com. 2024年3月22日閲覧。
  32. ^ Page 4 of 7 - Redis - Google Code Archive - Long-term storage for Google Code Project Hosting.”. code.google.com. 2024年3月22日閲覧。
  33. ^ Redis 3.0 release notes
  34. ^ Redis 4.0 release notes
  35. ^ Abutbul, Aviad (2017年9月26日). “Redis 4.0 Now Available on Redis Enterprise”. Redis. 2022年7月23日閲覧。
  36. ^ B, Cihan (2017年11月27日). “Announcing Redis Enterprise Pack 5.0 GA”. Redis. 2022年7月23日閲覧。
  37. ^ Redis (2018年10月22日). “Redis 5.0 is here!”. Redis. 2022年7月23日閲覧。
  38. ^ Redis (2020年4月30日). “Diving Into Redis 6.0”. Redis. 2022年7月23日閲覧。
  39. ^ Magrafta, Alon (2020年4月30日). “Rediscover Redis Security with Redis Enterprise 6.0”. Redis. 2022年7月23日閲覧。
  40. ^ Haber, Itamar (2022年4月27日). “Redis 7.0 Is Out!”. Redis. 2022年7月23日閲覧。
  41. ^ Clients”. Redis. 2023年5月19日閲覧。
  42. ^ CRAN – Package rredis
  43. ^ Redis documentation "Virtual Memory", redis.io, accessed January 18, 2011.
  44. ^ ReplicationHowto – redis – A persistent key-value database with built-in net interface written in ANSI-C for Posix systems – Google Project Hosting
  45. ^ a b Redis Cluster Specification, Redis.io, Retrieved 2013-12-25.
  46. ^ News about Redis: 2.8 is shaping, I'm back on Cluster, Antirez Weblog - Salvatore Sanfilippo, Retrieved 2013-12-25.
  47. ^ Redis Download Page, Redis.io, Retrieved 2013-12-25.
  48. ^ Redis Cluster - a Pragmatic Approach to Distribution, Redis.io, Retrieved 2013-12-25.
  49. ^ About Redis Stack”. Redis. 2023年5月19日閲覧。
  50. ^ Redis Licensing Overview | Redis”. Redis. 2023年9月4日閲覧。
  51. ^ RedisInsight | The Best Redis GUI”. Redis. 2023年5月21日閲覧。
  52. ^ RedisJSON | NoSQL Document Database”. Redis. 2023年5月21日閲覧。
  53. ^ RediSearch | Full-Text Search Engine for NoSQL Database”. Redis. 2023年5月21日閲覧。
  54. ^ RedisTimeSeries | A NoSQL Time Series Database”. Redis. 2023年5月21日閲覧。
  55. ^ RedisBloom | Bloom & Cuckoo Filtering for Redis”. Redis. 2023年5月21日閲覧。
  56. ^ Kogan, Lior. “RedisGraph End-of-Life Announcement”. Redis. 2023年9月4日閲覧。
  57. ^ RedisGears | Python Scripting in Redis”. Redis. 2023年5月21日閲覧。
  58. ^ RedisAI - A Server for Machine and Deep Learning Models”. oss.redis.com. 2023年9月4日閲覧。

外部リンク[編集]