Возможно вы искали: 'Русская рулетка 2: Зак...'

May 15 2025 19:32:04
  • Как сделать 8Gamers.Ru домашней страницей?
  • Игры
    • База данных по играх
    • Игровые новости
    • Игровая индустрия
    • Обзоры на игры
    • Прохождения игр
    • Гайды к играм
    • Превью о играх
    • Игровые тизеры
    • Игровые арты
    • Игровые обои
    • Игровые скриншоты
    • Игровые обложки
    • Игровые трейлеры
    • Игровое видео
    • Вышедшие игры
    • Ближайшие релизы игр
  • Кино и ТВ
    • База данных по кино
    • Статьи о кино
    • Постеры
    • Кадры из кино
    • Кино трейлеры
    • Сегодня в кино
    • Скоро в кино
  • Комиксы и манга
    • Манга по алфавиту
    • База данных по комиксах
    • Читать онлайн комиксы
    • Читать онлайн манга
    • База персонажей
  • Читы и коды
    • Чит-коды для PC игр
    • Чит-коды для консольных игр
    • Трейнеры
    • Коды Game Genie
  • Моддинг
    • Модификации
    • Карты к играм
    • Программы для моддинга
    • Статьи о моддинге
  • Геймдев
    • Всё о создании игр
    • Список движков
    • Утилиты в помощь игроделу
    • Конструкторы игр
    • Игровые движки
    • Библиотеки разработки
    • 3D-модели
    • Спрайты и тайлы
    • Музыка и звуки
    • Текстуры и фоны
  • Рецензии
    • Игры
    • Кино
    • Аниме
    • Комиксы
    • Мангу
    • Саундтреки
  • Саундтреки
    • Лирика
  • Файлы
    • Патчи к играм
    • Русификаторы к играм
    • Сохранения к играм
    • Субтитры к кино
  • Медиа
    • Видео
    • Фото
    • Аудио
    • Фан-арты
    • Косплей
    • Фото с виставок
    • Девушки из игр
    • Рисунки
    • Рисуем онлайн
    • Фотохостинг
  • Юмор
    • Анекдоты
    • Афоризмы
    • Истории
    • Стишки и эпиграммы
    • Тосты
    • Цитаты
  • Флеш
    • Азартные
    • Аркады
    • Бродилки
    • Гонки
    • Для девочек
    • Для мальчиков
    • Драки
    • Квесты
    • Леталки
    • Логические
    • Мультфильмы
    • Открытки
    • Приколы
    • Разное
    • Спорт
    • Стратегии
    • Стрелялки
Статистика

Статей: 87772
Просмотров: 96111483
Игры
Injustice:  Gods Among Us
Injustice: Gods Among Us
...
Dark Souls 2
Dark Souls 2
Dark Souls II - вторая часть самой хардкорной ролевой игры 2011-2012 года, с новым героем, сюжето...
Battlefield 4
Battlefield 4
Battlefield 4 - продолжение венценосного мультиплеер-ориентированного шутера от первого ли...
Кино
Steins;Gate
Steins;Gate
Любители японской анимации уже давно поняли ,что аниме сериалы могут дать порой гораздо больше пи...
Ку! Кин-дза-дза
Ку! Кин-дза-дза
Начинающий диджей Толик и всемирно известный виолончелист Владимир Чижов встречают на шумной моск...
Обзоры на игры
• Обзор Ibara [PCB/PS2] 18357
• Обзор The Walking ... 18801
• Обзор DMC: Devil M... 19879
• Обзор на игру Valk... 15877
• Обзор на игру Stars! 17764
• Обзор на Far Cry 3 17948
• Обзор на Resident ... 16024
• Обзор на Chivalry:... 17508
• Обзор на игру Kerb... 17981
• Обзор игры 007: Fr... 16619
Превью о играх
• Превью к игре Comp... 17960
• Превью о игре Mage... 14464
• Превью Incredible ... 14721
• Превью Firefall 13479
• Превью Dead Space 3 16334
• Превью о игре SimC... 14730
• Превью к игре Fuse 15442
• Превью Red Orche... 15542
• Превью Gothic 3 16343
• Превью Black & W... 17354
Главная » Статьи » Разное » Настройка dial-in сервера под Red Hat linux (dial-in redhat linux ppp billing statistic limit mgetty mysql)

Настройка dial-in сервера под Red Hat linux (dial-in redhat linux ppp billing statistic limit mgetty mysql)

Ключевые слова: dial-in, redhat, linux, ppp, billing, statistic, limit, mgetty, mysql, (найти похожие документы)

From: Igor Chumak <igoor(собак)mail.ru>
Date: Mon, 24 Jul 2004 18:21:07 +0000 (UTC)
Subject: Настройка dial-in сервера под Red Hat linux

Оригинал: http://212.26.129.139:8080/other/linux/dial_in.htm


Настройка dial-in сервера под Red Hat linux

После того, как я настроил pppd для доступа извне офиса к локальной
сети и интернет, мне захотелось большего:
* ограничить время работы удалённых юзеров (ибо их много, а
модемов мало)
* разграничить доступ к ресурсам сети (кого-то пускать везде,
кого-то только к прокси-серверу..)

Итак, чем я пользовался:
* mgetty 1.1.28-9
* ppp 2.4.1-3
* mysql 3.23.49-3
* mysql-server-3.23.49-3

Разграничение доступа к сети firewall'ом

1. Скрипт для создания dial-in юзеров выглядит так:

------------------------------------------
#!/bin/sh
name=$1
if [ -z $name ]
then
echo Username??
exit
fi
if [ $name == " *"]
then
echo Username??
exit
fi
echo Add user "$name"
cmd="/usr/sbin/useradd -c "Dial-in 2 $name" -d /dev/null -g dial-in-users -M -s /bin/false $name"
echo $cmd
/usr/sbin/useradd -c "Dial-in 2 $name" -d /dev/null -g dial-in-users -M -s /bin/false $name
if [ $? -eq 0 ]
then
echo Add pap-secrets entry..
echo $name $HOSTNAME "" * >> /etc/ppp/pap-secrets
addscript="INSERT INTO users VALUES ( '$name', '3600');"
echo Add time-limit..
mysql -B -s -h localhost -e "$addscript" dial_in
echo Set passwd user "$name"
passwd $name
fi
------------------------------------------

Группа dial-in-users должна существовать!


2. /etc/ppp/ip-up.local

При подъёме ppp+ интерфейса выполняется настройка firewall и
дополнительная проверка:

------------------------------------------
#!/bin/sh
pppPID=`cat /var/run/$IFNAME.pid`
dialindir="/etc/ppp/dial-in"
. $dialindir/firewall $PEERNAME $IFNAME
. $dialindir/ip-up-script $PEERNAME $IFNAME $pppPID
------------------------------------------


3. /etc/ppp/dial-in/firewall

Подразумевается, что firewall наш на базе iptables, и что последнее
правило в цепочках INPUT и FORWARD (policy DROP) изменению не подлежит
(у меня там LOG).

LAN_IP - IP-адрес, к которому даём полный доступ

WINS1,WINS2 - WINS-сервера в локальной сети

------------------------------------------
#!/bin/sh
mydirname="/etc/ppp/dial-in"
# Setup firewall rulezz 2 new PPP link
PEERNAME=$1
IFNAME=$2
export IFNAME
LAN_IP=192.168.10.202
WINS1=192.168.10.200
WINS2=192.168.10.201
# Сначала грохнем старые правила
# Наоборот сортированный список N правил, которые надобно грохнуть
inp=`iptables -L INPUT -n -v --line-number|grep $IFNAME|awk '{print $1}'|sort -n -r`
for i in $inp
do
echo $i
iptables -D INPUT $i
done

inp=`iptables -L FORWARD -n -v --line-number|grep $IFNAME|awk '{print $1}'|sort -n -r`
for i in $inp
do
echo $i
iptables -D FORWARD $i
done

lastINPUTrule=`iptables -L INPUT -n -v --line-number|awk '{print $1}'|sort -n -r|head -1`
lastFORWARDrule=`iptables -L FORWARD -n -v --line-number|awk '{print $1}'|sort -n -r|head -1`

# Теперь зададим новые
# INPUT
iptables -I INPUT $lastINPUTrule -p ALL -i $IFNAME -d $LAN_IP -j ACCEPT
#FORWARD
# wins access 2 all
iptables -I FORWARD $lastFORWARDrule -p tcp -i $IFNAME -d $WINS1 --dport wins -j ACCEPT
iptables -I FORWARD $lastFORWARDrule -p udp -i $IFNAME -d $WINS1 --dport wins -j ACCEPT
iptables -I FORWARD $lastFORWARDrule -p tcp -i $IFNAME -d $WINS2 --dport wins -j ACCEPT
iptables -I FORWARD $lastFORWARDrule -p udp -i $IFNAME -d $WINS2 --dport wins -j ACCEPT
#mydirname=`dirname $0`
#echo $mydirname/$PEERNAME>>/var/log/ppp.log
if [ -f $mydirname/$PEERNAME ]
then
. $mydirname/$PEERNAME $lastFORWARDrule $IFNAME
fi
------------------------------------------

Для юзеров с более хитрыми правами на сеть вызываются скрипты с доп.
правилами:

/etc/ppp/dial-in/USERNAME:
------------------------------------------
# $lastFORWARDrule $IFNAME
# Правила для юзера super
iptables -I FORWARD $1 -p tcp -i $2 -d 192.168.10.11 -j ACCEPT
------------------------------------------


Ограничение времени работы юзера

Суммарная продолжительность всех сеансов связи за сутки не должна
превышать заданного нами лимита.

1. Создаём базу dial_in со следующими таблицами:

------------------------------------------
# phpMyAdmin MySQL-Dump
# http://phpwizard.net/phpMyAdmin/
#
# Host: localhost Database : dial_in

# --------------------------------------------------------
#
# Table structure for table 'current_sessions'
#

CREATE TABLE current_sessions (
id bigint(10) NOT NULL auto_increment,
peername varchar(20) NOT NULL,
linkname varchar(10) NOT NULL,
pppd_pid int(8) DEFAULT '0' NOT NULL,
start_time datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
start_time_utc bigint(16) DEFAULT '0' NOT NULL,
PRIMARY KEY (id),
UNIQUE id (id)
);


# --------------------------------------------------------
#
# Table structure for table 'done_sessions'
#

CREATE TABLE done_sessions (
id bigint(14) NOT NULL auto_increment,
peername varchar(20) NOT NULL,
start_time datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
start_time_utc bigint(16) DEFAULT '0' NOT NULL,
length_session int(6) DEFAULT '0' NOT NULL,
PRIMARY KEY (id),
UNIQUE id (id),
KEY id_2 (id)
);


# --------------------------------------------------------
#
# Table structure for table 'users'
#

CREATE TABLE users (
peername varchar(20) NOT NULL,
timelimit int(8) DEFAULT '3600' NOT NULL,
PRIMARY KEY (peername),
UNIQUE peername (peername),
KEY peername_2 (peername)
);
------------------------------------------


2. /etc/ppp/dial-in/ip-up-script

Запоминает в таблице current_sessions начало сеанса связи

------------------------------------------
#!/bin/sh
mydirname="/etc/ppp/dial-in"
peername=$1
linkname=$2
ppp_pid=$3
now=`date +%Y:%m:%d %T`
now_utc=`date +%s`
script1="delete from current_sessions where peername="$peername" and linkname="$linkname""
script2="insert into current_sessions
(peername,linkname,pppd_pid,start_time,start_time_utc) values
("$peername","$linkname","$ppp_pid","$now","$now_utc")"
#mysql_user=" -u nobody "
mysql -B -s -h localhost $mysql_user -e "$script1" dial_in
mysql -B -s -h localhost $mysql_user -e "$script2" dial_in
. $mydirname/test-of-limit $peername $ppp_p
------------------------------------------


3. /etc/ppp/dial-in/test-of-limit

Проверяет, не превышен ли дневной лимит. При превышении рвёт связь и
шлёт письмо на root

------------------------------------------
#!/bin/sh
# Test user $1 for owerquoting && disconnect
peername=$1
ppp_pid=$2
#mysql_user=" -u nobody "
script1="select sum(length_session) from done_sessions where peername="$peername""
script2="select min(start_time_utc) from current_sessions where peername="$peername""
t1=`mysql -B -s -h localhost $mysql_user -e "$script1" dial_in`
t2=`mysql -B -s -h localhost $mysql_user -e "$script2" dial_in`
if [ $t2 != "NULL" ]
then
t3=`date +%s`
itogo=$(($t1-$t2+$t3))
else
itogo=$t1
fi
# echo $itogo $t1 $t2 $t3
script3="select min(timelimit) from users where
peername="$peername""
limit=`mysql -B -s -h localhost $mysql_user -e "$script3" dial_in`
if [ $limit != "NULL" ]
then
if [ $limit -lt $itogo ]
then
echo `date +%c` $peername $limit -lt $itogo | mail root -s "Overtime on PPP"
kill $ppp_pid
fi
fi
------------------------------------------


4. /etc/ppp/dial-in/ip-down-script

При окончании сеанса связи пересчитывает суточный баланс юзера

------------------------------------------
#!/bin/sh
#echo $0 $*>>/var/log/ppp-script
peername=$1
linkname=$2
#ppp_pid=$3
length_session=$3
#mysql_user=" -u nobody "
script1="select "$peername","$length_session",min(start_time_utc)
from current_sessions where peername="$peername" and linkname="$linkname""
script2="insert into done_sessions (peername,length_session,start_time_utc) $script1"
mysql -B -s -h localhost $mysql_user -e "$script2" dial_in
script3="delete from current_sessions where peername="$peername" and
linkname="$linkname""
mysql -B -s -h localhost $mysql_user -e "$script3" dial_in
------------------------------------------


5. /etc/ppp/dial-in/ppp.cron-10min

Через каждые 5-10 мин вызываем из cron'а, проверяем уже подключенных
юзеров.

------------------------------------------
#!/bin/sh
#peername=$1
#ppp_pid=$2
mydirname="/etc/ppp/dial-in"
#mysql_user=" -u nobody "
script1="select distinct CONCAT_WS(":",peername,pppd_pid) from current_sessions"
peer_list=`mysql -B -s -h localhost $mysql_user -e "$script1" dial_in`
for ii in $peer_list
do
# echo $ii
pdd=`expr index $ii :`
# echo $pdd
ppp_pid=${ii:pdd}
username=${ii:0:$((pdd-1))}
# echo $ppp_pid $username
. $mydirname/test-of-limit $username $ppp_pid
done
------------------------------------------


6. /etc/ppp/dial-in/ppp.cron-zero

Обнуляем статистику раз в сутки, отправляем отчет по почте

------------------------------------------
#!/bin/sh
#peername=$1
#ppp_pid=$2
#mysql_user=" -u nobody "
script2="delete from done_sessions"
now=`date +%s`
script1="update current_sessions set start_time_utc=$now"
. /etc/ppp/dial-in/statistika|mail root -s "PPP dayly statystic"
mysql -B -s -h localhost $mysql_user -e "$script1" dial_in
mysql -B -s -h localhost $mysql_user -e "$script2" dial_in
------------------------------------------

/etc/ppp/dial-in/statistika
------------------------------------------
#!/bin/sh
#mysql_user=" -u nobody "
script1="select * from current_sessions"
#script2="select * from done_sessions"
script2="select peername,count(id),sum(length_session) from done_sessions group by peername"
echo Current sessions
mysql -B -h localhost $mysql_user -e "$script1" dial_in
echo Done sessions
mysql -B -h localhost $mysql_user -e "$script2" dial_in
------------------------------------------

Доступ к базе либо от root (дополнительных настроек не потребуется),
либо от простого юзера (раскомментируем строчки с mysql_user,
настраиваем права доступа)

Всем скриптам дать chmod 755 !


Используемые статьи:

* Настройка PPP dial-in сервера (PAP аутентификация)
http://212.26.129.139/howto/PPP-dial-in.htm
* Iptables Tutorial 1.1.9
http://212.26.129.139/howto/iptables/Iptables%20Tutorial%201_1_9.htm
* Advanced Bash-Scripting Guide
http://212.26.129.139/howto/abs-guide/HTML/
1167 Прочтений •  [Настройка dial-in сервера под Red Hat linux (dial-in redhat linux ppp billing statistic limit mgetty mysql)] [08.05.2012] [Комментариев: 0]
Добавил: Ukraine Vova
Ссылки
HTML: 
[BB Url]: 
Похожие статьи
Название Добавил Добавлено
• Настройка dial-in сервера под Red H... Ukraine Vova 08.05.2012
Ни одного комментария? Будешь первым :).
Пожалуйста, авторизуйтесь для добавления комментария.

Проект входит в сеть сайтов «8Gamers Network»

Все права сохранены. 8Gamers.NET © 2011 - 2025

Статьи
Рецензия на Pressure
Рецензия на Pressure
Чтобы обратить на себя внимание, начинающие маленькие разработчики, как правило, уходят в жанры, ...
Рецензия на Lost Chronicles of Zerzura
Рецензия на Lost Chron...
Игры, сделанные без любви и старания, похожи на воздушный шар – оболочка есть, а внутри пусто. Lo...
Рецензия на The Bridge
Рецензия на The Bridge
«Верх» и «низ» в The Bridge — понятия относительные. Прогуливаясь под аркой, можно запросто перей...
Рецензия на SimCity
Рецензия на SimCity
Когда месяц назад состоялся релиз SimCity, по Сети прокатилось цунами народного гнева – глупые ош...
Рецензия на Strategy & Tactics: World War 2
Рецензия на Strategy &...
Название Strategy & Tactics: World War II вряд ли кому-то знакомо. Зато одного взгляда на ее скри...
Рецензия на игру Scribblenauts Unlimited
Рецензия на игру Scrib...
По сложившейся традиции в информационной карточке игры мы приводим в пример несколько похожих игр...
Рецензия на игру Walking Dead: Survival Instinct, The
Рецензия на игру Walki...
Зомби и продукция-по-лицензии — которые и сами по себе не лучшие представители игровой биосферы —...
Обратная связь | RSS | Донейт | Статистика | Команда | Техническая поддержка