Последний отсчет

Дмитрий Докучаев aka Forb

Xakep, номер #052, стр. 052-068-1

(forb@real.xakep.ru)

Подсчитываем трафик ПРАВИЛЬНО!

Если тебя волнует количество мусора, проходящего через твою машину (а, может, ты работаешь админом, и тогда тебе просто необходима такая информация), эта статья для тебя. Впрочем, думаю, она будет интересна многим, ведь все мы - пользователи инета, честно оплачивающие каждый байт исходящего трафика. Я постарался изложить все тонкости, которые могут тебе пригодиться при подсчете байтов на твоей машине. В качестве подопытной оси я выбрал FreeBSD, как наиболее защищенную и популярную платформу. Тем более, опираясь на эту статью, можно легко провести параллель с Linux, тем самым удовлетворив потребности линуксоида.

Вообще, подсчет трафика сводится к простому снифанию сетевого интерфейса. Для этого существуют свои программы, играющие роль так называемых "мирных сниферов". Но весь трафик на машине обычно перехватывается модулем ядра, а именно "ядерным" фаерволом системы. Для FreeBSD характерно наличие модуля ipfw.ko, с которым тесно взаимодействует /sbin/ipfw. Поэтому для самого разумного и гибкого метода подсчета трафика, нам придется прибегнуть к помощи фаервола. На мой взгляд, это достаточно несложно, но в конечном итоге все зависит от поставленной нами задачи. Допустим, нам нужно считать весь входящий и исходящий трафик. Решением в данном случае будет добавление в таблицу двух новых правил, а именно count входящих и исходящих пакетов. Это будет выглядеть следующим образом:

[root@server root]# ipfw add 1 count ip from any to me

[root@server root]# ipfw add 2 count ip from me to any

Синтаксис ipfw очень простой, ты наверняка поймешь его, даже если никогда не работал с этим фаерволом. В этих двух правилах будет храниться информация о набежавших пакетах, а именно весь трафик в байтах. Разумеется, тебе не нужно копить эти данные в теле правил. К примеру, пусть эта информация записывается каждый день в специальный файл, а затем обнуляется. Обнуление возможно с помощью команды /sbin/ipfw zero, которая выставит в тело каждого count-правила нулевое значение. Попробуем написать Perl-скрипт для вывода трафика в удобочитаемой форме, тем самым облегчив себе жизнь (ведь анализировать данные в байтах довольно сложно).

#!/usr/bin/perl

## Traffic count script

$param=shift; # Хватаем параметр из командной строки

if ($param eq '-z') { exit `ipfw zero` } ## Если он -z - чистим правила

mwrite(count(1),count(2)); ## Выполняем подсчет

sub count {

my($num)=shift;

(undef,undef,$res)=split(' ',`/sbin/ipfw show $num`); ## Выделяем байты из правил фаервола

retu $res;

}

sub mwrite {

my(@params)=@_;

foreach $num (@params) {

if (@params[0] eq $num) { $what = 'IN:' } else { $what = 'OUT:' } ## Какой трафик считаем?

if (length $num < 4) { $count = 0; $pref='' } ## Если длина числа меньше четырех - это байты

if (length $num > 3 && length $num < 7) { $count = 1; $pref='k' } ## Если от 5 до 6 - килобайты

if (length $num > 6 && length $num < 10) { $count = 2; $pref='m' } ## Мегабайты

if (length $num >= 10) {$count = 3; $pref='g' } ## Гигабайты

Содержание  Вперед на стр. 052-068-2
Выпуски журнала "Xakep"
Журнал Хакер. Содержание номера #001Журнал Хакер. Содержание номера #002Журнал Хакер. Содержание номера #003Журнал Хакер. Содержание номера #004Журнал Хакер. Содержание номера #005Журнал Хакер. Содержание номера #006Журнал Хакер. Содержание номера #007Журнал Хакер. Содержание номера #008Журнал Хакер. Содержание номера #009Журнал Хакер. Содержание номера #010Журнал Хакер. Содержание номера #011Журнал Хакер. Содержание номера #012Журнал Хакер. Содержание номера #013Журнал Хакер. Содержание номера #014Журнал Хакер. Содержание номера #015Журнал Хакер. Содержание номера #016Журнал Хакер. Содержание номера #017Журнал Хакер. Содержание номера #018Журнал Хакер. Содержание номера #019Журнал Хакер. Содержание номера #020Журнал Хакер. Содержание номера #021Журнал Хакер. Содержание номера #022Журнал Хакер. Содержание номера #023Журнал Хакер. Содержание номера #024Журнал Хакер. Содержание номера #025Журнал Хакер. Содержание номера #026Журнал Хакер. Содержание номера #027Журнал Хакер. Содержание номера #028Журнал Хакер. Содержание номера #029Журнал Хакер. Содержание номера #030Журнал Хакер. Содержание номера #031Журнал Хакер. Содержание номера #032Журнал Хакер. Содержание номера #033Журнал Хакер. Содержание номера #034Журнал Хакер. Содержание номера #035Журнал Хакер. Содержание номера #036Журнал Хакер. Содержание номера #037Журнал Хакер. Содержание номера #038Журнал Хакер. Содержание номера #039Журнал Хакер. Содержание номера #040Журнал Хакер. Содержание номера #041Журнал Хакер. Содержание номера #042Журнал Хакер. Содержание номера #043Журнал Хакер. Содержание номера #044Журнал Хакер. Содержание номера #045Журнал Хакер. Содержание номера #046Журнал Хакер. Содержание номера #047Журнал Хакер. Содержание номера #048Журнал Хакер. Содержание номера #049Журнал Хакер. Содержание номера #050Журнал Хакер. Содержание номера #051Журнал Хакер. Содержание номера #052Журнал Хакер. Содержание номера #053Журнал Хакер. Содержание номера #054Журнал Хакер. Содержание номера #055Журнал Хакер. Содержание номера #056Журнал Хакер. Содержание номера #057Журнал Хакер. Содержание номера #058Журнал Хакер. Содержание номера #059Журнал Хакер. Содержание номера #060Журнал Хакер. Содержание номера #061Журнал Хакер. Содержание номера #062Журнал Хакер. Содержание номера #063Журнал Хакер. Содержание номера #064Журнал Хакер. Содержание номера #065Журнал Хакер. Содержание номера #066Журнал Хакер. Содержание номера #067Журнал Хакер. Содержание номера #068Журнал Хакер. Содержание номера #069Журнал Хакер. Содержание номера #070Журнал Хакер. Содержание номера #071Журнал Хакер. Содержание номера #072Журнал Хакер. Содержание номера #073Журнал Хакер. Содержание номера #074Журнал Хакер. Содержание номера #075Журнал Хакер. Содержание номера #076Журнал Хакер. Содержание номера #077Журнал Хакер. Содержание номера #078Журнал Хакер. Содержание номера #079Журнал Хакер. Содержание номера #080Журнал Хакер. Содержание номера #081Журнал Хакер. Содержание номера #082Журнал Хакер. Содержание номера #083Журнал Хакер. Содержание номера #084Журнал Хакер. Содержание номера #085Журнал Хакер. Содержание номера #086Журнал Хакер. Содержание номера #087Журнал Хакер. Содержание номера #088Журнал Хакер. Содержание номера #089Журнал Хакер. Содержание номера #090Журнал Хакер. Содержание номера #091Журнал Хакер. Содержание номера #092Журнал Хакер. Содержание номера #093Журнал Хакер. Содержание номера #094Журнал Хакер. Содержание номера #095Журнал Хакер. Содержание номера #096Журнал Хакер. Содержание номера #097Журнал Хакер. Содержание номера #098Журнал Хакер. Содержание номера #099Журнал Хакер. Содержание номера #100Журнал Хакер. Содержание номера #101Журнал Хакер. Содержание номера #102Журнал Хакер. Содержание номера #103Журнал Хакер. Содержание номера #104Журнал Хакер. Содержание номера #105Журнал Хакер. Содержание номера #106Журнал Хакер. Содержание номера #107Журнал Хакер. Содержание номера #108Журнал Хакер. Содержание номера #109Журнал Хакер. Содержание номера #110Журнал Хакер. Содержание номера #111Журнал Хакер. Содержание номера #112Журнал Хакер. Содержание номера #113Журнал Хакер. Содержание номера #114