2012-02-09 20:26:00 +01:00
|
|
|
# Class: mysql::config
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
#
|
2013-04-07 22:20:36 +02:00
|
|
|
# [*root_password*] - root user password.
|
|
|
|
# [*old_root_password*] - previous root user password,
|
|
|
|
# [*bind_address*] - address to bind service.
|
|
|
|
# [*port*] - port to bind service.
|
|
|
|
# [*etc_root_password*] - whether to save /etc/my.cnf.
|
|
|
|
# [*service_name*] - mysql service name.
|
|
|
|
# [*config_file*] - my.cnf configuration file path.
|
|
|
|
# [*socket*] - mysql socket.
|
|
|
|
# [*datadir*] - path to datadir.
|
|
|
|
# [*ssl] - enable ssl
|
|
|
|
# [*ssl_ca] - path to ssl-ca
|
|
|
|
# [*ssl_cert] - path to ssl-cert
|
|
|
|
# [*ssl_key] - path to ssl-key
|
|
|
|
# [*log_error] - path to mysql error log
|
|
|
|
# [*default_engine] - configure a default table engine
|
|
|
|
# [*root_group] - use specified group for root-owned files
|
|
|
|
# [*restart] - whether to restart mysqld (true/false)
|
|
|
|
# [*character-set] - You can change the default server and
|
|
|
|
# client character set
|
|
|
|
# [*key_buffer] - Index blocks for MyISAM tables are buffered and
|
|
|
|
# are shared by all threads. key_buffer_size is the
|
|
|
|
# size of the buffer used for index blocks.
|
|
|
|
# [*max_allowed_packet] - The maximum size of one packet or any
|
|
|
|
# generated/intermediate string, or any
|
|
|
|
# parameter sent by the mysql_stmt_send_long_data()
|
|
|
|
# C API function.
|
|
|
|
# [*thread_stack] - The stack size for each thread.
|
|
|
|
# [*thread_cache_size] - How many threads server should cache for reuse.
|
|
|
|
# [*myisam-recover] - Set the MyISAM storage engine recovery mode.
|
|
|
|
# [*query_cache_limit] - Do not cache results that are larger than this
|
|
|
|
# number of bytes.
|
|
|
|
# [*query_cache_size] - The amount of memory allocated for caching query
|
|
|
|
# results.
|
|
|
|
# [*max_connections] - The maximum permitted number of simultaneous
|
|
|
|
# client connections.
|
|
|
|
# [*tmp_table_size] - The maximum size of internal in-memory temporary
|
|
|
|
# tables.
|
|
|
|
# [*max_heap_table_size] - This variable sets the maximum size to which
|
|
|
|
# user-created MEMORY tables are permitted to grow.
|
|
|
|
# [*table_open_cache] - The number of open tables for all threads.
|
|
|
|
# [*long_query_time] - If a query takes longer than this many seconds,
|
|
|
|
# the server increments the Slow_queries status
|
|
|
|
# variable.
|
|
|
|
#
|
2012-02-09 20:26:00 +01:00
|
|
|
#
|
|
|
|
# Actions:
|
|
|
|
#
|
|
|
|
# Requires:
|
|
|
|
#
|
|
|
|
# class mysql::server
|
|
|
|
#
|
|
|
|
# Usage:
|
|
|
|
#
|
|
|
|
# class { 'mysql::config':
|
|
|
|
# root_password => 'changeme',
|
|
|
|
# bind_address => $::ipaddress,
|
|
|
|
# }
|
|
|
|
#
|
2011-06-22 20:38:11 +02:00
|
|
|
class mysql::config(
|
2012-08-16 03:03:37 +02:00
|
|
|
$root_password = 'UNSET',
|
|
|
|
$old_root_password = '',
|
|
|
|
$bind_address = $mysql::params::bind_address,
|
|
|
|
$port = $mysql::params::port,
|
|
|
|
$etc_root_password = $mysql::params::etc_root_password,
|
|
|
|
$service_name = $mysql::params::service_name,
|
|
|
|
$config_file = $mysql::params::config_file,
|
|
|
|
$socket = $mysql::params::socket,
|
2012-08-22 03:09:48 +02:00
|
|
|
$pidfile = $mysql::params::pidfile,
|
2012-08-16 03:03:37 +02:00
|
|
|
$datadir = $mysql::params::datadir,
|
|
|
|
$ssl = $mysql::params::ssl,
|
|
|
|
$ssl_ca = $mysql::params::ssl_ca,
|
|
|
|
$ssl_cert = $mysql::params::ssl_cert,
|
|
|
|
$ssl_key = $mysql::params::ssl_key,
|
|
|
|
$log_error = $mysql::params::log_error,
|
|
|
|
$default_engine = 'UNSET',
|
2012-09-08 12:09:44 +02:00
|
|
|
$root_group = $mysql::params::root_group,
|
2012-11-16 20:49:24 +01:00
|
|
|
$restart = $mysql::params::restart,
|
2013-04-04 12:02:58 +02:00
|
|
|
$purge_conf_dir = false,
|
2013-04-07 22:20:36 +02:00
|
|
|
|
|
|
|
$key_buffer = $mysql::params::key_buffer,
|
|
|
|
$max_allowed_packet = $mysql::params::max_allowed_packet,
|
|
|
|
$thread_stack = $mysql::params::thread_stack,
|
|
|
|
$thread_cache_size = $mysql::params::thread_cache_size,
|
|
|
|
$myisam_recover = $mysql::params::myisam_recover,
|
|
|
|
$query_cache_limit = $mysql::params::query_cache_limit,
|
|
|
|
$query_cache_size = $mysql::params::query_cache_size,
|
|
|
|
|
|
|
|
$max_connections = 'UNSET',
|
|
|
|
$tmp_table_size = 'UNSET',
|
|
|
|
$max_heap_table_size = 'UNSET',
|
|
|
|
$table_open_cache = 'UNSET',
|
|
|
|
$long_query_time = 'UNSET',
|
|
|
|
$character_set = 'UNSET',
|
|
|
|
|
2012-02-09 20:26:00 +01:00
|
|
|
) inherits mysql::params {
|
|
|
|
|
|
|
|
File {
|
|
|
|
owner => 'root',
|
2012-05-02 06:42:34 +02:00
|
|
|
group => $root_group,
|
2012-02-09 20:26:00 +01:00
|
|
|
mode => '0400',
|
2013-04-04 12:02:58 +02:00
|
|
|
notify => $restart ? {
|
|
|
|
true => Exec['mysqld-restart'],
|
2012-09-08 12:09:44 +02:00
|
|
|
false => undef,
|
|
|
|
},
|
2012-02-09 20:26:00 +01:00
|
|
|
}
|
|
|
|
|
2012-05-02 06:42:34 +02:00
|
|
|
if $ssl and $ssl_ca == undef {
|
|
|
|
fail('The ssl_ca parameter is required when ssl is true')
|
|
|
|
}
|
|
|
|
|
|
|
|
if $ssl and $ssl_cert == undef {
|
|
|
|
fail('The ssl_cert parameter is required when ssl is true')
|
|
|
|
}
|
|
|
|
|
|
|
|
if $ssl and $ssl_key == undef {
|
|
|
|
fail('The ssl_key parameter is required when ssl is true')
|
|
|
|
}
|
|
|
|
|
2012-02-09 20:26:00 +01:00
|
|
|
# This kind of sucks, that I have to specify a difference resource for
|
|
|
|
# restart. the reason is that I need the service to be started before mods
|
|
|
|
# to the config file which can cause a refresh
|
|
|
|
exec { 'mysqld-restart':
|
|
|
|
command => "service ${service_name} restart",
|
2012-03-07 16:12:23 +01:00
|
|
|
logoutput => on_failure,
|
2012-02-09 20:26:00 +01:00
|
|
|
refreshonly => true,
|
2012-03-07 16:12:23 +01:00
|
|
|
path => '/sbin/:/usr/sbin/:/usr/bin/:/bin/',
|
2012-02-09 20:26:00 +01:00
|
|
|
}
|
2011-06-22 20:38:11 +02:00
|
|
|
|
|
|
|
# manage root password if it is set
|
2012-02-09 20:26:00 +01:00
|
|
|
if $root_password != 'UNSET' {
|
2011-06-22 20:38:11 +02:00
|
|
|
case $old_root_password {
|
2012-02-09 20:26:00 +01:00
|
|
|
'': { $old_pw='' }
|
2012-05-11 06:46:54 +02:00
|
|
|
default: { $old_pw="-p'${old_root_password}'" }
|
2011-06-22 20:38:11 +02:00
|
|
|
}
|
2012-02-09 20:26:00 +01:00
|
|
|
|
|
|
|
exec { 'set_mysql_rootpw':
|
2012-05-11 06:46:54 +02:00
|
|
|
command => "mysqladmin -u root ${old_pw} password '${root_password}'",
|
2011-06-22 20:38:11 +02:00
|
|
|
logoutput => true,
|
2012-05-11 06:46:54 +02:00
|
|
|
unless => "mysqladmin -u root -p'${root_password}' status > /dev/null",
|
2012-05-02 06:42:34 +02:00
|
|
|
path => '/usr/local/sbin:/usr/bin:/usr/local/bin',
|
2012-09-08 12:09:44 +02:00
|
|
|
notify => $restart ? {
|
2013-04-04 12:02:58 +02:00
|
|
|
true => Exec['mysqld-restart'],
|
2012-09-08 12:09:44 +02:00
|
|
|
false => undef,
|
|
|
|
},
|
2012-04-23 12:06:39 +02:00
|
|
|
require => File['/etc/mysql/conf.d'],
|
2011-06-22 20:38:11 +02:00
|
|
|
}
|
2012-02-09 20:26:00 +01:00
|
|
|
|
|
|
|
file { '/root/.my.cnf':
|
2011-06-24 08:39:58 +02:00
|
|
|
content => template('mysql/my.cnf.pass.erb'),
|
2012-02-09 20:26:00 +01:00
|
|
|
require => Exec['set_mysql_rootpw'],
|
2011-06-24 08:39:58 +02:00
|
|
|
}
|
2012-02-09 20:26:00 +01:00
|
|
|
|
2011-06-24 08:39:58 +02:00
|
|
|
if $etc_root_password {
|
2012-02-09 20:26:00 +01:00
|
|
|
file{ '/etc/my.cnf':
|
|
|
|
content => template('mysql/my.cnf.pass.erb'),
|
|
|
|
require => Exec['set_mysql_rootpw'],
|
|
|
|
}
|
2011-06-24 08:39:58 +02:00
|
|
|
}
|
2012-10-13 11:35:38 +02:00
|
|
|
} else {
|
|
|
|
file { '/root/.my.cnf':
|
|
|
|
ensure => present,
|
|
|
|
}
|
2011-06-22 20:38:11 +02:00
|
|
|
}
|
2012-02-09 20:26:00 +01:00
|
|
|
|
2011-10-31 18:39:08 +01:00
|
|
|
file { '/etc/mysql':
|
|
|
|
ensure => directory,
|
2012-02-09 20:26:00 +01:00
|
|
|
mode => '0755',
|
2011-10-31 18:39:08 +01:00
|
|
|
}
|
2011-12-14 00:36:56 +01:00
|
|
|
file { '/etc/mysql/conf.d':
|
2012-11-16 20:49:24 +01:00
|
|
|
ensure => directory,
|
|
|
|
mode => '0755',
|
|
|
|
recurse => $purge_conf_dir,
|
|
|
|
purge => $purge_conf_dir,
|
2011-12-14 00:36:56 +01:00
|
|
|
}
|
2012-02-09 20:26:00 +01:00
|
|
|
file { $config_file:
|
2011-06-22 20:38:11 +02:00
|
|
|
content => template('mysql/my.cnf.erb'),
|
2012-02-09 20:26:00 +01:00
|
|
|
mode => '0644',
|
2011-06-22 20:38:11 +02:00
|
|
|
}
|
2012-02-09 20:26:00 +01:00
|
|
|
|
2011-06-22 20:38:11 +02:00
|
|
|
}
|