【Linux】如何在Ubuntu 20.04上安装PostgreSQL

news/2024/7/9 23:14:03 标签: linux, ubuntu, postgresql

介绍

PostgreSQL或Postgres是一个关系数据库管理系统,提供SQL查询语言的实现。它符合标准,具有许多高级功能,如可靠的事务和无读锁的并发性。

本指南演示了如何在Ubuntu 20.04服务器上快速启动和运行Postgres,从安装PostgreSQL到设置新用户和数据库。如果你更喜欢关于安装和管理PostgreSQL数据库的更深入的教程,请参阅如何在Ubuntu 20.04上安装和使用PostgreSQL。

使用DigitalOcean托管数据库简化PostgreSQL数据库的创建。几分钟内创建一个Postgres数据库,让DigitalOcean处理数据迁移、升级、维护和安全。

先决条件

要遵循本教程,您将需要一台Ubuntu 20.04服务器,该服务器已按照我们的Ubuntu 20.04初始服务器设置指南进行配置。完成本必备教程后,您的服务器应具有具有sudo权限的非root用户和基本防火墙。

步骤1——安装PostgreSQL

要安装PostgreSQL,首先刷新服务器的本地包索引:

  • sudo apt update

然后,安装Postgres包以及一个-concontib包,该包添加了一些额外的实用程序和功能:

确保服务已启动:

步骤2——使用PostgreSQL角色和数据库

默认情况下,Postgres使用一个名为“角色”的概念来处理身份验证和授权。在某些方面,这些用户和组类似于普通Unix风格的用户和组。

安装后,Postgres被设置为使用ident身份验证,这意味着它将Postgres角色与匹配的Unix/Linux系统帐户相关联。如果Postgres中存在角色,则具有相同名称的Unix/Linux用户名可以作为该角色登录。

安装过程创建了一个名为postgres的用户帐户,该帐户与默认的postgres角色相关联。有几种方法可以利用这个帐户访问Postgres。一种方法是通过运行以下命令切换到服务器上的postgres帐户:  

  • sudo -i -u postgres


然后,您可以通过运行以下命令访问Postgres提示符:

  • psql


这将使您登录到PostgreSQL提示符,从这里您可以立即自由地与数据库管理系统交互。

要退出PostgreSQL提示,请运行以下操作:

  • \q

这将使您返回到postgres Linux命令提示符。要返回到常规系统用户,请运行exit命令:

  • exit

连接到Postgres提示符的另一种方法是直接使用sudo作为Postgres帐户运行psql命令:

  1. sudo -u postgres psql

这将使您直接登录到Postgres,而不需要中间的bash-shell。

同样,您可以通过运行以下程序退出交互式Postgres会话:

  • \q

第3步——创建新角色

如果您是以postgres帐户登录的,则可以通过运行以下命令创建新角色:

  • createuser --interactive

相反,如果您更喜欢在不从普通帐户切换的情况下对每个命令使用sudo,请运行:

  • sudo -u postgres createuser --interactive

无论哪种方式,脚本都会提示您做出一些选择,并根据您的响应,执行正确的Postgres命令,根据您的规范创建用户。

Output

Enter name of role to add: sammy Shall the new role be a superuser? (y/n) y

步骤4——创建新数据库

Postgres身份验证系统默认情况下做出的另一个假设是,对于用于登录的任何角色,该角色都将拥有一个可以访问的同名数据库。

这意味着,如果您在上一节中创建的用户名为sammy,则该角色将尝试连接到默认情况下也称为“sammy”的数据库。您可以使用createdb命令创建适当的数据库。

如果您是以postgres帐户登录的,您需要键入以下内容:

  • createdb sammy

相反,如果您更喜欢在不从正常帐户切换的情况下对每个命令使用sudo,则可以运行:

  • sudo -u postgres createdb sammy

步骤5——打开具有新角色的Postgres提示

要使用基于ident的身份验证登录,您需要一个与您的Postgres角色和数据库同名的Linux用户。

如果没有匹配的Linux用户,可以使用adduser命令创建一个。您必须从具有sudo权限的非root帐户(即不以postgres用户身份登录)执行此操作:

  • sudo adduser sammy

一旦此新帐户可用,您可以通过运行以下操作切换并连接到数据库:

  • sudo -i -u sammy
  • psql

或者,您可以内联执行此操作:

  • sudo -u sammy psql

假设所有组件都已正确配置,此命令将自动登录。

如果希望用户连接到其他数据库,可以通过如下方式指定数据库来实现:

  • psql -d postgres

登录后,您可以通过运行以下程序来检查当前连接信息:

  • \conninfo
Output

You are connected to database "sammy" as user "sammy" via socket in "/var/run/postgresql" at port "5432".

结论

现在,您已经在Ubuntu 20.04服务器上安装了PostgreSQL。如果您想了解更多关于Postgres的信息以及如何使用它,我们鼓励您查看以下指南:

  • 关系数据库管理系统的比较
  • 练习使用SQL运行查询

文章链接

【Linux】如何在Ubuntu 20.04上安装PostgreSQL[Quickstart] | 程序员云开发,云时代的程序员.b

欢迎收藏【架构师酒馆】和【开发者开聊】


http://www.niftyadmin.cn/n/5241048.html

相关文章

Diary14-Word样式设计

Word样式设计 一.样式 样式:其实就是一些表象信息的总结 样式的位置:【开始选项卡】->【样式功能区】->【其他】 1.1修改样式 【选中字体】->【找到对应的样式】->【右键】->【选择所有实例】->【再一次右键】->【修改】->…

【原创】Mac mini M1安装home-brew

Mac mini M1 所需神器 home-brew 按照官网的脚本无法安装。 无奈,从github下载安装包来安装。 Homebrew 结果,还需要先安装 Xcode command 命令行工具 xcode-select --install安装完了,却无法执行。 修改配置文件 cd vi .zshrc添加如下内…

蓝桥杯每日一题2023.12.5

题目描述 1.一步之遥 - 蓝桥云课 (lanqiao.cn) 题目分析 对于本题遵循多了就减少了就加的原则&#xff0c;用while进行计算即可 #include<bits/stdc.h> using namespace std; int x, ans; int main() {while(x ! 1){if(x < 1)x 97;else x - 127;ans ;}cout <&…

数学建模-二氧化碳排放及时空分布测度

二氧化碳排放及时空分布测度 整体求解过程概述(摘要) 面临全球气候变化的巨大挑战&#xff0c;我国积极响应《巴黎协定》的号召&#xff0c;提出“2030年前碳达峰&#xff0c;2060 年前实现碳中和”的碳排放发展目标&#xff0c;并将碳中和相关工作作为 2021 年的重点任务之一…

Java 控制台命令导入本地jar包到maven本地库中

1、新建POM文件&#xff0c;在maven库路径下创建POM文件 注意&#xff1a;这个路径需要与第2点导入命令中的grouoId、artifactId和version写法对应 Path&#xff1a;D:\RomanData\repository\com\sae\mail\1.0.0\mail-1.0.0.pom <?xml version"1.0" encoding&q…

php+redis抢购商品高并发实现

1、准备前库存先存储到redis // 创建Redis连接 $redis new Redis(); $redis->connect(127.0.0.1, 6379); // 假设Redis服务器在本地运行&#xff0c;端口为默认的6379 // 商品ID $productID 123; //库存 $stock10; $stockKey product: . $productID . :stock; $redis-&g…

k8s volumes and data

Overview 传统上&#xff0c;容器引擎(Container Engine)不提供比容器寿命更长的存储。由于容器被认为是瞬态(transient)的&#xff0c;这可能会导致数据丢失或复杂的外部存储选项。Kubernetes卷共享 Pod 生命周期&#xff0c;而不是其中的容器。如果容器终止&#xff0c;数据…

EPWM初学笔记

时钟 PCLKCR0 PCLKCR1 EPWM总体预览 三部分就可以简单的使用EPWM 时基模块&#xff0c;比较模块&#xff0c;动作限定模块 时基模块 TBCTL时基控制寄存器 TBCTR计数寄存器 TBPHS相位寄存器 TBPRD周期寄存器 比较模块 CMPCTL比较控制寄存器 影子模式&#xff0c;加载模式 CMP…