如何彻底清除和重新安装postgresql在ubuntu?

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

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

249325 次浏览

选择一个

如果你的安装没有损坏,你可以使用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

我知道已经提供了一个答案,但dselect对我不起作用。以下是找到要删除的包的方法:

# search postgr  | grep ^i
i   postgresql                      - object-relational SQL database (supported
i A postgresql-8.4                  - object-relational SQL database, version 8.
i A postgresql-client-8.4           - front-end programs for PostgreSQL 8.4
i A postgresql-client-common        - manager for multiple PostgreSQL client ver
i A postgresql-common               - PostgreSQL database-cluster manager


# aptitude purge postgresql-8.4 postgresql-client-8.4 postgresql-client-common postgresql-common postgresql


rm -r /etc/postgresql/
rm -r /etc/postgresql-common/
rm -r /var/lib/postgresql/

最后,编辑/etc/passwd和/etc/group

我在跟踪回复, 当编辑/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)

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

  1. < p > 列出所有与Postgres相关的包

    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
    
  2. 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
    
  3. Remove the following folders

    sudo rm -rf /var/lib/postgresql/
    sudo rm -rf /var/log/postgresql/
    sudo rm -rf /etc/postgresql/
    
apt-get purge postgresql*

就足够了。

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

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

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

我也有类似的情况:我需要在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是空的,运行service 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

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

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

首先删除已安装的postgres:-

Sudo apt-get清除postgr*

Sudo apt-get自动删除

然后安装synaptic:

Sudo apt-get安装突触

Sudo apt-get update

然后安装postgres

安装postgresql postgresql-contrib

我在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中。列表文件如果没有,你必须创建&&添加link &&保存它。

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