首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql慢查询优化-内存清理

前提介绍 同样的mysql,同样的查询,为啥在不同的服务器上的查询效率差别有10几倍 继上一篇索引优化后,在自己的服务器上已经从10几秒优化到了2s,以为万事大吉了, 谁知道,同样的操作,在客户的服务器上优化后...这让我开始怀疑客户服务器的内存使用 由于客户的mysql,当时我是使用docker镜像,所以一开始想到的解决方案是扩大docker容器的内存 但是后来一想,即使内存扩大了,保不住下次还会不够用,为啥一个小小的...mysql能把内存占满了, 不行,必须从mysql上解决根本问题,而不是一位的扩大内存 于是,我开始了如下操作: 解决过程 查看docker容器的cpu占用情况 image.png 神马?...image.png 查询存在的连接数 在mysql 输入 show processlist ;查询存在的连接数以及timeout的时间,可以帮助识别出有问题的查询语句 发现有好多造成查询慢的语句 mysql...wait_timeout过大有弊端,MySQL里大量的SLEEP连接无法及时释放,拖累系统性能; 设置过小,可能会遇到“MySQL has gone away”之类的报错 Linux系统中,默认是28800

2.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    清理电脑内存

    自己的电脑很卡,导致电脑卡的原因有很多种,电脑内存不足就是其中的一个主要原因,除了给自己的电脑增加内存外,我们还可以通过清理内存的方式来解决问题。   ...清理内存系统软件图解1   2.在打开的属性界面中点击磁盘清理,进入下一步。 清理内存系统软件图解2   3.在新出现的界面中勾选需要清理的文件,点击确定按钮即可。...清理内存系统软件图解4   2.扫描完成后,点击“一键清理”按钮即可。...清理内存系统软件图解5   方法三:使用360安全卫士清理内存   1.下载安装360安全卫士,然后在软件主界面上点击电脑清理选择,然后点击一键检测,软件就会自动开始扫描您电脑上的垃圾文件了。...如何清理电脑内存系统软件图解6   2.检测完毕后,点击一键清理按钮就可以了。 电脑内存系统软件图解7   以上几种方法都可以进行电脑内存清理

    2.5K20

    Redis内存碎片清理

    当Redis中清理了大量的Key之后原先Redis申请的内存(used_memory_rss)将继续持有而不会释放,此时查看内存信息将会看到存在大量的内存碎片。...那么,Redis的内存碎片可以清理么,该如何清理呢? 翻看了Redis的相关资料发现,Redis4版本之后开始支持内存碎片的清理,于是进行了一次测试,内容如下: 1....清理内存碎片 默认情况下自动清理碎片的参数是关闭的,可以按如下命令查看 127.0.0.1:6379> config get activedefrag 1) "activedefrag" 2) "no..." 启动自动清理内存碎片 127.0.0.1:6379> config set activedefrag yes OK 开启后再查看内存信息 127.0.0.1:6379> info memory #...相关参数配置说明 内存清理相关参数如下,可以使用config get的方式查看对应的值 # Enabled active defragmentation # 碎片整理总开关 # activedefrag

    5.4K34

    Linux内存分析与清理

    used:已经使用的内存数 free:空闲的内存数 shared:当前已经废弃不用 buffers Buffer:缓存内存数 cached Page:缓存内存数 可以看出buff/cache占用的内存份额很大...,有时候程序运行结束后,大量内存仍位于buff/cache中,有时运行程序会导致内存不足,因此需要将这部分内存释放出来。...Linux中的缓存分类 要清理Linux中的cache,首先要明白buff和cache的区别(free中的buff/cache),以及pagecache,dentries和inodes的区别。...pagecache 页面缓存(pagecache)可以包含磁盘块的任何内存映射。这可以是缓冲I/O,内存映射文件,可执行文件的分页区域——操作系统可以从文件保存在内存中的任何内容。...清理cache /proc/sys/vm/drop_caches (since Linux 2.6.16) Writing to this file causes the kernel to drop

    9.4K20

    linux的内存清理相关知识!

    1.清理内存使用情况  free -m 2.开始清理   echo 1 > /proc/sys/vm/drop_caches 3.清理内存使用情况  free -m 4.完成!...查看内存条数命令: dmidecode | grep -A16 "Memory Device$" ++++++++++++++++++++++++++++++++++++++++++++++++++...先说下free命令怎么看内存 [root@yuyii proc]# free total   used   free     shared buffers cached Mem: 515588 295452...: total——总物理内存 used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存 free——完全未被使用的内存 shared——应用程序共享内存 buffers...: 前个值表示-buffers/cache——应用程序使用的内存大小,used减去缓存值 后个值表示+buffers/cache——所有可供应用程序使用的内存大小,free加上缓存值 note:

    4.7K80

    Redis Lua内存清理的灾难

    灾难现场 客户需要清理lua内存,于是按照标准动作执行了script flush。发现系统直接hang住了,请求无法执行,超时报错。...开始排查 此时我们开始怀疑是否是清理内存导致了系统hang主,拨测失败,导致HA。...[lua内存] 果不其然,25G内存清理确实非常耗时,由于腾讯云4.0标准版的redis其实是引入arbiter节点当做集群版来管理,因此我们需要调大节点的timeout值,可以使用config get...单机版执行结论] 然后再次执行就没问题了 used_memory_lua:41984 used_memory_lua_human:41.00K used_memory_scripts:624 小结 建议如果需要清理...特别是不要再占用内存很高的情况下使用script flush Lua占用内存为25.15G,是极不合理的,如果读者遇到这种情况,建议排查内存泄露或者是否使用了动态生成脚本的方式

    2.5K100

    MemReduct内存自动清理工具

    MemReduct MemReduct是国外一款专业的内存清理软件,现在越来越多的软件由于硬件的普遍发展,对内存的使用都开始肆无忌惮起来,这对内存比较小的老电脑来说就非常不友好了,即使新电脑也会受不了,...如果你的电脑也因为常常内存不足而卡顿,就来下载这款软件试试吧。...也可以安装在服务器上,定期整理内存,保持内存空间舒畅。...適用於: 個人PC電腦速度慢,不能持續有效優化,經常要重啓解決一切問題 服務器大應用吃内存,不能持續有效釋放,經常需要重啓 下載地址: 官方網站 https://www.henrypp.org/product...链接:https://www.aliyundrive.com/s/mpu1HWvfK1m 整理前,略微卡顿 整理后,丝丝顺滑 还可以,自动清理(服务器上这个功能很有用) 追加更新:感动作者,强势更新

    4.2K31

    Redis内存碎片的产生与清理

    前言 在做redis内存清理时我们会关注redis的实时内存占用,即通过info memory命令查看内存使用情况: 我们比较常关注的是used_memory以及used_memory_rss,这两项分别是...大于1小于1.5:正常值,有一些内存碎片,但也可以提高性能,可以接受 大于1.5:说明内存碎片率比较大,需要考虑是否要进行内存碎片清理,要引起重视 小于1:内存不够redis用了,已经开始使用swap机制交换内存...,也就是使用硬盘了(swap可以在设置中禁用),需要考虑扩容redis了 如何清理内存碎片?...Redis版本4.0以下 重启redis,自动归还所有内存,简单粗暴 Redis版本4.0以上 可以开启自动内存碎片清理: 127.0.0.1:6379[6]> config set activedefrag...,redis也提供了手动内存碎片清理的命令: 127.0.0.1:6379> memory purge OK 总结 占有欲很高的的redis总是会留下已经不用的内存,这在生产环境中必然是不能接受的,所以内存碎片的清理非常重要

    3.1K31

    mysql 正确清理binlog日志

    mysq 正确清理binlog日志 前言: MySQL中的binlog日志记录了数据库中数据的变动,便于对数据的基于时间点和基于位置的恢复,但是binlog也会日渐增大,占用很大的磁盘空间,因此,要对...binlog使用正确安全的方法清理掉一部分没用的日志。...【方法一】手动清理binlog 清理前的准备: ① 查看主库和从库正在使用的binlog是哪个文件 ?...1 purge master logs to'mysql-bin.000022'; //删除指定日志文件的日志索引中binlog日志文件 注意: 时间和文件名一定不可以写错,尤其是时间中的年和文件名中的序号...使用该语法,会将对应的文件和mysql-bin.index中的对应路径删除。 【方法二】通过设置binlog过期的时间,使系统自动删除binlog文件 ?

    3.6K10

    MySQL 常见日志清理策略

    因此,定期清理这些日志是必要的,本篇文章我们一起来学习下如何清理 MySQL 中的日志文件。...例如,使用 purge binary logs to 'mysql-bin.000009' 来删除 mysql-bin.000009 之前的日志文件,或者使用 purge binary logs before...通用查询日志 (General Query Log)MySQL 的 general_log 是记录所有到达 MySQL 服务器的 SQL 语句的日志。...也可以使用 logrotate 功能来配置 general_log 自动轮转及清理。错误日志 (Error Log)错误日志记录 MySQL 服务器启动、关闭及运行时发生的错误及警告信息。...总结:本篇文章简单介绍了 MySQL 中六种常见日志及其清理策略,不同环境可以采用不同的清理策略,本文只是提供一种思路,方法各种各样,重要的是要根据实际情况制定合理的日志保留策略,并确保不会影响到数据库的正常运行和备份需求

    14410

    快速安全清理MySQL binlog

    一、问题提出 之前写过一篇名为“快速安全删除MySQL大表”的博客,讲解如何在不影响线上数据库服务的前提下删除大表。实际上清理MySQL binlog也会遇到同样的问题。...最初的做法是,每天凌晨2:30执行下面的操作清理10天前binlog: mysql -uroot -p123456 -s /data/3306/mysqldata/mysql.sock -e "purge...随着业务量增长出现了两点变化:一是数据库负载增加;二是由于磁盘空间紧张,原存储binglog的磁盘上也存储了MySQL数据。这种情况下,即便是在业务低峰期,每次执行清理任务时也会卡库。...事实证明这种方案行之有效,能够不影响数据库服务同时清理binlog。下面是相关脚本文件及其说明。...mysql mysql 1073742308 Aug 21 11:03 mysqlbinlog.026767 -rw-rw---- 1 mysql mysql 1073742288 Aug 21 11

    1.8K10

    如何彻底卸载清理MySQL

    我们因为各种各样的原因可能需要卸载MySQL或者卸载重装,但是如果MySQL不能清理干净的话是很容易出现问题的。本文就讲讲如何彻底的卸载MySQL,将MySQL从我们的电脑上清理干净。...清理注册表。 1. 卸载软件本身 首先就是把MySQL软件本身卸载掉,卸载的方式有很多种。可以通过各种软件管家卸载掉,也可以通过计算机自带的控制面板卸载掉。这一步很简单,不再赘述。 2....这里我们需要清理两个文件夹。...第一个是:C:\Program Files (x86)\MySQL, 第二个是:C:\ProgramData\MySQL,这里的ProgramData可能是隐藏的,我们需要在资源管理器中设置查看隐藏的文件...清理注册表 往往我们进行完上面的两个步骤,我们计算机上的mysql就已经完全删除了,这时进行重装和其他操作就不会有问题了,但是如果这样还是有问题的话,我们就要尝试清理注册表的信息。

    7.6K20

    centos7释放内存|yum清理缓存与释放内存

    腾讯云服务器内存占用过高,安装的是centos7系统,准备对centos7释放内存,发现使用yum清理缓存与释放内存非常的方便,先使用free -m命令来查看centos7系统剩余了多少内存,准备清理掉...,于是我使用了“sync; echo 3 > /proc/sys/vm/drop_caches”命令来释放包括网页,目录项,索引这3项的内存,完整情况如下,可以看出可用内存达到了622M,效果显著: [...         622           0         114         602 Swap:             0           0           0 那如何使用yum清理缓存呢...清理yum缓存使用yum clean 命令,yum clean 的参数有headers, packages, metadata, dbcache, plugins, expire-cache, rpmdb...yum clean headers  #清理/var/cache/yum的headers yum clean packages #清理/var/cache/yum下的软件包 yum clean metadata

    9.7K31

    linux下清理系统缓存并释放内存

    当linux频繁读取文件后,物理内存会很快被用完,当程序结束后,内存不会被正常释放,而是一直caching,因此有必要手动清理系统缓存释放内存。...sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件 手动释放内存的命令 > echo 3>/proc/sys/vm/drop_caches drop_caches...的值可以是0-3之间的数字,代表不同的含义:0:不释放(系统默认值) 1:释放页缓存 2:释放dentries和inodes 查看内存 > free -h total——总物理内存 used——已使用内存...,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存 free——完全未被使用的内存 shared——应用程序共享内存 buffers——缓存,主要用于目录方面,inode值等(ls...大目录可看到这个值增加) cached——缓存,用于已打开的文件 恢复默认设置 缓存可以提升系统的运行效率,如果发现系统内存经常不够用,应该考虑添加内存,而不是经常清理 > echo 0>/proc/sys

    9.4K10
    领券