不知怎的,我已经设法在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不存在”,所以我会去找其中一个,但我相信这不会是它的结束。

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


当前回答

选择一个

如果你的安装没有损坏,你可以使用pg_dropcluster删除不需要的PostgreSQL服务器(“集群”)。如果你只是想重新启动一个新的PostgreSQL实例,可以优先使用该方法,而不是完全清除并重新安装。

$ pg_lsclusters
Ver Cluster Port Status Owner    Data directory              Log file
11  main    5432 online postgres /var/lib/postgresql/11/main /var/log/postgresql/postgresql-11-main.log
$ sudo systemctl stop postgresql@11-main
$ sudo pg_dropcluster --stop 11 main
$ sudo pg_createcluster --start 11 main

选项B

如果你真的需要彻底清除并重新安装,首先要确保PostgreSQL没有运行。ps -C postgres不显示任何结果。

现在运行:

apt-get --purge remove postgresql\*

从你的系统中删除所有PostgreSQL。仅仅清除postgres包是不够的,因为它只是一个空的元包。

一旦所有PostgreSQL包被删除,运行:

rm -r /etc/postgresql/
rm -r /etc/postgresql-common/
rm -r /var/lib/postgresql/
userdel -r postgres
groupdel postgres

你现在应该能够:

apt-get install postgresql

或完整安装:

apt-get install postgresql-8.4 postgresql-contrib-8.4 postgresql-doc-8.4

其他回答

我在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/

我在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

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

首先删除已安装的postgres:-

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

然后安装synaptic:

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

然后安装postgres

安装postgresql postgresql-contrib

我在看回复 当编辑/etc/group时,我也删除了这一行:

ssl-cert:x:112:postgres

然后,当我试图安装postgresql时,我得到了这个错误

Preconfiguring packages ...
dpkg: unrecoverable fatal error, aborting:
 syntax error: unknown group 'ssl-cert' in statoverride file
E: Sub-process /usr/bin/dpkg returned an error code (2)

将“ssl-cert:x:112:postgres”行放回/etc/group中似乎可以修复它(所以我能够安装postgresql)

apt-get purge postgresql*

就足够了。