netfilterは、LinuxカーネルのネットワークスタックのいろいろをフックしてあれこれするためのAPIです。身近なところだと、iptablesやnftablesの実装に利用されています。カーネル内のAPIなので敷居が高そうに思われるかもしれませんが、簡単なLoadable Kernel Module (LKM) を書くだけで利用でき、カーネルに直接変更を加える必要がないので、かなりお手軽です。それでいて、iptablesやnftablesでも利用されているだけあってできることの範囲は広く、パケットの監視やファイアウォールを始めとしてパケットを読み書きするような処理なら割と何でもできます。 この記事では、netfilterを使うカーネルモジュールの基本的な書き方を紹介します。なお、動作確認はKernel 3.14で行いました。カーネルのバージョンによってメンバや定数の名称が変化している
![netfilterでパケットの送受信を制御する](https://cdn-ak-scissors.b.st-hatena.com/image/square/d9fa89e4a0153a59ccfc2cf6caf3a3679f2f4a5d/height=288;version=1;width=512/https%3A%2F%2Fblog.mono0x.net%2Fog%2F2015_02_24_netfilter.png)