如何在Ubuntu上安装和配置PostgreSQL
【大咖・来了 第7期】10月24日晚8点观看《智能导购对话机器人实践》
本教程中,你将学习如何在 Ubuntu Linux 上安装和使用开源数据库 PostgreSQL。
PostgreSQL (又名 Postgres) 是一个功能强大的自由开源的关系型数据库管理系统 (RDBMS) ,其在可靠性、稳定性、性能方面获得了业内极高的声誉。它旨在处理各种规模的任务。它是跨平台的,而且是 macOS Server 的默认数据库。
如果你喜欢简单易用的 SQL 数据库管理器,那么 PostgreSQL 将是一个正确的选择。PostgreSQL 对标准的 SQL 兼容的同时提供了额外的附加特性,同时还可以被用户大量扩展,用户可以添加数据类型、函数并执行更多的操作。
之前我曾论述过 在 Ubuntu 上安装 MySQL。在本文中,我将向你展示如何安装和配置 PostgreSQL,以便你随时可以使用它来满足你的任何需求。
在 Ubuntu 上安装 PostgreSQL
PostgreSQL 可以从 Ubuntu 主存储库中获取。然而,和许多其它开发工具一样,它可能不是最新版本。
首先在终端中使用 apt 命令 检查 Ubuntu 存储库 中可用的 PostgreSQL 版本:
<span class="pln">apt show postgresql</span>
在我的 Ubuntu 18.04 中,它显示 PostgreSQL 的可用版本是 10(10+190 表示版本 10)而 PostgreSQL 版本 11 已经发布。
<span class="typ">Package</span><span class="pun">:</span><span class="pln"> postgresql</span>
<span class="typ">Version</span><span class="pun">:</span><span class="pln"> </span><span class="lit">10</span><span class="pun">+</span><span class="lit">190</span>
<span class="typ">Priority</span><span class="pun">:</span><span class="pln"> optional</span>
<span class="typ">Section</span><span class="pun">:</span><span class="pln"> database</span>
<span class="typ">Source</span><span class="pun">:</span><span class="pln"> postgresql</span><span class="pun">-</span><span class="pln">common </span><span class="pun">(</span><span class="lit">190</span><span class="pun">)</span>
<span class="typ">Origin</span><span class="pun">:</span><span class="pln"> </span><span class="typ">Ubuntu</span>
根据这些信息,你可以自主决定是安装 Ubuntu 提供的版本还是还是获取 PostgreSQL 的最新发行版。
我将向你介绍这两种方法:
方法一:通过 Ubuntu 存储库安装 PostgreSQL
在终端中,使用以下命令安装 PostgreSQL:
<span class="kwd">sudo</span><span class="pln"> apt update</span>
<span class="kwd">sudo</span><span class="pln"> apt install postgresql postgresql</span><span class="pun">-</span><span class="pln">contrib</span>
根据提示输入你的密码,依据于你的网速情况,程序将在几秒到几分钟安装完成。说到这一点,随时检查 Ubuntu 中的各种网络带宽。
什么是 postgresql-contrib?
postgresql-contrib 或者说 contrib 包,包含一些不属于 PostgreSQL 核心包的实用工具和功能。在大多数情况下,最好将 contrib 包与 PostgreSQL 核心一起安装。
方法二:在 Ubuntu 中安装最新版本的 PostgreSQL 11
要安装 PostgreSQL 11, 你需要在 sources.list
中添加官方 PostgreSQL 存储库和证书,然后从那里安装它。
不用担心,这并不复杂。 只需按照以下步骤。
首先添加 GPG 密钥:
<span class="kwd">wget</span><span class="pln"> </span><span class="pun">--</span><span class="pln">quiet </span><span class="pun">-</span><span class="pln">O </span><span class="pun">-</span><span class="pln"> https</span><span class="pun">:</span><span class="com">//www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -</span>
现在,使用以下命令添加存储库。如果你使用的是 Linux Mint,则必须手动替换你的 Mint 所基于的 Ubuntu 版本号:
<span class="kwd">sudo</span><span class="pln"> sh </span><span class="pun">-</span><span class="pln">c </span><span class="str">'echo "deb http://apt.postgresql.org/pub/repos/apt/ `lsb_release -cs`-pgdg main" >> /etc/apt/sources.list.d/pgdg.list'</span>
现在一切就绪。使用以下命令安装 PostgreSQL:
<span class="kwd">sudo</span><span class="pln"> apt update</span>
<span class="kwd">sudo</span><span class="pln"> apt install postgresql postgresql</span><span class="pun">-</span><span class="pln">contrib</span>
PostgreSQL GUI 应用程序
你也可以安装用于管理 PostgreSQL 数据库的 GUI 应用程序(pgAdmin):
sudo apt install pgadmin4
PostgreSQL 配置
你可以通过执行以下命令来检查 PostgreSQL 是否正在运行:
<span class="pln">service postgresql status</span>
通过 service
命令,你可以启动、关闭或重启 postgresql
。输入 service postgresql
并按回车将列出所有选项。现在,登录该用户。
默认情况下,PostgreSQL 会创建一个拥有所权限的特殊用户 postgres
。要实际使用 PostgreSQL,你必须先登录该账户:
<span class="kwd">sudo</span><span class="pln"> </span><span class="kwd">su</span><span class="pln"> postgres</span>
你的提示符会更改为类似于以下的内容:
<span class="pln">postgres@ubuntu</span><span class="pun">-</span><span class="typ">VirtualBox</span><span class="pun">:</span><span class="str">/home/</span><span class="pln">ubuntu$ </span>
现在,使用 psql
来启动 PostgreSQL Shell:
<span class="pln">psql</span>
你应该会看到如下提示符:
<span class="pln">postgress</span><span class="pun">=#</span>
你可以输入 \q
以退出,输入 \?
获取帮助。
要查看现有的所有表,输入如下命令:
<span class="pln">\l</span>
输出内容类似于下图所示(单击 q
键退出该视图):
PostgreSQL Tables
使用 \du
命令,你可以查看 PostgreSQL 用户:
PostgreSQLUsers
你可以使用以下命令更改任何用户(包括 postgres
)的密码:
<span class="pln">ALTER USER postgres WITH PASSWORD </span><span class="str">'my_password'</span><span class="pun">;</span>
注意:将 postgres
替换为你要更改的用户名,my_password
替换为所需要的密码。另外,不要忘记每条命令后面的 ;
(分号)。
建议你另外创建一个用户(不建议使用默认的 postgres
用户)。为此,请使用以下命令:
<span class="pln">CREATE USER my_user WITH PASSWORD </span><span class="str">'my_password'</span><span class="pun">;</span>
运行 \du
,你将看到该用户,但是,my_user
用户没有任何的属性。来让我们给它添加超级用户权限:
<span class="pln">ALTER USER my_user WITH SUPERUSER</span><span class="pun">;</span>
你可以使用以下命令删除用户:
<span class="pln">DROP USER my_user</span><span class="pun">;</span>
要使用其他用户登录,使用 \q
命令退出,然后使用以下命令登录:
<span class="pln">psql </span><span class="pun">-</span><span class="pln">U my_user</span>
你可以使用 -d
参数直接连接数据库:
<span class="pln">psql </span><span class="pun">-</span><span class="pln">U my_user </span><span class="pun">-</span><span class="pln">d my_db</span>
你可以使用其他已存在的用户调用 PostgreSQL。例如,我使用 ubuntu
。要登录,从终端执行以下命名:
<span class="pln">psql </span><span class="pun">-</span><span class="pln">U ubuntu </span><span class="pun">-</span><span class="pln">d postgres</span>
注意:你必须指定一个数据库(默认情况下,它将尝试将你连接到与登录的用户名相同的数据库)。
如果遇到如下错误:
<span class="pln">psql</span><span class="pun">:</span><span class="pln"> FATAL</span><span class="pun">:</span><span class="pln"> </span><span class="typ">Peer</span><span class="pln"> authentication failed </span><span class="kwd">for</span><span class="pln"> user </span><span class="str">"my_user"</span>
确保以正确的用户身份登录,并使用管理员权限编辑 /etc/postgresql/11/main/pg_hba.conf
:
<span class="kwd">sudo</span><span class="pln"> </span><span class="kwd">vim</span><span class="pln"> </span><span class="pun">/</span><span class="pln">etc</span><span class="pun">/</span><span class="pln">postgresql</span><span class="pun">/</span><span class="lit">11</span><span class="pun">/</span><span class="pln">main</span><span class="pun">/</span><span class="pln">pg_hba</span><span class="pun">.</span><span class="pln">conf</span>
注意:用你的版本替换 11
(例如 10
)。
对如下所示的一行进行替换:
<span class="kwd">local</span><span class="pln"> all postgres peer</span>
替换为:
<span class="kwd">local</span><span class="pln"> all postgres md5</span>
然后重启 PostgreSQL:
<span class="kwd">sudo</span><span class="pln"> service postgresql restart</span>
使用 PostgreSQL 与使用其他 SQL 类型的数据库相同。由于本文旨在帮助你进行初步的设置,因此不涉及具体的命令。不过,这里有个 非常有用的要点 可供参考! 另外, 手册(man psql
)和 文档 也非常有用。