mysql - puppet :file_line 评估 os.path.join

标签 mysql regex django puppet

我正在尝试替换 Django-Settings 行

'NAME': os.path.join(BASE_DIR,'db.sqlite3'),

'NAME': os.path.join(BASE_DIR,'db.mysql'),

但是没有找到。

带有 ENGINE 参数的另一行工作正常。问题一定是“os.path.join”部分。

  # replace sqlite3 db with mysql
    file { '/var/www/mysite/mysite/settings.py':
      ensure => present,
    }
    file_line { 'replace db engine':
      path                => '/var/www/mysite/mysite/settings.py',
      replace             => true,
      line                => "'ENGINE': 'django.db.backends.mysql',",
      match               => "'ENGINE': 'django.db.backends.sqlite3',",
      append_on_no_match  => false,
    }

    file_line { 'replace db name':
      path                => '/var/www/mysite/mysite/settings.py',
      replace             => true,
      line                => "\'NAME\': os.path.join(BASE_DIR , \'db.mysql\'),",
      match               => "\'NAME\': os.path.join(BASE_DIR , \'db.sqlite3\'),",
      append_on_no_match  => false,
    }

我尝试使用\' 和不使用\。

有人可以帮忙吗?

编辑: 因此,如果我事先添加这样的内容:

  class { '::mysql::server':
    root_password    => 'strongpassword',
    override_options => { 'mysqld' => { 'max_connections' => '1024' } }
  }

  mysql::db { 'mynewDB':
    user     => 'admin',
    password => 'secret',
    host     => 'master.puppetlabs.vm',
    sql        => '/tmp/states.sql',
    require => File['/tmp/states.sql'],
  }

然后我将 NAME 参数替换为“mynewDB”? 我理解正确吗?

最佳答案

您需要记住,file_line 资源的 match 参数传达的是正则表达式,而不是纯字符串。 Puppet 使用 Ruby 风格的正则表达式。在该方言中,与许多其他方言一样,括号 (()) 是元字符,表示分组。如果您希望将它们解释为文字,则必须转义它们。此外,由于 Ruby 正则表达式使用与 Puppet 字符串相同的转义字符,因此您还必须对转义字符进行转义,以将其通过 Puppet 传递到底层正则表达式引擎。另一方面,您不需要在双引号字符串内转义单引号,反之亦然,尽管这样做应该不会有害。

示例:

file_line { 'replace db name':
  path                => '/var/www/mysite/mysite/settings.py',
  replace             => true,
  line                => "'NAME': os.path.join(BASE_DIR , 'db.mysql'),",
  match               => "'NAME': os.path.join\\(BASE_DIR , 'db.sqlite3'\\),",
  append_on_no_match  => false,
}

但是这样的设计有点糟糕。如果您试图确保所需的数据库被正确命名(无论实际名称应该是什么),那么您应该尽可能地以不依赖于当前数据库名称。

我不了解 Django 细节,但如果您只能依赖设置文件中指定的一个 NAME 属性,那么您可以这样做:

file_line { 'replace db name':
  path                => '/var/www/mysite/mysite/settings.py',
  replace             => true,
  line                => 'Whatever the line should really be',
  match               => "\\s*'NAME':.*",
  append_on_no_match  => false,
}

那里的匹配表达式匹配具有任意数量的前导空格的行,后跟文字字符 'NAME':,后跟任何内容

但是您还应该考虑 file_line 是否是适合该工作的工具。仅当您需要容纳在 Puppet 之外管理的文​​件的某些部分时,这才真正有意义,这是一种令人不舒服的情况,尽管有时我们会遇到这种情况。不过,如果可能的话,最好允许 Puppet 管理整个文件,包括其完整内容。

关于mysql - puppet :file_line 评估 os.path.join,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53719928/

相关文章:

php - Mysql join 查询从其他表中检索具有 id 的用户的个人资料图像

php - Where + 和 Where from 模型

python - 如何通过 python 脚本运行 mongodb 查询?

php - 使用一个 mysql 的结果进行第二个查询

php - 如何按最新帖子或评论(如果有)获取所有带评论顺序的帖子 - zend Framework 2 php mysql

regex - 使用 perl regexp 和 $^R 解析嵌套元组

regex - 如何在 VIM 查找/搜索中转义反斜杠和正斜杠?

java - Java 中的正则表达式差异

django - 创建扩展用户配置文件

python - PIL ImageDraw.Draw.text 填充属性引发 TypeError : an integer is required