【PostgreSQL】基于CentOS系统安装PostgreSQL数据库

一、参考链接

阿里巴巴开源镜像站-OPSX镜像站-阿里云开发者社区

postgresql镜像-postgresql下载地址-postgresql安装教程-阿里巴巴开源镜像站

二、PostgreSQL介绍

PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),是以加州大学计算机系开发的POSTGRES,4.2版本为基础的对象关系型数据库管理系统。POSTGRES的许多领先概念只是在比较迟的时候才出现在商业网站数据库中。PostgreSQL支持大部分的SQL标准并且提供了很多其他现代特性,如复杂查询、外键、触发器、视图、事务完整性、多版本并发控制等。同样,PostgreSQL也可以用许多方法扩展,例如通过增加新的数据类型、函数、操作符、聚集函数、索引方法、过程语言等。另外,因为许可证的灵活,任何人都可以以任何目的免费使用、修改和分发PostgreSQL。(——PostgreSQL_百度百科)

三、PostgreSQL安装

本实验基于CentOS 7.9系统进行演示操作

 [root@postgresql ~]# cat /etc/redhat-release 
 CentOS Linux release 7.9.2009 (Core)

安装准备

 修改主机名
 # hostnamectl set-hostname prostgresql
 
 关闭防火墙
 # systemctl stop firewalld
 # systemctl disable firewalld
 
 关闭SELinux安全模式
 # setenforce 0
 # getenforce 
 
 配置网络信息并测试连通性
 vim /etc/sysconfig/network-scripts/ifcfg-ens32
 主要修改如下参数信息即可。
 BOOTPROTO=static
 ONBOOT=yes
 IPADDR=192.168.200.25
 PREFIX=24
 GATEWAY=192.168.200.1
 DNS1=192.168.200.1
 按:wq保存退出。
 
 重启网卡
 # systemctl restart network
 # ping bing.com
 
 配置阿里云CentOS YUM源,加快镜像访问下载
 参考链接:https://blog.csdn.net/qq_45392321/article/details/121450443
 # yum clean all
 # yum makecache
 # yum repolist
 
 升级系统🆙
 # yum update
 
 检查postgresql是否安装
 # rpm -qa | grep postgre
 
 检查PostgreSQL 安装位置
 # rpm -qal | grep postgres
 
 新增postgres用户组
 # groupadd postgres
 
 新增postgres用户并且设置这个postgres用户属于创建的postgres用户组
 # useradd -g postgres postgres
 
 修改postgres用户密码
 [root@postgresql ~]# passwd postgres
 Changing password for user postgres.
 New password: 
 BAD PASSWORD: The password is a palindrome
 Retype new password: 
 passwd: all authentication tokens updated successfully.
 [root@postgresql ~]# 
 
 重启系统
 reboot

1、查询并安装postgresql-server

 yum list | grep postgresql-server
 
 yum install -y postgresql-server.x86_64</pre>

![image-20220224135741784](https://upload-images.jianshu.io/upload_images/21120971-ef223f72732a02ae.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) 

### 2、初始化postgresql-server数据库

> **service postgresql initdb**

```sh
 # service postgresql initdb
 Hint: the preferred way to do this is now "postgresql-setup initdb"
 Initializing database ... OK

3、启动postgresql服务并设置开机自启动

 systemctl start postgresql
 systemctl enable postgresql

4、查看postgresql服务状态

 systemctl status postgresql

5、查看服务进程信息

 [root@postgresql ~]# ps -ef | grep postgres
 postgres   1405      1  0 16:05 ?        00:00:00 /usr/bin/postgres -D /var/lib/pgsql/data -p 5432
 postgres   1406   1405  0 16:05 ?        00:00:00 postgres: logger process 
 postgres   1408   1405  0 16:05 ?        00:00:00 postgres: checkpointer process 
 postgres   1409   1405  0 16:05 ?        00:00:00 postgres: writer process 
 postgres   1410   1405  0 16:05 ?        00:00:00 postgres: wal writer process 
 postgres   1411   1405  0 16:05 ?        00:00:00 postgres: autovacuum launcher process 
 postgres   1412   1405  0 16:05 ?        00:00:00 postgres: stats collector process 
 root       1440   1131  0 16:07 pts/0    00:00:00 grep --color=auto postgres
 [root@postgresql ~]# 

6、查看postgresql服务端口是否开启

 # ss -tunpl | grep postgres
 tcp    LISTEN     0      128    127.0.0.1:5432                  *:*                   users:(("postgres",pid=1349,fd=4))
 tcp    LISTEN     0      128       [::1]:5432               [::]:*                   users:(("postgres",pid=1349,fd=3))
 [root@postgresql ~]#
 # netstat -tunpl | grep 5432
 tcp    0   0 127.0.0.1:5432    0.0.0.0:*    LISTEN      1349/postgres 
 tcp6   0   0 ::1:5432          :::*         LISTEN      1349/postgres

四、测试连接

1、切换postgres用户

 [root@postgresql ~]# su postgres
 [postgres@postgresql root]$ 

2、连接数据库

 [root@postgresql ~]# su postgres
 [postgres@postgresql root]$ psql -U postgres
 could not change directory to "/root"
 psql (9.2.24)
 Type "help" for help.
 
 postgres=# 
 
 # 使用 \l 用于查看已经存在的数据库:
 postgres=# \l
  List of databases
  Name    |  Owner   | Encoding  | Collate | Ctype |   Access privileges 
 -----------+----------+-----------+---------+-------+-----------------------
  postgres  | postgres | SQL_ASCII | C       | C     | 
  template0 | postgres | SQL_ASCII | C       | C     | =c/postgres          +
  |          |           |         |       | postgres=CTc/postgres
  template1 | postgres | SQL_ASCII | C       | C     | =c/postgres          +
  |          |           |         |       | postgres=CTc/postgres
 (3 rows)
 
 postgres=# 
 
 # 进入命令行工具,可以使用 \help 来查看各个命令的语法
 postgres-# \help

3、创建数据库

 # 创建一个 runoobdb 的数据库
 postgres=# CREATE DATABASE xybdiy;
 CREATE DATABASE
 postgres=# 
 
 # 使用 \c + 数据库名 来进入数据库
 postgres=# \c xybdiy
 You are now connected to database "xybdiy" as user "postgres".
 xybdiy=# 

4、创建表格

 # 创建了一个表,表名为 COMPANY 表格,主键为 ID,NOT NULL 表示字段不允许包含 NULL 值
 xybdiy=# CREATE TABLE COMPANY(
 xybdiy(#    ID INT PRIMARY KEY     NOT NULL,
 xybdiy(#    NAME           TEXT    NOT NULL,
 xybdiy(#    AGE            INT     NOT NULL,
 xybdiy(#    ADDRESS        CHAR(50),
 xybdiy(#    SALARY         REAL
 xybdiy(# );
 NOTICE:  CREATE TABLE / PRIMARY KEY will create implicit index "company_pkey" for table "company"
 CREATE TABLE
 
 # 使用 \d 命令来查看表格是否创建成功
 xybdiy=# \d
  List of relations
  Schema |  Name   | Type  |  Owner 
 --------+---------+-------+----------
  public | company | table | postgres
 (1 row)
 
 xybdiy=# CREATE TABLE DEPARTMENT(
 xybdiy(#    ID INT PRIMARY KEY      NOT NULL,
 xybdiy(#    DEPT           CHAR(50) NOT NULL,
 xybdiy(#    EMP_ID         INT      NOT NULL
 xybdiy(# );
 NOTICE:  CREATE TABLE / PRIMARY KEY will create implicit index "department_pkey" for table "department"
 CREATE TABLE
 xybdiy=# \d
  List of relations
  Schema |    Name    | Type  |  Owner 
 --------+------------+-------+----------
  public | company    | table | postgres
  public | department | table | postgres
 (2 rows)
 
 xybdiy=#

五、修改配置文件

1、修改postgresql的配置文件

 # vim /var/lib/pgsql/data/postgresql.conf
 # 修改监听IP
 listen_addresses = '*'
 
 # 打开日志采集器
 logging_collector = on
 
 # 设置日志目录
 log_directory = 'pg_log'

2、修改 pg_hba.conf 服务连接配置文件

 # vim /var/lib/pgsql/data/pg_hba.conf
  77 # TYPE  DATABASE   USER      ADDRESS                 METHOD
  78 
  79 # "local" is for Unix domain socket connections only
  80 local   all        all                               trust
  81 # IPv4 local connections:
  82 host    all        all          127.0.0.1/32         trust
  83 host    all        all          0.0.0.0/0            trust
  84 # IPv6 local connections:
  85 host    all        all          ::1/128               md5

3、重启postgresql服务

 # systemctl restart postgresql

五、测试远程连接

测试连接

image-20220225171841803

测试成功后,连接

image-20220225171804258

连接成功

image-20220225172044099
image-20220225172032907

至此,安装PostgreSQ数据库完成。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352