linux限制pptp连接数_linux pptpd 限制单账号session限制及登录日志(改进版)

原文http://www.cnblogs.com/niusys/p/4204360.html

原文不足之一已经有人吐槽了

这个单用户的实现方法造成的结果是,两个人踢来踢去的~~

不足之二是断线之后不会清理pptpd-users下面的用户,

可能会导致用户登录之后会kill掉原pid,

假如该pid已经分配给其它进程使用了的话,无辜的进程就会被关掉

改进了上面两个问题,并把网上的登录日志功能添加了进来

vi /etc/ppp/auth-up#!/bin/sh

# get the username/ppp line number from the parameters

REALDEVICE=$1

USER=$2

# create the directory to keep pid files per user

test -d /var/run/pptpd-users |mkdir -p /var/run/pptpd-users

restrict_mode=2

#  mode 1 :

#  if there is a session already for this user, terminate the old one

#  mode 2 :

#   prevent a new  login for same user

if [ -f /var/run/pptpd-users/$USER ]; then

case $restrict_mode in

1) kill -HUP `cat /var/run/pptpd-users/$USER`;;

2) kill -HUP `cat /var/run/$REALDEVICE.pid` ;;

*) : ;;

esac

fi

vi/etc/ppp/ip-up.local#!/bin/sh

# copy  the pid file of current user to /var/run/pptpd-users

cp "/var/run/$1.pid"  /var/run/pptpd-users/$PEERNAME

echo  "##################################" >> /var/log/pptpd.log

echo  "Now User $PEERNAME is connected!!!" >> /var/log/pptpd.log

echo  "##################################" >> /var/log/pptpd.log

echo  "time: `date -d today +%F_%T`" >> /var/log/pptpd.log

echo  "clientIP: $6" >> /var/log/pptpd.log

echo  "username: $PEERNAME" >> /var/log/pptpd.log

echo  "device: $1" >> /var/log/pptpd.log

echo  "***IP: $4" >> /var/log/pptpd.log

echo  "assignIP: $5" >> /var/log/pptpd.log

vi  /etc/ppp/ip-down.local#!/bin/sh

echo  "#####################################" >> /var/log/pptpd.log

echo  "Now User $PEERNAME is disconnected!!!" >> /var/log/pptpd.log

echo  "#####################################" >> /var/log/pptpd.log

echo  "time: `date -d today +%F_%T`" >> /var/log/pptpd.log

echo  "clientIP: $6" >> /var/log/pptpd.log

echo  "username: $PEERNAME" >> /var/log/pptpd.log

echo  "device: $1" >> /var/log/pptpd.log

echo  "***IP: $4" >> /var/log/pptpd.log

echo  "assignIP: $5" >> /var/log/pptpd.log

echo  "connect time: $CONNECT_TIME s" >> /var/log/pptpd.log

echo  "bytes sent: $BYTES_SENT B" >> /var/log/pptpd.log

echo  "bytes rcvd: $BYTES_RCVD B" >> /var/log/pptpd.log

sum_bytes=$(($BYTES_SENT+$BYTES_RCVD))

sum=`echo  "scale=2;$sum_bytes/1024/1024"|bc`

echo  "bytes sum: $sum MB" >> /var/log/pptpd.log

ave=`echo  "scale=2;$sum_bytes/1024/$CONNECT_TIME"|bc`

echo  "average speed: $ave KB/s" >> /var/log/pptpd.log

rm -f  /var/run/pptpd-users/$PEERNAME

chmoda+x  /etc/ppp/*

流程如下:

1.用户登录判断是否有/var/run/pptpd-users/用户名的文件

2.如果有平滑重启这个***用户进程,如果没有创建这个文件,文本里面有用户进程ID

3.(可选模式1或模式2)

模式1老的连接被踢掉,新的连接可以使用

模式2先登录的session保持在线,之后阻止登录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值