導讀 | 建立統一管理的,具有靈活性的雲原生生產部署來部署一個個性化的數據庫即服務(DBaaS)。 |
經過在 Kubernetes 上運行 PostgreSQL 數據庫,你能建立統一管理的,具有靈活性的雲原生生產部署應用來部署一個個性化的數據庫即服務爲你的特定需求進行量身定製。html
對於 Kubernetes,使用 Operator 容許你提供額外的上下文去管理有狀態應用。當使用像PostgreSQL 這樣開源的數據庫去執行包括配置、擴展、高可用和用戶管理時,Operator 也頗有幫助。linux
讓咱們來探索如何在 Kubernetes 上啓動並運行 PostgreSQL。sql
將 PostgreSQL 和 Kubernetes 結合使用的第一步是安裝一個 Operator。在針對 Linux 系統的Crunchy 的快速啓動腳本的幫助下,你能夠在任意基於 Kubernetes 的環境下啓動和運行開源的Crunchy PostgreSQL Operator。數據庫
快速啓動腳本有一些必要前提:bash
Wget 工具已安裝。
kubectl 工具已安裝。
在你的 Kubernetes 中已經定義了一個 StorageClass。
擁有集羣權限的可訪問 Kubernetes 的用戶帳號,以安裝 Operator 的 RBAC 規則。
一個 PostgreSQL Operator 的 命名空間。
執行這個腳本將提供給你一個默認的 PostgreSQL Operator 部署,其默認假設你採用 動態存儲和一個名爲 standard 的 StorageClass。這個腳本容許用戶採用自定義的值去覆蓋這些默認值。工具
經過下列命令,你能下載這個快速啓動腳本並把它的權限設置爲可執行:post
wget chmod +x ./quickstart.sh
而後你運行快速啓動腳本:測試
./examples/quickstart.sh
在腳本提示你相關的 Kubernetes 集羣基本信息後,它將執行下列操做:
下載 Operator 配置文件
將$HOME/.pgouser 這個文件設置爲默認設置
以 Kubernetes Deployment 部署 Operator
設置你的.bashrc 文件包含 Operator 環境變量
設置你的$HOME/.bash_completion 文件爲pgo bash_completion 文件
在快速啓動腳本的執行期間,你將會被提示在你的 Kubernetes 集羣設置 RBAC 規則。在另外一個終端,執行快速啓動命令所提示你的命令。ui
一旦這個腳本執行完成,你將會獲得提示設置一個端口以轉發到 PostgreSQL Operator pod。在另外一個終端,執行這個端口轉發操做;這將容許你開始對 PostgreSQL Operator 執行命令!嘗試輸入下列命令建立集羣:spa
pgo create cluster mynewcluster
你能輸入下列命令測試你的集羣運行情況:
pgo test mynewcluster
如今,你能在 Kubernetes 環境下管理你的 PostgreSQL 數據庫了!你能夠在官方文檔找到很是全面的命令,包括擴容,高可用,備份等等。
這篇文章部分參考了該做者爲 Crunchy 博客而寫的在 Kubernetes 上開始運行 PostgreSQL。
via: https://opensource.com/article/19/3/how-run-postgresql-kubernetes
做者:Jonathan S. Katz 選題:lujun9972 譯者:arrowfeng 校對:wxy
本文由 LCTT 原創編譯,Linux中國 榮譽推出