lib/cookbooks/mysql/attributes/server.rb in server_maint-0.0.4 vs lib/cookbooks/mysql/attributes/server.rb in server_maint-0.0.5
- old
+ new
@@ -17,61 +17,82 @@
# limitations under the License.
#
default['mysql']['bind_address'] = attribute?('cloud') ? cloud['local_ipv4'] : ipaddress
default['mysql']['port'] = 3306
+default['mysql']['nice'] = 0
-case node["platform"]
-when "centos", "redhat", "fedora", "suse", "scientific", "amazon"
+case node["platform_family"]
+when "debian"
default['mysql']['server']['packages'] = %w{mysql-server}
- default['mysql']['service_name'] = "mysqld"
+ default['mysql']['service_name'] = "mysql"
default['mysql']['basedir'] = "/usr"
default['mysql']['data_dir'] = "/var/lib/mysql"
default['mysql']['root_group'] = "root"
default['mysql']['mysqladmin_bin'] = "/usr/bin/mysqladmin"
default['mysql']['mysql_bin'] = "/usr/bin/mysql"
- set['mysql']['conf_dir'] = '/etc'
- set['mysql']['confd_dir'] = '/etc/mysql/conf.d'
- set['mysql']['socket'] = "/var/lib/mysql/mysql.sock"
- set['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
- set['mysql']['old_passwords'] = 1
- set['mysql']['grants_path'] = "/etc/mysql_grants.sql"
+ default['mysql']['conf_dir'] = '/etc/mysql'
+ default['mysql']['confd_dir'] = '/etc/mysql/conf.d'
+ default['mysql']['socket'] = "/var/run/mysqld/mysqld.sock"
+ default['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
+ default['mysql']['old_passwords'] = 0
+ default['mysql']['grants_path'] = "/etc/mysql/grants.sql"
+when "rhel", "fedora", "suse"
+ if node["mysql"]["version"].to_f >= 5.5
+ default['mysql']['service_name'] = "mysql"
+ default['mysql']['pid_file'] = "/var/run/mysql/mysql.pid"
+ else
+ default['mysql']['service_name'] = "mysqld"
+ default['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
+ end
+ default['mysql']['server']['packages'] = %w{mysql-server}
+ default['mysql']['basedir'] = "/usr"
+ default['mysql']['data_dir'] = "/var/lib/mysql"
+ default['mysql']['root_group'] = "root"
+ default['mysql']['mysqladmin_bin'] = "/usr/bin/mysqladmin"
+ default['mysql']['mysql_bin'] = "/usr/bin/mysql"
+
+ default['mysql']['conf_dir'] = '/etc'
+ default['mysql']['confd_dir'] = '/etc/mysql/conf.d'
+ default['mysql']['socket'] = "/var/lib/mysql/mysql.sock"
+ default['mysql']['old_passwords'] = 1
+ default['mysql']['grants_path'] = "/etc/mysql_grants.sql"
# RHEL/CentOS mysql package does not support this option.
- set['mysql']['tunable']['innodb_adaptive_flushing'] = false
+ default['mysql']['tunable']['innodb_adaptive_flushing'] = false
when "freebsd"
default['mysql']['server']['packages'] = %w{mysql55-server}
default['mysql']['service_name'] = "mysql-server"
default['mysql']['basedir'] = "/usr/local"
default['mysql']['data_dir'] = "/var/db/mysql"
default['mysql']['root_group'] = "wheel"
default['mysql']['mysqladmin_bin'] = "/usr/local/bin/mysqladmin"
default['mysql']['mysql_bin'] = "/usr/local/bin/mysql"
- set['mysql']['conf_dir'] = '/usr/local/etc'
- set['mysql']['confd_dir'] = '/usr/local/etc/mysql/conf.d'
- set['mysql']['socket'] = "/tmp/mysqld.sock"
- set['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
- set['mysql']['old_passwords'] = 0
- set['mysql']['grants_path'] = "/var/db/mysql/grants.sql"
+ default['mysql']['conf_dir'] = '/usr/local/etc'
+ default['mysql']['confd_dir'] = '/usr/local/etc/mysql/conf.d'
+ default['mysql']['socket'] = "/tmp/mysqld.sock"
+ default['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
+ default['mysql']['old_passwords'] = 0
+ default['mysql']['grants_path'] = "/var/db/mysql/grants.sql"
when "windows"
default['mysql']['server']['packages'] = ["MySQL Server 5.5"]
default['mysql']['version'] = '5.5.21'
default['mysql']['arch'] = 'win32'
default['mysql']['package_file'] = "mysql-#{mysql['version']}-#{mysql['arch']}.msi"
default['mysql']['url'] = "http://www.mysql.com/get/Downloads/MySQL-5.5/#{mysql['package_file']}/from/http://mysql.mirrors.pair.com/"
default['mysql']['service_name'] = "mysql"
default['mysql']['basedir'] = "#{ENV['SYSTEMDRIVE']}\\Program Files (x86)\\MySQL\\#{mysql['server']['packages'].first}"
- default['mysql']['data_dir'] = "#{mysql['basedir']}\\Data"
- default['mysql']['bin_dir'] = "#{mysql['basedir']}\\bin"
- default['mysql']['mysqladmin_bin'] = "#{mysql['bin_dir']}\\mysqladmin"
- default['mysql']['mysql_bin'] = "#{mysql['bin_dir']}\\mysql"
+ default['mysql']['data_dir'] = "#{node['mysql']['basedir']}\\Data"
+ default['mysql']['bin_dir'] = "#{node['mysql']['basedir']}\\bin"
+ default['mysql']['mysqladmin_bin'] = "#{node['mysql']['bin_dir']}\\mysqladmin"
+ default['mysql']['mysql_bin'] = "#{node['mysql']['bin_dir']}\\mysql"
- default['mysql']['conf_dir'] = "#{mysql['basedir']}"
+ default['mysql']['conf_dir'] = node['mysql']['basedir']
default['mysql']['old_passwords'] = 0
- default['mysql']['grants_path'] = "#{mysql['conf_dir']}\\grants.sql"
+ default['mysql']['grants_path'] = "#{node['mysql']['conf_dir']}\\grants.sql"
when "mac_os_x"
default['mysql']['server']['packages'] = %w{mysql}
default['mysql']['basedir'] = "/usr/local/Cellar"
default['mysql']['data_dir'] = "/usr/local/var/mysql"
default['mysql']['root_group'] = "admin"
@@ -84,70 +105,136 @@
default['mysql']['data_dir'] = "/var/lib/mysql"
default['mysql']['root_group'] = "root"
default['mysql']['mysqladmin_bin'] = "/usr/bin/mysqladmin"
default['mysql']['mysql_bin'] = "/usr/bin/mysql"
- set['mysql']['conf_dir'] = '/etc/mysql'
- set['mysql']['confd_dir'] = '/etc/mysql/conf.d'
- set['mysql']['socket'] = "/var/run/mysqld/mysqld.sock"
- set['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
- set['mysql']['old_passwords'] = 0
- set['mysql']['grants_path'] = "/etc/mysql/grants.sql"
+ default['mysql']['conf_dir'] = '/etc/mysql'
+ default['mysql']['confd_dir'] = '/etc/mysql/conf.d'
+ default['mysql']['socket'] = "/var/run/mysqld/mysqld.sock"
+ default['mysql']['pid_file'] = "/var/run/mysqld/mysqld.pid"
+ default['mysql']['old_passwords'] = 0
+ default['mysql']['grants_path'] = "/etc/mysql/grants.sql"
end
if attribute?('ec2')
default['mysql']['ec2_path'] = "/mnt/mysql"
default['mysql']['ebs_vol_dev'] = "/dev/sdi"
default['mysql']['ebs_vol_size'] = 50
end
default['mysql']['reload_action'] = "restart" # or "reload" or "none"
-default['mysql']['use_upstart'] = node.platform?("ubuntu") && node.platform_version.to_f >= 10.04
+default['mysql']['use_upstart'] = node['platform'] == "ubuntu" && node['platform_version'].to_f >= 10.04
default['mysql']['auto-increment-increment'] = 1
default['mysql']['auto-increment-offset'] = 1
default['mysql']['allow_remote_root'] = false
+default['mysql']['tunable']['character-set-server'] = "utf8"
+default['mysql']['tunable']['collation-server'] = "utf8_general_ci"
default['mysql']['tunable']['back_log'] = "128"
default['mysql']['tunable']['key_buffer'] = "256M"
+default['mysql']['tunable']['myisam_sort_buffer_size'] = "8M"
+default['mysql']['tunable']['myisam_max_sort_file_size'] = "2147483648"
+default['mysql']['tunable']['myisam_repair_threads'] = "1"
+default['mysql']['tunable']['myisam_recover'] = "BACKUP"
default['mysql']['tunable']['max_allowed_packet'] = "16M"
default['mysql']['tunable']['max_connections'] = "800"
-default['mysql']['tunable']['max_heap_table_size'] = "32M"
+default['mysql']['tunable']['max_connect_errors'] = "10"
+default['mysql']['tunable']['concurrent_insert'] = "2"
+default['mysql']['tunable']['connect_timeout'] = "10"
+default['mysql']['tunable']['tmp_table_size'] = "32M"
+default['mysql']['tunable']['max_heap_table_size'] = node['mysql']['tunable']['tmp_table_size']
+default['mysql']['tunable']['bulk_insert_buffer_size'] = node['mysql']['tunable']['tmp_table_size']
default['mysql']['tunable']['myisam_recover'] = "BACKUP"
default['mysql']['tunable']['net_read_timeout'] = "30"
default['mysql']['tunable']['net_write_timeout'] = "30"
default['mysql']['tunable']['table_cache'] = "128"
-default['mysql']['tunable']['table_open_cache'] = "128"
+
default['mysql']['tunable']['thread_cache'] = "128"
default['mysql']['tunable']['thread_cache_size'] = 8
default['mysql']['tunable']['thread_concurrency'] = 10
default['mysql']['tunable']['thread_stack'] = "256K"
+default['mysql']['tunable']['sort_buffer_size'] = "2M"
+default['mysql']['tunable']['read_buffer_size'] = "128k"
+default['mysql']['tunable']['read_rnd_buffer_size'] = "256k"
+default['mysql']['tunable']['join_buffer_size'] = "128k"
default['mysql']['tunable']['wait_timeout'] = "180"
+default['mysql']['tunable']['open-files-limit'] = "8192"
+default['mysql']['tunable']['open-files'] = "1024"
+default['mysql']['tunable']['sql_mode'] = nil
+
+default['mysql']['tunable']['skip-character-set-client-handshake'] = false
+default['mysql']['tunable']['skip-name-resolve'] = false
+
+
+default['mysql']['tunable']['server_id'] = nil
default['mysql']['tunable']['log_bin'] = nil
default['mysql']['tunable']['log_bin_trust_function_creators'] = false
-default['mysql']['tunable']['relay_log'] = nil
+
+default['mysql']['tunable']['relay_log'] = nil
+default['mysql']['tunable']['relay_log_index'] = nil
default['mysql']['tunable']['log_slave_updates'] = false
+
default['mysql']['tunable']['sync_binlog'] = 0
default['mysql']['tunable']['skip_slave_start'] = false
+default['mysql']['tunable']['read_only'] = false
default['mysql']['tunable']['log_error'] = nil
+default['mysql']['tunable']['log_warnings'] = false
default['mysql']['tunable']['log_queries_not_using_index'] = true
default['mysql']['tunable']['log_bin_trust_function_creators'] = false
-default['mysql']['tunable']['innodb_buffer_pool_size'] = "128M"
default['mysql']['tunable']['innodb_log_file_size'] = "5M"
+default['mysql']['tunable']['innodb_buffer_pool_size'] = "128M"
+default['mysql']['tunable']['innodb_buffer_pool_instances'] = "4"
default['mysql']['tunable']['innodb_additional_mem_pool_size'] = "8M"
default['mysql']['tunable']['innodb_data_file_path'] = "ibdata1:10M:autoextend"
-default['mysql']['tunable']['innodb_flush_log_at_trx_commit'] = "1"
default['mysql']['tunable']['innodb_flush_method'] = false
default['mysql']['tunable']['innodb_log_buffer_size'] = "8M"
+default['mysql']['tunable']['innodb_write_io_threads'] = "4"
+default['mysql']['tunable']['innodb_io_capacity'] = "200"
+default['mysql']['tunable']['innodb_file_per_table'] = true
+default['mysql']['tunable']['innodb_lock_wait_timeout'] = "60"
+if node['cpu'].nil? or node['cpu']['total'].nil?
+ default['mysql']['tunable']['innodb_thread_concurrency'] = "8"
+ default['mysql']['tunable']['innodb_commit_concurrency'] = "8"
+ default['mysql']['tunable']['innodb_read_io_threads'] = "8"
+ default['mysql']['tunable']['innodb_flush_log_at_trx_commit'] = "8"
+else
+ default['mysql']['tunable']['innodb_thread_concurrency'] = "#{(Integer(node['cpu']['total'])) * 2}"
+ default['mysql']['tunable']['innodb_commit_concurrency'] = "#{(Integer(node['cpu']['total'])) * 2}"
+ default['mysql']['tunable']['innodb_read_io_threads'] = "#{(Integer(node['cpu']['total'])) * 2}"
+ default['mysql']['tunable']['innodb_flush_log_at_trx_commit'] = "#{(Integer(node['cpu']['total'])) * 2}"
+end
+default['mysql']['tunable']['innodb_support_xa'] = true
+default['mysql']['tunable']['innodb_table_locks'] = true
+default['mysql']['tunable']['skip-innodb-doublewrite'] = false
+default['mysql']['tunable']['transaction-isolation'] = nil
+
default['mysql']['tunable']['query_cache_limit'] = "1M"
default['mysql']['tunable']['query_cache_size'] = "16M"
default['mysql']['tunable']['log_slow_queries'] = "/var/log/mysql/slow.log"
+default['mysql']['tunable']['slow_query_log'] = node['mysql']['tunable']['log_slow_queries'] # log_slow_queries is deprecated
+ # in favor of slow_query_log
default['mysql']['tunable']['long_query_time'] = 2
default['mysql']['tunable']['expire_logs_days'] = 10
default['mysql']['tunable']['max_binlog_size'] = "100M"
+default['mysql']['tunable']['binlog_cache_size'] = "32K"
+
+default['mysql']['tmpdir'] = ["/tmp"]
+default['mysql']['read_only'] = false
+
+default['mysql']['log_dir'] = node['mysql']['data_dir']
+default['mysql']['log_files_in_group'] = false
+default['mysql']['innodb_status_file'] = false
+
+unless node['platform_family'] && node['platform_version'].to_i < 6
+ # older RHEL platforms don't support these options
+ default['mysql']['tunable']['event_scheduler'] = 0
+ default['mysql']['tunable']['table_open_cache'] = "128"
+ default['mysql']['tunable']['binlog_format'] = "statement" if node['mysql']['tunable']['log_bin']
+end