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

聊聊Docker不適合跑?MySQL?的N個(gè)原因

 更新時(shí)間:2022年12月05日 08:43:18   作者:老王談運(yùn)維  
容器是為了解決“在切換運(yùn)行環(huán)境時(shí),如何保證軟件能夠正常運(yùn)行”這一問題,這篇文章主要介紹了Docker?為什么不適合跑?MySQL?有N個(gè)原因,需要的朋友可以參考下

容器的定義:容器是為了解決“在切換運(yùn)行環(huán)境時(shí),如何保證軟件能夠正常運(yùn)行”這一問題。

目前,容器和 Docker 依舊是技術(shù)領(lǐng)域最熱門的詞語,無狀態(tài)的服務(wù)容器化已經(jīng)是大勢所趨,同時(shí)也帶來了一個(gè)熱點(diǎn)問題被大家所爭論不以:數(shù)據(jù)庫 MySQL 是否需要容器化?

認(rèn)真分析大家的各種觀點(diǎn),發(fā)現(xiàn)贊同者僅僅是從容器優(yōu)勢的角度來闡述 MySQL 需要容器化,幾乎沒有什么業(yè)務(wù)場景進(jìn)行驗(yàn)證自己的觀點(diǎn);反過來再看反對(duì)者,他們從性能、數(shù)據(jù)安全等多個(gè)因素進(jìn)行闡述 MySQL不需要容器化,也舉證了一些不適合的業(yè)務(wù)場景。

下面,我們就聊一下 Docker 不適合跑 MySQL 的 N 個(gè)原因!

數(shù)據(jù)安全問題

不要將數(shù)據(jù)儲(chǔ)存在容器中,這也是 Docker 官方容器使用技巧中的一條。容器隨時(shí)可以停止、或者刪除。當(dāng)容器被rm掉,容器里的數(shù)據(jù)將會(huì)丟失。為了避免數(shù)據(jù)丟失,用戶可以使用數(shù)據(jù)卷掛載來存儲(chǔ)數(shù)據(jù)。但是容器的 Volumes 設(shè)計(jì)是圍繞 Union FS 鏡像層提供持久存儲(chǔ),數(shù)據(jù)安全缺乏保證。如果容器突然崩潰,數(shù)據(jù)庫未正常關(guān)閉,可能會(huì)損壞數(shù)據(jù)。另外,容器里共享數(shù)據(jù)卷組,對(duì)物理機(jī)硬件損傷也比較大。

性能問題

大家都知道,MySQL 屬于關(guān)系型數(shù)據(jù)庫,對(duì)IO要求較高。當(dāng)一臺(tái)物理機(jī)跑多個(gè)時(shí),IO就會(huì)累加,導(dǎo)致IO瓶頸,大大降低 MySQL 的讀寫性能。

在一次Docker應(yīng)用的十大難點(diǎn)專場上,某國有銀行的一位架構(gòu)師也曾提出過:“數(shù)據(jù)庫的性能瓶頸一般出現(xiàn)在IO上面,如果按 Docker 的思路,那么多個(gè)docker最終IO請(qǐng)求又會(huì)出現(xiàn)在存儲(chǔ)上面。現(xiàn)在互聯(lián)網(wǎng)的數(shù)據(jù)庫多是share nothing的架構(gòu),可能這也是不考慮遷移到 Docker 的一個(gè)因素吧”。

其實(shí)也有相對(duì)應(yīng)的一些策略來解決這個(gè)問題,比如:

1)數(shù)據(jù)庫程序與數(shù)據(jù)分離

如果使用Docker 跑 MySQL,數(shù)據(jù)庫程序與數(shù)據(jù)需要進(jìn)行分離,將數(shù)據(jù)存放到共享存儲(chǔ),程序放到容器里。如果容器有異常或 MySQL 服務(wù)異常,自動(dòng)啟動(dòng)一個(gè)全新的容器。另外,建議不要把數(shù)據(jù)存放到宿主機(jī)里,宿主機(jī)和容器共享卷組,對(duì)宿主機(jī)損壞的影響比較大。

2)跑輕量級(jí)或分布式數(shù)據(jù)庫

Docker 里部署輕量級(jí)或分布式數(shù)據(jù)庫,Docker 本身就推薦服務(wù)掛掉,自動(dòng)啟動(dòng)新容器,而不是繼續(xù)重啟容器服務(wù)。

3)合理布局應(yīng)用

對(duì)于IO要求比較高的應(yīng)用或者服務(wù),將數(shù)據(jù)庫部署在物理機(jī)或者KVM中比較合適。目前騰訊云的TDSQL和阿里的Oceanbase都是直接部署在物理機(jī)器,而非Docker 。

狀態(tài)問題

在 Docker 中水平伸縮只能用于無狀態(tài)計(jì)算服務(wù),而不是數(shù)據(jù)庫。

Docker 快速擴(kuò)展的一個(gè)重要特征就是無狀態(tài),具有數(shù)據(jù)狀態(tài)的都不適合直接放在 Docker 里面,如果 Docker 中安裝數(shù)據(jù)庫,存儲(chǔ)服務(wù)需要單獨(dú)提供。

目前,騰訊云的TDSQL(金融分布式數(shù)據(jù)庫)和阿里云的Oceanbase(分布式數(shù)據(jù)庫系統(tǒng))都直接運(yùn)行中在物理機(jī)器上,并非使用便于管理的 Docker 上。

資源隔離方面

資源隔離方面,Docker 確實(shí)不如虛擬機(jī)KVM,Docker是利用Cgroup實(shí)現(xiàn)資源限制的,只能限制資源消耗的最大值,而不能隔絕其他程序占用自己的資源。如果其他應(yīng)用過渡占用物理機(jī)資源,將會(huì)影響容器里 MySQL 的讀寫效率。

需要的隔離級(jí)別越多,獲得的資源開銷就越多。相比專用環(huán)境而言,容易水平伸縮是Docker的一大優(yōu)勢。然而在 Docker 中水平伸縮只能用于無狀態(tài)計(jì)算服務(wù),數(shù)據(jù)庫并不適用。

難道 MySQL 不能跑在容器里嗎?

MySQL 也不是全然不能容器化。以下幾種場景還是適合的。

1)對(duì)數(shù)據(jù)丟失不敏感的業(yè)務(wù)(例如用戶搜索商品)就可以數(shù)據(jù)化,利用數(shù)據(jù)庫分片來來增加實(shí)例數(shù),從而增加吞吐量。

2)docker適合跑輕量級(jí)或分布式數(shù)據(jù)庫,當(dāng)docker服務(wù)掛掉,會(huì)自動(dòng)啟動(dòng)新容器,而不是繼續(xù)重啟容器服務(wù)。

3)數(shù)據(jù)庫利用中間件和容器化系統(tǒng)能夠自動(dòng)伸縮、容災(zāi)、切換、自帶多個(gè)節(jié)點(diǎn),也是可以進(jìn)行容器化的。

典型案例:同程旅游、京東、阿里的數(shù)據(jù)庫容器化都是不錯(cuò)的案例,大家可以自行去查看

到此這篇關(guān)于Docker 為什么不適合跑 MySQL ? 有N個(gè)原因的文章就介紹到這了,更多相關(guān)Docker 跑 MySQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Docker容器互相連接三種實(shí)現(xiàn)方法詳解

    Docker容器互相連接三種實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了Docker容器互連三種實(shí)現(xiàn)方法詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • 詳解Docker在哪里保存日志文件

    詳解Docker在哪里保存日志文件

    本文主要介紹了Docker在哪里保存日志文件,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • docker部署nginx并且實(shí)現(xiàn)https的方法步驟

    docker部署nginx并且實(shí)現(xiàn)https的方法步驟

    啟用HTTPS可以提高網(wǎng)站的安全性、可信度,同時(shí)符合法規(guī)要求,本文主要介紹了docker部署nginx并且實(shí)現(xiàn)https的方法步驟,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • Docker私服倉庫Harbor安裝的步驟詳解

    Docker私服倉庫Harbor安裝的步驟詳解

    這篇文章主要介紹了Docker私服倉庫Harbor安裝的步驟詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • Docker load之后鏡像名字為none問題解決方法

    Docker load之后鏡像名字為none問題解決方法

    這篇文章主要介紹了Docker load之后鏡像名字為none問題解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Docker自動(dòng)化構(gòu)建Automated Build實(shí)現(xiàn)過程圖解

    Docker自動(dòng)化構(gòu)建Automated Build實(shí)現(xiàn)過程圖解

    這篇文章主要介紹了Docker自動(dòng)化構(gòu)建Automated Build實(shí)現(xiàn)過程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 詳解利用ELK搭建Docker容器化應(yīng)用日志中心

    詳解利用ELK搭建Docker容器化應(yīng)用日志中心

    這篇文章主要介紹了詳解利用ELK搭建Docker容器化應(yīng)用日志中心,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • SpringBoot 整合 Docker的詳細(xì)過程

    SpringBoot 整合 Docker的詳細(xì)過程

    這篇文章主要介紹了SpringBoot 整合 Docker的詳細(xì)過程,本文通過一個(gè)簡單的項(xiàng)目來給大家介紹整合的詳細(xì)過程,需要的朋友可以參考下
    2021-11-11
  • Docker容器和本機(jī)之間的文件傳輸方法

    Docker容器和本機(jī)之間的文件傳輸方法

    這篇文章主要介紹了Docker容器和本機(jī)之間的文件傳輸方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 深入理解docker的四種網(wǎng)絡(luò)方式

    深入理解docker的四種網(wǎng)絡(luò)方式

    本篇文章主要介紹了深入理解docker的四種網(wǎng)絡(luò)方式,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02

最新評(píng)論