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)
創(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ù)失暴。
這里的VPS是設(shè)置一個(gè)虛擬的內(nèi)網(wǎng),有了這個(gè)才能更好地構(gòu)建一個(gè)內(nèi)網(wǎng)微服務(wù)微饥。
Security Group其實(shí)定義的是防火墻相關(guān)的端口開(kāi)關(guān)逗扒,這個(gè)在后面會(huì)用到。
整個(gè)創(chuàng)建過(guò)程需要幾分鐘欠橘,創(chuàng)建完就能看在面板上看到我們剛創(chuàng)建的微服務(wù)了矩肩,集群頁(yè)面會(huì)展示運(yùn)行的服務(wù)數(shù),任務(wù)數(shù)肃续,CPU和內(nèi)存黍檩。
創(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è)值。
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ò)展功能衍慎。
Service創(chuàng)建出來(lái)的時(shí)候的面板:
創(chuàng)建一個(gè)任務(wù) Task
創(chuàng)建任務(wù)時(shí)候可以選擇docker的聯(lián)網(wǎng)方式,分別是bridge和host皮钠,默認(rèn)的docker都是bridge方式稳捆。
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端口的映射墩新。
Essential代表它是這個(gè)任務(wù)的主要容器贸弥,如果這個(gè)容器失去聯(lián)系了,Task將被Kill掉海渊,這個(gè)也是導(dǎo)致上訴死循環(huán)的一個(gè)重要原因绵疲。
創(chuàng)建Container Registory(docker鏡像倉(cāng)庫(kù))
創(chuàng)建鏡像很簡(jiǎn)單,只要把上面顯示的命令行在本地鏡像上執(zhí)行一下就可以了臣疑,具體操作類似GIT把本地倉(cāng)庫(kù)push到遠(yuǎn)程倉(cāng)庫(kù)最岗。
把Eureka Server和我們的微服務(wù)推到遠(yuǎn)程的docker倉(cāng)庫(kù)之后,如圖所示可以看到這兩個(gè)Image朝捆。
在ECS上部署我們的微服務(wù)
按照上面的任務(wù)創(chuàng)建方式創(chuàng)建一個(gè)任務(wù),任務(wù)里面運(yùn)行兩個(gè)docker懒豹,分別是我們的Eureka Server和一個(gè)簡(jiǎn)單的服務(wù)
這時(shí)候update我們的Service
等一段時(shí)間后就能看到我們的服務(wù)正運(yùn)行在ECS集群上了
這時(shí)候還有最后一步芙盘,因?yàn)槲覀冊(cè)O(shè)置了防火墻,所以要去防火墻開(kāi)啟8081端口和8870端口脸秽,因?yàn)槲覀兊姆?wù)運(yùn)行在這兩個(gè)端口上儒老。
到這里,我們就可以用ECS實(shí)例的公網(wǎng)地址訪問(wèn)我們?cè)贏WS上創(chuàng)立的第一個(gè)微服務(wù)了记餐。
最后附上官網(wǎng)文檔上ECS的一個(gè)結(jié)構(gòu)圖
上一篇:Spring Cloud 微服務(wù)(四) Docker化
下一篇:Spring Cloud 微服務(wù)(六) 服務(wù)消費(fèi)Feign
(1) http://docs.aws.amazon.com/AmazonECS/latest/developerguide/Welcome.html