不知怎的,我已经设法在Ubuntu上完全安装了postgresql。我想从头开始,但是当我用apt-get“清除”包时,它仍然会留下痕迹,导致重新安装配置不能正常运行。

完成之后:

apt-get purge postgresql
apt-get install postgresql

它说

Setting up postgresql-8.4 (8.4.3-0ubuntu9.10.1) ...
Configuring already existing cluster (configuration: /etc/postgresql/8.4/main, data: /var/lib/postgresql/8.4/main, owner: 108:112)
Error: move_conffile: required configuration file     /var/lib/postgresql/8.4/main/postgresql.conf does not exist
Error: could not create default cluster. Please create it manually with

  pg_createcluster 8.4 main --start

or a similar command (see 'man pg_createcluster').
update-alternatives: using /usr/share/postgresql/8.4/man/man1/postmaster.1.gz to provide /usr/share/man/man1/postmaster.1.gz (postmaster.1.gz) in auto mode.

Setting up postgresql (8.4.3-0ubuntu9.10.1) ...

我有一个“/etc/postgresql”里面什么都没有,“/etc/postgresql-common/”有一个“pg_upgradecluser”。目录和根目录。CRT和user_clusters文件。

/etc/passwd有一个postgres用户;清除脚本似乎没有触及它。有一堆症状我都克服了结果又暴露了下一个。

就在这一秒,当我运行命令“pg_createcluster…”它会抱怨“/var/lib/postgresql/8.4/main/postgresql.conf不存在”,所以我会去找其中一个,但我相信这不会是它的结束。

难道就没有一些简单的一行(或两个)语句可以让我从头开始吗?


当前回答

以下是我卸载和重新安装的步骤。这对我很管用。

首先删除已安装的postgres:-

Sudo apt-get清除postgr* Sudo apt-get自动删除

然后安装synaptic:

Sudo apt-get安装突触 Sudo apt-get update

然后安装postgres

安装postgresql postgresql-contrib

其他回答

apt-get purge postgresql*

就足够了。

我在Ubuntu 8.04.2上删除postgres 8.3的步骤

List All Postgres related packages dpkg -l | grep postgres ii postgresql 8.3.17-0ubuntu0.8.04.1 object-relational SQL database (latest versi ii postgresql-8.3 8.3.9-0ubuntu8.04 object-relational SQL database, version 8.3 ii postgresql-client 8.3.9-0ubuntu8.04 front-end programs for PostgreSQL (latest ve ii postgresql-client-8.3 8.3.9-0ubuntu8.04 front-end programs for PostgreSQL 8.3 ii postgresql-client-common 87ubuntu2 manager for multiple PostgreSQL client versi ii postgresql-common 87ubuntu2 PostgreSQL database-cluster manager ii postgresql-contrib 8.3.9-0ubuntu8.04 additional facilities for PostgreSQL (latest ii postgresql-contrib-8.3 8.3.9-0ubuntu8.04 additional facilities for PostgreSQL Remove all above listed sudo apt-get --purge remove postgresql postgresql-8.3 postgresql-client postgresql-client-8.3 postgresql-client-common postgresql-common postgresql-contrib postgresql-contrib-8.3 Remove the following folders sudo rm -rf /var/lib/postgresql/ sudo rm -rf /var/log/postgresql/ sudo rm -rf /etc/postgresql/

我也有类似的情况:我需要在debian上清除postgresql 9.1(我之前是从8.4迁移过来的,我得到了一些错误)。

我做了什么:

首先,我删除了配置和数据库

$ sudo pg_dropcluster --stop 9.1 main

然后删除postgresql

$ sudo apt-get remove --purge postgresql postgresql-9.1 

然后重新安装

$ sudo apt-get install postgresql postgresql-9.1

在我的情况下,我注意到/etc/postgresql/9.1是空的,运行服务postgresql start没有返回任何东西

所以,在更多的谷歌搜索之后,我得到了这个命令:

$ sudo pg_createcluster 9.1 main

这样我就可以启动服务器了,但是现在我得到了与日志相关的错误。经过更多的搜索,我最终更改了/var/log/postgresql目录的权限

$ sudo chown root.postgres /var/log/postgresql
$ sudo chmod g+wx /var/log/postgresql

这解决了问题,希望这有帮助

我在Ubuntu 13.04上也遇到了同样的问题。以下命令删除了Postgres 9.1:

sudo apt-get purge postgresql
sudo apt-get autoremove postgresql

在我看来,也许只有第二个命令是必要的,但从那里我能够安装postgresql 9.2 (sudo apt-get install postgresql-9.2)。

我在ubuntu 16.04中也遇到了同样的问题

但是我已经解决了这个问题,这很简单,只要遵循这些步骤,你就可以在你的系统中安装postgresql 10:

把这个添加到你的sources.list中:

sudo vim /etc/apt/sources.list

deb http://ftp.de.debian.org/debian/ wheezy main non-free contrib

deb-src http://ftp.de.debian.org/debian/ wheezy main non-free contrib

然后将这些链接添加到您的pgdg中。列表文件如果不存在,你必须创建&&添加链接&&保存它。

sudo vim /etc/apt/sources.list.d/pgdg.list

deb http://apt.postgresql.org/pub/repos/apt/ xenial-pgdg main

deb http://apt.postgresql.org/pub/repos/apt/ precise-pgdg main

然后更新你的系统

sudo apt-get update

sudo apt-get upgrade

并安装未满足的依赖项:

apt-get install ssl-cert

就是这样。现在使用这些命令安装postgresql

sudo apt-get install postgresql-10