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
ISUCONボツ技かるた / ISUCON Reject Karuta
Search
Hiroki Tanaka
January 18, 2020
Programming
120
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
ISUCONボツ技かるた / ISUCON Reject Karuta
Hiroki Tanaka
January 18, 2020
More Decks by Hiroki Tanaka
See All by Hiroki Tanaka
DockerCIビルドを一歩先へ Buildkitを運用前提で試食してみた / Docker ci with buildkit
dabits
0
200
U30エンジニアだからこそ実現できた劇的ビフォーアフター #bcu30
dabits
1
4.6k
Other Decks in Programming
See All in Programming
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
200
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.2k
The Arts and Crafts of Work in the AI Era — Toward Mastery in Software Development
kuranuki
1
730
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
250
The NotImplementedError Problem in Ruby
koic
1
660
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
130
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
380
Oxlintのカスタムルールの現況
syumai
6
1k
Vite+ Unified Toolchain for the Web
naokihaba
0
170
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
240
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
520
New "Type" system on PicoRuby
pocke
1
730
Featured
See All Featured
A designer walks into a library…
pauljervisheath
211
24k
Between Models and Reality
mayunak
4
330
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
410
Principles of Awesome APIs and How to Build Them.
keavy
128
17k
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
150
Deep Space Network (abreviated)
tonyrice
0
170
Pawsitive SEO: Lessons from My Dog (and Many Mistakes) on Thriving as a Consultant in the Age of AI
davidcarrasco
0
160
Fireside Chat
paigeccino
42
3.9k
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
200
Leading Effective Engineering Teams in the AI Era
addyosmani
9
2k
How to Build an AI Search Optimization Roadmap - Criteria and Steps to Take #SEOIRL
aleyda
1
2.1k
Transcript
ISUCON ボツ技 かるた 2020/01/18 @dabits
ISUCON、ご存知ですか?
ISUCONとは • Iikanji Speed Up CONtest = ISUCON • 3人1組8時間で行うサーバサイドチューニングコ
ンテスト • LINE社が毎年主催、賞金100万円 • 問題作成は毎年持ち回り ◦ ‘19 さくらインターネット & mercari ◦ ‘18 DeNA
ISUCONの楽しさ • スコアランキングがリアルタイムに出る • 割と本当の業務に直結する改善課題が多い • 何気にチームワークが一番大事
ISUCONのボツ技とは • ISUCON本戦もしくは本番環境では絶対に使えな いチューニング手法 • 本戦前の個人練習戦で編み出したり、人から聞 いたり。。。!
年始なので 「い」「す」「こ」「ん」の かるたにして紹介します
ISUCONの「い」
いえないような パスワード 暗号強度 い 6d8bc1284964660372e0 b7f84d9053cb40b50b39 ↓ aG9nZWZ1Z2FwaXlvCg==
いえないようなパスワード暗号強度 • DBに保存するパスワードを極力簡単な暗号化方式にすること でCPUリソースを確保する技 • 問題によってはログイン試行回数が多く、SHA1など暗号化処 理でCPUを大量消費する • まぎれもなく本番環境ではそんなことしてはいけない、本戦で も場合によっては失格に
ISUCONの「す」
すべて /dev/shm す /var/lib/mysql /dev/shm
すべて/dev/shm • I/Oが発生するものをすべて/dev/shmに入れる技 • /var/lib/mysqlを/dev/shmに突っ込むと実質オンメモリに!? • スコアが低い割に再起動すると吹っ飛ぶのでボツ
ISUCONの「こ」
このデータ 整合性 ないけどいいや こ
このデータ整合性ないけどいいや • 3台のサーバを自由に使っていい問題の場合、すべてのサー バで捌く代わりにデータ同期を取らない技 • ベンチマーカーの作りが甘い場合、1セッションをすべて1サー バで捌くことがあり、ベンチがNGにならない • 本番環境を前提にした場合、LBで確実にuidごとに分岐でき ればいいが、そもDBシャーディングなどのほうが良い
ISUCONの「ん」
んんん、ここは 流入制限で sleep1 ! ん
んんん、ここは流入制限でsleep 1! • 頻繁にajaxされるページに対してsleep 1を入れることにより、 1ユーザあたりのリクエスト数を減らしてCPUリソースを確保す る技 • ISUCONではルール上JSの書き換えが禁止されているため、 ポーリングの回数を減らすためにこの手法が度々使われる
• ISUCONでは容認されるが本番環境ではそもそもポーリング の頻度をクライアントプログラム側で減らすべき
興味を持ったら 過去問題やってみましょ! https://github.com/isucon
ありがとうございました