MySQL 5.6での機能強化点(その2) - NoSQL APIとパフォーマンス・スキーマ
MySQL 5.6での機能強化点
前回の記事ではMySQL 5.6での主要な機能強化点として、InnoDBとオプティマイザの改善点について紹介しました。今回はNoSQL APIとパフォーマンス・スキーマについて紹介します。
NoSQL API(InnoDB memcached plugin)
MySQL 5.6では、新たな試みとしてNoSQLのインターフェースを追加しています。InnoDB上のデータにSQLを使わずにアクセスすることも可能になり、SQLを使うよりも高速に処理可能です。NoSQLのインターフェースには、オープンソースの分散キャッシュであるmemcachedを活用し、memcachedをMySQLサーバーのプラグインとして動作できるようにしています。
memcachedはLiveJournalというブログサイトのために開発されたキャッシュの仕組みで、現在では多数のWebサイトでMySQLと組み合わせて利用されています。一般的には、MySQLとmemcachedを組み合わせる場合、データの取得時にアプリケーションは先ずmemcachedに対してアクセスして対象のデータがキャッシュされているかを確認します。対象データがキャッシュされていれば処理は完了しますが、データがキャッシュされていなかった場合は、MySQLにアクセスし直して必要なデータを取り出す必要があります。また、データの更新時にデータを永続化するためには、memcached上のデータだけではなくMySQL上のデータも合わせて更新する処理を、なんらかの形で実装する必要があります。
InnoDBのmemcachedプラグインを使用した場合は、memcachedプロトコル経由でデータを追加更新した際に自動的にInnoDB上にデータを永続化できます。また、処理のスピードも、SQLレイヤーをバイパスできる分高速になります。以下のグラフは、単純なデータの追加処理をSQLのINSERTコマンドを使った場合とmemcachedプロトコルのSETコマンドを使った場合のTPSの比較ですが、memcached経由の方が9倍多く処理できています。
同一のデータに対して、SQLとmemcachedによるアクセスが可能なため、キーバリュー型のシンプルなアクセスでいい場合はmemcachedを使って処理を高速化し、JOINなどの複雑な操作が必要な場合はSQLを使う、といったSQLとNoSQLの両方の利点をいかしたハイブリッドな使い方が可能になっています。
また、事前にinnodb_memcache.containersテーブルにInnoDB上のテーブルに対するマッピング情報を定義しておくことで、memcachedプロトコル経由であっても任意の各テーブルにアクセスできます。更に、memcachedによるデータの変更もバイナリログに記録されるため、レプリケーションと組み合わせて使うことも可能です。
InnoDBのmemcachedプラグインの詳細については、こちらを参照下さい。
連載バックナンバー
Think ITメルマガ会員登録受付中
全文検索エンジンによるおすすめ記事
- performance_schemaをsysで使い倒す!
- MySQL5.6- さらなる機能追加とNoSQL
- MySQL 5.6での機能強化点(その1)- パフォーマンスと使い勝手を大きく向上
- DBドキュメント出力とMEBのためのGUI、次期版6.1の新機能を紹介
- 再現性のあるスロークエリーには「SHOW PROFILE」を試してみよう
- NoSQL&RDBMSクラスタ MySQL Cluster
- MySQL 5.6での機能強化点(その3)- 人気のレプリケーションが更に機能強化
- MySQL5.5- 性能改善と可用性向上
- MySQLのチューニングを戦う方へ
- オラクル、「MySQL 5.7 Development Milestone Release(DMR)」をリリース