2019-10-18 18:24:35 +08:00
|
|
|
|
[#]: collector: (lujun9972)
|
|
|
|
|
[#]: translator: (lnrCoder)
|
2019-10-19 22:50:40 +08:00
|
|
|
|
[#]: reviewer: (wxy)
|
2019-10-19 22:52:31 +08:00
|
|
|
|
[#]: publisher: (wxy)
|
|
|
|
|
[#]: url: (https://linux.cn/article-11480-1.html)
|
2019-10-18 18:24:35 +08:00
|
|
|
|
[#]: subject: (How to Install and Configure PostgreSQL on Ubuntu)
|
|
|
|
|
[#]: via: (https://itsfoss.com/install-postgresql-ubuntu/)
|
|
|
|
|
[#]: author: (Sergiu https://itsfoss.com/author/sergiu/)
|
|
|
|
|
|
|
|
|
|
如何在 Ubuntu 上安装和配置 PostgreSQL
|
|
|
|
|
======
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
> 本教程中,你将学习如何在 Ubuntu Linux 上安装和使用开源数据库 PostgreSQL。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
[PostgreSQL][1] (又名 Postgres) 是一个功能强大的自由开源的关系型数据库管理系统 ([RDBMS][2]) ,其在可靠性、稳定性、性能方面获得了业内极高的声誉。它旨在处理各种规模的任务。它是跨平台的,而且是 [macOS Server][3] 的默认数据库。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
如果你喜欢简单易用的 SQL 数据库管理器,那么 PostgreSQL 将是一个正确的选择。PostgreSQL 对标准的 SQL 兼容的同时提供了额外的附加特性,同时还可以被用户大量扩展,用户可以添加数据类型、函数并执行更多的操作。
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
之前我曾论述过 [在 Ubuntu 上安装 MySQL][4]。在本文中,我将向你展示如何安装和配置 PostgreSQL,以便你随时可以使用它来满足你的任何需求。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
![][5]
|
|
|
|
|
|
|
|
|
|
### 在 Ubuntu 上安装 PostgreSQL
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
PostgreSQL 可以从 Ubuntu 主存储库中获取。然而,和许多其它开发工具一样,它可能不是最新版本。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
首先在终端中使用 [apt 命令][7] 检查 [Ubuntu 存储库][6] 中可用的 PostgreSQL 版本:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
apt show postgresql
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
在我的 Ubuntu 18.04 中,它显示 PostgreSQL 的可用版本是 10(10+190 表示版本 10)而 PostgreSQL 版本 11 已经发布。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
Package: postgresql
|
|
|
|
|
Version: 10+190
|
|
|
|
|
Priority: optional
|
|
|
|
|
Section: database
|
|
|
|
|
Source: postgresql-common (190)
|
|
|
|
|
Origin: Ubuntu
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
根据这些信息,你可以自主决定是安装 Ubuntu 提供的版本还是还是获取 PostgreSQL 的最新发行版。
|
|
|
|
|
|
|
|
|
|
我将向你介绍这两种方法:
|
|
|
|
|
|
|
|
|
|
#### 方法一:通过 Ubuntu 存储库安装 PostgreSQL
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
在终端中,使用以下命令安装 PostgreSQL:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
sudo apt update
|
|
|
|
|
sudo apt install postgresql postgresql-contrib
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
根据提示输入你的密码,依据于你的网速情况,程序将在几秒到几分钟安装完成。说到这一点,随时检查 [Ubuntu 中的各种网络带宽][8]。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
> 什么是 postgresql-contrib?
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
> postgresql-contrib 或者说 contrib 包,包含一些不属于 PostgreSQL 核心包的实用工具和功能。在大多数情况下,最好将 contrib 包与 PostgreSQL 核心一起安装。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
#### 方法二:在 Ubuntu 中安装最新版本的 PostgreSQL 11
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
要安装 PostgreSQL 11, 你需要在 `sources.list` 中添加官方 PostgreSQL 存储库和证书,然后从那里安装它。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
不用担心,这并不复杂。 只需按照以下步骤。
|
|
|
|
|
|
|
|
|
|
首先添加 GPG 密钥:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
现在,使用以下命令添加存储库。如果你使用的是 Linux Mint,则必须手动替换你的 Mint 所基于的 Ubuntu 版本号:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt/ `lsb_release -cs`-pgdg main" >> /etc/apt/sources.list.d/pgdg.list'
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
现在一切就绪。使用以下命令安装 PostgreSQL:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
sudo apt update
|
|
|
|
|
sudo apt install postgresql postgresql-contrib
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
> PostgreSQL GUI 应用程序
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
> 你也可以安装用于管理 PostgreSQL 数据库的 GUI 应用程序(pgAdmin):
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
> `sudo apt install pgadmin4`
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
### PostgreSQL 配置
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你可以通过执行以下命令来检查 PostgreSQL 是否正在运行:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
service postgresql status
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
通过 `service` 命令,你可以启动、关闭或重启 `postgresql`。输入 `service postgresql` 并按回车将列出所有选项。现在,登录该用户。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
默认情况下,PostgreSQL 会创建一个拥有所权限的特殊用户 `postgres`。要实际使用 PostgreSQL,你必须先登录该账户:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
sudo su postgres
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你的提示符会更改为类似于以下的内容:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
postgres@ubuntu-VirtualBox:/home/ubuntu$
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
现在,使用 `psql` 来启动 PostgreSQL Shell:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
psql
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你应该会看到如下提示符:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
postgress=#
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你可以输入 `\q` 以退出,输入 `\?` 获取帮助。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
要查看现有的所有表,输入如下命令:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
\l
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
输出内容类似于下图所示(单击 `q` 键退出该视图):
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
![PostgreSQL Tables][10]
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
使用 `\du` 命令,你可以查看 PostgreSQL 用户:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
![PostgreSQLUsers][11]
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你可以使用以下命令更改任何用户(包括 `postgres`)的密码:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
ALTER USER postgres WITH PASSWORD 'my_password';
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
**注意:**将 `postgres` 替换为你要更改的用户名,`my_password` 替换为所需要的密码。另外,不要忘记每条命令后面的 `;`(分号)。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
建议你另外创建一个用户(不建议使用默认的 `postgres` 用户)。为此,请使用以下命令:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
CREATE USER my_user WITH PASSWORD 'my_password';
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
运行 `\du`,你将看到该用户,但是,`my_user` 用户没有任何的属性。来让我们给它添加超级用户权限:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
ALTER USER my_user WITH SUPERUSER;
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你可以使用以下命令删除用户:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
DROP USER my_user;
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
要使用其他用户登录,使用 `\q` 命令退出,然后使用以下命令登录:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
psql -U my_user
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你可以使用 `-d` 参数直接连接数据库:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
psql -U my_user -d my_db
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
你可以使用其他已存在的用户调用 PostgreSQL。例如,我使用 `ubuntu`。要登录,从终端执行以下命名:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
psql -U ubuntu -d postgres
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
**注意:**你必须指定一个数据库(默认情况下,它将尝试将你连接到与登录的用户名相同的数据库)。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
如果遇到如下错误:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
psql: FATAL: Peer authentication failed for user "my_user"
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
确保以正确的用户身份登录,并使用管理员权限编辑 `/etc/postgresql/11/main/pg_hba.conf`:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
sudo vim /etc/postgresql/11/main/pg_hba.conf
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
**注意:**用你的版本替换 `11`(例如 `10`)。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
对如下所示的一行进行替换:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
local all postgres peer
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
替换为:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
local all postgres md5
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
然后重启 PostgreSQL:
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
sudo service postgresql restart
|
|
|
|
|
```
|
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
使用 PostgreSQL 与使用其他 SQL 类型的数据库相同。由于本文旨在帮助你进行初步的设置,因此不涉及具体的命令。不过,这里有个 [非常有用的要点][12] 可供参考! 另外, 手册(`man psql`)和 [文档][13] 也非常有用。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
### 总结
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
阅读本文有望指导你完成在 Ubuntu 系统上安装和准备 PostgreSQL 的过程。如果你不熟悉 SQL,你应该阅读 [基本的 SQL 命令][15]。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
2019-10-19 22:50:40 +08:00
|
|
|
|
如果你有任何问题或疑惑,请随时在评论部分提出。
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
via: https://itsfoss.com/install-postgresql-ubuntu/
|
|
|
|
|
|
|
|
|
|
作者:[Sergiu][a]
|
|
|
|
|
选题:[lujun9972][b]
|
|
|
|
|
译者:[lnrCoder](https://github.com/lnrCoder)
|
2019-10-19 22:50:40 +08:00
|
|
|
|
校对:[wxy](https://github.com/wxy)
|
2019-10-18 18:24:35 +08:00
|
|
|
|
|
|
|
|
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
|
|
|
|
|
|
|
|
[a]: https://itsfoss.com/author/sergiu/
|
|
|
|
|
[b]: https://github.com/lujun9972
|
|
|
|
|
[1]: https://www.postgresql.org/
|
|
|
|
|
[2]: https://www.codecademy.com/articles/what-is-rdbms-sql
|
|
|
|
|
[3]: https://www.apple.com/in/macos/server/
|
|
|
|
|
[4]: https://itsfoss.com/install-mysql-ubuntu/
|
|
|
|
|
[5]: https://i1.wp.com/itsfoss.com/wp-content/uploads/2019/08/install-postgresql-ubuntu.png?resize=800%2C450&ssl=1
|
|
|
|
|
[6]: https://itsfoss.com/ubuntu-repositories/
|
|
|
|
|
[7]: https://itsfoss.com/apt-command-guide/
|
|
|
|
|
[8]: https://itsfoss.com/network-speed-monitor-linux/
|
|
|
|
|
[9]: https://itsfoss.com/fix-gvfsd-smb-high-cpu-ubuntu/
|
|
|
|
|
[10]: https://i2.wp.com/itsfoss.com/wp-content/uploads/2019/07/postgresql_tables.png?fit=800%2C303&ssl=1
|
|
|
|
|
[11]: https://i1.wp.com/itsfoss.com/wp-content/uploads/2019/07/postgresql_users.png?fit=800%2C244&ssl=1
|
|
|
|
|
[12]: https://gist.github.com/Kartones/dd3ff5ec5ea238d4c546
|
|
|
|
|
[13]: https://www.postgresql.org/docs/manuals/
|
|
|
|
|
[14]: https://itsfoss.com/sync-any-folder-with-dropbox/
|
|
|
|
|
[15]: https://itsfoss.com/basic-sql-commands/
|