MySQL自用脚本/shell命令(不定期更新)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 批量kill MySQL中的sleep状态的连接 方法1.  基于MySQL本身的查询和kill指令(感谢飞飞哥友情赞助) 点击(此处)折叠或打开 mysql>select concat('KILL ',id,';') from information_schema.
批量kill MySQL中的sleep状态的连接
方法1.  基于MySQL本身的查询和kill指令(感谢飞飞哥友情赞助)

点击(此处)折叠或打开

  1. mysql>select concat('KILL ',id,';') from information_schema.processlist where user='root' into outfile '/tmp/a.txt';
  2. Query OK, 2 rows affected (0.00 sec)
  3. mysql>source /tmp/a.txt;
  4. Query OK, 0 rows affected (0.00 sec)

方法2.  使用管道命令(修正)

点击(此处)折叠或打开

  1. mysqladmin -uroot -pPWD processlist | grep -i sleep | awk '{print $2}' | xargs -n 1 mysqladmin -uroot -pPWD processlist kill

简易延伸(修正)
使用Linux的定时任务来定时检测MySQL的连接数,并根据一定的阈值来批量kill sleep连接或者Query连接(防止数据库连接被爆)
类似脚本,在使用前,无论如何请在测试环境先进行详细验证之后再慎重使用......


点击(此处)折叠或打开

  1. #!/bin/bash
  2. #Author Wang.wenan @ 2015/09/30
  3. #Edit @ 2015/10/09
  4. USER=root
  5. PASSWORD=PWD
  6. SLIMIT=10000
  7. QLIMIT=10000
  8. n=`mysqladmin processlist -uUSERpPASSWORD | grep -i sleep |wc -l`
  9. m=`mysqladmin processlist -uUSERpPASSWORD | grep -i Query |wc -l`
  10. if [ "n"gtSLIMIT ]
  11. then
  12.     echo "sleep connection is too many, count:$n \n\n\n" >> /home/log/MySQL_Connection_Killer.log
  13.     mysqladmin processlist -uUSERpPASSWORD | grep -i sleep >> /home/log/MySQL_Connection_Killer.log
  14.     mysqladmin processlist -uUSERpPASSWORD | grep -i sleep |awk '{print 2}' | xargs -n 1 mysqladmin -uUSER -p$PASSWORD kill
  15.     echo "sleep is too many, so killed them all at $(date -d today +%Y-%m-%d\ %H:%M:%S)" >> /home/log/MySQL_Connection_Killer.log
  16. else
  17.     echo "MySQL Connection check is passed, sleep connection count:$n" >> /home/log/MySQL_Connection_Killer.log
  18. fi
  19. if [ "m"gtQLIMIT ]
  20. then
  21.     echo "Query connection is too many, count:$m \n\n\n" >> /home/log/MySQL_Connection_Killer.log
  22.     mysqladmin processlist -uUSERpPASSWORD | grep -i Query >> /home/log/MySQL_Connection_Killer.log
  23.     mysqladmin processlist -uUSERpPASSWORD | grep -i Query |awk '{print 2}' | xargs -n 1 mysqladmin -uUSER -p$PASSWORD kill
  24.     echo "Query is too many, so killed them all at $(date -d today +%Y-%m-%d\ %H:%M:%S)" >> /home/log/MySQL_Connection_Killer.log
  25. else
  26.     echo "MySQL Connection check is passed, Query connection count:$m" >> /home/log/MySQL_Connection_Killer.log
  27. fi

使用crontab,随意设置时间间隔

查看MySQL数据库状态(小改)
转载自http://www.orczhou.com/index.php/2014/03/some-tricky-about-mysqladmin-extended-status/
PS:如果标题格式和下面的数据没有对齐,在红线标出的print语句添加空格修改就好

点击(此处)折叠或打开

  1. mysqladmin -P3306 -uroot -p -h127.0.0.1 -r -i 1 extended-status |awk -F"|" "BEGIN{ count=0; }"'{ if($2 ~ /Variable_name/ && ((++count)%20 == 1)){\
  2. print "----------|---------|--- MySQL Command Status --|----- Innodb row operation -----|-- Buffer Pool Read --";\
  3. print "---Time---|---QPS---|select insert update delete|  read  inserted updated deleted|   logical    physical";\
  4. }\
  5. else if (2 ~ /Queries/){queries=3;}\
  6. else if (2 ~ /Com_select /){com_select=3;}\
  7. else if (2 ~ /Com_insert /){com_insert=3;}\
  8. else if (2 ~ /Com_update /){com_update=3;}\
  9. else if (2 ~ /Com_delete /){com_delete=3;}\
  10. else if (2 ~ /Innodb_rows_read/){innodb_rows_read=3;}\
  11. else if (2 ~ /Innodb_rows_deleted/){innodb_rows_deleted=3;}\
  12. else if (2 ~ /Innodb_rows_inserted/){innodb_rows_inserted=3;}\
  13. else if (2 ~ /Innodb_rows_updated/){innodb_rows_updated=3;}\
  14. else if (2 ~ /Innodb_buffer_pool_read_requests/){innodb_lor=3;}\
  15. else if (2 ~ /Innodb_buffer_pool_reads/){innodb_phr=3;}\
  16. else if ($2 ~ /Uptime / && count >= 2){\
  17. printf(" %s |%9d",strftime("%H:%M:%S"),queries);\
  18. printf("|%6d %6d %6d %6d",com_select,com_insert,com_update,com_delete);\
  19. printf("|%8d %6d %7d %7d",innodb_rows_read,innodb_rows_inserted,innodb_rows_updated,innodb_rows_deleted);\
  20. printf("|%10d %11d\n",innodb_lor,innodb_phr);\
  21. }}';

效果图


shell,查询指定SQL的trace信息

点击(此处)折叠或打开

  1. mysql -uUSER -pPWD -hHOST -e "use ins_tc_prd;set session optimizer_trace='enabled=on';set optimizer_trace_max_mem_size = 1638400;explain SQL;select * from information_schema.optimizer_trace\G;" > trace_log.log

#查看表空间的使用情况

点击(此处)折叠或打开

  1. select table_name,
  2.        (data_length+ index_length) /1024/1024 as total_mb,
  3.        table_rows
  4. from information_schema.tables
  5. where table_schema= 'zabbix' ;//不写就是全部

在mysql client显示具体的信息

点击(此处)折叠或打开

  1. [Client] prompt='\u@\h(\d) \\r:\m:\\s:>'

在mysql client使用tab自动完成

点击(此处)折叠或打开

  1. [mysql] auto-rehash

避免脚本中总是出现密码insecure的小技巧

在脚本中添加 export MYSQL_PWD=xxxxxxxx, 然后在mysql的连接命令中去掉-p选项, 在脚本中就不会出现讨厌的提示信息了~~\(≧▽≦)/~

通过.frm文件来获取表结构
需要安装mysql-utilities; 3306是mysql实例的监听端口, 3310是一个空端口

点击(此处)折叠或打开

  1. mysqlfrm --user=root --basedir=/usr/ --server=root:root@localhost:3306 /home/mysql/data/sakila/actor.frm --port=3310
效果如图:


解析所有的.frm文件

点击(此处)折叠或打开

  1. mysqlfrm --diagnostic /home/mysql/data/sakila
效果与上图类似
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
1
分享
相关文章
定期备份数据库:基于 Shell 脚本的自动化方案
本篇文章分享一个简单的 Shell 脚本,用于定期备份 MySQL 数据库,并自动将备份传输到远程服务器,帮助防止数据丢失。
|
2月前
|
【linux】Shell脚本中basename和dirname的详细用法教程
本文详细介绍了Linux Shell脚本中 `basename`和 `dirname`命令的用法,包括去除路径信息、去除后缀、批量处理文件名和路径等。同时,通过文件备份和日志文件分离的实践应用,展示了这两个命令在实际脚本中的应用场景。希望本文能帮助您更好地理解和应用 `basename`和 `dirname`命令,提高Shell脚本编写的效率和灵活性。
115 32
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
多种脚本批量下载 Docker 镜像:Shell、PowerShell、Node.js 和 C#
本项目提供多种脚本(Shell、PowerShell、Node.js 和 C#)用于批量下载 Docker 镜像。配置文件 `docker-images.txt` 列出需要下载的镜像及其标签。各脚本首先检查 Docker 是否安装,接着读取配置文件并逐行处理,跳过空行和注释行,提取镜像名称和标签,调用 `docker pull` 命令下载镜像,并输出下载结果。使用时需创建配置文件并运行相应脚本。C# 版本需安装 .NET 8 runtime。
131 2
|
5月前
|
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
197 1
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
171 2
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
139 82
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等