Spring Cloud 微服務(wù)(五) 部署到AWS ECS

AWS是亞馬遜托管的云服務(wù)买鸽,其中ECS是亞馬遜的EC2實(shí)例在容器方面的優(yōu)化,自帶docker贯被,而且每個(gè)機(jī)器都有個(gè)亞馬遜實(shí)現(xiàn)的容器"ECS agent"來(lái)負(fù)責(zé)容器的治理眼五,另外Spring Cloud本身也有對(duì)AWS的支持,封裝了AWS的服務(wù)刃榨,叫做spring-cloud-aws弹砚。我們?cè)?a href="http://www.reibang.com/p/1ce2bc8ce674" target="_blank">上一篇文章實(shí)現(xiàn)了微服務(wù)的docker化,下一步可以把我們的服務(wù)發(fā)布到ECS上對(duì)外提供服務(wù)枢希。

ECS層級(jí)結(jié)構(gòu)
mind_diagram_2 (2).png
創(chuàng)建一個(gè)集群 Cluster

集群是ECS最大的一個(gè)層級(jí)桌吃,集群的選擇通常考慮地理因素苞轿,比如國(guó)內(nèi)訪問(wèn)多的話就考慮在東京建立集群茅诱,目前AWS中國(guó)還沒(méi)和其他AWS互連逗物,而且只能使用部分功能,韓國(guó)區(qū)沒(méi)有ECS服務(wù)瑟俭。創(chuàng)建過(guò)程中特別注意Key pair一定要預(yù)先定義好翎卓,然后在這里選擇一個(gè)Key pair,筆者就試過(guò)沒(méi)有設(shè)置Key pari導(dǎo)致無(wú)法ssh到創(chuàng)建的實(shí)例上摆寄。Number of Instances代表我們想要開(kāi)的實(shí)例數(shù)失暴。

image.png

這里的VPS是設(shè)置一個(gè)虛擬的內(nèi)網(wǎng),有了這個(gè)才能更好地構(gòu)建一個(gè)內(nèi)網(wǎng)微服務(wù)微饥。


image.png

Security Group其實(shí)定義的是防火墻相關(guān)的端口開(kāi)關(guān)逗扒,這個(gè)在后面會(huì)用到。


image.png

整個(gè)創(chuàng)建過(guò)程需要幾分鐘欠橘,創(chuàng)建完就能看在面板上看到我們剛創(chuàng)建的微服務(wù)了矩肩,集群頁(yè)面會(huì)展示運(yùn)行的服務(wù)數(shù),任務(wù)數(shù)肃续,CPU和內(nèi)存黍檩。
image.png
創(chuàng)建一個(gè)服務(wù) Service

一個(gè)集群可以運(yùn)行很多服務(wù),Number of tasks定義了預(yù)期要運(yùn)行多少個(gè)task始锚,如果目前運(yùn)行的task低于這個(gè)值刽酱,ECS會(huì)自動(dòng)發(fā)起task滿足這個(gè)值。

image.png

Task Placement 定義了當(dāng)給定數(shù)量task要啟動(dòng)時(shí)疼蛾,ECS會(huì)優(yōu)先把task按照一定的算法啟動(dòng)到某個(gè)實(shí)例上肛跌,比如spread代表平均地放置task,random代表隨機(jī)察郁。下面的ELB和Auto scaling分別是負(fù)載均衡和自動(dòng)擴(kuò)展功能衍慎。

image.png

Service創(chuàng)建出來(lái)的時(shí)候的面板:

image.png
創(chuàng)建一個(gè)任務(wù) Task

創(chuàng)建任務(wù)時(shí)候可以選擇docker的聯(lián)網(wǎng)方式,分別是bridge和host皮钠,默認(rèn)的docker都是bridge方式稳捆。

image.png

Task可以添加docker container,并且為每個(gè)container配置不同屬性麦轰。這里定義使用的鏡像乔夯,待會(huì)我們會(huì)創(chuàng)建一個(gè)鏡像。為了防止突然升高的內(nèi)存導(dǎo)致的高昂費(fèi)用款侵,可以設(shè)置內(nèi)存最大值末荐。這里說(shuō)一個(gè)筆者遇到的坑,128兆內(nèi)存其實(shí)是不夠運(yùn)行Spring Boot應(yīng)用的新锈,我在創(chuàng)建過(guò)程中使用了默認(rèn)的128兆內(nèi)存甲脏,導(dǎo)致微服務(wù)剛起來(lái)沒(méi)多久就因?yàn)槌鰞?nèi)存導(dǎo)致Task被干掉,同時(shí)Service里定義了最小存活Task為1,所以每次被干掉之后又會(huì)重新啟動(dòng)一個(gè)Task块请,導(dǎo)致了服務(wù)一只在不斷循環(huán)重啟娜氏,所以對(duì)于網(wǎng)絡(luò)應(yīng)用這里的推薦內(nèi)存值是300-500兆內(nèi)存。
Port mappings實(shí)現(xiàn)的是docker端口的映射墩新。

image.png

Essential代表它是這個(gè)任務(wù)的主要容器贸弥,如果這個(gè)容器失去聯(lián)系了,Task將被Kill掉海渊,這個(gè)也是導(dǎo)致上訴死循環(huán)的一個(gè)重要原因绵疲。

image.png
創(chuàng)建Container Registory(docker鏡像倉(cāng)庫(kù))

創(chuàng)建鏡像很簡(jiǎn)單,只要把上面顯示的命令行在本地鏡像上執(zhí)行一下就可以了臣疑,具體操作類似GIT把本地倉(cāng)庫(kù)push到遠(yuǎn)程倉(cāng)庫(kù)最岗。

image.png

把Eureka Server和我們的微服務(wù)推到遠(yuǎn)程的docker倉(cāng)庫(kù)之后,如圖所示可以看到這兩個(gè)Image朝捆。

image.png
在ECS上部署我們的微服務(wù)

按照上面的任務(wù)創(chuàng)建方式創(chuàng)建一個(gè)任務(wù),任務(wù)里面運(yùn)行兩個(gè)docker懒豹,分別是我們的Eureka Server和一個(gè)簡(jiǎn)單的服務(wù)

image.png

這時(shí)候update我們的Service


image.png

等一段時(shí)間后就能看到我們的服務(wù)正運(yùn)行在ECS集群上了

image.png

這時(shí)候還有最后一步芙盘,因?yàn)槲覀冊(cè)O(shè)置了防火墻,所以要去防火墻開(kāi)啟8081端口和8870端口脸秽,因?yàn)槲覀兊姆?wù)運(yùn)行在這兩個(gè)端口上儒老。

image.png
image.png

到這里,我們就可以用ECS實(shí)例的公網(wǎng)地址訪問(wèn)我們?cè)贏WS上創(chuàng)立的第一個(gè)微服務(wù)了记餐。

最后附上官網(wǎng)文檔上ECS的一個(gè)結(jié)構(gòu)圖


ECS層級(jí)結(jié)構(gòu)(1)

上一篇:Spring Cloud 微服務(wù)(四) Docker化
下一篇:Spring Cloud 微服務(wù)(六) 服務(wù)消費(fèi)Feign

(1) http://docs.aws.amazon.com/AmazonECS/latest/developerguide/Welcome.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末驮樊,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子片酝,更是在濱河造成了極大的恐慌囚衔,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件雕沿,死亡現(xiàn)場(chǎng)離奇詭異练湿,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)审轮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門肥哎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人疾渣,你說(shuō)我怎么就攤上這事篡诽。” “怎么了榴捡?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵杈女,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng)碧信,這世上最難降的妖魔是什么赊琳? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮砰碴,結(jié)果婚禮上躏筏,老公的妹妹穿的比我還像新娘。我一直安慰自己呈枉,他們只是感情好趁尼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著猖辫,像睡著了一般酥泞。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上啃憎,一...
    開(kāi)封第一講書(shū)人閱讀 51,245評(píng)論 1 299
  • 那天谁不,我揣著相機(jī)與錄音裸准,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛侦另,可吹牛的內(nèi)容都是我干的芙贫。 我是一名探鬼主播刺彩,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼亥啦,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了辉阶?” 一聲冷哼從身側(cè)響起先壕,我...
    開(kāi)封第一講書(shū)人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎谆甜,沒(méi)想到半個(gè)月后垃僚,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡店印,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年冈在,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片按摘。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡包券,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出炫贤,到底是詐尸還是另有隱情溅固,我是刑警寧澤,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布兰珍,位于F島的核電站侍郭,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜亮元,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一猛计、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧爆捞,春花似錦奉瘤、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至成肘,卻和暖如春卖局,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背双霍。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工砚偶, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人洒闸。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓蟹演,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親顷蟀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容