Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
小さく始める自作入門!~RedisっぽいKVSを作って学んだこと~
Search
yamaken_0216
November 12, 2025
Programming
0
150
小さく始める自作入門!~RedisっぽいKVSを作って学んだこと~
TechBull LT&交流会 #3
yamaken_0216
November 12, 2025
Tweet
Share
Other Decks in Programming
See All in Programming
nilとは何か 〜interfaceの構造とnil!=nilから理解する〜
kuro_kurorrr
3
1.8k
Agent Skills Workshop - AIへの頼み方を仕組み化する
gotalab555
15
8.2k
Geminiの機能を調べ尽くしてみた
naruyoshimi
0
200
株式会社 Sun terras カンパニーデック
sunterras
0
2k
20260228_JAWS_Beginner_Kansai
takuyay0ne
5
460
文字コードの話
qnighy
44
17k
LangChain4jとは一味違うLangChain4j-CDI
kazumura
1
160
モジュラモノリスにおける境界をGoのinternalパッケージで守る
magavel
0
3.5k
朝日新聞のデジタル版を支えるGoバックエンド ー価値ある情報をいち早く確実にお届けするために
junkiishida
1
660
The Past, Present, and Future of Enterprise Java
ivargrimstad
0
430
Go Conference mini in Sendai 2026 : Goに新機能を提案し実装されるまでのフロー徹底解説
yamatoya
0
540
今更考える「単一責任原則」 / Thinking about the Single Responsibility Principle
tooppoo
3
1.6k
Featured
See All Featured
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
60
42k
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
The Cost Of JavaScript in 2023
addyosmani
55
9.8k
Done Done
chrislema
186
16k
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
140
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Context Engineering - Making Every Token Count
addyosmani
9
740
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
150
Code Review Best Practice
trishagee
74
20k
16th Malabo Montpellier Forum Presentation
akademiya2063
PRO
0
64
Designing for Performance
lara
611
70k
Principles of Awesome APIs and How to Build Them.
keavy
128
17k
Transcript
小さく始める 自作入門! ~RedisっぽいKVSを作って学んだこと~
やまけん Profile SaaS企業でバックエンドエンジニアをしています。 最近、TechBullの運営になりました。 趣味 サッカー観戦、旅行、Podcast聴くこと 少し前に群馬で滝行体験ツアーにいきました。 yamaken_0216
何か自作してみたいな〜。 って思う時期ありますよね。
Key-Value Store作ってみよう!
なぜ、Key-Value Storeを選んだのか 身近なミドルウェアで仕様が明確 使い方を理解しており、動作イメージが掴みやすい 最小構成が数十行で完成 小さく始めて段階的に機能追加できる 参考となるOSSがある Redis, Valkey, Memcachedなどのコードを参考にできる
(今回はRedisを参考にしました。 )
Redisの説明 正式名称 : REmote DIctionary Server インメモリKVS RESP ( REdis
Serialization Protocol)で通信 データ構造 String, List, Set, Hash, Sorted Set... その他の機能 永続化、 Pub/Sub、 トランザクション...
redis-cli (Client) redis-server ユーザー Redis の説明 コマンド入力 入力されたコマンドを RESPにシリアライズする Responseされた
RESPをデシリアライズする RequestされたRESPを 解析して、処理する Request Response 結果を返す
redis-cli (Client) redis-server ユーザー Redis の説明 コマンド入力 入力されたコマンドを RESPにシリアライズする Responseされた
RESPをデシリアライズする RequestされたRESPを 解析して、処理する Request Response 結果を返す 今回自作するところ
どう作っていくのか。 コアはシンプルなので簡単な流れだけ紹介!
どう作っていくのか。 1. 基本的なRESPを理解する 2. TCPサーバーとPINGコマンドを作る 3. SET,GETコマンドを実装する 4. 好きなように拡張しよう
どう作っていくのか。 1. 基本的なRESPを理解する 2. TCPサーバーとPINGコマンドを作る 3. SET,GETコマンドを実装する 4. 好きなように拡張しよう
1 . 基本的なRESPを理解する RESPとは、Redis Serialization Protocolのこと Redisクライアントとサーバーが通信するためのテキスト ベースのプロトコル RESP2とRESP3がある この段階では、基本的なプロトコルのRESP2を使う
1 . 基本的なRESPを理解する 出典: Redis 公式ドキュメント https://redis.io/docs/latest/develop/reference/protocol-spec/
どう作っていくのか。 1. 基本的なRESPを理解する 2. TCPサーバーとPINGコマンドを作る 3. SET,GETコマンドを実装する 4. 好きなように拡張しよう
2.TCPサーバーとPINGコマンドを作る TCPサーバーを作る 好きな言語 標準ライブラリで提供されているものを使うと簡単! 簡易的なPINGコマンドを作る PINGというコマンドがリクエストされたらPONGと返す
どう作っていくのか。 1. 基本的なRESPを理解する 2. TCPサーバーとPINGコマンドを作る 3. SET,GETコマンドを実装する 4. 好きなように拡張しよう
3.SET,GETコマンドを実装する SETコマンドを実装する リクエスト SET key名 value名 ハッシュ(連想配列)に保存する レスポンス OKを返す
3.SET,GETコマンドを実装する GETコマンドを実装する リクエスト GET key名 ハッシュ(連想配列)からkey名の値を取得する レスポンス 取得した値を返す これで、最小構成でインメモリKVSは完成
どう作っていくのか。 1. 基本的なRESPを理解する 2. TCPサーバーとPINGコマンドを作る 3. SET,GETコマンドを実装する 4. 好きなように拡張しよう
4.好きなように拡張しよう 拡張する機能候補 TTL機能の追加 型の追加( String , List, Set, Hash, Sorted
Set...) データの永続化 ...
自作時に参考になったもの 公式ドキュメント 今回はRedisのドキュメントを参考になった GitHub 自作KVSしてる人のコードもあるので参考になる LLM コードリーディングや仕様の壁打ちに使った
まとめ 公式ドキュメントを読もう 最小構成でどう作るかが大事 LLMを使って理解をする 興味を持った方、ぜひ一緒に自作しましょう!
Thank you!