Shoeisha Technology Media

CodeZine(コードジン)

特集ページ一覧

ファイルディスクリプタについて(6)
~多重I/Oの性能とC10K問題

第6回

  • ブックマーク
  • LINEで送る
  • このエントリーをはてなブックマークに追加
2010/03/05 14:00

 本連載では、プログラムの外部との入出力を行うための抽象的なインタフェース「ファイルディスクリプタ」の機能や管理方法などを紹介していきます。第6回では、多重I/Oの性能と問題点について検証していきます。

目次

はじめに

 前回は、複数のファイルディスクリプタを一元管理する「多重I/O」機能について紹介しました。今回は、多重I/Oの性能と問題点について検証していきます。

連載概要

 サンプルプログラムは100行前後程度までは画面に記載します。全プログラムは圧縮してページ上部よりダウンロード可能にしています。makeコマンドでコンパイルできます。i386/x86_64環境で動作確認済みです。

 プログラムのボリューム上、エラー処理や引数チェックなどを省いているので、あらかじめご了解ください。また使用法を誤るとシステムに重大な影響を与える可能性があります。利用する場合は責任のとれる環境において実行するよう、お願いします。

 当トピックでは、実際にプログラムを通して動作確認や性能測定を行うことで、個人的な見解を述べさせていただきます。あくまで個人的な感想に基づいているので、反論や指摘などあるかと思います。指摘や質問などは大歓迎なので、その際はぜひご連絡ください。可能な限りの対応に努めます。

性能測定について

 第4回で触れましたが、select(2), poll(2)は、管理するディスクリプタが大量になると性能上の問題が発生すると言われています。いわゆるC10K問題で、目安としてクライアント10,000台あたりで性能劣化が発生するとのことです。epoll(7)はその点を解消していると言われていますが、ではどれだけの違いがあるのか。

 明確な性能値が提示されている資料は、見聞の少ない私は見たことがないので、今回はいろいろなプログラムを使って実測してみました。

 その道に優れた方に当レポートを参照していただき、ご意見ご感想ご叱責いただけることを期待しております。

 なお、今回使用しましたマシンのCPU・メモリ・OS・アーキテクチャは下記の通りです。

ローカルポート数の設定
# cat /proc/cpuinfo | grep "model name"
model name : Intel(R) Core(TM)2 Duo CPU E6850 @ 3.00GHz
model name : Intel(R) Core(TM)2 Duo CPU E6850 @ 3.00GHz
# cat /proc/meminfo | grep MemTotal
MemTotal: 2015528 kB
# cat /etc/redhat-release
CentOS release 5.3 (Final)
# uname -a
Linux host 2.6.18-128.el5 #1 SMP Wed Dec 17 11:41:38 EST 2008 x86_64 x86_64 x86_64 GNU/Linux

  • ブックマーク
  • LINEで送る
  • このエントリーをはてなブックマークに追加

著者プロフィール

  • 赤松 エイト(エイト)

    (株)DTSに勤てます。 WebアプリやJavaやLL等の上位アプリ環境を密かに憧れつつも、ず~っとLinuxとかHP-UXばかり、ここ数年はカーネル以上アプリ未満のあたりを行ったり来たりしています。 mixiもやってまして、こちらは子育てとか日々の日記メインです。

バックナンバー

連載:ファイルディスクリプタについて
All contents copyright © 2005-2019 Shoeisha Co., Ltd. All rights reserved. ver.1.5