实战:判断mysql中当前用户的连接数-分组筛选_MySQL
#connets.sh
#!/bin/sh
#ocpyang@126.com
#根据输入参数u或d来显示出对应的用户名或数据库名中用户的连接数.
#也可以输入u 具体用户名或d 具体数据库名做进一步的分组筛选
#set mysql evn
MYSQL_USER=system #mysql的用户名
MYSQL_PASS='password' #mysql的登录用户密码
MYSQL_HOST=192.168.2.188
export black='/033[0m'
export boldblack='/033[1;0m'
export red='/033[31m'
export boldred='/033[1;31m'
export green='/033[32m'
export boldgreen='/033[1;32m'
export yellow='/033[33m'
export boldyellow='/033[1;33m'
export blue='/033[34m'
export boldblue='/033[1;34m'
export magenta='/033[35m'
export boldmagenta='/033[1;35m'
export cyan='/033[36m'
export boldcyan='/033[1;36m'
export white='/033[37m'
export boldwhite='/033[1;37m'
cecho ()
## -- Function to easliy print colored text -- ##
# Color-echo.
# 参数 $1 = message
# 参数 $2 = color
{
local default_msg="No message passed."
message=${1:-$default_msg} # 如果$1没有输入则为默认值default_msg.
color=${2:-black} # 如果$1没有输入则为默认值black.
case $color in
black)
printf "$black" ;;
boldblack)
printf "$boldblack" ;;
red)
printf "$red" ;;
boldred)
printf "$boldred" ;;
green)
printf "$green" ;;
boldgreen)
printf "$boldgreen" ;;
yellow)
printf "$yellow" ;;
boldyellow)
printf "$boldyellow" ;;
blue)
printf "$blue" ;;
boldblue)
printf "$boldblue" ;;
magenta)
printf "$magenta" ;;
boldmagenta)
printf "$boldmagenta" ;;
cyan)
printf "$cyan" ;;
boldcyan)
printf "$boldcyan" ;;
white)
printf "$white" ;;
boldwhite)
printf "$boldwhite" ;;
esac
printf "%s/n" "$message"
tput sgr0 # tput sgr0即恢复默认值
printf "$black"
return
}
cechon ()
# Color-echo.
# 参数1 $1 = message
# 参数2 $2 = color
{
local default_msg="No message passed."
# Doesn't really need to be a local variable.
message=${1:-$default_msg} # 如果$1没有输入则为默认值default_msg.
color=${2:-black} # 如果$1没有输入则为默认值black.
case $color in
black)
printf "$black" ;;
boldblack)
printf "$boldblack" ;;
red)
printf "$red" ;;
boldred)
printf "$boldred" ;;
green)
printf "$green" ;;
boldgreen)
printf "$boldgreen" ;;
yellow)
printf "$yellow" ;;
boldyellow)
printf "$boldyellow" ;;
blue)
printf "$blue" ;;
boldblue)
printf "$boldblue" ;;
magenta)
printf "$magenta" ;;
boldmagenta)
printf "$boldmagenta" ;;
cyan)
printf "$cyan" ;;
boldcyan)
printf "$boldcyan" ;;
white)
printf "$white" ;;
boldwhite)
printf "$boldwhite" ;;
esac
printf "%s" "$message"
tput sgr0 # tput sgr0即恢复默认值
printf "$black"
return
}
if [ "$#" -lt 1 ];then
echo "**********************************"
echo "you must input paraters"
echo "**********************************"
echo "USAGE01: $0 d |$0 d database_name"
echo "eg01: $0 d|$0 d mysql"
echo "USAGE02: $0 u |$0 u username"
echo "eg02: $0 u |$0 u wind"
exit 1;
fi
#Case conversion
ipt=`echo $1 |tr '[a-z]' '[A-Z]'`
#source /usr/local/mysql/scripts/mysql_env.ini
logfiledate_init="tmpinit.`date +%Y%m%d%H%M%S`.txt"
logfiledate_midd="tmpmidd.`date +%Y%m%d%H%M%S`.txt"
judegedate_01="judegedate01.`date +%Y%m%d%H%M%S`.txt"
judegedate_02="judegedate02.`date +%Y%m%d%H%M%S`.txt"
mysql -h${MYSQL_HOST} -u${MYSQL_USER} -p${MYSQL_PASS} -e"show processlist;" >${logfiledate_init}
if [ "$#" -eq 1 ]; then
if [ "$ipt" = 'D' ];then
awk '{tt[$4]++} BEGIN { printf "%-20s %-20s/n" ,"dbname","connect";} END{for (i in tt) printf "%-20s %-20s/n" ,i,tt[i]}' ${logfiledate_init} | grep -v "NULL"
elif [ "$ipt" = 'U' ];then
awk '{tt[$2]++} BEGIN { printf "%-20s %-20s/n" ,"username","connect";} END{for (i in tt) printf "%-20s %-20s/n" ,i,tt[i]}' ${logfiledate_init} | grep -v "NULL"
else
cechon "输入错误!" red
echo " "
fi
elif [ "$#" -eq 2 ]; then
grep -i $2 ${logfiledate_init} > ${logfiledate_midd}
if [ "$ipt" = 'D' ];then
SCHEMA_JUDEGE01="select schema_name from information_schema.schemata where schema_name='$2';"
mysql -h${MYSQL_HOST} -u${MYSQL_USER} -p${MYSQL_PASS} -e"${SCHEMA_JUDEGE01}" >${judegedate_01}
if [ ! -s "${judegedate_01}" ];then
cechon "you input schema_name $2 not exits,pleae check your schema_name" red
rm -rf ${SCHEMA_JUDEGE01}
exit 0
else
awk '{tt[$4]++} BEGIN { printf "%-20s %-20s/n" ,"dbname","connect";} END{for (i in tt) printf "%-20s %-20s/n" ,i,tt[i]}' ${logfiledate_midd} | grep -v "NULL"
fi
elif [ "$ipt" = 'U' ];then
SCHEMA_JUDEGE02="select user from mysql.user where user='$2';"
mysql -h${MYSQL_HOST} -u${MYSQL_USER} -p${MYSQL_PASS} -e"${SCHEMA_JUDEGE02}" >${judegedate_02}
if [ ! -s "${judegedate_02}" ];then
cechon "you input username $2 not exits,pleae check your user_name" red
rm -rf ${SCHEMA_JUDEGE02}
exit 0
else
awk '{tt[$2]++} BEGIN { printf "%-20s %-20s/n" ,"username","connect";} END{for (i in tt) printf "%-20s %-20s/n" ,i,tt[i]}' ${logfiledate_midd} | grep -v "NULL"
fi
else
cechon "输入错误!" red
echo " "
fi
fi
#清除临时文件
rm -rf ${logfiledate_init}
rm -rf ${logfiledate_midd}
rm -rf ${judegedate_01}
rm -rf ${judegedate_02}

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)
