1

我有以下类,它安装 mysql 并设置一个名为 user 的用户,但是当 create-database 命令运行时,尚未创建用户。我如何链接命令以便在 create-database 尝试使用它之前创建用户?

class { '::mysql::server':
  package_name            => 'mariadb-server.x86_64',
  root_password           => 'root',
  remove_default_accounts => true,
  override_options        => $override_options,
  restart                 => true,
  users                   => {
    'user@%' => {
      ensure                   => 'present',
      max_connections_per_hour => '0',
      max_queries_per_hour     => '0',
      max_updates_per_hour     => '0',
      max_user_connections     => '0',
      password_hash            => '...',
    }
  },
  grants                  => {
    'user@%/*.*' => {
      ensure     => 'present',
      options    => ['GRANT'],
      privileges => ['ALL'],
      table      => '*.*',
      user       => 'user@%',
    },
  }
}->
exec { 'create-database':
  creates => '/opt/dbinstalled',
  command => '/usr/bin/mysql -u user -puser < /create-db.sql'
}

我正在使用 puppetlabs-mysql 包来安装 mysql。

4

1 回答 1

1

您应该查看元参数的文档require, before, subscribe, notify。它们用于描述资源排序(before, notify),或者如果依赖失败( ),资源排序和失败require, subscribe。请注意,元subscribe, notify参数仅适用于某些资源类型(exec, service等)。

在这种情况下,您将执行以下操作来链接一个类:

exec { 'create-database':
  creates => '/opt/dbinstalled',
  command => '/usr/bin/mysql -u user -puser < /create-db.sql',
  require => Class[::mysql::server],
}

但是你真的只需要对用户资源的依赖:

exec { 'create-database':
  creates => '/opt/dbinstalled',
  command => '/usr/bin/mysql -u user -puser < /create-db.sql',
  require => User[username or array of users],
}

另外你可能只想创建一次数据库,所以我们可以给它一个subscribe/refreshonly幂等性:

exec { 'create-database':
  creates     => '/opt/dbinstalled',
  command     => '/usr/bin/mysql -u user -puser < /create-db.sql',
  subscribe   => User[username or array of users],
  refreshonly => true,
}

请注意,如果您更改订阅的资源,这将重新运行user资源,因此请查看参数以作为其他方法来建立幂等性。create-databaseexecunless, onlyifexec

于 2016-05-24T17:15:44.173 回答