欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Rainbond自動(dòng)部署初始化Schema的數(shù)據(jù)庫(kù)步驟教程

 更新時(shí)間:2022年04月20日 14:57:35   作者:張震  
這篇文章主要為大家介紹了Rainbond自動(dòng)部署初始化Schema的數(shù)據(jù)庫(kù)過(guò)程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

為什么使用Rainbond?

我們使用容器的方式部署數(shù)據(jù)庫(kù)組件,特別是企業(yè)有大量的項(xiàng)目開(kāi)發(fā)業(yè)務(wù)的,部署的開(kāi)發(fā)、測(cè)試數(shù)據(jù)庫(kù)組件較多時(shí)。經(jīng)常會(huì)遇到以下問(wèn)題:

  • 業(yè)務(wù)需要使用數(shù)據(jù)庫(kù),但部署完數(shù)據(jù)庫(kù)后,需要在數(shù)據(jù)庫(kù)中執(zhí)行創(chuàng)建schema的操作或者一些初始化數(shù)據(jù)的創(chuàng)建。
  • 開(kāi)發(fā)測(cè)試多套部署環(huán)境,需要多次重復(fù)1的步驟。
  • 項(xiàng)目比較多,時(shí)間久了項(xiàng)目需要的數(shù)據(jù)庫(kù)Schema不清楚。
  • 項(xiàng)目交付時(shí)數(shù)據(jù)庫(kù)Schema管理混亂。

現(xiàn)在如果是使用Go等語(yǔ)言研發(fā)的業(yè)務(wù)系統(tǒng),都具備了ORM層自動(dòng)初始化和更新Schema的能力,如果是這樣本文對(duì)你無(wú)用。但目前大多數(shù)其他開(kāi)發(fā)語(yǔ)言的業(yè)務(wù)都不具備這種能力。

如果我們把數(shù)據(jù)庫(kù)也作為一個(gè)業(yè)務(wù)中的一個(gè)服務(wù)模塊來(lái)管理的話(huà),我們希望服務(wù)啟動(dòng)后即可直接完成Schema的初始化,直接提供數(shù)據(jù)服務(wù)能力。

那么在Rainbond中如何達(dá)成這樣的效果呢?

Schema初始化在傳統(tǒng)模式中一般有兩種方案:

在數(shù)據(jù)庫(kù)啟動(dòng)后手動(dòng)導(dǎo)入;人工通過(guò)客戶(hù)端操作,沒(méi)有自動(dòng)化程度可言;在業(yè)務(wù)服務(wù)啟動(dòng)時(shí)連接數(shù)據(jù)庫(kù)進(jìn)行初始化,依賴(lài)業(yè)務(wù)服務(wù)端的能力。

可以看出,這兩種方式都存在各自的弊端,那么有沒(méi)有方式能夠讓數(shù)據(jù)庫(kù)啟動(dòng)時(shí)自動(dòng)初始化指定的數(shù)據(jù)呢?答案是 有!

我們以MySQL為例, 官方對(duì)于 Docker 有著良好的支持,首先來(lái)看 Dockerhub上 Mysql官方鏡像 的一段描述:

description

在數(shù)據(jù)庫(kù)容器首次啟動(dòng)時(shí),將創(chuàng)建一個(gè)指定名稱(chēng)的新數(shù)據(jù)庫(kù),并使用提供的環(huán)境變量對(duì)其進(jìn)行初始化。 此外,它將執(zhí)行在 /docker-entrypoint-initdb.d 中找到的擴(kuò)展名為 .sh,.sql 和 .sql.gz 的文件。 文件將按字母順序執(zhí)行。 默認(rèn)情況下,SQL文件將導(dǎo)入到MYSQL_DATABASE 變量指定的數(shù)據(jù)庫(kù)中。因此我們只需要在Mysql鏡像工作機(jī)制的基礎(chǔ)上維護(hù)好數(shù)據(jù)庫(kù)初始化所需要的SQL即可。上文我們說(shuō)到把數(shù)據(jù)庫(kù)也作為一個(gè)獨(dú)立的服務(wù)模塊,我們也可以通過(guò)代碼把Sql等腳步管理起來(lái),劃分版本分支。

Rainbond 支持多種組件創(chuàng)建方式,在這里我們采用 從源碼創(chuàng)建組件 的方式,編寫(xiě) Dockerfile 并上傳至支持 Git/Svn 協(xié)議的客戶(hù)端,即可在平臺(tái)直接進(jìn)行構(gòu)建;這種方式 透明、可復(fù)用、并且能夠進(jìn)行自動(dòng)化構(gòu)建。

目錄結(jié)構(gòu)

./
└── Dockerfile
    └── config
        ├── my.cnf
        ├── conf.d
             ├── docker.cnf
    └── sql
        ├── init_database
    └── README.md

Dockerfile文件

#基礎(chǔ)鏡像
FROM mysql:latest
MAINTAINER Aaron <Aaron_ops@163.com>
#把sql文件拷貝到/docker-entrypoint-initdb.d/目錄下,以便啟動(dòng)時(shí)自動(dòng)執(zhí)行這個(gè)sql
COPY ./sql/*.sql /docker-entrypoint-initdb.d
#拷貝mysql配置文件
COPY ./config/ /etc/mysql/
#Mysql密碼
ENV MYSQL_ROOT_PASSWORD rainbond
#數(shù)據(jù)持久化目錄
VOLUME [ "/var/lib/mysql" ]
#端口
EXPOSE 3306

項(xiàng)目地址:https://github.com/Aaron-23/Initialize-db

使用該項(xiàng)目在平臺(tái)進(jìn)行構(gòu)建,Rainbond 將會(huì)自動(dòng)檢測(cè) Dockerfile 中定義的環(huán)境變量,存儲(chǔ),端口等信息,對(duì)這些配置項(xiàng)進(jìn)行自動(dòng)化配置,在 Dockerfile 構(gòu)建完畢后自動(dòng)啟動(dòng)數(shù)據(jù)庫(kù)。

需要注意的是 MySQL 屬于有狀態(tài)服務(wù),所以在構(gòu)建前需將組件類(lèi)型修改為有狀態(tài)單實(shí)例,關(guān)于組件狀態(tài)請(qǐng)參考 組件部署類(lèi)型。

advancedsettings

status

啟動(dòng)完成,進(jìn)入運(yùn)行中狀態(tài)

Overview

通過(guò) Web終端 進(jìn)入數(shù)據(jù)庫(kù)查看相關(guān)數(shù)據(jù)已經(jīng)完成初始化

db

通過(guò)這種方式進(jìn)行數(shù)據(jù)庫(kù)初始化,不需要修改程序代碼,無(wú)需借助外部工具,通過(guò)平臺(tái)的能力快速部署數(shù)據(jù)庫(kù)并完成初始化,在后續(xù)使用過(guò)程中可以通過(guò)性能分析,資源監(jiān)控,實(shí)例伸縮等功能完成服務(wù)運(yùn)行時(shí)的全生命周期管理,提升開(kāi)發(fā)效率,增強(qiáng)業(yè)務(wù)穩(wěn)定性。

另外我們還可以將此組件發(fā)布到 Rainbond 內(nèi)部組件庫(kù)中,后續(xù)開(kāi)發(fā)、測(cè)試和交付過(guò)程可以直接一鍵安裝此組件即可獲得數(shù)據(jù)初始完成的數(shù)據(jù)庫(kù)服務(wù)。

以上 MySQL數(shù)據(jù)庫(kù) 僅為參考示例,MongoDB,PostgreSQL等數(shù)據(jù)庫(kù)均支持同類(lèi)型數(shù)據(jù)初始化方式。

Rainbond 云原生應(yīng)用管理平臺(tái),實(shí)現(xiàn)微服務(wù)架構(gòu)不用改代碼,管理 Kubernetes 不用學(xué)容器,幫企業(yè)實(shí)現(xiàn)應(yīng)用上云,一站式將任何企業(yè)應(yīng)用持續(xù)交付到 Kubernetes 集群、混合云、多云等基礎(chǔ)設(shè)施。是 Rainstore 云原生應(yīng)用商店的支撐平臺(tái)。

1. Rainbond 官網(wǎng)

2. Rainbond 安裝使用

3. Rainbond 參考手冊(cè)全集

以上就是Rainbond自動(dòng)部署初始化Schema的數(shù)據(jù)庫(kù)步驟教程的詳細(xì)內(nèi)容,更多關(guān)于Rainbond自動(dòng)部署初始化Schema數(shù)據(jù)庫(kù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • k8s中secret的用法詳解

    k8s中secret的用法詳解

    secret用于加密pod訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的用戶(hù)憑證,這篇文章主要介紹了k8s中secret的用法詳解,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • 詳解k8s ConfigMap 中 subPath 字段和 items 字段

    詳解k8s ConfigMap 中 subPath 字段和 items

    volumeMounts.subPath 屬性可用于指定所引用的卷內(nèi)的子路徑,而不是其根路徑,這篇文章主要介紹了詳解k8s ConfigMap 中 subPath 字段和 items 字段,需要的朋友可以參考下
    2023-03-03
  • 詳解kubernetes pod的編排和生命周期

    詳解kubernetes pod的編排和生命周期

    這篇文章主要介紹了kubernetes pod的編排和生命周期的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用K8S,感興趣的朋友可以了解下
    2021-04-04
  • 自定義資源CRD使用介紹

    自定義資源CRD使用介紹

    這篇文章主要為大家介紹了自定義資源CRD的使用示例介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • k8s入門(mén)實(shí)戰(zhàn)deployment使用詳解

    k8s入門(mén)實(shí)戰(zhàn)deployment使用詳解

    這篇文章主要為大家介紹了k8s入門(mén)實(shí)戰(zhàn)deployment使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • 在K8S中實(shí)現(xiàn)會(huì)話(huà)保持的兩種方案

    在K8S中實(shí)現(xiàn)會(huì)話(huà)保持的兩種方案

    這篇文章主要介紹了在K8S中實(shí)現(xiàn)會(huì)話(huà)保持的兩種方案,每種方案結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • 關(guān)于Rancher部署并導(dǎo)入K8S集群的問(wèn)題

    關(guān)于Rancher部署并導(dǎo)入K8S集群的問(wèn)題

    這篇文章主要介紹了關(guān)于Rancher部署并導(dǎo)入K8S集群的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • Kubernetes控制器中DaemonSet與Job的使用教程

    Kubernetes控制器中DaemonSet與Job的使用教程

    這篇文章主要介紹了Kubernetes控制器中DaemonSet與Job的使用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • 關(guān)于CentOS7日志文件及journalctl日志查看方法

    關(guān)于CentOS7日志文件及journalctl日志查看方法

    這篇文章主要介紹了關(guān)于CentOS7日志文件及journalctl日志查看方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 淺析k8s中各組件和kube?apiserver通信時(shí)的認(rèn)證和鑒權(quán)問(wèn)題

    淺析k8s中各組件和kube?apiserver通信時(shí)的認(rèn)證和鑒權(quán)問(wèn)題

    這篇文章主要介紹了k8s中各組件和kube?apiserver通信時(shí)的認(rèn)證和鑒權(quán),本文使用的k8s集群是用kubekey搭建,命令是./kk create cluster --with-kubernetes v1.21.5 --with-kubesphere v3.2.1,需要的朋友可以參考下
    2022-06-06

最新評(píng)論