コンテンツへスキップ →

MySQLのmy.cnf設定最適化メモ

Webエンジニアのためのデータベース技術[実践]入門であらためてデータベースを学びなおしているところです。負荷が少ないサービスだと、そのままの設定でも動きますが、利用者が膨大に増えた場合はそうもいっていられません。今回はその中のMySQL設定ファイルmy.cnfについて。

my.cnfの設定

log-binバイナリログを有効にするためのパラメータ。バイナリログには実行されたSQL文が記録されている。データが壊れた場合、バックアップした時間からしか復旧できないが、バイナリログがあればその間も補填できる。
slow-query-log実行に時間がかかったSQL文を記録。改善に役立つ。デフォルトは10秒。
max_connections同時接続最大人数。デフォルトは100。
innodb_buffer_pool_sizeメモリ上で管理するためのバッファサイズ。物理メモリの60%〜80%が望ましい。
innodb_flush_methodInnoDBデータファイル、InooDBログファイルの読み書き方式。O_DIRECTだとダイレクトなのでオーバーヘッドを減らせる。

このあたりがパフォーマンスに直結する重要設定。log-binやslow-queryはデフォルトではOFFになっています。

[sc name=”engeneer”]

SHARE

スキルアップにMENTA

MENTAはいろんなプロに相談できるNo1メンターサービスです。

僕自身もプロダクトの壁打ち・相談にのっています。個人開発でもコードレビュー、セキュリティ面のチェック、デザイン、広告、コンテンツマーケ、SNS集客について相談する、など使えます。

YouTubeでも発信中!

PROFILE

入江 慎吾
あらゆるスキルが学べるパーソナルメンターサービスMENTAの代表/個人開発が好きでこれまでに30個ほどのWEBサービスやアプリを作ってきました/福岡のWEB制作会社勤務→フリーランスエンジニア→法人立ち上げ→M&A億単位の売却を経験。 (詳しいプロフィール)

カテゴリー: 開発奮闘記