• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Linux系统下MySQL用户限额的实现

mysql 搞代码 4年前 (2022-01-09) 26次浏览 已收录 0个评论

原理:由于Linux系统下MySQL每个用户的数据库都是以目录的形式存在于/var/db/mysql或者其他目录下。一个目录就是一个数据库。所以可以通过检

原理:
由于Linux系统下MySQL每个用户的数据库都是以目录的形式存在于/var/db/mysql或者其他目录下。

一个目录就是一个数据库。所以可以通过检测目录的大小得到数据库大小,判断容量是否超过限额,如果超过限额就取消该用户的insert,create,update,create temp table权限,,允许select,delete等其他权限。

实现的脚本如下:
su-2.05b# cat quotamysql.sh
#!/bin/sh
#hmy-2004-8-19 v-0.1

mysqldir=/usr/db/mysql
infofiledir=/root/hmywork
limitfile=limitmysql
userfile=user_mysql
#定义初始变量
while [ 1 ];
do
sleep 10
#每隔10秒检查一次

for i in `cat ${infofiledir}/${userfile}`
do
now=`du ${mysqldir}/$i |tail -n 1 |awk ‘{print $1}’`
#取得当前目录大小
limit=`grep $i ${infofiledir}/${limitfile}|awk ‘{print $2}’`
#取得限额大小
if [ “$now” -gt “$limit” ];
#如果大于限额就执行下面的mysql语句
then
mysql –user=MySql@AdminU_ser –password=***********< use mysql
update db set in本文来源gaodaimacom搞#^代%!码&网*sert_priv=’N’ ,update_priv=’N’, create_priv=’N’,Create_tmp_table_priv=’N’ where db=’$i’;
flush privileges ;
EOF
echo $i database full! `date`>;>;fulluser
sed /`echo $i`/d $userfile >;tempfile
fi
done
cp tempfile $userfile

done


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Linux系统下MySQL用户限额的实现
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址