Skip to content

Zeroplex 生活隨筆

軟體開發、伺服器和生活瑣事

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

在 PostgreSQL 建立 admin 帳號

Posted on 2022 年 2 月 24 日2022 年 2 月 24 日 By 日落 在〈在 PostgreSQL 建立 admin 帳號〉中有 1 則留言

PostgreSQL 的使用者權限管理和 MySQL 差很多,花了好一陣子才搞懂。

一開始操作都必須使用 postgres 的使用者身份來操作,所以都會需要 sudo:

# 建立預備要給予 admin 權限的帳號
# 如果不想要 sudo 則設定成 Linux 相同帳號名稱
sudo -u postgres createuser zeroplex

再來是要幫上面新增的使用者設定 role,這邊需要進入 PostgreSQL 的 console 中下指令:

sudo -u postgres psql
psql (14.2)
Type "help" for help.

-- 透過 \du 來列出現有的使用者與角色
postgres=# \du
                                    List of roles
 Role name |                         Attributes                         | Member of  
-----------+------------------------------------------------------------+------------
 postgres  | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
 zeroplex  |                                                            | {}

從上表的內容,可以看出剛剛新增的帳號什麼權限都沒有,但是預設帳號 postgres 擁有 Superuser 的權限。

若要建立的帳號擁有 admin 權限 (在 PostgreSQL 中叫做 superuser),則須透過 alter user 來授予權限:

postgres=# alter user zeroplex with superuser;
ALTER ROLE

-- 再次列出使用者與其角色 (role)
postgres=# \du
                                    List of roles
 Role name |                         Attributes                         | Member of  
-----------+------------------------------------------------------------+------------
 postgres  | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
 zeroplex  | Superuser                                                  | {}

除了 superuser 以外,還有其他不同權限的角色可以指派,請參考 PostgreSQL alter user 的說明。

接著就可以不用 sudo 直接下 PostgreSQL 管理相關指令:

$ createdb test

注意:使用者如果擁有 superuser 權限以後,下管理相關指令是不需要 sudo 的,因此必須承擔意外造成的風險。個人建議還是切換成 sudo -u postgres 以後在進行操作比較保險。

Tags:PostgreSQL

文章導覽

Previous Post: Customize HTTP header in Unit Test on Lumen
Next Post: 常見的圖形條碼

Comment (1) on “在 PostgreSQL 建立 admin 帳號”

  1. 小吳表示:
    2022 年 2 月 24 日23:46

    錯字:
    s/以後在進行/以後再進行/

    回覆

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *


其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD GCP Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.