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
140
小さく始める自作入門!~RedisっぽいKVSを作って学んだこと~
TechBull LT&交流会 #3
yamaken_0216
November 12, 2025
Tweet
Share
Other Decks in Programming
See All in Programming
開発者から情シスまで - 多様なユーザー層に届けるAPI提供戦略 / Postman API Night Okinawa 2026 Winter
tasshi
0
210
AI時代のキャリアプラン「技術の引力」からの脱出と「問い」へのいざない / tech-gravity
minodriven
21
7.4k
Honoを使ったリモートMCPサーバでAIツールとの連携を加速させる!
tosuri13
1
180
そのAIレビュー、レビューしてますか? / Are you reviewing those AI reviews?
rkaga
6
4.6k
Lambda のコードストレージ容量に気をつけましょう
tattwan718
0
150
なぜSQLはAIぽく見えるのか/why does SQL look AI like
florets1
0
480
Vibe Coding - AI 驅動的軟體開發
mickyp100
0
180
MDN Web Docs に日本語翻訳でコントリビュート
ohmori_yusuke
0
660
Apache Iceberg V3 and migration to V3
tomtanaka
0
180
Metaprogramming isn't real, it can't hurt you
okuramasafumi
0
100
今から始めるClaude Code超入門
448jp
8
9.1k
CSC307 Lecture 06
javiergs
PRO
0
690
Featured
See All Featured
Six Lessons from altMBA
skipperchong
29
4.2k
Jamie Indigo - Trashchat’s Guide to Black Boxes: Technical SEO Tactics for LLMs
techseoconnect
PRO
0
66
Design in an AI World
tapps
0
150
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
320
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Statistics for Hackers
jakevdp
799
230k
We Have a Design System, Now What?
morganepeng
54
8k
Believing is Seeing
oripsolob
1
59
Designing for Performance
lara
610
70k
Optimizing for Happiness
mojombo
379
71k
A Soul's Torment
seathinner
5
2.3k
So, you think you're a good person
axbom
PRO
2
1.9k
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!