我正在尝试构建使用 Puppet 配置的 Vagrant 盒子。
我使用来自http://files.vagrantup.com/precise64.box的Ubuntu 12.04 LTS 盒子。
我还使用http://forge.puppetlabs.com/puppetlabs/postgresql模块来安装具有以下清单的 PostgreSQL:
class db {
class { 'postgresql': version => '9.1' }
class { 'postgresql::server': }
}
class { 'db': }
它安装正确,但数据库是使用 SQL_ASCII 编码创建的:
$ psql -l -U postgres
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+-----------+---------+-------+-----------------------
postgres | postgres | SQL_ASCII | C | C |
template0 | postgres | SQL_ASCII | C | C | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | SQL_ASCII | C | C | =c/postgres +
| | | | | postgres=CTc/postgres
谷歌搜索后,我认为这可能是一个语言环境问题,但对我来说它看起来是正确的:
$ locale
LANG=en_US.UTF-8
LANGUAGE=
LC_CTYPE=
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=
你知道我应该怎么做才能安装默认为 UTF8 编码的 PostgreSQL 吗?能够为此使用 Puppet 也很好。