
puppetlabs/mysql
モジュールを使用する次の Puppet クラスがあります:
class hg_playground::makowals::brains::db {
class { '::mysql::client':
package_name => 'mariadb',
}
$override_options = {
'mysqld' => {
'log-bin' => '',
'server-id' => $mysql_server_id,
}
}
class { '::mysql::server':
package_name => 'mariadb-server',
root_password => 'TESTOWY',
remove_default_accounts => true,
override_options => $override_options,
}
mysql_user { 'slave_user@localhost':
ensure => 'present',
password_hash => mysql_password('master_replication'),
}
mysql_grant { 'slave_user@localhost/*.*':
ensure => 'present',
options => ['GRANT'],
privileges => ['REPLICATION SLAVE'],
table => '*.*',
user => 'slave_user@localhost',
}
mysql_database { 'somedb':
ensure => 'present',
}
}
そこで何が起こるかというと
- mariadb-serverが正しくインストールされています
- dbのルートパスワードが設定されていません
/root/.my.cnf
私は持っているpassword='TESTOWY'
- 新しいユーザーもデータベースも作成されません
もちろん、エージェントを実行してもエラーは発生しません。このような状況でデバッグを開始するにはどうすればよいでしょうか? クラスの実行からの通知には、興味深いものは何も表示されません。
notice /Stage[main]/Mysql::Server::Install/Package[mysql-server]/ensure created
notice /Stage[main]/Mysql::Server::Config/File[mysql-config-file]/content content changed '{md5}54dc3e561e817f9c0a376a58383eb013' to '{md5}ff09a4033f718f08f69da17f0aa86652'
notice /Stage[main]/Mysql::Server::Service/Service[mysqld]/ensure ensure changed 'stopped' to 'running'
notice /Stage[main]/Mysql::Server::Root_password/File[/root/.my.cnf]/ensure defined content as '{md5}042e1a46bc15a260a349dbbe1bac8e71'
答え1
私が使用しているcentos 5
mariadb はメイン リポジトリにないため、指定せずpackage_name
、クラスと動作をテストしました。追加したのはmysql::server
クラスに require のみで、DB の作成には mysql::db クラスを使用しました。
class hg_playground::makowals::brains::db {
class { '::mysql::client':
package_name => 'mariadb',
}
$override_options = {
'mysqld' => {
'log-bin' => '',
'server-id' => $mysql_server_id,
}
}
class { '::mysql::server':
package_name => 'mariadb-server',
root_password => 'TESTOWY',
remove_default_accounts => true,
override_options => $override_options,
}
mysql_user { 'slave_user@localhost':
ensure => 'present',
password_hash => mysql_password('master_replication'),
}
mysql_grant { 'slave_user@localhost/*.*':
ensure => 'present',
options => ['GRANT'],
privileges => ['REPLICATION SLAVE'],
table => '*.*',
user => 'slave_user@localhost',
}
mysql_database { 'somedb':
ensure => 'present',
require => Class['mysql::server']
}
}
Puppet 実行出力。
=> default: Notice: Compiled catalog for centos7.example.com in environment testing in 2.97 seconds
==> default: Notice: /Stage[main]/Mysql::Client::Install/Package[mysql_client]/ensure: created
==> default: Notice: /Stage[main]/Mysql::Server::Install/Package[mysql-server]/ensure: created
==> default: Notice: /Stage[main]/Mysql::Server::Config/File[mysql-config-file]/content: content changed '{md5}54dc3e561e817f9c0a376a58383eb013' to '{md5}40a2060d1d62cb5c3f33e5e74be19889'
==> default: Notice: /Stage[main]/Mysql::Server::Installdb/Exec[mysql_install_db]/returns: executed successfully
==> default: Notice: /Stage[main]/Mysql::Server::Service/Service[mysqld]/ensure: ensure changed 'stopped' to 'running'
==> default: Notice: /Stage[main]/Mysql::Server::Root_password/Mysql_user[root@localhost]/password_hash: defined 'password_hash' as '*416F1598B4E5F9CD0DBFC2E35867FA1F96EBF4F5'
==> default: Notice: /Stage[main]/Mysql::Server::Root_password/File[/root/.my.cnf]/ensure: defined content as '{md5}cd27be3d51dcd48e92de9df7e894accb'
==> default: Notice: /Stage[main]/Mysql::Server::Account_security/Mysql_user[[email protected]]/ensure: removed
==> default: Notice: /Stage[main]/Mysql::Server::Account_security/Mysql_user[root@::1]/ensure: removed
==> default: Notice: /Stage[main]/Mysql::Server::Account_security/Mysql_user[@localhost]/ensure: removed
==> default: Notice: /Stage[main]/Mysql::Server::Account_security/Mysql_user[[email protected]]/ensure: removed
==> default: Notice: /Stage[main]/Mysql::Server::Account_security/Mysql_user[@centos7.example.com]/ensure: removed
==> default: Notice: /Stage[main]/Mysql::Server::Account_security/Mysql_database[test]/ensure: removed
==> default: Notice: /Stage[main]/Hg_playground::Makowals::Brains::Db/Mysql_user[slave_user@localhost]/ensure: created
==> default: Notice: /Stage[main]/Hg_playground::Makowals::Brains::Db/Mysql_grant[slave_user@localhost/*.*]/privileges: privileges changed ['USAGE'] to 'REPLICATION SLAVE'
==> default: Notice: /Stage[main]/Hg_playground::Makowals::Brains::Db/Mysql_grant[slave_user@localhost/*.*]/options: defined 'options' as 'GRANT'
==> default: Notice: /Stage[main]/Hg_playground::Makowals::Brains::Db/Mysql_database[somedb]/ensure: created
答え2
mysql::server クラスには、バージョンを含む package_name 属性が必要です。
class{ 'mysql::server':
package_name => "mariadb-server-${mariadb_version}",
...
}
すでに必要なものを提供するリポジトリ バージョンを追加していることを前提として、 eg を使用してapt-cache search mariadb-server
パッケージ名がどのようになっているかを確認します。mariadb の異なるバージョン ファミリには個別のリポジトリがあります。