博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql之 CentOS系统针对mysql参数优化
阅读量:6229 次
发布时间:2019-06-21

本文共 2307 字,大约阅读时间需要 7 分钟。

内核相关参数(/etc/sysctl.conf) 

  以下参数可以直接放到sysctl.conf文件的末尾:
    net.core.somaxconn = 65535
    net.core.netdev_max_backlog = 65535
    net.ipv4.tcp_max_syn_backlog = 65535
    加快TCP连接的回收:
    net.ipv4.tcp_fin_timeout = 10
    net.ipv4.tcp_tw_reuse = 1
    net.ipv4.tcp_tw_recycle = 1

    TCP连接接收和发送缓冲区大小的默认值和最大值:

    net.core.wmem_default = 87380
    net.core.wmem_max = 16777216
    net.core.rmem_default = 87380
    net.core.rmem_max = 16777216

    减少失效连接所占用的TCP资源的数量,加快资源回收的效率

    net.ipv4.tcp_keepalive_time = 120
    net.ipv4.tcp_keepalive_intvl = 30
    net.ipv4.tcp_keepalive_probes = 3

    kernel.shmmax = 4294967295

    Linux内核参数中最重要的参数之一,用于定义单个共享内存段的最大值。
    注意:
      1. 这个参数应该设置的足够大,以便能在一个共享内存段下容纳整个的Innodb
      缓冲池的大小
      2. 这个值的大小对于64位linux系统,可取的最大值为物理内存值-1byte,建议
      值为大于物理内存的一半,一般取值大于Innodb缓冲池的大小即可,可以取物理内存-1byte

      vm.swappiness = 0

      这个参数当内存不足时会对性能产生比较明显的影响。
    Linux系统内存交换区:
      在Linux系统安装时都会有一个特殊的磁盘分区,称之为系统交换分区。
    使用free-m命令可以看到swap就是内存交换区.
    作用:
      当操作系统因为没有足够的内存时就会将一些虚拟内存写到磁盘的交换区中
    这样就会发生内存交换。
    在MySQL服务器上是否要使用交换分区有一些争议:
        在MySQL服务所在的Linux系统上完全禁用交换分区。
    带来的风险:
      1. 降低操作系统的性能
      2. 容易造成内存溢出,崩溃,或都被操作系统kill掉
    结论:
      在MySQL服务器上保留交换区还是很必要的,但是要控制何时使用交换分区。
    Vm.swappiness = 0
    就是告诉Linux内核除非虚拟内存完全满了,否则不要使用交换区。

 

增加资源限制(/etc/security/limit.conf)

这个文件实际上是Linux PAM也就是插入式认证模块的配置文件。
打开文件数的限制:
  soft nofile 65535
  hard nofile 65535
  * 表示对所有用户有效
  soft 指的是当前系统生效的设置
  hard 表明系统中所能设定的最大值
  nofile 表示所限制的资源是打开文件的最大数目
  65535 限制的数量
  soft不能大于hard
  直接加到limit.conf文件的末尾就可以了。
  结论:把可打开的文件数量增加到65535个以保证可以打开足够多的文件句柄。
  注意:这个文件的修改需要重启系统才能生效。

磁盘调度策略(/sys/block/devname/queue/scheduler)

cat /sys/block/devname/queue/scheduler
调度策略: noop anticipatory deadline [cfg]

noop(电梯式调度策略)

NOOP实现了一个FIFO队列,它像电梯的工作方法一样对I/O请求进行组织,当有一个新
的请求到来时,它将请求合并到最近的请求之后,以此来保证请求同一介质。NOOP倾向饿死读而
利于写,因此NOOP对于闪存设备、RAM及嵌入式系统是最好的选择。

deadline(截止时间调度策略)

deadline确保了在一个截止时间内服务请求,这个截止时间是可调整的,而默认读期限
短于写期限。这样就防止了写操作因为不能被读取而饿死的现象,deadline对数据库类应用是最
好的选择。

anticipatory(预料I/O调度策略)

本质上与deadline一样,但在最后一次读操作之后,要等待6ms,才能继续进行对其它I/O
请求进行调度。它会在每个6ms中插入新的I/O操作,而会将一些小写入流合并成一个大写入流,用
写入延时换区最大的写入吞吐量。AS适合于写入较多的环境,比如文件服务器,AS对数据库环境表
现很差。

修改调度策略:

  echo <schedulername> > /sys/block/devname/queue/scheduler
  如 echo deadline /sys/block/devname/queue/scheduler

转载于:https://www.cnblogs.com/andy6/p/9722950.html

你可能感兴趣的文章
iframe调用父页面javascript函数的方法
查看>>
windows休眠命令
查看>>
iOS中的UIScrollView
查看>>
程序中新建Thread部署到WebSphere中产生的问题
查看>>
vtk学习笔记 --- 显示label之vtkLabelPlacementMapper
查看>>
也谈未来移动设备发展的趋势
查看>>
Hive快速入门
查看>>
时光启程了岁月里所有的狼狈
查看>>
ORA-00119,ORA-00132 错误处理
查看>>
让你永远赢得Popcap bookworm
查看>>
数据库同步和数据库复制技术分析
查看>>
oracle 密码问题
查看>>
019—两道题学会MYSQL多表查询02
查看>>
STM32学习笔记(4):通用定时器基本定时功能
查看>>
MVC 一个简单的MVC框架
查看>>
用户画像——persona分析法
查看>>
第一片51cto博文
查看>>
c++中back_inserter
查看>>
Discuz与Moodle实现同步登录:
查看>>
Linux C语言的定时器使用方法
查看>>