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
【Ottertune】MLでDBを最適化するツールの紹介
Search
Hank Ehly
August 25, 2022
Technology
1
740
【Ottertune】MLでDBを最適化するツールの紹介
Hank Ehly
August 25, 2022
Tweet
Share
More Decks by Hank Ehly
See All by Hank Ehly
Fivetranでデータ移動を自動化する
hankehly
0
270
Celeryの紹介と本番運用のTips
hankehly
0
120
ChatGPTを活用した 便利ツールの紹介
hankehly
1
950
Efficient Energy Analytics with Airflow, Spark, and MLFlow
hankehly
0
150
Deferrable Operators入門
hankehly
0
200
【初心者/ハンズオン】Dockerコンテナの基礎知識
hankehly
0
250
Compositeパターン: オブジェクトの階層関係をエレガントに表現する方法
hankehly
0
140
10/29 Airflowの基礎を学ぶハンズオンワークショップ
hankehly
0
130
システム/データ品質保証のための Airflow 活用法
hankehly
0
430
Other Decks in Technology
See All in Technology
データマネジメントを支える武器としてのメタデータ管理
10xinc
2
1k
Getting started with controlling LEGO using Swift
hcrane
0
140
オーティファイ会社紹介資料 / Autify Company Deck
autifyhq
7
100k
中学生でもわかる深層学習
e869120
14
4.6k
LLM + RAG を使った SORACOM Support Bot の裏側の歴史
soracom
PRO
1
650
技術広報経験0のEMがエンジニアブランディングをはじめてみた
coconala_engineer
1
140
エンジニアブランディングチームの KPI / KPI's of engineer branding team
chaspy
1
140
初心者が行く!サーバレスWebアプリ開発の道
nagaharutogawa
0
460
GraphQLに入門してみた
chiroruxx
2
130
20240321_生成AI時代のDevOps
kzkmaeda
2
620
やっていきテスト
k6s4i53rx
0
160
生成AI・LLM時代における 機械学習エンジニアとしてのキャリア戦略・開発戦略 / my-career-and-development-strategies-for-ml-engineer-2024
yuya4
4
970
Featured
See All Featured
Fashionably flexible responsive web design (full day workshop)
malarkey
397
65k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
18
6.8k
Why You Should Never Use an ORM
jnunemaker
PRO
50
8.6k
Embracing the Ebb and Flow
colly
78
4.1k
The Illustrated Children's Guide to Kubernetes
chrisshort
28
46k
Docker and Python
trallard
33
2.6k
Writing Fast Ruby
sferik
619
59k
Building Adaptive Systems
keathley
29
1.8k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
240
1.2M
We Have a Design System, Now What?
morganepeng
42
6.7k
Web development in the modern age
philhawksworth
201
10k
JazzCon 2018 Closing Keynote - Leadership for the Reluctant Leader
reverentgeek
178
11k
Transcript
【Ottertune】MLでDBを最適化する ツールの紹介
自己紹介 • Hank Ehly (ハンク イーリー) • ENECHANGE株式会社 • qiita.com/hankehly
• github.com/hankehly • connpass.com/user/hankehly
アジェンダ 1. DBチューニングの問題点 2. OtterTuneとは 3. 営業とのQ&A
AWS RDSとは • マネージド PostgreSQL、MySQL、... • バージョン更新 / バックアップ等 自動化される
• デフォルトパラメータ • DBの使われ方に最適化されていない
DBチューニングの問題点 • RDBの費用を抑えて性能を最適化したいよね? (A) PostgreSQLの内部の専門的な知識 (B) 試行錯誤でパラメータ変更を繰り返し、最適化されるまで、パフォーマンスへの 影響を検証する時間 (私はどちらも持っていない) •
本来より高いクラウドコストを支払っていて、低いパフォーマンスしか出せていない
OtterTuneとは AWS の RDS と連携し、PostgreSQL と MySQL の設定項目を機械学習で最適化する SaaS プロダクト
1. 接続 • OtterTuneアカウント作成 • Agentをデプロイする 2. メトリック取得 • DB のハードウェア、パラメータ、メトリクス情報を 定期的に取得する • データやクエリーを見ない 3. 最適化 • ユーザーが設定した目標に向けて、 DB の設定を機械学習で最適化していく
①今この設定だよ ②多分これに変えたら パフォーマンス上がるよ ③どうする?
営業とのQ&A 1. どんな情報を取得するか • 数値、カウンター、レイテンシー情報 • PostgreSQL Statistics Collector •
CloudWatchメトリック(CPU使用率など) • クエリーの内容/スキーマは取得されません 2. RDSとどう接続するか • Agentをデプロイする(Fargate) • 公式 CloudFormation / Terraform
module "ottertune-iam" { source = "ottertune/ottertune-iam/aws" version = "0.0.6" external_id
= "***" } (Terraform)
営業とのQ&A 3. 設定変更によるダウンタイムはあるか • 設定変更によるダウンタイムは今まで発生したことがないそうです • 変更すると再起動が必要な設定はあるけど、事前に分かるもののみ 4. 日本語対応(ダッシュボード /
サポート等) ない 5. 設定変更は自動なのか、人がやるのか • どちらも対応している • 完全に自動化できる • 人間が変更内容を見てボタンクリックで適用することもできる(human in the loop と呼ぶ)
営業とのQ&A 6. 設定変更はどの頻度で行われるか • 調整できるけど、24時間に1回が推奨される • 大体20回目のイテレーションで、パフォーマンスチューニングがMAXに到達する
営業とのQ&A 7. どのくらいのパフォーマンス向上が期待できるか ワークロードによるけど、デフォルトの RDS 設定を使っている場合 5% 〜 15% は期待
できる
営業とのQ&A 8. PostgreSQL のバージョン変更したらどうなるか • 何もなかったように、新しいメトリック/設定項目を考慮範囲に含められるだけ • OtterTuneのサービスが途切れることはない 9. 設定変更によってパフォーマンスが下がったことはあるか?
• あるけど、最初の方だけで、ノイズに近い • 継続的な設定調整でパフォーマンスがだんだん悪くなることはない 10. でもお高いでしょ? • 1 db = $0 • 〜5 db = $450/月 • https://ottertune.com/pricing 11. 検証環境で学習させて本番環境に適用することは? • 環境によってワークロードが違うので、検証環境で学習させて、本番環境に変更を展開することはあまり意味がない
営業とのQ&A 12. どのDBがサポートされるか
13. どのパラメータを調整するか • autovacuum_vacuum_cost_delay • autovacuum_vacuum_cost_limit • autovacuum_vacuum_scale_factor • autovacuum_vacuum_threshold
• bgwriter_delay • bgwriter_lru_maxpages • bgwriter_lru_multiplier • checkpoint_completion_target • 等々 営業とのQ&A
ご清聴ありがとうございます