微服務與Docker介紹

来源:http://www.cnblogs.com/wintersun/archive/2016/01/16/5136385.html
-Advertisement-
Play Games

什麼是微服務 微服務應用的一個最大的優點是,它們往往比傳統的應用程式更有效地利用計算資源。這是因為它們通過擴展組件來處理功能瓶頸問題。這樣一來,開發人員只需要為額外的組件部署計算資源,而不需要部署一個完整的應用程式的全新迭代。最終的結果是有更多的資源可以提供給其它任務。 • 一種軟體架構模式 • 復...


什麼是微服務

微服務應用的一個最大的優點是,它們往往比傳統的應用程式更有效地利用計算資源。這是因為它們通過擴展組件來處理功能瓶頸問題。這樣一來,開發人員只需要為額外的組件部署計算資源,而不需要部署一個完整的應用程式的全新迭代。最終的結果是有更多的資源可以提供給其它任務。

• 一種軟體架構模式
• 複雜應用解耦為小而眾的服務
• 各服務精而專
• 服務間通信通過API完成

image

微服務應用程式的另一個好處是,它們更快且更容易更新。當開發者對一個傳統的單體應用程式進行變更時,他們必須做詳細的QA測試,以確保變更不會影響其他特性或功能。但有了微服務,開發者可以更新應用程式的單個組件,而不會影響其他的部分。測試微服務應用程式仍然是必需的,但它更容易識別和隔離問題,從而加快開發速度並支持DevOps和持續應用程式開發。

第三個好處是,微服務架構有助於新興的雲服務,如事件驅動計算。類似AWS Lambda這樣的功能讓開發人員能夠編寫代碼處於休眠狀態,直到應用程式事件觸發。事件處理時才需要使用計算資源,而企業只需要為每次事件,而不是固定數目的計算實例支付。

擴展立方模型(Scale  Cube)

《The <wbr>Art <wbr>of <wbr>Scalability》中的三維伸縮性模型

Y軸 功能解耦 通過分解 不同模塊擴展
X軸 水平副本 通過副本擴展
Z軸 數據分區 通過分解 相似內容擴展

Docker是什麼

Docker 是一個開源的應用容器引擎,讓開發者可以打包他們的應用以及依賴包到一個可移植的容器中,然後發佈到任何流行的 Linux 機器上,也可以實現虛擬化。容器是完全使用沙箱機制,相互之間不會有任何介面(類似 iPhone 的 app)。幾乎沒有性能開銷,可以很容易地在機器和數據中心中運行。最重要的是,他們不依賴於任何語言、框架包括系統。

image

Docker包含兩方面技術

-鏡像技術 
打破“代碼即應用”的觀念
從系統環境開始,自底至上打包應用

image

image

微服務和Docker

Dev
開發簡單有效的模塊       
配置是一個運行時的限制    
不再是異常複雜的應用   
new    WebServer().start(8080);
   
Ops
管理硬體設施
監控&反饋   
不是應用的執行細節    


結合擴展立方(Scale   Cube)

image

Docker化實踐

本質:進程隔離,資源管理

• App-Centric的體現
• Single-Process的真實含義

image

Docker化實踐——進程隔離

image

Dockerfile、Docker鏡像與Docker容器

image

容器內技術棧:
1.單進程理念
2.不存在傳統的init進程(全局PID=1)
——dockerinit與init進程的區別
3.缺少基本的服務進程
——cron
——rsyslogd等
4.與內核進程通信能力薄弱(ipc命名空間隔離)
 
導致遺留系統Docker化存在壓力。 重構?非重構下的最佳實踐?

Docker化實踐——日誌管理


原理:stdout&stderr

傳統模式:
      -stdout&stderr   
      -磁碟日誌文件
      -日誌伺服器
日誌持久化磁碟的弊端
      -移植性
      -部署複雜度
日誌Docker層面管理
      -json-file    
      -syslog(並非應用調用syslog)
      -fluetd

image

以syslog為例
image

Docker化實踐——日誌管理

image

Docker化實踐——配置管理

傳統方式:配置文件
• Docker容器的無狀態
• 配置文件的狀態性
• Docker容器依賴配置文件
• 額外的配置管理需求
• 非自動化
• 非標準化

• 沿用傳統模式——配置文件
——使用掛載volume的方式
——配置文件與宿主機耦合

• 採用環境變數方式
——打包配置進入Docker鏡像
——打包配置進入Docker容器
——完美支持編排工具compose
 
• 環境變數與配置文件共存
——修改Docker鏡像執行入口
——使用環境變數替換配置文件


今天先到這兒,希望對您有參考作用, 您可能感興趣的文章:
構建高效的研發與自動化運維
IT基礎架構規劃方案一(網路系統規劃)
餐飲行業解決方案之客戶分析流程
餐飲行業解決方案之採購戰略制定與實施流程
餐飲行業解決方案之業務設計流程
供應鏈需求調研CheckList
企業應用之性能實時度量系統演變

如有想瞭解更多軟體設計與架構,系統 IT,企業信息化 資訊,請關註我的微信訂閱號:

MegadotnetMicroMsg_thumb1_thumb1_thu[2]


作者:Petter Liu
出處:http://www.cnblogs.com/wintersun/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
該文章也同時發佈在我的獨立博客中-Petter Liu Blog


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近,有個項目突然接到總部的安全漏洞報告,查看後知道是XSS攻擊。問題描述: 在頁面上有個隱藏域: 當前頁面提交到Controller時,未對action屬性做任何處理,直接又回傳到頁面上 如果此時action被用戶惡意修改為:***""*** 此時當頁面刷新時將執行alert(1),雖然錯...
  • 在插件實例修改3增加一個聯繫人功能配置文件 1 2 3 4 5 6 7 8 9 10 11 12...
  • define的用法小結define的用法只是一種純粹的替換功能,巨集定義的替換是預處理器處理的替換。 一:簡單的巨集定義用法 格式:#define 標識符 替換內容 替換的內容可以是數字,字元,字元串,特殊字元和空格,後面是什麼內容就會替換成什麼內容。 例如: #define N 5 效...
  • 參考書籍:Head First Java1、假設某方法是別人寫在某個類裡面的2、而此時你根本就不知道這個方法是否有風險(比如伺服器出故障會使程式受到影響);3、那最好的方法應該就是,在調用這個類的方法時,加上可能發生異常的處理方案,未雨綢繆。關鍵字:try……catch,throws,throw,f...
  • Day 2308 Udp接收端09 Udp鍵盤錄入數據方式10 Udp聊天11 TCP傳輸12 TCP傳輸213 TCP練習14 TCP複製文件08 Udp接收端需求:定義一個應用程式,用於接收udp協議傳輸的數據並處理。思路:1.定義UdpSocket服務。2.定義一個數據報包,因為要存儲接收到的...
  • 手動安裝django_chartit庫1 下載壓縮包2 解壓到python安裝目錄下,文件夾名為django_chartit,並檢查文件夾下是否有setup.py文件3 在cmd中進入django_chartit文件夾下,cmd命令為 cd C:\Python27\django_chartit4 輸...
  • 搭建一個簡單的跨平臺C開發的基礎框架, 主要是使用posix線程庫和 自己寫的一個分級 日誌庫,以後可以在這個基礎上搭建你需要的框架會容易一點. 在Window和Linux上測試通過.
  • 服務定位器隱藏了類之間的依賴關係,導致錯誤從編譯時推遲到了運行時,並且,在引入破壞性更改時,這個模式導致代碼不清晰,增加了維護難度。
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...