主頁 > 資料庫 > CentOS 8.2使用pgAdmin安裝PostgreSQL

CentOS 8.2使用pgAdmin安裝PostgreSQL

2020-12-20 07:25:09 資料庫

目錄
  • 什么是PostgreSQL?
  • 什么是pgAdmin?
  • 環境規格:
  • 第一步:更新Linux服務器軟體包
  • 第二步:安裝Postgres官方Yum存盤庫
  • 第三步:CentOS 8上安裝Postgres資料庫服務器
  • 第四步:配置Postgres資料庫服務以進行網路訪問
  • 第五步:Postgres資料庫服務配置Linux防火墻
  • 第六步:CentOS 8上安裝pgAdmin Yum存盤庫
  • 第七步:CentOS 8上安裝pgAdmin Web UI
  • 結論

PostgreSQL是最高級的RDBMS,而pgAdmin是Postgres的Web UI,在這里,您將看到如何在CentOS 8上使用pgAdmin安裝PostgreSQL,

什么是PostgreSQL?


PostgreSQL(也稱為Postgres)是一個免費的開源關系資料庫管理系統(RDBMS),強調可擴展性和SQL遵從性,PostgreSQL最初被命名為POSTGRES,指的是Ingres資料庫的后繼者,在1996年,該專案被更名為PostgreSQL,以反映其對SQL的支持,

PostgreSQL的事務具有原子性,一致性,隔離性,耐久性(ACID)屬性,自動可更新視圖,實體化視圖,觸發器,外鍵和存盤程序,它旨在處理各種作業負載,從單臺機器到具有多個并發用戶的資料倉庫或Web服務,它是macOS Server的默認資料庫,也可用于Linux,FreeBSD,OpenBSD和Windows,(來源:維基百科)

PostgreSQL是一個免費軟體,并根據PostgreSQL許可證發行(免費和開放源代碼,允許)

什么是pgAdmin?


pgAdmin是用于Postgres資料庫服務器的免費開放源代碼圖形用戶界面(GUI)管理工具,

pgAdmin在桌面和Web界面中可用,pgAdmin是PostgreSQL的其他管理工具中功能豐富且最受歡迎的功能,

就像PostgreSQL一樣,pgAdmin也是一個免費軟體,它也根據PostgreSQL許可證分發,

環境規格:


  • CPU :3.4 GHz(2核)
  • 記憶體:2 GB
  • 儲存空間:20 GB
  • 作業系統:CentOS 8.2
  • 主機名:postgres.lianglab.cn
  • IP地址:192.168.6.160/24

第一步:更新Linux服務器軟體包


使用SSH客戶端并登錄到postgres.lianglab.cn作為用戶,

使用dnf命令更新Linux服務器軟體包,

[root@postgres ~]# hostnamectl set-hostname postgres.lianglab.cn
[root@postgres ~]#dnf update -y
Dependencies resolved.
Nothing to do.
Complete!

我們的Linux作業系統已經是最新的,

檢查Linux作業系統和內核版本,

[root@postgres ~]# uname -r
4.18.0-193.28.1.el8_2.x86_64
[root@postgres ~]# cat /etc/redhat-release
CentOS Linux release 8.2.2004 (Core)

第二步:安裝Postgres官方Yum存盤庫


盡管Linux yum存盤庫中提供了Postgres資料庫服務器,但是要安裝最新版本,我們必須在Linux服務器中添加PostgreSQL官方yum存盤庫,

[root@postgres ~]# dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-8-x86_64/pgdg-redhat-repo-latest.noarch.rpm
Last metadata expiration check: 1:47:55 ago on Sat 19 Dec 2020 07:50:22 PM CST.
pgdg-redhat-repo-latest.noarch.rpm                           15 kB/s |  11 kB     00:00    
Dependencies resolved.
============================================================================================
 Package                    Architecture     Version           Repository              Size
============================================================================================
Installing:
 pgdg-redhat-repo           noarch           42.0-14           @commandline            11 k

Transaction Summary
============================================================================================
Install  1 Package

Total size: 11 k
Installed size: 11 k
Downloading Packages:
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                                    1/1 
  Installing       : pgdg-redhat-repo-42.0-14.noarch                                    1/1 
  Verifying        : pgdg-redhat-repo-42.0-14.noarch                                    1/1 
Installed products updated.

Installed:
  pgdg-redhat-repo-42.0-14.noarch                                                           

Complete!

通過執行以下命令,在標準yum存盤庫中禁用PostgreSQL模塊,

[root@postgres ~]# dnf list postgresql
PostgreSQL common RPMs for RHEL/CentOS 8 - x86_64           191 kB/s | 511 kB     00:02    
PostgreSQL 13 for RHEL/CentOS 8 - x86_64                    9.2 kB/s | 196 kB     00:21    
PostgreSQL 12 for RHEL/CentOS 8 - x86_64                    8.0 kB/s | 418 kB     00:52    
PostgreSQL 11 for RHEL/CentOS 8 - x86_64                     18 kB/s | 608 kB     00:34    
PostgreSQL 10 for RHEL/CentOS 8 - x86_64                    135 kB/s | 411 kB     00:03    
PostgreSQL 9.6 for RHEL/CentOS 8 - x86_64                   3.1 kB/s | 400 kB     02:09    
PostgreSQL 9.5 for RHEL/CentOS 8 - x86_64                   4.4 kB/s | 356 kB     01:20    
Available Packages
postgresql.x86_64               10.14-1.module_el8.2.0+487+53cc39ce                AppStream
[root@postgres ~]# 
[root@postgres ~]# dnf -qy module disable postgresql
[root@postgres ~]# dnf list postgresql
Last metadata expiration check: 0:10:17 ago on Sat 19 Dec 2020 09:45:13 PM CST.
Error: No matching Packages to list

第三步:CentOS 8上安裝Postgres資料庫服務器


【1】使用dnf命令在Linux服務器上安裝Postgres資料庫服務器13(在撰寫本文時為最新),

[root@postgres ~]# dnf install -y postgresql13-server
Last metadata expiration check: 0:11:15 ago on Sat 19 Dec 2020 09:45:13 PM CST.
Dependencies resolved.
============================================================================================
 Package                     Architecture   Version                    Repository      Size
============================================================================================
Installing:
 postgresql13-server         x86_64         13.1-1PGDG.rhel8           pgdg13         5.6 M
Installing dependencies:
 postgresql13                x86_64         13.1-1PGDG.rhel8           pgdg13         1.4 M
 postgresql13-libs           x86_64         13.1-1PGDG.rhel8           pgdg13         410 k

Transaction Summary
============================================================================================
Install  3 Packages

Total download size: 7.4 M
Installed size: 31 M
Downloading Packages:
(1/3): postgresql13-libs-13.1-1PGDG.rhel8.x86_64.rpm        9.1 kB/s | 410 kB     00:45    
(2/3): postgresql13-13.1-1PGDG.rhel8.x86_64.rpm             9.6 kB/s | 1.4 MB     02:27    
(3/3): postgresql13-server-13.1-1PGDG.rhel8.x86_64.rpm      5.3 kB/s | 5.6 MB     17:46    
--------------------------------------------------------------------------------------------
Total                                                       7.1 kB/s | 7.4 MB     17:46     
warning: /var/cache/dnf/pgdg13-e81daebfc8b779ec/packages/postgresql13-13.1-1PGDG.rhel8.x86_64.rpm: Header V4 DSA/SHA1 Signature, key ID 442df0f8: NOKEY
PostgreSQL 13 for RHEL/CentOS 8 - x86_64                    1.6 MB/s | 1.7 kB     00:00    
Importing GPG key 0x442DF0F8:
 Userid     : "PostgreSQL RPM Building Project <[email protected]>"
 Fingerprint: 68C9 E2B9 1A37 D136 FE74 D176 1F16 D2E1 442D F0F8
 From       : /etc/pki/rpm-gpg/RPM-GPG-KEY-PGDG
Key imported successfully
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                                    1/1 
  Installing       : postgresql13-libs-13.1-1PGDG.rhel8.x86_64                          1/3 
  Running scriptlet: postgresql13-libs-13.1-1PGDG.rhel8.x86_64                          1/3 
  Installing       : postgresql13-13.1-1PGDG.rhel8.x86_64                               2/3 
  Running scriptlet: postgresql13-13.1-1PGDG.rhel8.x86_64                               2/3 
  Running scriptlet: postgresql13-server-13.1-1PGDG.rhel8.x86_64                        3/3 
  Installing       : postgresql13-server-13.1-1PGDG.rhel8.x86_64                        3/3 
  Running scriptlet: postgresql13-server-13.1-1PGDG.rhel8.x86_64                        3/3 
  Verifying        : postgresql13-13.1-1PGDG.rhel8.x86_64                               1/3 
  Verifying        : postgresql13-libs-13.1-1PGDG.rhel8.x86_64                          2/3 
  Verifying        : postgresql13-server-13.1-1PGDG.rhel8.x86_64                        3/3 
Installed products updated.

Installed:
  postgresql13-13.1-1PGDG.rhel8.x86_64          postgresql13-libs-13.1-1PGDG.rhel8.x86_64  
  postgresql13-server-13.1-1PGDG.rhel8.x86_64  

Complete!

【2】執行一次以下命令來初始化Postgres資料庫,

[root@postgres ~]# /usr/pgsql-13/bin/postgresql-13-setup initdb
Initializing database ... OK

【3】啟用并啟動Postgres資料庫服務,

[root@postgres ~]# systemctl enable --now postgresql-13
Created symlink /etc/systemd/system/multi-user.target.wants/postgresql-13.service → /usr/lib/systemd/system/postgresql-13.service.

【4】檢查Postgres資料庫服務的狀態

[root@postgres ~]# systemctl status postgresql-13.service
● postgresql-13.service - PostgreSQL 13 database server
   Loaded: loaded (/usr/lib/systemd/system/postgresql-13.service; enabled; vendor preset: d>
   Active: active (running) since Sat 2020-12-19 22:18:10 CST; 3min 55s ago
     Docs: https://www.postgresql.org/docs/13/static/
  Process: 945378 ExecStartPre=/usr/pgsql-13/bin/postgresql-13-check-db-dir ${PGDATA} (code>
 Main PID: 945384 (postmaster)
    Tasks: 8 (limit: 23840)
   Memory: 17.4M
   CGroup: /system.slice/postgresql-13.service
           ├─945384 /usr/pgsql-13/bin/postmaster -D /var/lib/pgsql/13/data/
           ├─945385 postgres: logger 
           ├─945387 postgres: checkpointer 
           ├─945388 postgres: background writer 
           ├─945389 postgres: walwriter 
           ├─945390 postgres: autovacuum launcher 
           ├─945391 postgres: stats collector 
           └─945392 postgres: logical replication launcher 

Dec 19 22:18:10 postgres.lianglab.cn systemd[1]: Starting PostgreSQL 13 database server...
Dec 19 22:18:10 postgres.lianglab.cn postmaster[945384]: 2020-12-19 22:18:10.802 CST [94538>
Dec 19 22:18:10 postgres.lianglab.cn postmaster[945384]: 2020-12-19 22:18:10.802 CST [94538>
Dec 19 22:18:10 postgres.lianglab.cn systemd[1]: Started PostgreSQL 13 database server.

【5】檢查Postgres資料庫服務埠監聽資訊

[root@postgres ~]# netstat -anptl| grep postmaster
tcp        0      0 127.0.0.1:5432          0.0.0.0:*               LISTEN      945384/postmaster   
[root@postgres ~]# ss -anptl| grep postmaster
LISTEN    0         244              127.0.0.1:5432             0.0.0.0:*        users:(("postmaster",pid=945384,fd=6))         

【6】檢查已安裝的PostgreSQL服務器的版本,

[root@postgres ~]# psql -V
psql (PostgreSQL) 13.1

【7】切換到postgres用戶并連接到psql shell來設定管理員用戶密碼,

[root@postgres ~]# su - postgres
[postgres@postgres ~]$ psql 
psql (13.1)
Type "help" for help.

postgres=# ALTER USER postgres WITH PASSWORD 'liang123';
ALTER ROLE
postgres=# \q
[postgres@postgres ~]$ exit
logout

第四步:配置Postgres資料庫服務以進行網路訪問


PostgreSQL的默認服務埠是5432/tcp,執行以下命令以驗證PostgreSQL服務正在偵聽此埠,

[root@postgres ~]# ss -tulpn | grep 5432
tcp     LISTEN   0        244            127.0.0.1:5432           0.0.0.0:*      users:(("postmaster",pid=945384,fd=6))         

您可能會注意到PostgreSQL服務最初僅在localhost介面上運行,但是,要使我們的Postgres資料庫可用于網路客戶端,必須將PostgreSQL配置為在所有(或某些特定)介面上運行,

在vi文本編輯器中編輯PostgreSQL組態檔,

[root@postgres ~]# vi /var/lib/pgsql/13/data/postgresql.conf

在其中搜索以下指令,

# listen_addresses = 'localhost'

并用以下指令替換它,

listen_addresses = '*'
[root@postgres ~]# cat /var/lib/pgsql/13/data/postgresql.conf| grep listen_addresses
#listen_addresses = 'localhost'		# what IP address(es) to listen on;
[root@postgres ~]# vi /var/lib/pgsql/13/data/postgresql.conf
[root@postgres ~]# cat /var/lib/pgsql/13/data/postgresql.conf| grep listen_addresses
#listen_addresses = 'localhost'		# what IP address(es) to listen on;
listen_addresses = '*'
[root@postgres ~]# 

現在,您的Postgres資料庫服務已配置為在所有網路介面上進行偵聽,

允許192.168.6.0/24網路客戶端訪問pg_hba.conf檔案中的PostgreSQL服務,

[root@postgres ~]# echo "host all all 192.168.6.0/24 md5" >> /var/lib/pgsql/13/data/pg_hba.conf

重新啟動Postgres資料庫服務以應用更改,

[root@postgres ~]# systemctl restart postgresql-13.service

再次使用ss命令檢查網路服務,

[root@postgres ~]# ss -tulpn | grep 5432
tcp     LISTEN   0        244              0.0.0.0:5432           0.0.0.0:*      users:(("postmaster",pid=946059,fd=6))         
tcp     LISTEN   0        244                 [::]:5432              [::]:*      users:(("postmaster",pid=946059,fd=7))              

Postgres Service現在在所有網路介面上運行,

第五步:Postgres資料庫服務配置Linux防火墻


在CentOS 8中,我們已經為PostgreSQL提供了防火墻服務,因此我們可以通過使用firewall-cmd命令來允許它

[root@postgres ~]# firewall-cmd --permanent --add-service=postgresql
success
[root@postgres ~]# firewall-cmd --reload
success

Postgres資料庫服務器已安裝在Linux服務器上,

第六步:CentOS 8上安裝pgAdmin Yum存盤庫


pgAdmin是一個流行的Web界面,用于PostgreSQL資料庫的資料庫管理,

在PostgreSQL官方yum存盤庫中也提供了pgAdmin,但這在我們的CentOS 8服務器沒有作用的

因此,我們正在從pgAdmin官方yum存盤庫中安裝pgAdmin的最新穩定版本,

首先需要從Linux服務器上洗掉PostgreSQL yum存盤庫,

[root@postgres ~]# cat /etc/yum.repos.d/pgdg-redhat-all.repo | grep pgdg| wc -l
33
[root@postgres ~]# dnf remove -y pgdg-redhat-repo
Dependencies resolved.
========================================================================================================================================================================
 Package                                      Architecture                       Version                                Repository                                 Size
========================================================================================================================================================================
Removing:
 pgdg-redhat-repo                             noarch                             42.0-14                                @@commandline                              11 k

Transaction Summary
========================================================================================================================================================================
Remove  1 Package

Freed space: 11 k
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                                                                                                                1/1 
  Erasing          : pgdg-redhat-repo-42.0-14.noarch                                                                                                                1/1 
  Verifying        : pgdg-redhat-repo-42.0-14.noarch                                                                                                                1/1 
Installed products updated.

Removed:
  pgdg-redhat-repo-42.0-14.noarch                                                                                                                                       

Complete!
[root@postgres ~]# cat /etc/yum.repos.d/pgdg-redhat-all.repo | grep pgdg| wc -l
cat: /etc/yum.repos.d/pgdg-redhat-all.repo: No such file or directory    #####pgdg-redhat-all.repo檔案已經被洗掉掉,
0
[root@postgres ~]# ll /etc/yum.repos.d/
total 12
-rw-r--r--. 1 root root 1752 Sep 28 10:01 CentOS-Base.repo
-rw-r--r--. 1 root root 1220 Sep 28 10:01 epel.repo
-rw-r--r--. 1 root root  200 Dec 18 23:12 mongodb-org-4.4.repo
[root@postgres ~]# 

在您的Linux作業系統中添加pgAdmin官方yum存盤庫,

[root@postgres ~]# dnf install -y https://ftp.postgresql.org/pub/pgadmin/pgadmin4/yum/pgadmin4-redhat-repo-1-1.noarch.rpm
Last metadata expiration check: 2:56:09 ago on Sat 19 Dec 2020 07:50:22 PM CST.
pgadmin4-redhat-repo-1-1.noarch.rpm                                                                                                     3.0 kB/s | 6.6 kB     00:02    
Dependencies resolved.
========================================================================================================================================================================
 Package                                           Architecture                        Version                          Repository                                 Size
========================================================================================================================================================================
Installing:
 pgadmin4-redhat-repo                              noarch                              1-1                              @commandline                              6.6 k

Transaction Summary
========================================================================================================================================================================
Install  1 Package

Total size: 6.6 k
Installed size: 4.0 k
Downloading Packages:
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                                                                                                                1/1 
  Installing       : pgadmin4-redhat-repo-1-1.noarch                                                                                                                1/1 
  Verifying        : pgadmin4-redhat-repo-1-1.noarch                                                                                                                1/1 
Installed products updated.

Installed:
  pgadmin4-redhat-repo-1-1.noarch                                                                                                                                       

Complete!

現在需要安裝阿里云EPEL(Enterprise Linux的額外軟體包) yum存盤庫,因為pgAdmin需要一些標準yum存盤庫中不可用的軟體包,

使用dnf命令并安裝EPEL yum存盤庫,

[root@postgres yum.repos.d]# yum install -y https://mirrors.aliyun.com/epel/epel-release-latest-8.noarch.rpm

[root@postgres yum.repos.d]# sed -i 's|^#baseurl=https://download.fedoraproject.org/pub|baseurl=https://mirrors.aliyun.com|' /etc/yum.repos.d/epel*
[root@postgres yum.repos.d]# sed -i 's|^metalink|#metalink|' /etc/yum.repos.d/epel*

為新安裝的yum存盤庫構建快取,

[root@postgres yum.repos.d]#  dnf makecache
CentOS-8 - Base - mirrors.tongdun.cn                        1.8 MB/s | 3.9 kB     00:00    
CentOS-8 - Extras - mirrors.tongdun.cn                      811 kB/s | 1.5 kB     00:00    
CentOS-8 - AppStream - mirrors.tongdun.cn                   2.7 MB/s | 4.3 kB     00:00    
Extra Packages for Enterprise Linux Modular 8 - x86_64       17 kB/s | 3.0 kB     00:00    
Extra Packages for Enterprise Linux 8 - x86_64               37 kB/s | 4.7 kB     00:00    
MongoDB Repository                                          1.6 kB/s | 2.5 kB     00:01    
pgadmin4                                                    2.3 kB/s | 2.9 kB     00:01    
Metadata cache created.

第七步:CentOS 8上安裝pgAdmin Web UI


已添加所有存盤庫,現在,您可以使用dnf命令安裝pgAdmin ,

[root@postgres tdops]# dnf install -y pgadmin4
...
Installed:
  apr-1.6.3-9.el8.x86_64
  apr-util-1.6.1-6.el8.x86_64
  apr-util-bdb-1.6.1-6.el8.x86_64
  apr-util-openssl-1.6.1-6.el8.x86_64
  avahi-libs-0.7-19.el8.x86_64
  centos-logos-httpd-80.5-2.el8.noarch
  cups-libs-1:2.2.6-33.el8.x86_64
  dejavu-fonts-common-2.35-6.el8.noarch
  dejavu-sans-fonts-2.35-6.el8.noarch
  fontconfig-2.13.1-3.el8.x86_64
  fontpackages-filesystem-1.44-22.el8.noarch
  glx-utils-8.4.0-4.20181118git1830dcb.el8.x86_64
  graphite2-1.3.10-10.el8.x86_64
  harfbuzz-1.7.5-3.el8.x86_64
  httpd-2.4.37-21.module_el8.2.0+494+1df74eae.x86_64
  httpd-filesystem-2.4.37-21.module_el8.2.0+494+1df74eae.noarch
  httpd-tools-2.4.37-21.module_el8.2.0+494+1df74eae.x86_64
  libICE-1.0.9-15.el8.x86_64
  libSM-1.2.3-1.el8.x86_64
  libX11-1.6.8-3.el8.x86_64
  libX11-common-1.6.8-3.el8.noarch
  libX11-xcb-1.6.8-3.el8.x86_64
  libXau-1.0.8-13.el8.x86_64
  libXdamage-1.1.4-14.el8.x86_64
  libXext-1.3.3-9.el8.x86_64
  libXfixes-5.0.3-7.el8.x86_64
  libXrender-0.9.10-7.el8.x86_64
  libXxf86vm-1.1.4-9.el8.x86_64
  libglvnd-1:1.2.0-6.el8.x86_64
  libglvnd-egl-1:1.2.0-6.el8.x86_64
  libglvnd-glx-1:1.2.0-6.el8.x86_64
  libjpeg-turbo-1.5.3-10.el8.x86_64
  libwayland-client-1.17.0-1.el8.x86_64
  libwayland-server-1.17.0-1.el8.x86_64
  libxcb-1.13.1-1.el8.x86_64
  libxshmfence-1.3-2.el8.x86_64
  mailcap-2.1.48-3.el8.noarch
  mesa-libEGL-19.3.4-2.el8.x86_64
  mesa-libGL-19.3.4-2.el8.x86_64
  mesa-libgbm-19.3.4-2.el8.x86_64
  mesa-libglapi-19.3.4-2.el8.x86_64
  mod_http2-1.11.3-3.module_el8.2.0+486+c01050f0.1.x86_64
  pcre2-utf16-10.32-1.el8.x86_64
  pgadmin4-4.28-1.el8.noarch
  pgadmin4-desktop-4.28-1.el8.x86_64
  pgadmin4-server-4.28-1.el8.x86_64
  pgadmin4-web-4.28-1.el8.noarch
  python3-mod_wsgi-4.6.4-4.el8.x86_64
  python3-pip-9.0.3-16.el8.noarch
  python3-setuptools-39.2.0-5.el8.noarch
  python36-3.6.8-2.module_el8.1.0+245+c39af44f.x86_64
  qt5-qtbase-5.12.5-4.el8.x86_64
  qt5-qtbase-common-5.12.5-4.el8.noarch
  qt5-qtbase-gui-5.12.5-4.el8.x86_64
  xcb-util-0.4.0-10.el8.x86_64
  xcb-util-image-0.4.0-9.el8.x86_64
  xcb-util-keysyms-0.4.0-7.el8.x86_64
  xcb-util-renderutil-0.3.9-10.el8.x86_64
  xcb-util-wm-0.4.1-12.el8.x86_64

Complete!

要配置SELinux策略,pgAdmin設定腳本需要semanage命令,該命令在policycoreutils-python-utils軟體包中提供,

因此,您應該在執行pgAdmin安裝腳本之前安裝它,

[root@postgres tdops]# dnf install -y policycoreutils-python-utils
Dependencies resolved.
================================================================================
 Package                    Arch   Version                         Repo    Size
================================================================================
Installing:
 policycoreutils-python-utils
                            noarch 2.9-9.el8                       BaseOS 251 k
Installing dependencies:
 checkpolicy                x86_64 2.9-1.el8                       BaseOS 348 k
 python3-audit              x86_64 3.0-0.17.20191104git1c2f876.el8 BaseOS  86 k
 python3-libsemanage        x86_64 2.9-2.el8                       BaseOS 127 k
 python3-policycoreutils    noarch 2.9-9.el8                       BaseOS 2.2 M
 python3-setools            x86_64 4.2.2-2.el8                     BaseOS 601 k

Transaction Summary
================================================================================
Install  6 Packages

Total download size: 3.6 M
Installed size: 11 M
Downloading Packages:
(1/6): python3-audit-3.0-0.17.20191104git1c2f87  27 kB/s |  86 kB     00:03
(2/6): policycoreutils-python-utils-2.9-9.el8.n  44 kB/s | 251 kB     00:05
(3/6): python3-libsemanage-2.9-2.el8.x86_64.rpm  46 kB/s | 127 kB     00:02
(4/6): checkpolicy-2.9-1.el8.x86_64.rpm          40 kB/s | 348 kB     00:08
(5/6): python3-setools-4.2.2-2.el8.x86_64.rpm    85 kB/s | 601 kB     00:07
(6/6): python3-policycoreutils-2.9-9.el8.noarch 125 kB/s | 2.2 MB     00:18
--------------------------------------------------------------------------------
Total                                           147 kB/s | 3.6 MB     00:25
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                        1/1
  Installing       : python3-setools-4.2.2-2.el8.x86_64                     1/6
  Installing       : python3-libsemanage-2.9-2.el8.x86_64                   2/6
  Installing       : python3-audit-3.0-0.17.20191104git1c2f876.el8.x86_64   3/6
  Installing       : checkpolicy-2.9-1.el8.x86_64                           4/6
  Installing       : python3-policycoreutils-2.9-9.el8.noarch               5/6
  Installing       : policycoreutils-python-utils-2.9-9.el8.noarch          6/6
  Running scriptlet: policycoreutils-python-utils-2.9-9.el8.noarch          6/6
  Verifying        : checkpolicy-2.9-1.el8.x86_64                           1/6
  Verifying        : policycoreutils-python-utils-2.9-9.el8.noarch          2/6
  Verifying        : python3-audit-3.0-0.17.20191104git1c2f876.el8.x86_64   3/6
  Verifying        : python3-libsemanage-2.9-2.el8.x86_64                   4/6
  Verifying        : python3-policycoreutils-2.9-9.el8.noarch               5/6
  Verifying        : python3-setools-4.2.2-2.el8.x86_64                     6/6

Installed:
  checkpolicy-2.9-1.el8.x86_64
  policycoreutils-python-utils-2.9-9.el8.noarch
  python3-audit-3.0-0.17.20191104git1c2f876.el8.x86_64
  python3-libsemanage-2.9-2.el8.x86_64
  python3-policycoreutils-2.9-9.el8.noarch
  python3-setools-4.2.2-2.el8.x86_64

Complete!

pgAdmin軟體帶有撰寫良好的配置腳本,用于配置pgAdmin Web服務,

執行它以創建管理員用戶,配置SELinux策略和Apache Web服務器以部署pgAdmin Web服務,

[root@postgres tdops]# /usr/pgadmin4/bin/setup-web.sh
Setting up pgAdmin 4 in web mode on a Redhat platform...
Creating configuration database...
NOTE: Configuring authentication for SERVER mode.

Enter the email address and password to use for the initial pgAdmin user account:

Email address: [email protected]
Password: 
Retype password:
pgAdmin 4 - Application Initialisation
======================================

Creating storage and log directories...
Configuring SELinux...
The Apache web server is not running. We can enable and start the web server for you to finish pgAdmin 4 installation. Continue (y/n)? y
Created symlink /etc/systemd/system/multi-user.target.wants/httpd.service → /usr/lib/systemd/system/httpd.service.
Apache successfully enabled.
Apache successfully started.
You can now start using pgAdmin 4 in web mode at http://127.0.0.1/pgadmin4

上面的腳本安裝了一個組態檔(/etc/httpd/conf.d/pgadmin4.conf),以將pgAdmin部署在Apache Web服務器上,

此檔案中不需要自定義,您僅需要啟用和啟動httpd服務,

[root@postgres tdops]# cat /etc/httpd/conf.d/pgadmin4.conf
LoadModule wsgi_module modules/mod_wsgi.so
WSGIDaemonProcess pgadmin processes=1 threads=25 python-home=/usr/pgadmin4/venv
WSGIScriptAlias /pgadmin4 /usr/pgadmin4/web/pgAdmin4.wsgi

<Directory /usr/pgadmin4/web/>
	WSGIProcessGroup pgadmin
	WSGIApplicationGroup %{GLOBAL}
	<IfModule mod_authz_core.c>
		# Apache 2.4
		Require all granted
	</IfModule>
	<IfModule !mod_authz_core.c>
		# Apache 2.2
		Order Deny,Allow
		Deny from All
		Allow from 127.0.0.1
		Allow from ::1
	</IfModule>
</Directory>
[root@postgres tdops]# systemctl enable --now httpd.service
[root@postgres tdops]# systemctl status  httpd.service
● httpd.service - The Apache HTTP Server
   Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)
   Active: active (running) since Sat 2020-12-19 23:22:01 CST; 1min 57s ago
     Docs: man:httpd.service(8)
 Main PID: 948184 (httpd)
   Status: "Running, listening on: port 80"
    Tasks: 241 (limit: 23840)
   Memory: 34.6M
   CGroup: /system.slice/httpd.service
           ├─948184 /usr/sbin/httpd -DFOREGROUND
           ├─948198 /usr/sbin/httpd -DFOREGROUND
           ├─948199 /usr/sbin/httpd -DFOREGROUND
           ├─948200 /usr/sbin/httpd -DFOREGROUND
           ├─948201 /usr/sbin/httpd -DFOREGROUND
           └─948202 /usr/sbin/httpd -DFOREGROUND

Dec 19 23:22:01 postgres.lianglab.cn systemd[1]: Starting The Apache HTTP Server...

配置Linux防火墻,以允許傳入流量到Apache Web服務器,

[root@postgres tdops]# firewall-cmd --permanent --add-service=http
success
[root@postgres tdops]# firewall-cmd --reload
success

在網路瀏覽器中打開URL http://192.168.6.160/pgadmin4

setup-web.sh腳本創建的管理員用戶身份登錄pgAdmin ,

成功登錄后,您可以訪問pgAdmin儀表板,

要將您的PostgreSQL資料庫服務器添加到pgAdmin清單中,請單擊“添加新服務器”,

提供服務器名稱,然后單擊“連接”選項卡,

我們的Postgres資料庫服務器已添加到pgAdmin中,您可以在左側面板中看到資料庫服務器的樹,

結論

在此安裝指南中,您學習了如何在CentOS 8服務器上使用pgAdmin安裝PostgreSQL,為了學習更多關于Postgres的資料庫,

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/237525.html

標籤:PostgreSQL

上一篇:【趙強老師】MongoDB中的索引(下)

下一篇:MongoDB入門

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more