2009-10-03 15:19:11 +02:00
|
|
|
class mysql::server::base {
|
|
|
|
package { mysql-server:
|
|
|
|
ensure => present,
|
|
|
|
}
|
|
|
|
file{'/etc/mysql/my.cnf':
|
|
|
|
source => [
|
2009-11-14 15:06:59 +01:00
|
|
|
"puppet://$server/modules/site-mysql/${fqdn}/my.cnf",
|
|
|
|
"puppet://$server/modules/site-mysql/my.cnf",
|
2009-11-02 00:57:26 +01:00
|
|
|
"puppet://$server/modules/mysql/config/my.cnf.${operatingsystem}",
|
|
|
|
"puppet://$server/modules/mysql/config/my.cnf"
|
2009-10-03 15:19:11 +02:00
|
|
|
],
|
|
|
|
ensure => file,
|
|
|
|
require => Package[mysql-server],
|
|
|
|
notify => Service[mysql],
|
|
|
|
owner => root, group => 0, mode => 0644;
|
|
|
|
}
|
|
|
|
file{'/var/lib/mysql/data':
|
|
|
|
ensure => directory,
|
|
|
|
require => Package[mysql-server],
|
|
|
|
before => File['/etc/mysql/my.cnf'],
|
|
|
|
owner => mysql, group => mysql, mode => 0755;
|
|
|
|
}
|
|
|
|
|
|
|
|
file{'/var/lib/mysql/data/ibdata1':
|
|
|
|
ensure => file,
|
|
|
|
require => Package[mysql-server],
|
|
|
|
before => File['/opt/bin/setmysqlpass.sh'],
|
|
|
|
owner => mysql, group => mysql, mode => 0660;
|
|
|
|
}
|
|
|
|
|
|
|
|
case $mysql_rootpw {
|
|
|
|
'': { fail("You need to define a mysql root password! Please set \$mysql_rootpw in your site.pp or host config") }
|
|
|
|
}
|
|
|
|
file{'/opt/bin/setmysqlpass.sh':
|
2009-11-02 00:57:26 +01:00
|
|
|
source => "puppet://$server/modules/mysql/config/${operatingsystem}/setmysqlpass.sh",
|
2009-10-03 15:19:11 +02:00
|
|
|
require => Package[mysql-server],
|
|
|
|
owner => root, group => 0, mode => 0500;
|
|
|
|
}
|
|
|
|
file {'/root/.my.cnf':
|
|
|
|
content => template('mysql/root/my.cnf.erb'),
|
|
|
|
require => [ Package[mysql-server] ],
|
|
|
|
owner => root, group => 0, mode => 0400;
|
|
|
|
}
|
|
|
|
exec{'set_mysql_rootpw':
|
|
|
|
command => "/opt/bin/setmysqlpass.sh $mysql_rootpw",
|
|
|
|
unless => "mysqladmin -uroot status > /dev/null",
|
|
|
|
require => [ File['/opt/bin/setmysqlpass.sh'], Package[mysql-server] ],
|
|
|
|
}
|
|
|
|
file{'/etc/cron.d/mysql_backup.cron':
|
2009-11-02 00:57:26 +01:00
|
|
|
source => [ "puppet://$server/modules/mysql/backup/mysql_backup.cron.${operatingsystem}",
|
|
|
|
"puppet://$server/modules/mysql/backup/mysql_backup.cron" ],
|
2009-10-03 15:19:11 +02:00
|
|
|
require => [ Exec[set_mysql_rootpw], File['/root/.my.cnf'] ],
|
|
|
|
owner => root, group => 0, mode => 0600;
|
|
|
|
}
|
|
|
|
file{'/etc/cron.weekly/mysql_optimize_tables.rb':
|
2009-11-02 00:57:26 +01:00
|
|
|
source => "puppet://$server/modules/mysql/optimize/optimize_tables.rb",
|
2009-10-03 15:19:11 +02:00
|
|
|
require => [ Exec[set_mysql_rootpw], File['/root/.my.cnf'] ],
|
|
|
|
owner => root, group => 0, mode => 0700;
|
|
|
|
}
|
|
|
|
service {mysql:
|
|
|
|
ensure => running,
|
|
|
|
enable => true,
|
|
|
|
hasstatus => true,
|
|
|
|
require => Package[mysql],
|
|
|
|
}
|
|
|
|
|
|
|
|
# Collect all databases and users
|
|
|
|
Mysql_database<<| tag == "mysql_${fqdn}" |>>
|
|
|
|
Mysql_user<<| tag == "mysql_${fqdn}" |>>
|
|
|
|
Mysql_grant<<| tag == "mysql_${fqdn}" |>>
|
|
|
|
}
|