4

我正在尝试使用 Chef solo 在 Vagrant 盒子上设置 postgresql,但遇到了一些问题。我需要默认的 postgres 编码/语言环境为 UTF8。默认情况下,精确 64 位 Ubuntu 框的语言环境设置为“C”,因此 postgres 使用 LATIN1 进行编码。这是我到目前为止所做的:

我有一个厨师食谱,通过执行以下操作来设置语言环境:

template "/etc/profile.d/lang.sh" do
  source  "lang.sh.erb"
  mode "0644"
end

execute "locale-gen" do
  command "locale-gen en_US.UTF-8"
end

execute "dpkg-reconfigure-locales" do
  command "dpkg-reconfigure locales"
end

其中 lang.sh.erb 看起来像:

export LANGUAGE="en_US.UTF-8"
export LANG="en_US.UTF-8"
export LC_ALL="en_US.UTF-8"

这会正确设置语言环境,但不幸的是它不会修改当前环境。所以我有另一个配方,在包含 postgresql 之前只设置 ENV

ENV["LANGUAGE"] = ENV["LANG"] = ENV["LC_ALL"] = "en_US.UTF-8"
include_recipe "postgresql::server"

这没有效果。语言环境设置正确:

postgres@precise64:~$ locale
LANG=en_US.UTF-8
LANGUAGE=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
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=en_US.UTF-8

但是 postgres 在安装时使用了“C”语言环境。

postgres@precise64:~$ psql -l
                             List of databases
   Name    |  Owner   | Encoding | Collate | Ctype |   Access privileges
-----------+----------+----------+---------+-------+-----------------------
 postgres  | postgres | LATIN1   | en_US   | en_US |
 template0 | postgres | LATIN1   | en_US   | en_US | =c/postgres          +
           |          |          |         |       | postgres=CTc/postgres
 template1 | postgres | LATIN1   | en_US   | en_US | =c/postgres          +
           |          |          |         |       | postgres=CTc/postgres
(3 rows)

为了归属,我从http://www.softr.li/blog/2012/05/22/chef-recipe-to-install-a-postgresql-server-on-a-machine-configured-with -en_us-locales

4

3 回答 3

3

我发现对我有用的解决方案是在引导 shell 脚本中,或者作为内联 shell,在运行任何配方之前将 /etc/default/lang.sh 复制到框中。(所以应该在框定义之后在 Vagrant 文件中完成的第一件事) lang 文件:

export LANGUAGE=en_US.UTF-8
export LANG=en_US.UTF-8
export LC_ALL=en_US.UTF-8

从这里开始,数据库应该使用 UTF-8 编码进行设置。希望这会有所帮助,因为我花了几天时间寻找解决方案,并从各种讨论中提出了一些点点滴滴,但意识到问题在于设置值的时间......

于 2013-11-14T16:20:32.447 回答
1

the environment variable doesn't work for chef resources.

According to the postgresql cookbook, you should set the attribute node['postgresql']['initdb_locale'] to setup the locale when initializing a database. For example, use this section under parent section name: serverin your .kitchen.yml:

attributes:
  postgresql:
    initdb_locale: "en_US.UTF_8"
于 2013-10-04T13:30:28.987 回答
1

您可以在事后将 postgres 模板数据库删除并重新创建为 UTF-8。这不是一个完美的解决方案,但它确实适用于您的厨师食谱。见:http ://www.pebra.net/blog/2013/06/10/when-struggling-with-postgresql-and-utf8-slash-latin/

include_recipe "postgresql::server"
include_recipe "database::postgresql"

execute "Psql template1 to UTF8" do
user "postgres"
command <<-SQL
echo "
UPDATE pg_database SET datistemplate = FALSE WHERE datname = 'template1';
DROP DATABASE template1;
CREATE DATABASE template1 WITH TEMPLATE = template0 ENCODING = 'UNICODE' LC_CTYPE='en_US.utf8'      LC_COLLATE='en_US.utf8';
UPDATE pg_database SET datistemplate = TRUE WHERE datname = 'template1';
\\c template1
VACUUM FREEZE;" | psql postgres -t
SQL
# only_if '[ $(echo "select count(*) from pg_database where datname = \'template1\' and datcollate = \'en_US.utf8\'" |psql postgres -t) -eq 0 ]'
end
于 2014-01-17T18:10:20.617 回答