MySQL服务器端的参数有很多,但是对于大多数初学者来说,众多的参数往往使得我们不知所措,但是哪些参数是需要我们调整的,哪些对服务器的性能影响最大呢?对于使用Myisam存储引擎来说,主要有key_buffer_size和table_cache两个参数。对于InnoDB引擎来说主要还是以innodb_开始的参数,也很好辨认。

查看MySQL参数,可以使用show variables和show status命令查看,前者查看服务器静态参数,即在数据库启动后不会动态更改的值,比如缓冲区、字符集等。后者查看服务器的动态运行状态信息,即数据库运行期间动态变化的信息,比如锁,当前连接数等。

key_buffer_size这个参数是用来设置索引块(index blocks)缓存的大小,它被所有线程共享,严格说是它决定了数据库索引处理的速度,尤其是索引读的速度。那我们怎么才能知道key_buffer_size的设置是否合理呢,一般可以检查状态值Key_read_requests和Key_reads,比例key_reads / key_read_requests应该尽可能的低,比如1:100,1:1000 ,1:10000。其值可以用以i下命令查得:

mysql> show status like 'key_read%';+-------------------+------------+| Variable_name     | Value      |+-------------------+------------+| Key_read_requests | 3916880184 | | Key_reads         | 1014261    | +-------------------+------------+2 rows in set (0.00 sec)

3916880184/1024/1024=?M    //单位为兆

我的key_buffer_size值为:

key_buffer_size=536870912/1024/1024=512M,

key_reads / key_read_requests=1014261: 3916880184≈1:4000,照上面来看,健康状况还行。

table_cache指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。通过检查峰值时间的状态值Open_tables和Opened_tables,可以决定是否需要增加table_cache的值。如果你发现open_tables等于table_cache,并且opened_tables在不断增长,那么你就需要增加table_cache的值了(上述状态值可以使用SHOW STATUS LIKE ‘Open%tables’获得)。注意,不能盲目地把table_cache设置成很大的值。如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。

open_tables表示当前打开的表缓存数,如果执行flush tables操作,则此系统会关闭一些当前没有使用的表缓存而使得此状态值减小;

opend_tables表示曾经打开的表缓存数,会一直进行累加,如果执行flush tables操作,值不会减小。

在mysql默认安装情况下,table_cache的值在2G内存以下的机器中的值默认时256到512,如果机器有4G内存,则默认这个值是2048,但这决意味着机器内存越大,这个值应该越大,因为table_cache加大后,使得mysql对SQL响应的速度更快了,不可避免的会产生更多的死锁(dead lock),这样反而使得数据库整个一套操作慢了下来,严重影响性能。所以平时维护中还是要根据库的实际情况去作出判断,找到最适合你维护的库的table_cache值。

就是table_cache加大后碰到文件描述符不够用的问题,在mysql的配置文件中有这么一段提示:引用“The number of open tables for all threads. Increasing this value increases the number of file descriptors that mysqld requires.Therefore you have to make sure to set the amount of open files allowed to at least 4096 in the variable "open-files-limit" in” section [mysqld_safe]”说的就是要注意这个问题,一想到这里,部分兄弟可能会用ulimit -n 作出调整,但是这个调整实际是不对的,换个终端后,这个值又会回到原始值,所以最好用sysctl或者修改/etc/sysctl.conf文件,同时还要在配置文件中把open_files_limit这个参数增大,对于4G内存服务器,相信现在购买的服务器都差不多用4G的了,那这个这个open_files_limit至少要增大到4096,如果没有什么特殊情况,设置成8192就可以了。

innodb_buffer_pool_size 这个参数和MyISAM的key_buffer_size有相似之处,但也是有差别的。这个参数主要缓存innodb表的索引,数据,插入数据时的缓冲。为Innodb加速优化首要参数。  该参数分配内存的原则:这个参数默认分配只有8M,可以说是非常小的一个值。如果是一个专用DB服务器,那么他可以占到内存的70%-80%。这个参数不能动态更改,所以分配需多考虑。分配过大,会使Swap占用过多,致使Mysql的查询特慢。如果你的数据比较小,那么可分配是你的数据大小+10%左右做为这个参数的值。

小编推荐:欲学习电脑技术、系统维护、网络管理、编程开发和安全攻防等高端IT技术,请 点击这里注册账号,公开课频道价值万元IT培训教程免费学,让您少走弯路、事半功倍,好工作升职加薪!

免责声明:本站系公益性非盈利IT技术普及网,本文由投稿者转载自互联网的公开文章,文末均已注明出处,其内容和图片版权归原网站或作者所有,文中所述不代表本站观点,若有无意侵权或转载不当之处请从网站右下角联系我们处理,谢谢合作!

mysql服务器端的参数有很多_但是对于大多数初学者来说_mysql优化的重要参数 key_buffer_size table_cache...相关推荐

  1. 微信小程序点击带id参数跳转_微信小程序页面跳转方法和携带参数详解

    1.页面跳转方式 (1)标签跳转 open-type的属性值对应api里的用法即wx.的用法 1 跳转到新页面 (2)wx.navigateTo 方法跳转 此方法能够从跳转的页面会回到当前页面 1 w ...

  2. 内存条上面参数详解_「内存」新旧光威16GB内存条参数对比,发现镁光颗粒

    我第一次买了两条,一条当场翻车了,就换了一条,当时没有发现有任何颗粒上的变化,新旧内存都是南亚颗粒的. 这次我当时同批次的第二条内存翻车了,换来的内存我看了一眼,居然是镁光颗粒的,看来是这批产品有所更 ...

  3. python多元回归 导出参数统计结果_如何从统计模型中WLS回归的二维参数得到检验的预测...

    我使用statsmodels递增地增加WLS regression functions的参数.在 我有一个10x3的数据集X,我这样声明:X = np.array([[1,2,3],[1,2,3],[ ...

  4. python默认参数 可变对象_最小经验原则(POLA)与可变默认参数

    题目 任何长时间学习Python的人都会遇到下面的问题. def foo(a=[]): a.append(5) return a Python初学者期望这个函数总是会返回一个只包含一个元素的列表:[5 ...

  5. 华为5ipro详细参数使用功能_详细讲解双计双控智能电表技术参数以及新增功能优势...

    双计双控智能电表(升级版)是一款具有两路计量两路控制智能费控功能的电表,相当于两台智能电表组合成一台智能电表.它采用微电子技术研制的新型电度表,该表具有高精度计量.智能费控.自动结算电费.恶性负载识别 ...

  6. mysql优化的重要参数 key_buffer_size table_cache

    MySQL服务器端的参数有很多,但是对于大多数初学者来说,众多的参数往往使得我们不知所措,但是哪些参数是需要我们调整的,哪些对服务器的性能影响最大呢?对于使用Myisam存储引擎来说,主要有key_b ...

  7. mysql spool csv报错_参数化之利用CSV Data Set Config从文件读取参数并关联变量

    1. 添加CSV Data Set Config 右键线程组->配置元件->CSV Data Set Config 2. 配置 新建test.cvs文件内容如下 CSV Data Set ...

  8. mysql临时表如何分页查询慢_数据量很大,分页查询很慢,怎么优化?

    作者:悠悠i,来源: http://uee.me/aVSnD 当需要从数据库查询的表有上万条记录的时候,一次性查询所有结果会变得很慢,特别是随着数据量的增加特别明显,这时需要使用分页查询.对于数据库分 ...

  9. mysql 优化300例_MySQL配置文件my.cnf参数优化和中文详解

    Mysql参数优化对于新手来讲,是比较难懂的东西,其实这个参数优化,是个很复杂的东西,对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的 ...

最新文章

  1. ruid/euid/suid
  2. error: dereferencing pointer to incomplete type
  3. Ollivander's Inventory(连接查询、单表双实例、子查询)
  4. JavaScript-2(数组与字符串的方法)
  5. Python uuid 介绍
  6. c语言怎样计算栈的长度,数据结构与算法:栈 C语言实现
  7. QT关于Excel的操作
  8. flash动画制作成品_Flash如何制作沿曲线移动的箭头动画
  9. 个人h5第三方支付接口_个人免签支付接口系统搭建源码多种方式
  10. 用python解决搬砖问题_如何像要饭一般”用“python (一)(非编程类工作/科研搬砖工)...
  11. 动物识别论文整理——一种基于生物特征的鱼类分类模型
  12. Repository does not allow updating assets 解决方法
  13. Macs Fan Control Pro for mac( 电脑风扇控制软件)
  14. 什么是零点漂移,怎么抑制零点漂移?(硬件每日一题)
  15. form表单提交时传递额外的参数
  16. 中国首条3D刷脸地铁开通,终于理解数加加众包为啥采集人脸了
  17. Docker学习--Docker镜像的管理操作
  18. 石墨计算机,电脑CPU可不可以用石墨做?
  19. mysql中vlookup函数_VLOOKUP函数的使用方法(入门级)
  20. 【01】花卉识别-基于tensorflow2.3实现

热门文章

  1. [JS]在ACM模式下获取输入
  2. Only the original thread that created a view hierarchy can touch its views
  3. github READme 的使用教程
  4. android DrawerLayout 改变系统默认的灰色
  5. 转 前端工程师凭什么这么值钱?
  6. Activiti——数据表结构
  7. PyTorch 笔记(01)— Ubuntu 使用 pip 清华源安装 PyTorch
  8. 关于打开新链接,用当前页还是用新页面?
  9. 学习笔记-express路径问题
  10. Nginx反向代理负载均衡