ip_conntrackを設定する理由
パケットフィルタリングツールであるiptablesは、パケットを解析するときにip_conntrackというファイルにトラッキング情報を記録します。
ip_conntrackには、最大トラッキング数があり、それをオーバーすると新規セッションを弾いてしまって、ネットワークパフォーマンスの劣化を招きます。
/var/log/messageにこのようなメッセージが出ていたら、ip_conntrackが溢れている状態です。
ip_conntrack: table full, dropping packet |
大量のトラフィックを捌くロードバランサーやキャッシュなどの目的を持ったLinuxマシンで、iptablesを使っているときには、ip_conntrackの最大トラッキング数を忘れずに設定しておきましょう。
ここでは、手元のマシンCentOS 5と6で設定をしていきます。
検証環境
CentOS 6.3(64bit)
CentOS 5.8(64bit)
ip_conntrackの設定方法
まず、現在のトラッキング数と最大トラッキング数を確認しましょう。
現在使用しているip_conntrackのトラッキング数を確認します。
CentOS 5 # cat /proc/sys/net/ipv4/netfilter/ip_conntrack_count 24030 CentOS 6 # cat /proc/sys/net/netfilter/nf_conntrack_count 24030 |
最大トラッキング数を確認。
CentOS 5 # cat /proc/sys/net/ipv4/ip_conntrack_max 65536 CentOS 6 # cat /proc/sys/net/netfilter/nf_conntrack_max net.nf_conntrack_max = 65536 |
カーネルパラメータに最大トラッキング数を設定してきます。
ip_conntrackは1トラッキングにつき350バイトのメモリを必要とします。
http://www.netfilter.org/documentation/FAQ/netfilter-faq-3.html
You can easily increase the number of maximal tracked connections, but be aware that each tracked connection eats about 350 bytes of non-swappable kernel memory!
これは、スワップできないメモリです。
メモリ量と相談して、余裕を持って最大トラッキング数を決めましょう。
今回は100万トラッキング(約350Mバイト必要)としました。
CentOS 5 # emacs /etc/sysctl.conf net.ipv4.netfilter.ip_conntrack_max = 1000000 CentOS 6 # emacs /etc/sysctl.conf net.nf_conntrack_max = 1000000 |
カーネルパラメータを反映します。
「sysctl -p」を実行すると、設定ファイルが読み込まれて値が反映されます。
CentOS 5/6 /sbin/sysctl -p |
設定値を確認しましょう。
CentOS 5 # cat /proc/sys/net/ipv4/ip_conntrack_max 1000000 CentOS 6 # cat /proc/sys/net/netfilter/nf_conntrack_max 1000000 |
無事、設定が完了しました。
iptablesをリスタートしたとき、設定がリセットされないようにする
CentOS 5の場合、iptablesのバージョンが低く(iptables v1.3.5)、iptablesをリスタート、またはOSをリブートするときに最大トラッキング数がデフォルト値に戻ってしまいます。
このまま運用すると、トラフィック増大時にトラッキング数オーバーとなり、ネットワークパフォーマンスの劣化を招く結果となってしまいます。
これを、回避するようにします。
※CentOS 6(iptables v1.4.7)、Ubuntu 12(iptables v1.4.12)では同様の現象はありませんでした。
まず、iptablesをリスタートして設定が元に戻る事を確認します。
# /etc/init.d/iptables restart Flushing firewall rules: [ OK ] Setting chains to policy ACCEPT: filter [ OK ] Unloading iptables modules: [ OK ] Applying iptables firewall rules: [ OK ] Loading additional iptables modules: ip_conntrack_netbios_n[ OK ] |
設定されている最大トラッキング数を確認してみましょう。
# cat /proc/sys/net/ipv4/ip_conntrack_max 65536 |
リスタートしたときに「Unloading iptables modules」となり、モジュールがアンロードされて設定が戻ってしまっているのが判りますね。
これを回避するために、iptables-configで設定をnoにします。
# emacs /etc/sysconfig/iptables-config IPTABLES_MODULES_UNLOAD="no" |
カーネルパラメータを再反映します。
# /sbin/sysctl -p # cat /proc/sys/net/ipv4/ip_conntrack_max 1000000 |
iptablesをrestartします。
# /etc/init.d/iptables restart Flushing firewall rules: [ OK ] Setting chains to policy ACCEPT: filter [ OK ] Applying iptables firewall rules: [ OK ] Loading additional iptables modules: ip_conntrack_netbios_n[ OK ] |
今回は、モジュールがアンロードされていません。
# cat /proc/sys/net/ipv4/ip_conntrack_max 1000000 |
簡単ですね!
ip_conntrackの値をNagios/Muninで監視
最後に、ip_conntrackの数値を監視するNagios/Muninのプラグインをご紹介します。
Githubで公開されています。
Nagios
https://github.com/hrix/nagios-plugin-ip_conntrack
Munin
https://github.com/hrix/munin-plugin-ip_conntrack
これを設定しておけば、安心できますね。
e-Agencyではカーネルのチューニングが大好きなエンジニアを募集しています。
PICK UP
-

タグ: ECサイト最適化, shutto翻訳, ウェビナー開催, グローバル展開, コラム, 多言語翻訳, 海外顧客対応, 翻訳ソリューション, 越境EC
2026年2月18日(水)開催 【越境EC完全攻略!】越境ECにおける“勝ちパターン“を一気に解説 トレンド|Tips|成功事例 -

タグ: GA4, Looker Studio, コラム, データドリブン, データ可視化, マーケティング分析, 会員ランク分析, 行動データ活用, 顧客セグメンテーション
GA4 × Looker Studioによるデータ活用:会員ランク別・行動可視化の重要性と実践プロセス -

タグ: Amplitude入門, GA4計測, オープン社内報, コラム, トレンド総まとめ, プッシュ通知分析, プロダクト分析, メールテンプレート, 社内ニュースまとめ, 社内動向, 迷惑メールガイドライン
【オープン社内報 2026年2月号】イー・エージェンシー プレミアムニュース|株式会社イー・エージェンシー公式note -

タグ: Webサイト多言語変換サービス, shutto翻訳, コラム, 事例紹介
株式会社とうこう・あい様:shutto翻訳ご利用事例 -

タグ: CRM機能, DATA CAST, EC顧客育成, HTMLメールエディター, future Scenario Cast, コラム, シナリオ配信, ステップ配信, セミナー開催, メールマーケティング
2026年2月17日(火)開催 CRM機能&HTMLメールエディター標準搭載 「future Scenario Cast」(フューチャーシナリオキャスト) 徹底解説 -

タグ: ECサイト翻訳, shutto翻訳, コラム, プロ翻訳, ローカライゼーション, 品質評価, 多言語対応, 機械翻訳, 翻訳方法比較, 翻訳精度
生成AI翻訳・自動翻訳・人力翻訳の違いと多言語化の最適解|ウェブサイト翻訳ツールの選び方


