最近要做一些有关PostgreSQL多实例运行的例子,一般都普遍需要在不同的机器上安装上PostgreSQL Server,然后在不同的机器上进行配置,比如通过plproxy进行一些demo的设置。当然这样的需求可以通过多个虚拟机的方式实现,比如创建多个vmware的虚拟机,大家一起跑就是了。不过这样有点资源浪费,而且需要维护不同的机器。尝试着在同一台机器上运行多个PostgreSQL Server实例来完成需要。
目标: 在一台机器上运行多个PostgreSQL Server实例.
运行环境:Ubnntu 8.04.1(vmware中运行)
1. 首先通过sudo apt-get install postgresql安装上PostgreSQL Server。在安装的过程中会建议安装其它有关的pkg,可以都装上,最后安装完成后最好有以下包列表:
postgresql
postgresql-8.3
postgresql-client-8.3
postgresql-client-common
postgresql-common
安装完成后,apt-get会自动根据安装脚本完成PostgreSQL的数据库初始化工作,并启动一个PostgreSQL实例(称为一个cluster),且该实例的名称是:main. 请记住main,我们在后面还会用到。
2. 修改文件
2.1 修改/usr/bin/pg_ctlcluster
/usr/bin/pg_ctlcluster是用以控制PostgreSQL Server启动、停止、重启的脚本,便于完成对PostgreSQL Server的控制。默认的PostgreSQL cluster只能通过本地访问,不能通过TCP/IP以网络方式进行。修改/usr/bin/pg_ctlcluster文件,把253行修改为以下内容:
目标: 在一台机器上运行多个PostgreSQL Server实例.
运行环境:Ubnntu 8.04.1(vmware中运行)
1. 首先通过sudo apt-get install postgresql安装上PostgreSQL Server。在安装的过程中会建议安装其它有关的pkg,可以都装上,最后安装完成后最好有以下包列表:
postgresql
postgresql-8.3
postgresql-client-8.3
postgresql-client-common
postgresql-common
安装完成后,apt-get会自动根据安装脚本完成PostgreSQL的数据库初始化工作,并启动一个PostgreSQL实例(称为一个cluster),且该实例的名称是:main. 请记住main,我们在后面还会用到。
2. 修改文件
2.1 修改/usr/bin/pg_ctlcluster
/usr/bin/pg_ctlcluster是用以控制PostgreSQL Server启动、停止、重启的脚本,便于完成对PostgreSQL Server的控制。默认的PostgreSQL cluster只能通过本地访问,不能通过TCP/IP以网络方式进行。修改/usr/bin/pg_ctlcluster文件,把253行修改为以下内容:
- 253 my $postmaster_opts = '-i';
- 254 if (!(PgCommon::get_conf_value $version, $cluster, 'postgresql.conf', 'unix_socket_directory'