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。