Mysql运行环境优化(Linux系统)

  这篇文章主要介绍了Mysql运行环境优化(Linux系统),本文优化了修改Linux默认的IO调度算法、扩大文件描述符、禁用numa特性、修改swappiness设置、优化文件系统挂载参数等配置,需要的朋友可以参考下

  一、修改Linux默认的IO调度算法.

  linux默认的IO调度算法为cfq,需要修改为dealine,如果是SSD或者PCIe-SSD设备,需要修改为noop,可以使用下面两种修改方式。

  1、在线动态修改,重启失效。

  代码如下:

  echo “deadline” > /sys/block/sda/queue/scheduler

  tips:这里的sda代表你需要修改的硬盘,根据你实际情况修改。

  2、修改/etc/grub.conf,永久生效。

  修改/etc/grub.conf配置文件,在kernel那行增加一个配置,例如:

  代码如下:

  kernel /vmlinuz-2.6.32-279.el6.x86_64 ro root=UUID=e01d6bb4-bd74-404f-855a-0f700fad4de0 rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun1

  6 crashkernel=auto KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM elevator=deadline rhgb quiet

  主要关注elevator这个参数,设置内核的话需要重启系统才能生效。

  最后可以通过 cat /sys/block/sda/queue/scheduler 观察一下,修改前和修改后的区别。

  二、扩大文件描述符

  这个是经常修改的参数,高并发的程序都会修改。

  1、动态修改,重启失效,只能使用root,并且当前session有效。

  代码如下:

  ulimit -n 51200

  2、修改配置文件,永久生效。

  在/etc/security/limits.conf配置文件中增加一行

  代码如下:

  * hard nofile 51200

  扩大可开启进程数 nprocess /etc/security/limits.conf

  在/etc/security/limits.conf配置文件中增加一行

  代码如下:

  * hard nproc 51200

  最后修改/etc/pam.d/login文件添加

  代码如下:

  session required /lib64/security/pam_limits.so

  重启系统以后使用 ulimit -a 命令查看是否生效。

  三、禁用numa特性

  新一代架构的NUMA不适合跑数据库,它本意是为了提高内存利用率,但是实际效果不好,反而可能导致一CPU的内存尚有剩余,但是另外一个不够用,发生swap的问题,因此建议关闭或者修改NUMA的调度机制。

  1、修改/etc/grub.conf关闭NUMA,重启后生效。

  代码如下:

  kernel /vmlinuz-2.6.32-279.el6.x86_64 ro root=UUID=e01d6bb4-bd74-404f-855a-0f700fad4de0 rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun1

  6 crashkernel=auto KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM elevator=deadline numa=off rhgb quiet

  2、修改/etc/init.d/mysql或者mysqld_safe脚本,设置启动mysqld进程时的NUMA调度机制,例如。

  在新版的mysqld_safe脚本中自带如下内容,所以不需要添加,你可以看看你的mysqld_safe脚本有没有如下内容。

  代码如下:

  if true && test $numa_interleave -eq 1

  then

  # Locate numactl, ensure it exists.

  if ! my_which numactl > /dev/null 2>&1

  then

  log_error “numactl command not found, required for –numa-interleave”

  exit 1

  # Attempt to run a command, ensure it works.

  elif ! numactl –interleave=all true

  then

  log_error “numactl failed, check if numactl is properly installed”

  fi # Launch mysqld with numactl.

  cmd=”$cmd numactl –interleave=all”

  elif test $numa_interleave -eq 1

  then

  log_error “–numa-interleave is not supported on this platform”

  exit 1

  fi

  四、修改swappiness设置
swappiness是linux的一个内核参数,用来控制物理内存交换出去的策略.它允许一个百分比的值,最小的为0,最大的为100,改值默认是60.可以通过下面命令观察

  代码如下:

  # sysctl -a | grep swappiness

  vm.swappiness = 60

  这个设置值到底有什么影响呢?

  vm.swappiness设置为0表示尽量少使用swap,100表示尽量将inactive的内存页交换到swap里或者释放cache(cache类似于预读的文件)。

  inactive内存的意思是程序映射着,但是”长时间”不用的内存。我们可以利用vmstat查看系统里面有多少inactive的内存。

  代码如下:

  # vmstat -a 1

  procs ———–memory———- —swap– —–io—- –system– —–cpu——

  r b swpd free inact active si so bi bo in cs us sy id wa st

  0 0 16930764 192752 3673320 28601732 0 0 19 31 0 0 1 0 99 0 0

  1 0 16930764 192752 3673320 28601732 0 0 0 0 1136 271 0 0 100 0 0

  0 0 16930764 192748 3673320 28601732 0 0 0 56 1167 325 1 0 99 0 0

  0 0 16930764 192740 3673320 28601732 0 0 0 40 1039 164 0 0 100 0 0

  在Centos7之前,这个值建议设置为0,但是在新版本的内核里面,这样设置可能导致OOM(内存溢出),然后kernel会杀掉使用内存最多的mysqld进程。

  所以现在这个值推荐设置为1,设置方法如下:

  在/etc/sysctl.conf文件中增加一行。

  代码如下:

  vm.swappiness = 1

  # sysctl -p //运行这个命令,让配置立刻生效。

  五、优化文件系统挂载参数。

  首先关于使用什么文件系统,网上很多测试,烟花缭乱.大概的结论如下。

  xfs > ext3:xfs性能优于ext3

  ext4 > ext3:ext4性能优于ext3

  ext4 ??? xfs :xfs和ext4谁更优秀?我说不太准…..

  然后就是挂载文件系统使用的参数:

  代码如下:

  defaults,noatime,nodiratime,barrier=0(在xfs上使用nobarrier)

  文件系统挂载参数是在/etc/fstab文件中修改,重启时候生效。

  noatime表示不记录访问时间,nodiratime不记录目录的访问时间。

  barrier=0,表示关闭barrier功能.barrier的主要目的是为了保证磁盘写数据的安全性,但是会降低性能。如果有BBU之类的电池备份电源保证控制卡不瞬间掉电,那么这个功能就可以放心大胆的关闭。

  可以通过一下命令,查看配置是否生效.

  代码如下:

  # cat /proc/mounts

  rootfs / rootfs rw 0 0

  proc /proc proc rw,nosuid,nodev,noexec,relatime 0 0

  sysfs /sys sysfs rw,seclabel,nosuid,nodev,noexec,relatime 0 0

  devtmpfs /dev devtmpfs rw,seclabel,nosuid,relatime,size=8188388k,nr_inodes=2047097,mode=755 0 0

  devpts /dev/pts devpts rw,seclabel,relatime,gid=5,mode=620,ptmxmode=000 0 0

  tmpfs /dev/shm tmpfs rw,seclabel,nosuid,nodev,relatime 0 0

  /dev/sda3 / ext4 rw,seclabel,relatime,noatime,nodiratime,barrier=0,data=ordered 0 0

  none /selinux selinuxfs rw,relatime 0 0

  devtmpfs /dev devtmpfs rw,seclabel,nosuid,relatime,size=8188388k,nr_inodes=2047097,mode=755 0 0

  /proc/bus/usb /proc/bus/usb usbfs rw,relatime 0 0

  none /proc/sys/fs/binfmt_misc binfmt_misc rw,relatime 0 0

 

  /dev/sda1 /boot ext4 rw,seclabel,noatime,nodiratime,barrier=0,data=ordered 0 0

 

时间: 2024-09-12 06:54:08

Mysql运行环境优化(Linux系统)的相关文章

Mysql运行环境优化(Linux系统)_Mysql

一.修改Linux默认的IO调度算法. linux默认的IO调度算法为cfq,需要修改为dealine,如果是SSD或者PCIe-SSD设备,需要修改为noop,可以使用下面两种修改方式. 1.在线动态修改,重启失效. 复制代码 代码如下: echo "deadline" > /sys/block/sda/queue/scheduler tips:这里的sda代表你需要修改的硬盘,根据你实际情况修改. 2.修改/etc/grub.conf,永久生效. 修改/etc/grub.co

在Linux上优化Mysql运行环境让你对Mysql更多了解

  接触过Mysql的都是知道它是数据库,很多用户知道如何使用Mysql数据库,但对Mysql运行环境的优化却知之甚少,如果你想要掌握Mysql数据库,对Mysql运行环境的优化也要了解一些,下面小编就给大家介绍下Linux优化Mysql运行环境的方法. 一.修改Linux默认的IO调度算法. linux默认的IO调度算法为cfq,需要修改为dealine,如果是SSD或者PCIe-SSD设备,需要修改为noop,可以使用下面两种修改方式. 1.在线动态修改,重启失效. echo "deadli

优化Linux系统硬盘性能的一些具体措施

http://www.aliyun.com/zixun/aggregation/32995.html">在Windows系统中,磁盘碎片是一个常见的问题,如果不注意,系统性能可能被侵蚀.Linux使用第二扩展文件系统(ext2),它以一种完全不同的方式处理文件存储.Linux没有Windows系统中发现的那种问题,这使得许多人认为磁盘碎片化根本不是一个问题.但是,这是不正确的. 所有的文件系统随着时间的推移都趋向于碎片化.Linux文件系统减少了碎片化,但是并没有消除.由于它不经常出现,所

mysql cluster 配置问题(Linux系统)

问题描述 mysql cluster 配置问题(Linux系统) 1C http://blog.csdn.net/chengfei112233/article/details/7700559按照上面的做,在 启动MySQL服务引擎时失败[root@localhost my_cluster]# /home/mysql/mysqlc/bin/mysqld --defaults-file=/home/mysql/my_cluster/conf/my.cnf & [1] 14213[root@local

php+MYSQL运行环境的配置

  安装步骤: 1.将压缩包解压到C:\PHP这个目录下. 2.将"C:\php\dlls"目录下的所有文件复制到"c:\WinNT\System32(Winodws98系统为C:\Windows\System)"目录下,有旧的文件存在就覆盖它. 3.将C:\PHP\php.ini-dist这个文件改名为PHP.ini,复制到"C:\WinNT(Winodws98系统为C:\Windows)"目录下,并修改里面的内容,具体如下: 找到"

在Linux运行期间升级Linux系统(Uboot+kernel+Rootfs)

版本:v1.2   Crifan Li 摘要 本文主要介绍了如何在嵌入式Linux系统运行的时候,进行升级整个Linux系统,包括uboot,kernel和rootfs.以及简介Linux中的已有的通用的Nor Flash驱动m25p80,和简介mtd util以及相关工具mtdinfo,flash_erase,flash_eraseall,nanddump,nandwrite等的基本用法. 本文提供多种格式供: 在线阅读 HTML HTMLs PDF CHM TXT RTF WEBHELP 下

centos7最小版本安装nginx+tomcat+java+mysql运行环境

最近项目从windows搬到linux,由于项目组成员有限并且有其它紧急的任务需要处理,因而这个任务就落到我的头上了.下面记录下centos最小版本安装nginx+tomcat+mysql+java的运行环境. centos7 minimal安装 参考:http://www.tecmint.com/centos-7-installation/ 安装java 下载Java,可到oracle官网获取相应的连接 wget http://download.oracle.com/otn-pub/java/

云主机搭建php+mysql运行环境教程(护卫神 PHP套件)_win服务器

    目前windows系统使用iis来搭建php+mysql环境的居多,由于手动配置会出现很多意想不到的错误以及安全上的问题,这里推荐的是护卫神·PHP套件,可以非常方便的搭建好php+mysql+phpmyadmin    一般系统安装完成以后,都自带了iis,这里就不介绍了,在远程云主机上面下载护卫神·PHP套件 ISAPI版:下载    FastCGI版:电信下载 上面是护卫神php套件下载,一般windows 2003下载的是ISAPI版 在远程服务器上下载万护卫神php套件后,打开

(转)虚拟机环境中linux系统增加磁盘空间

前段时间在vmware ESXi虚拟化环境中安装了一套turbolinux系统,当时并没有在意磁盘如何规划,使用了LVM,心想反正能够随时扩展.不料时间不长,问题出现了,分配的磁盘空间满了.以为能够象windows Server环境中使用磁盘管理增加动态磁盘那样方便呢,就随意在ESX管理器中将原有的磁盘从10G增加到了13G,重启挂载LVM没有左右,重启系统了. 重启后 ,使用fdisk -l能够看到/dev/sda的空间已经增加了,但仍还是原来的两个磁盘/dev/sda1和/dev/sda2