Korzystam z Puppet, aby zapewnić MySQL sparametryzowaną klasę:
class mysql::server( $password ) {
package { 'mysql-server': ensure => installed }
package { 'mysql': ensure => installed }
service { 'mysqld':
enable => true,
ensure => running,
require => Package['mysql-server'],
}
exec { 'set-mysql-password':
unless => "mysqladmin -uroot -p$password status",
path => ['/bin', '/usr/bin'],
command => "mysqladmin -uroot password $password",
require => Service['mysqld'],
}
}
Jak mogę chronić $password
? Obecnie usunąłem domyślne uprawnienia do odczytu świata z pliku definicji węzła i wyraźnie dałem puppet
uprawnienia odczytu przez ACL.
Zakładam, że inni zetknęli się z podobną sytuacją, więc być może istnieje lepsza praktyka.