亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解基于docker 如何部署surging分布式微服務(wù)引擎

 更新時間:2018年06月18日 11:04:37   作者:fanly11  
這篇文章主要介紹了詳解基于docker 如何部署surging分布式微服務(wù)引擎,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1、前言

轉(zhuǎn)眼間surging 開源已經(jīng)有1年了,經(jīng)過1年的打磨,surging已從最初在window 部署的分布式微服務(wù)框架,到現(xiàn)在的可以在docker部署利用rancher 進行服務(wù)編排的分布式微服務(wù)引擎,再把業(yè)務(wù)進行剝離, 通過配置路徑就能驅(qū)動加載業(yè)務(wù)模塊,這樣的細粒度設(shè)計,能更加靈活從業(yè)務(wù)中針對于對象加以細分,能更加靈活的拆分聚合服務(wù)。而這篇文章我們來談?wù)劵赿ocker 如何部署

surging源碼下載

2、概述

容器,就是用來存放鏡像的器皿,而鏡像是構(gòu)建成的一個輕量的、獨立的、可執(zhí)行的包,包括了執(zhí)行它所需要的所有東西:代碼、運行環(huán)境、系統(tǒng)工具、系統(tǒng)庫、設(shè)置。

程序被構(gòu)建成鏡像放到容器中,那么它所依賴的下層環(huán)境就不再重要了。它可以在任何地方運行,甚至在混合云環(huán)境下也可以。所以為何容器能流行起來, 而容器技術(shù)興起讓Docke也漸漸的映入大家的眼簾,

那么Docker又是什么呢?

  1. Docker是基于Go語言開發(fā)并開源的容器引擎
  2. Docker將應(yīng)用軟件運行時所需的一切都打包成互相隔離的容器
  3. Docker可以自動執(zhí)行并配置開發(fā)/線上環(huán)境,快速構(gòu)建,測試和運行復(fù)雜的多容器應(yīng)用程序
  4. 對擁有數(shù)千個節(jié)點或容器的應(yīng)用程序,Docker也能快速的擴展和調(diào)配
  5. 可以運行在主流的Linux系統(tǒng),Mac以及Windows上,并且保證無論軟件在哪里部署,都能正常運行并得到相同的結(jié)果

相關(guān)概念介紹

Image鏡像和Container容器:你可以把兩者理解為類和實例對象,或者是ISO系統(tǒng)鏡像和虛擬機的關(guān)系。不同的Image所包含的軟件或者環(huán)境是不同的,但是你可以使用Dockerfile(docker特有語法規(guī)則所創(chuàng)建的文件)進行管理。而Container則是以Image作為模板,可以獨立運行的微型系統(tǒng),一個Image可以創(chuàng)建出來多個Container容器的實例

Registry:Docker Hub鏡像倉庫,為每個人提供龐大的鏡像資源進行拉取和使用

Dockerfile:是一個將鏡像命令組合在一起的文件,用于Image的自動構(gòu)建

3、環(huán)境搭建

系統(tǒng)環(huán)境

宿主機:Windows 10 專業(yè)版

Linux服務(wù)器: CentOS 3.10

1.安裝Docker

Docker 要求 CentOS 系統(tǒng)的內(nèi)核版本高于 3.10 ,查看本頁面的前提條件來驗證你的CentOS 版本是否支持 Docker 。

通過 uname -r 命令查看你當(dāng)前的內(nèi)核版本

[root@runoob ~]# uname -r 3.10.0-862.E17.X86_64

# yum install docker-engine 安裝docker包

安裝成功后,使用docker version命令查看是否安裝成功,安裝成功后------如下圖

啟動 Docker

systemctl start docker

查看docker信息,如下圖

systemctl status docker

測試運行 hello-world

#docker run hello-world

2.安裝rancher

下載鏡像

docker pull rancher/server

啟動 rancher

docker run -d --restart=always -p 8080:8080 rancher/server

安裝成功后,通過http://ip:8080訪問,如下圖所示

3.安裝rabbitmq

 下載鏡像

docker run -d --restart=always -p 8080:8080 rancher/server

 

復(fù)制代碼 代碼如下:

 #docker run -d --name rabbitmq --publish 5672:5672 --publish 4369:4369 --publish 25672:25672 --publish 15671:15671 --publish 15672:15672 \rabbitmq:management
 

安裝成功后,通過http://ip:15672訪問,如下圖所示

4.安裝Consul

下載鏡像

#docker pull docker.io/consul:latest

創(chuàng)建 Consul 配置

#vim /opt/platform/consul/server.json
{
  "datacenter": "quark-consul",
  "data_dir": "/consul/data",
  "server": true,
  "ui": true,
  "bind_addr": "192.168.249.162",
  "client_addr": "192.168.249.162",
  "bootstrap_expect": 1,
  "retry_interval": "10s",
  "rejoin_after_leave": false,
  "skip_leave_on_interrupt": true
}

配置說明

官方在啟動容器的時候是將一部分配置作為 docker run 的參數(shù),而我是把參數(shù)寫到了配置文件里。

  1. datacenter:數(shù)據(jù)中心名稱(庫名)
  2. data_dir:數(shù)據(jù)存儲目錄
  3. server:運行在server模式
  4. ui:使用UI界面
  5. bind_addr:內(nèi)部集群通信綁定的地址。默認是 0.0.0.0 ,如果有多塊網(wǎng)卡,需要指定,否則啟動報錯
  6. client_addr:客戶端接口綁定的地址,默認是 127.0.0.1 ;
  7. retry_join:重新加入集群
  8. retry_interval:重試時間
  9. rejoin_after_leave:在離開集群之后才重試加入
  10. skip_leave_on_interrupt:在啟動后,是否 Ctrl+C 優(yōu)雅退出,我們是容器模式,所以不用管,直接 true 就好了。

啟動 consul-server

復(fù)制代碼 代碼如下:
docker run -d --net=host --name consul -v /opt/platform/consul/config:/consul/config -v /opt/platform/consul/data:/consul/data consul agent

安裝成功后,通過http://ip:8500訪問,如下圖所示

5. 安裝dotnetcore 2.1 runtime

下載鏡像

#sudo docker pull microsoft/dotnet:2.1-runtime

啟動  

#sudo docker run -it microsoft/dotnet:2.1-runtime

三、部署程序

 1. 部署surging引擎,無需引用任何業(yè)務(wù)模塊,新建Dockerfile文件

FROM microsoft/dotnet:2.1-runtime
WORKDIR /app
COPY . .
ENTRYPOINT ["dotnet", "Surging.Services.Server.dll"]

發(fā)布程序

dotnet publish -r centos.7-x64 -c release

使用Dockerfile創(chuàng)建鏡像

#docker build -t surgingserver .

啟動

#docker run --name surgingserver --env Mapping_ip=192.168.249.162 --env Mapping_Port=198 --env RootPath=/home/fanly --env 
Register_Conn=192.168.249.162:8500 --env EventBusConnection=172.17.0.4 --env Surging_Server_IP=0.0.0.0 -v /home/fanly:/home/fanly -it -p 198:198 surgingserver

配置說明

  1. Mapping_ip:映射的外部IP(環(huán)境變量)
  2. Mapping_port :映射的外部端口 (環(huán)境變量)
  3. RootPath:業(yè)務(wù)模塊存儲的根路徑 (環(huán)境變量)
  4. Register_Conn:注冊中心地址 (環(huán)境變量)
  5. EventBusConnection:eventbus 地址 (環(huán)境變量)
  6. Surging_Server_IP:容器內(nèi)部IP (環(huán)境變量)

啟動后在rancher如下圖所示

因為方便,把宿主機的目錄進行了掛載,microsurging 為分布式微服務(wù)引擎,Modules 為業(yè)務(wù)模塊目錄,surgingapi為網(wǎng)關(guān)

2. 部署surging網(wǎng)關(guān), 新建Dockerfile文件

FROM microsoft/dotnet:2.1-runtime
WORKDIR /app
COPY . .
ENTRYPOINT ["dotnet", "Surging.ApiGateway.dll"]

發(fā)布程序

dotnet publish -r centos.7-x64 -c release

使用Dockerfile創(chuàng)建鏡像

docker build -t surgingapi .

啟動

復(fù)制代碼 代碼如下:
#docker run --name surgingapi -it -p 729:729 --env Register_Conn=192.168.249.162:8500 surgingapi

啟動后在rancher如下圖所示

可以通過http://ip:729進行訪問

然后可以通過postman 來測試網(wǎng)關(guān),如下圖

四、總結(jié)

通過1年的開發(fā),surging 也趨于完善,性能非常不錯,平均訪問在0.12ms 左右

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 教你用100?行shell實現(xiàn)Docker詳解

    教你用100?行shell實現(xiàn)Docker詳解

    這篇文章主要為大家介紹了教你用100?行shell實現(xiàn)Docker詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • docker的三種安裝方式匯總

    docker的三種安裝方式匯總

    這篇文章主要介紹了docker的三種安裝方式匯總,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 在Ubuntu中安裝Docker教程

    在Ubuntu中安裝Docker教程

    這篇文章主要介紹了在Ubuntu中安裝Docker教程,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • Docker 使用 Supervisor 來管理進程操作

    Docker 使用 Supervisor 來管理進程操作

    這篇文章主要介紹了Docker 使用 Supervisor 來管理進程操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • CentOS7 Nexus安裝步驟詳細介紹

    CentOS7 Nexus安裝步驟詳細介紹

    這篇文章主要介紹了CentOS7 Nexus安裝步驟詳細介紹的相關(guān)資料,這里對CentOS7 安裝Nexus 進行了詳細介紹,需要的朋友可以參考下
    2016-11-11
  • 使用docker?compose一鍵部署WordPress博客的方法

    使用docker?compose一鍵部署WordPress博客的方法

    這篇文章主要介紹了docker-compose一鍵部署WordPress博客,本文分步驟給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • 解決docker run時候啟動兩個占有不同端口的問題

    解決docker run時候啟動兩個占有不同端口的問題

    這篇文章主要介紹了解決docker run時候啟動兩個占有不同端口的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 在Docker容器中部署靜態(tài)網(wǎng)頁的方法教程

    在Docker容器中部署靜態(tài)網(wǎng)頁的方法教程

    這篇文章主要給大家介紹了在Docker容器中部署靜態(tài)網(wǎng)頁的方法教程,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • docker中使用mongodb數(shù)據(jù)庫詳解(在局域網(wǎng)訪問)

    docker中使用mongodb數(shù)據(jù)庫詳解(在局域網(wǎng)訪問)

    這篇文章主要給大家介紹了在docker中使用mongodb數(shù)據(jù)庫,在局域網(wǎng)訪問的相關(guān)資料,文中將步驟介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • Docker常見的錯誤和異常整理大全

    Docker常見的錯誤和異常整理大全

    這篇文章主要給大家介紹了關(guān)于Docker常見的錯誤和異常整理的相關(guān)資料,文中通過代碼示例介紹的非常詳細,對新手們學(xué)習(xí)Docker具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08

最新評論