Chef-solo + postgres导致无效的pg_hba.conf

Pet*_*vic 3 postgresql vagrant chef-solo

我正在尝试使用流浪者+厨师独奏设置postgres。

我使用的是官方收据:http//community.opscode.com/cookbooks/postgresql

由于我Berksfile包含:

site :opscode

cookbook "postgresql"
Run Code Online (Sandbox Code Playgroud)

我的Vagrantfile块是:

config.berkshelf.enabled = true

config.vm.provision "chef_solo" do |chef|

chef.add_recipe "postgresql::server"

  chef.json = {

  "postgresql" => {
      "version" => "9.2",
      "password" => { "postgres" => "123" },
      config: { 
      "ssl" => "false" 
  },
      pg_hba: [  
          { type: 'local', db: 'all', user: 'all', addr: '', method: 'trust' },
          { type: 'local', db: 'all', user: 'all', addr: '127.0.0.1/32', method: 'trust' },
          { type: 'local', db: 'all', user: 'all', addr: '::1/128 ', method: 'trust' } 
  ]
  }
end
Run Code Online (Sandbox Code Playgroud)

的生成内容/etc/postgresql/9.2/main/pg_hba.conf如下:

# This file was automatically generated and dropped off by Chef!

# PostgreSQL Client Authentication Configuration File
# ===================================================
#
# Refer to the "Client Authentication" section in the PostgreSQL
# documentation for a complete description of this file.

# TYPE  DATABASE        USER            ADDRESS                 METHOD

###########
# Other authentication configurations taken from chef node defaults:
###########

local   all             all                                     trust

local   all             all             127.0.0.1/32            trust

local   all             all             ::1/128                 trust

# "local" is for Unix domain socket connections only
local   all             all                                     peer
Run Code Online (Sandbox Code Playgroud)

但是,如果我运行sudo service postgresql restart,它将失败并显示错误:

The PostgreSQL server failed to start. Please check the log output:
2013-11-10 08:12:05 GMT LOG:  invalid authentication method "127.0.0.1/32"
2013-11-10 08:12:05 GMT CONTEXT:  line 17 of configuration file "/etc/postgresql/9.2/main/pg_hba.conf"
2013-11-10 08:12:05 GMT LOG:  invalid authentication method "::1/128"
2013-11-10 08:12:05 GMT CONTEXT:  line 19 of configuration file "/etc/postgresql/9.2/main/pg_hba.conf"
2013-11-10 08:12:05 GMT FATAL:  could not load pg_hba.conf
Run Code Online (Sandbox Code Playgroud)

有问题的条目是持有地址的条目。知道我的用例有什么问题吗?

Mil*_*dev 5

第一行是正确的,实际上这是唯一行。提及地址的人应该是“主机”,而不是“本地”。目前,最后一个是没有用的。

在Postgres的文档中有更多信息- “客户端身份验证”,“ pg_hba.conf文件”