mysql之 CentOS系统针对mysql参数优化

内核相关参数(/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

时间: 2024-11-05 21:58:01

mysql之 CentOS系统针对mysql参数优化的相关文章

CentOS系统操作mysql的常用命令

MySQL名字的来历MySQL是一个小型关系型数据库管理系统,MySQL被广泛地应用在Internet上的中小型网站中.由于其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库.CentOS系统中操作mysql的常用命令. 1.CentOS系统中MySQL常用命令create database name; 创建数据库 use databasename; 选择数据库 drop database name 直接删除数据库,不

centos系统重新安装mysql软件

在某些情况下想把centos中的数据库相关安装文件全部删除掉,需要用到yum命令,具体方法如下: 查找mysql相关的安装文件: [[email protected] ~]# rpm -qa | grep mysqlmysql-5.1.47-1.fc11.i586mysql-server-5.1.47-1.fc11.i586mysql-libs-5.1.47-1.fc11.i586 删除列表中所有的文件: [[email protected] ~]# rpm -e mysql-5.1.47-1.

[转载]window系统下TCP参数优化

注:此文转载自红黑联盟,最近服务器遇到周期性down掉的问题,拖了两三周请教了前辈之后才知道无关应用和数据库的事情,是tcp设置的问题.从网上找个这篇文章,解释的很不错.有兴趣请至红黑联盟翻阅原文. TCP连接的状态与关闭方式及其对Server与Client的影响 http://www.2cto.com/net/201304/206071.html 通常会采用修改注册表的方式改进Windows的系统参数.下面将为大家介绍Windows系统下的TCP参数优化方式,适用于Windows 2003.W

CentOS系统 Amoeba+MySql主从读写分离配置 适合新手傻瓜式教程!-----仅供参考!

废话不说,直接开始: 一.安装mysql的三种方式,这里采用第2种(安装方式不再详解,请参照) http://www.cnblogs.com/babywaa/articles/4837946.html 1.rpm安装2.源码安装3.通用二进制源码安装 环境准备 192.168.5.10 master1 192.158.5.20 slave1 二.配置master服务器,192.168.5.101.第一步:登陆mysql,给root账号添加密码     //参考命令:SETPASSWORD = P

Centos系统下面MySql数据库源码包编译

第一步:配置好网络环境,下载cmake软件包(mysql5.5以后是通过cmake来编译的)wget http://www.cmake.org/files/v2.8/cmake-2.8.5.tar.gz 第二步:压解软件包cmaketar -zxvf /data/cmake-2.8.5.tar.gz 进入 cmake-2.8.5 第三步:安装软件包gcc-c++ yum -y install gcc-c++ 第四步:执行./configure来编译cmake./configure make &&a

CentOS系统下Tomcat的优化

一.JVM内存优化 vim ./bin/catalina.sh 在catalina.sh文件中添加以下配置: JAVA_OPTS="-server -Xms128m -Xmx128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -XX:MaxNewSize=32m" 观察配置内容是否生效: 首先查看tomcat进程编号: ps -ef|grep tomcat 然后查看tomcat实际内存信息,通过查看内存信息判断配置是否成功:(进程

Mac os安装MySQL数据库,系统提示mysql: command not found该怎么办

当我们安装好MySQL后,在终端输入mysql命令,发现并不能看到自己安装的数据库,这是因为你没有配置环境变量. 在os系统中安装MySQL数据库默认保存在/usr/local/mysql 那么我们应该如何配置环境变量呢? 1.打开terminal,输入:sudo su   回车  进入系统管理员管理目录(当然你要输入你的用户密码才能进入) 2.输入命令:vim /etc/profile   接着就进入到vim编辑界面 3.在vim编辑界面,按i进入编辑状态,接着,就可以增加路径名称,输入命令:

Linux(Centos )的网络内核参数优化来提高服务器并发处理能力

系统版本  CentOS Linux release 7.6.1810 (Core) 简介 提高服务器性能有很多方法,比如划分图片服务器,主从数据库服务器,和网站服务器在服务器.但是硬件资源额定有限的情况下,最大的压榨服务器的性能,提高服务器的并发处理能力,是很多运维技术人员思考的问题.要提高Linux系统下的负载能力,可以使用nginx等原生并发处理能力就很强的web服务器,如果使用Apache的可以启用其Worker模式,来提高其并发处理能力.除此之外,在考虑节省成本的情况下,可以修改Lin

高并发情况下Linux系统及kernel参数优化

众所周知在默认参数情况下Linux对高并发支持并不好,主要受限于单进程最大打开文件数限制.内核TCP参数方面和IO事件分配机制等.下面就从几方面来调整使Linux系统能够支持高并发环境. Iptables相关 如非必须,关掉或卸载iptables防火墙,并阻止kernel加载iptables模块.这些模块会影响并发性能. 单进程最大打开文件数限制 一般的发行版,限制单进程最大可以打开1024个文件,这是远远不能满足高并发需求的,调整过程如下: 在#号提示符下敲入: # ulimit–n 6553