コンテンツへスキップ →

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

無料メルマガ<特典付き>

個人開発・ビジネスについての有益な情報を無料メルマガでお届けします。

特典:個人開発の教科書<心得編>
これまでの個人開発経験を秘伝のタレ的な内容としてエッセンスをまとめました。35ページにわたる大ボリュームです。

個人開発のスキルアップにMENTA

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

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

YouTubeでも個人開発ノウハウを発信中!

PROFILE

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

カテゴリー: 開発奮闘記