码迷,mamicode.com
首页 > 数据库 > 详细

Mysql配置参数常见问题

时间:2015-04-07 20:00:46      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:mysql   参数   

Mysql安装时进行初始化安装,最长碰到的问题就是配置参数兼容性的问题,因为数据库的参数发生改变,导致数据库无法识别的情况很让人头疼,好在有官方文档的指引,才能解决这类问题的发生

当前广泛应用的是mysql5.5以上版本,这里以5.6为例,一下包含了所有mysql5.6在使用的参数:

http://dev.mysql.com/doc/refman/5.6/en/mysqld-option-tables.html

比如如下的报错:

[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).

警告说明该参数过去为隐式的默认值,但在新的版本中弃用,需要在配置或启动时显式的增加该配置参数explicit_defaults_for_timestamp。

查看官网解释:

1、Mysql的Timestamp列如果没有显式的声明为空,则给时间戳列分配为非空属性。(其他数据类型的列,如没有显式的声明非空,则允许为空)也就是说当设置这些列为空值时,默认转化为当前的时间戳。

 

2、当Timestamp作为表中首列时,如不声明为空、显式的Default和ON UPDATE子句。则自动分配为default current_timestamp和on update current_timestamp属性。

 

3、当Timestamp列作为表中第二列时,如不声明为空、default子句,则自动分配为default ‘0000-00-00 00:00:00‘(‘零‘ 时间戳)。对于不指明具体Timestamp的行,该列会自动分配零时间戳,且不会产生警告。

 

这些非标行为仍作为默认的时间戳规则直到5.6.6版本被弃用,所以当初始化数据库时会出现上面的告警信息时,可以通过指定explicit_defaults_for_timestamp参数来改变这种非标行为

 

explicit_defaults_for_timestamp采用boolean(布尔)值,默认为FALSE,可以再配置文件my.cnf中明确的开启开参数

explicit_defaults_for_timestamp=true

 

在5.1版本中innodb_file_io_threads参数,设置mysql innodb引擎I/O线程的数量,5.1版使用Innodb plugin时,才用innodb_read_io_threads和innodb_write_io_threads参数来代替,而到了5.6版本则直接使用这两个参数,取消了innodb_file_io_threads参数。

innodb_read_io_threads 默认值4、最小值1、最大值64。

 

 

 

本文出自 “LinuxOracle” 博客,请务必保留此出处http://onlinekof2001.blog.51cto.com/3106724/1629665

Mysql配置参数常见问题

标签:mysql   参数   

原文地址:http://onlinekof2001.blog.51cto.com/3106724/1629665

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!