Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >如何在Debian 9上安装PostgreSQL

如何在Debian 9上安装PostgreSQL

作者头像
双面人
发布于 2019-04-10 08:03:02
发布于 2019-04-10 08:03:02
2.6K00
代码可运行
举报
文章被收录于专栏:热爱IT热爱IT
运行总次数:0
代码可运行

PostgreSQL,通常简称为Postgres,是一种开源的通用对象 - 关系数据库管理系统。 PostgreSQL具有许多高级功能,如在线备份,即时恢复,嵌套事务,SQL和JSON查询,多版本并发控制(MVCC),异步复制等。

在本教程中,我们将向您展示如何在Debian 9上安装PostgreSQL并探索基本数据库管理的基础知识。

安装PostgreSQL

在撰写本文时,Debian存储库中提供的PostgreSQL的最新版本是PostgreSQL版本9.6。

要在Debian服务器上安装PostgreSQL,请完成以下步骤:

01、首先更新本地包索引:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo apt update

02、安装PostgreSQL服务器和PostgreSQL contrib包,它为PostgreSQL数据库提供了额外的功能:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo apt install postgresql postgresql-contrib

03、安装完成后,PostgreSQL服务将自动启动。 要验证安装,我们将使用psql实用程序连接到PostgreSQL数据库服务器并打印服务器版本:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo -u postgres psql -c "SELECT version();"

输出内容:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
                                                 version                                                  
-----------------------------------------------------------------------------------------------------------
PostgreSQL 9.6.10 on x86_64-pc-linux-gnu, compiled by gcc (Debian 6.3.0-18+deb9u1) 6.3.0 20170516, 64-bit
(1 row)

Psql是一个交互式终端程序,允许您与PostgreSQL服务器进行交互。

PostgreSQL角色和身份验证方法

PostgreSQL使用角色的概念处理数据库访问权限。 角色可以表示数据库用户或一组数据库用户。

PostgreSQL支持许多身份验证方法。 最常用的方法是:

  • 信任 - 使用此方法,只要满足pg_hba.conf中定义的条件,角色就可以在没有密码的情况下进行连接。
  • 密码 - 角色可以通过提供密码进行连接。 密码可以存储为scram-sha-256 md5和密码(明文)
  • Ident - 仅在TCP / IP连接上支持此方法。 通过获取客户端的操作系统用户名,使用可选的用户名映射来工作。
  • 对等 - 与Ident相同,但仅在本地连接上支持。

PostgreSQL客户端身份验证在名为pg_hba.conf的配置文件中定义。 默认情况下,本地连接PostgreSQL设置为使用对等身份验证方法。

安装PostgreSQL时会自动创建postgres用户。 该用户是PostgreSQL实例的超级用户,它相当于MySQL root用户。

要首先以postgres用户身份登录PostgreSQL服务器,需要切换到postgres用户,然后使用psql实用程序访问PostgreSQL提示符:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo su - postgres
psql

从这里,您可以与PostgreSQL实例进行交互。 要退出PostgreSQL shell类型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
\q

您可以使用sudo命令访问PostgreSQL提示符而无需切换用户:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo -u postgres psql

postgres用户通常仅在本地主机中使用,建议不要为此用户设置密码。

创建PostgreSQL角色和数据库

您可以使用createuser命令从命令行创建新角色。 只有具有CREATEROLE权限的超级用户和角色才能创建新角色。

在下面的示例中,我们将创建一个名为jonh的新角色,该数据库名为johndb并授予数据库权限。

01、创建一个新的PostgreSQL角色

以下命令将创建一个名为john的新角色:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo su - postgres -c "createuser john"

02、创建一个新的PostgreSQL数据库

使用createdb命令创建名为johndb的新数据库:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo su - postgres -c "createdb johndb"

03、授予权限

要在我们在上一步中创建的数据库上为john用户授予权限,请连接到PostgreSQL shell:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo -u postgres psql

运行以下查询:

grant all privileges on database johndb to john;

启用对PostgreSQL服务器的远程访问

默认情况下,PostgreSQL服务器仅侦听本地接口127.0.0.1。 要启用对PostgreSQL服务器的远程访问,请打开配置文件postgresql.conf并在CONNECTIONS AND AUTHENTICATION部分添加listen_addresses ='*'。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo vim /etc/postgresql/9.6/main/postgresql.conf

/etc/postgresql/9.6/main/postgresql.conf

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#------------------------------------------------------------------------------
# CONNECTIONS AND AUTHENTICATION
#------------------------------------------------------------------------------

# - Connection Settings -

listen_addresses = '*'     # what IP address(es) to listen on;

保存文件并重启PostgreSQL服务:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo service postgresql restart

输出结果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
LISTEN   0         128                 0.0.0.0:5432             0.0.0.0:*
LISTEN   0         128                    [::]:5432                [::]:*

从上面的输出可以看出,PostgreSQL服务器正在监听所有接口(0.0.0.0)。

最后一步是通过编辑pg_hba.conf文件将服务器配置为接受远程连接。

以下是一些显示不同用例的示例:

/etc/postgresql/9.6/main/pg_hba.conf

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# TYPE  DATABASE        USER            ADDRESS                 METHOD

# The user jane will be able access all databases from all locations using a md5 password
host    all             jane            0.0.0.0/0                md5

# The user jane will be able access only the janedb from all locations using a md5 password
host    janedb          jane            0.0.0.0/0                md5

# The user jane will be able access all databases from a trusted location (192.168.1.134) without a password
host    all             jane            192.168.1.134            trust

您已经学习了如何在Debian 9服务器上安装和配置PostgreSQL。 有关此主题的更多信息,请参阅PostgreSQL文档

(adsbygoogle = window.adsbygoogle || []).push({});

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018/11/24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
如何在 CentOS 8 上安装 Postgresql
PostgreSQL 或者 Postgres 是一个开源的,多用途的关系型数据库管理系统。它有很多高级特性,可以允许你构建容错的环境或者复杂的应用。
雪梦科技
2020/05/11
6.8K0
如何在 CentOS 8 上安装 Postgresql
PostgreSQL集群篇——2、PG环境安装准备
PostgreSQL官方文档中讲到了多种高可用、负载均衡和复制特性解决方案,如下图所示:
cn華少
2021/07/15
3.1K1
从零开始学PostgreSQL (一):Centos8 RPM安装PostgreSQL16
DBA实战
2024/09/06
2490
从零开始学PostgreSQL (一):Centos8 RPM安装PostgreSQL16
如何配置来完成PostgreSQL数据库远程连接
安装PostgreSQL数据库之后,默认是只接受本地访问连接。如果想在其他主机上访问PostgreSQL数据库服务器,就需要进行相 应的配置。配置远程连接PostgreSQL数据库的步骤很简单,只需要修改data目录下的pg_hba.conf和postgresql.conf, 其中pg_hba.conf是用来配置对数据库的访问权限,postgresql.conf文件用来配置PostgreSQL数据库服务器的相应的参数。 下面介绍配置的步骤:
飞奔去旅行
2019/06/13
2.4K0
01 . PostgreSQL简介部署
PostgreSQL简介 简介 PostgreSQL在业内通常也简称PG,是一个关系型数据库管理系统,适用于各种Linux操作系统、Windows、Solaris、BSD和Mac OS X。PostgreSQL遵循BSD许可,是一个开源软件,PostgreSQL作为全球第四大关系型数据库服务,正在以飞快的速度发展,目前已经广泛用在各个行业,PostgreSQL本身具有哪些功能特点,请往下看 # 1. PostgreSQL数据库是目前功能最强大的开源数据库,是架构上和Oracle最接近的开源数据库.它基
iginkgo18
2020/09/27
1.2K0
PostgreSQL入门
这时相当于系统用户postgres以同名数据库用户的身份,登录数据库,这是不用输入密码的。如果一切正常,系统提示符会变为"postgres=#",表示这时已经进入了数据库控制台。以下的命令都在控制台内完成。
老马
2019/05/25
1.9K0
PostgreSQL基础(二):PostgreSQL的安装与配置
PostgreSQL不推荐使用root管理,在安装成功postgreSQL后,他默认会给你创建一个用户:postgres
Lansonli
2024/09/06
3.7K0
PostgreSQL基础(二):PostgreSQL的安装与配置
CentOS 7.9 安装 Postgresql 9.6
下面的步骤都是按照 9.6 版本进行安装的,如果时境过迁,9.6 也不支持了,只需要更改下面的版本号即可,将 9.6 版本改为你安装的版本,例如版本 10 ,只需要将下面所有的 9.6 改为 10 。
wsuo
2021/08/31
1.1K0
CentOS 7.9 安装 Postgresql 9.6
CentOS7 安装PostgreSQL
版权声明:本文为木偶人shaon原创文章,转载请注明原文地址,非常感谢。 https://blog.csdn.net/wh211212/article/details/79627984
shaonbean
2019/05/26
6450
PostgreSQL安装和使用教程
本篇博客将为您提供关于PostgreSQL数据库的安装和使用教程,帮助您快速上手使用这个强大的开源关系型数据库系统。我们将介绍安装过程和基本使用方法,让您能够轻松开始使用PostgreSQL。
猫头虎
2024/04/08
9560
PostgreSQL安装和使用教程
PostgreSQL数据库连接报错:psql: error: FATAL: password authentication failed for user ..
江湖有缘
2023/11/08
2.2K0
PostgreSQL数据库连接报错:psql: error: FATAL: password authentication failed for user ..
PostgreSQL本地/远程登陆配置
关于PostgreSQL与PostGIS使用,可参看《PostgreSQL与PostGIS的基础入门》。本篇文章主要介绍如何实现本地与远程登陆,并对其认证方式进行总结。
create17
2019/04/17
14K0
PostgreSQL本地/远程登陆配置
PostgreSQL远程连接配置管理/账号密码分配 转
说明:这个是由于没有配置远程访问且认证方式没改造成的,只需要更改使用账号密码认证即可。
双面人
2019/05/21
2.8K0
2.5 Linux(Ubuntu18.04)安装数据库PostgreSQL
2.5 Linux(Ubuntu18.04)安装数据库PostgreSQL “卜算子·大数据”一个开源、成体系的大数据学习教程。——每周日更新 本节主要内容: 创建一台database虚拟机(本章称为
王小雷
2019/05/28
1K0
如何在CentOS 7上安装PostgreSQL关系数据库
PostgreSQL关系数据库系统是一个功能强大的,可扩展的,并符合标准的开源数据库平台。本指南将帮助您在CentOS 7 Linode上安装和配置PostgreSQL。
沈唁
2018/09/20
4.6K0
Linux 上安装 PostgreSQL
可以参考:https://www.cnblogs.com/freeweb/p/8006639.html#top
别先生
2020/09/01
6.5K0
Linux 上安装 PostgreSQL
Postgresql10离线安装
1、在很多时候,服务器不能联网,需要离线安装,下面是Postgresql10离线安装的步骤:
别先生
2021/03/08
1.4K0
如何在腾讯云上启用 PostgreSQL 数据库远程访问?
EarlGrey
2017/06/02
7.5K0
如何在腾讯云上启用 PostgreSQL 数据库远程访问?
CentOS7 部署 PostgreSQL
陳斯托洛夫斯記
2024/08/07
980
PostgreSQL创建角色,并把数据库赋给角色
目前位于数据库postgres下。创建tom用户。对于PostgreSQL,用户tom相当于是一种role(角色):
双面人
2019/12/25
4.1K0
相关推荐
如何在 CentOS 8 上安装 Postgresql
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档