SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

連載記事

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

CodeZine BOOKS(コードジン・ブックス)は、CodeZineの連載からカットアップした、開発現場の課題解決に役立つ書籍シリーズです。

書籍に関する記事を見る

'); googletag.cmd.push(function() { googletag.pubads().addEventListener('slotRenderEnded', function(e) { var ad_id = e.slot.getSlotElementId(); if (ad_id == 'div-gpt-ad-1659428980688-0') { var ad = $('#'+ad_id).find('iframe'); if ($(ad).width() == 728) { var ww = $(window).width(); ww = ww*0.90; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/728+","+ww/728+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/728+","+ww/728+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/728+","+ww/728+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/728+","+ww/728+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(90*ww/728)+"px;width:"+728+"px;}", 0 ); } else { if ($(window).width() < 340) { var ww = $(window).width(); ww = ww*0.875; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/320+","+ww/320+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/320+","+ww/320+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/320+","+ww/320+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/320+","+ww/320+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(180*ww/320)+"px;width:"+320+"px;}", 0 ); } } } }); }); } else { document.write('
'); document.write('
'); }
イベントレポート

MySQLハックの最前線が垣間見えた
「DeNA Technology Seminar #2」


  • X ポスト
  • このエントリーをはてなブックマークに追加

 ディー・エヌ・エーは29日、技術セミナー「DeNA Technology Seminar #2」を開催した。ソーシャルプラットフォームの裏側にフォーカスして3 月に開催されたセミナーに続き、2回目の開催となる。今回のテーマは「MySQL」。社外の講師も交え、モバゲータウンの膨大なトラフィックを支えるディー・エヌ・エーならではの実践的なチューニングネタ、ハックネタが紹介された。

  • X ポスト
  • このエントリーをはてなブックマークに追加

 ディー・エヌ・エーは29日、技術セミナー「DeNA Technology Seminar #2」を開催した。ソーシャルプラットフォームの裏側にフォーカスして3月に開催されたセミナーに続き、2回目の開催となる。今回のテーマは「MySQL」。社外の講師も交え、モバゲータウンの膨大なトラフィックを支えるディー・エヌ・エーならではの実践的なチューニングネタ、ハックネタが紹介された。

アプリに変更を加えずにDBの分散管理を実現する
「Spiderストレージエンジン」

 MySQLの特徴の一つに、「ストレージエンジン」(SQLパーサーと分離されたデータ管理部分の実装)を自由に選べることがある。斯波健徳氏はその実装の一つ、「Spiderストレージエンジン」について紹介した。

 Spiderストレージエンジンは、大規模データベースを細かく分散管理する「Database Sharding」を可能にするストレージエンジン。複数のデータベースサーバーに分散したテーブルを束ね、1つのテーブルとして利用できるようにし、トランザクションもサポートする。アプリケーションの変更が不要なため、導入も容易。

 導入事例として、動画検索サイトの「sagool.tv」や、角川グループのコンテンツを横断検索できるサービス「KADOKAWord.jp」、行動ターゲティング広告配信技術の「マイクロアド」を紹介した。いずれもレコード数やトラフィックの増加に伴うデータベース参照性能の低下を改善させた例だ。

 今後の予定については、MySQLのフォークの一つである「MariaDB」へのバンドル、MariaDB 5.3で利用可能なBKA(テーブルのJOINを高速化する機能)への対応、レプリケーションのエラー発生時にリトライを行うパッチなどを挙げた。

SQLをショートカットして
パフォーマンスを向上させるプラグイン

 株式会社ディー・エヌ・エー システム統括本部 IT基盤部の樋口証氏は、非SQL処理でMySQLのパフォーマンス最適化を行うプラグイン「MySQL handlersocket plugin」を紹介した。MySQLサーバーのSQLパーサーを介さずに、独自プロトコルでストレージエンジンを直接たたくことで、単純なCRUD処理の高速実行を実現するもので、クライアントライブラリはC++とPerlの2つが用意されている。

 単純な参照クエリでの検証では、数倍~10倍程度の差が出たという。高速化の要因としては、「SQLパース処理をしていないこと」「リクエストを集約実行していること」「独自プロトコルで通信すること」の3点を挙げた。中でも独自プロトコルについては、もともとの結果セットのメタデータが大きいため、想定より効果があったと述べている。

 今後の課題としては、ビルド時にmysqlのソースコードが必要なため導入が多少面倒なこと、バージョンやビルドオプションの違いによる互換性の問題、InnoDB以外での検証、部分的なread-modify-write操作のサポート、クライアントライブラリの整備などを挙げた。

 テスト運用中のため一般公開はしていないが、今後BSDライセンスでの公開を予定しているという。公開の際には、ディー・エヌ・エーの技術者ブログで告知されるようだ。

MySQL 5.5の新機能

 最後に、「漢のコンピューター道」の奥野幹也氏が、現在マイルストーンリリース(ベータ版)で提供されているMySQL 5.5の新機能を紹介した。

 InnoDB Plugin 1.1によるInnoDBの性能改善や、4バイトUTF-8対応、準同期のレプリケーション、より柔軟になったパーティショニングといった機能詳細を順次解説しつつ、総評として「性能が向上しつつ利便性も向上したMySQL 5.5は正しい進歩を遂げた」とまとめた。詳細については、slideshareで公開されている発表資料を参照するとよいだろう。

 また、安定性を重視して設計されているMySQLにおいても、レプリケーションまわりを初めとするトラブルは避けられないと述べ、トラブルシューティングの心構えとして、トラブルは想定外の事象のため決まったセオリーはなく、「仕様を理解する」「自分で再現してみる」「ソースコードを読む」「OSに詳しくなる」といったMySQLに詳しくなる努力が肝要だと述べた。


 今回のセミナーは発表から4日ほどで満席になる人気セミナーだったようだ。当日の様子はUstream(の録画番組)や#denatechでも確認できる。

 ディー・エヌ・エーでは、今後も2か月に1回程度のペースで継続的に開催していきたいとしている。興味を持った方はブログやtwitterをチェックしておくとよいだろう。

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
イベントレポート連載記事一覧

もっと読む

この記事の著者

CodeZine編集部(コードジンヘンシュウブ)

CodeZineは、株式会社翔泳社が運営するソフトウェア開発者向けのWebメディアです。「デベロッパーの成長と課題解決に貢献するメディア」をコンセプトに、現場で役立つ最新情報を日々お届けします。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/5308 2012/07/09 15:33
" ); }

おすすめ

アクセスランキング

  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  4. 4
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  5. 5
    計測と改善をひたすら繰り返したら、年間コストを1億円削減した──不確実性の高いプロジェクトに挑む
  1. 6
    ガートナー、日本企業が2025年に向けて押さえておくべきインフラストラクチャとオペレーションのトップトレンドを発表
  2. 7
    「VRAM」 ~マンガでプログラミング用語解説
  3. 8
    AWS、「Data Exports for FOCUS 1.0」の一般提供を開始
  4. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  5. 10
    健全なソフトウェア設計の第一歩! 既存のPHPソースコードからクラス図を自動生成しよう

アクセスランキング

  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  4. 4
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  5. 5
    計測と改善をひたすら繰り返したら、年間コストを1億円削減した──不確実性の高いプロジェクトに挑む
  6. 6
    ガートナー、日本企業が2025年に向けて押さえておくべきインフラストラクチャとオペレーションのトップトレンドを発表
  7. 7
    「VRAM」 ~マンガでプログラミング用語解説
  8. 8
    AWS、「Data Exports for FOCUS 1.0」の一般提供を開始
  9. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  10. 10
    健全なソフトウェア設計の第一歩! 既存のPHPソースコードからクラス図を自動生成しよう
  1. 1
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  2. 2
    Python 3.13の新機能、対話型インタプリタの機能強化や高速化などを解説
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    「CUDA」 ~マンガでプログラミング用語解説
  6. 6
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  7. 7
    今後生成AIとどう向き合うべきなのか? 現場のエンジニアと研究者が最新研究事例から語り合う
  8. 8
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  9. 9
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  10. 10
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

メールバックナンバー

アクセスランキング

  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  4. 4
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  5. 5
    計測と改善をひたすら繰り返したら、年間コストを1億円削減した──不確実性の高いプロジェクトに挑む
  1. 6
    ガートナー、日本企業が2025年に向けて押さえておくべきインフラストラクチャとオペレーションのトップトレンドを発表
  2. 7
    「VRAM」 ~マンガでプログラミング用語解説
  3. 8
    AWS、「Data Exports for FOCUS 1.0」の一般提供を開始
  4. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  5. 10
    健全なソフトウェア設計の第一歩! 既存のPHPソースコードからクラス図を自動生成しよう

アクセスランキング

  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  4. 4
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  5. 5
    計測と改善をひたすら繰り返したら、年間コストを1億円削減した──不確実性の高いプロジェクトに挑む
  6. 6
    ガートナー、日本企業が2025年に向けて押さえておくべきインフラストラクチャとオペレーションのトップトレンドを発表
  7. 7
    「VRAM」 ~マンガでプログラミング用語解説
  8. 8
    AWS、「Data Exports for FOCUS 1.0」の一般提供を開始
  9. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  10. 10
    健全なソフトウェア設計の第一歩! 既存のPHPソースコードからクラス図を自動生成しよう
  1. 1
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  2. 2
    Python 3.13の新機能、対話型インタプリタの機能強化や高速化などを解説
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    「CUDA」 ~マンガでプログラミング用語解説
  6. 6
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  7. 7
    今後生成AIとどう向き合うべきなのか? 現場のエンジニアと研究者が最新研究事例から語り合う
  8. 8
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  9. 9
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  10. 10
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善