摘要:可是并沒有統(tǒng)一的版本號管理功能,只是額外提供了內(nèi)包的依賴路徑。描述文件支持兩種格式,普通方式和方式,可以直接在其中描述依賴庫的遠(yuǎn)程地址版本號等,一個簡單的例子我這里使用普通格式然后在根目錄執(zhí)行,即可獲得相關(guān)版本的依賴包非常輕量級,非常簡潔。
與Linux、OpenStack等成熟的技術(shù)社區(qū)相比,Rancher社區(qū)還是處于初級發(fā)展階段,一個技術(shù)社區(qū)的成敗并不是單純的代碼貢獻(xiàn),而學(xué)習(xí)文檔的數(shù)量和代碼管理作業(yè)流程也是非常重要的。如何讓懷揣不同需求的工程師都能在社區(qū)中快速找到相應(yīng)的解決方案,這就需要大家協(xié)同合作共同促進(jìn)社區(qū)發(fā)展與完善。除了我們所熟知的Rancher & RancherOS,Rancher Labs的開發(fā)團(tuán)隊在實踐中提煉了很多實用的小工具,這些小工具雖然并不會左右Rancher發(fā)展的大局,但是在項目標(biāo)準(zhǔn)化和開發(fā)效率上給團(tuán)隊帶來巨大的便捷。這次主要是帶著大家一起來認(rèn)識一下這些小工具。
Golang包管理工具-Trash項目地址:https://github.com/rancher/trash
目前主流的編程語言 Python、Ruby、Java、Php 等已經(jīng)把包管理的流程設(shè)計的猶如行云流水般流暢,一般情況下開發(fā)者是不需要操心類庫包依賴管理以及升級、備份、團(tuán)隊協(xié)作的。Golang在1.5版本開始,官方開始引入包管理的設(shè)計,加了 vendor目錄來支持本地包管理依賴,但是需要特殊設(shè)置GO15VENDOREXPERIMENT=1,在1.6時代這個特性已經(jīng)是默認(rèn)的了??墒莢endor并沒有統(tǒng)一的版本號管理功能,只是額外提供了project內(nèi)包的依賴路徑。于是Trash這個工具就應(yīng)運而生了,Trash的使用非常簡單,只需要有一份依賴包的描述文件即可。
描述文件 trash.conf 支持兩種格式,普通方式和YAML方式,可以直接在其中描述依賴庫的遠(yuǎn)程地址、版本號等,一個簡單的例子(我這里使用普通格式):
然后在根目錄執(zhí)行trash,即可獲得相關(guān)版本的依賴包:
非常輕量級,非常簡潔。
Golang編譯工具-Dapper項目地址:https://github.com/rancher/da...
我們在編譯golang執(zhí)行程序的時候,因為涉及到協(xié)作開發(fā),這就會碰到一個問題,就是如何保證編譯環(huán)境的一致性。環(huán)境一致性最好的辦法就是使用容器技術(shù),Dapper就是利用Docker build鏡像的過程中可以執(zhí)行各種命令生成容器的原理。只需在項目的根目錄下創(chuàng)建Dockerfile.dapper 文件,這是一個參考Dockerfile標(biāo)準(zhǔn)的文件,執(zhí)行 dapper 命令即可按照約定規(guī)則生成最終的執(zhí)行程序,通過這種方式統(tǒng)一的編譯環(huán)境。
幾乎所有的Rancher項目都是基于Dapper來編譯的,隨意打開一個項目比如rancher-dns就可以看到 Dockerfile.dapper 文件:
DAPPER_SOURCE 指定了容器內(nèi)的源碼路徑
DAPPER_OUTPUT 指定了編譯后的輸出路徑,bin dist 目錄會自動在項目根目錄下創(chuàng)建
DAPPER_DOCKER_SOCKET 設(shè)置為True相當(dāng)于docker run -v /var/run/docker.sock:/var/run/docker.sock ...
DAPPER_ENV 相當(dāng)于docker run -e TAG -e REPO ...
有一點需要注意的是,目前Dapper裝載源碼有兩種方式bind和cp,bind就是直接mount本地的源碼路徑,但是如果使用remote docker daemon方式那就得使用cp模式了。
Golang項目標(biāo)準(zhǔn)化工具 go-skel項目地址:https://github.com/rancher/go...
介紹了包管理工具和打包編譯工具,如果我們在創(chuàng)建一個golang項目時能把這兩個工具整合起來一起使用,那就太贊了。go-skel就是提供了這樣一個便利,我們直接來demo一下。
clone一份go-skel的源碼,創(chuàng)建一個rancher-tour(./skel.sh rancher-tour)的項目:
執(zhí)行完畢后,會創(chuàng)建一個標(biāo)準(zhǔn)的項目,包含了dapper和trash這兩個工具,同時定義了一份Makefile,我們可以通過make命令來簡化操作:
比如我們要執(zhí)行一個ci操作,那就可以直接運行 make ci,自動運行單元測試,并在bin目錄下生成最終的可執(zhí)行程序:
標(biāo)準(zhǔn)項目已經(jīng)創(chuàng)建了一些初始化代碼,集成了 github.com/urfave/cli ,所以我們可以執(zhí)行執(zhí)行rancher-tour:
微服務(wù)輔助小工具 Giddyup項目地址:https://github.com/cloudnauti...
一個傳統(tǒng)的服務(wù)在容器化的過程中,通常我們會將其拆分成多個微服務(wù),充分展現(xiàn)每個容器只做好一件事情這樣的哲學(xué)。那么就會出現(xiàn)我們在Rancher中看到的sidekick容器,數(shù)據(jù)卷容器,專門負(fù)責(zé)更新配置信息的容器等等。
實際應(yīng)用中我們會遇到一些問題,比如這些微服務(wù)容器的啟動是無序的,無序啟動會導(dǎo)致微服務(wù)之間可能出現(xiàn)連接失敗,進(jìn)而導(dǎo)致整個服務(wù)不可用;再比如我們?nèi)绾蝸砼卸ㄒ蕾嚨奈⒎?wù)已經(jīng)正常啟動,這可能需要一個health check的服務(wù)端口。giddyup就是簡化這種微服務(wù)檢查工作的利器,它都能做些什么呢:
Get connection strings from DNS or Rancher Metadata.
Determine if your container is the leader in the service.
Proxy traffic to the leader
Wait for service to have the desired scale.
Get the scale of the service
Get Managed-IP of the container (/self/container/primary_ip)
我們還是創(chuàng)建stack并在其中創(chuàng)建service來體驗一下giddyup的部分功能,service中包含兩個容器分別為主容器main和sidekick容器conf,他們共享網(wǎng)絡(luò)棧:
我們可以在conf內(nèi)啟動giddyup health,會啟動一個監(jiān)聽1620端口的http服務(wù),服務(wù)路徑是/ping:
此時我們可以在其他服務(wù)的容器內(nèi)查看這個服務(wù) health port的健康狀態(tài),通過giddyup ip stringify獲取服務(wù)地址,使用giddyup probe可以查看相關(guān)狀態(tài):
可以看到probe返回了OK的信息,說明giddy/main的health port是正常的,如果我們把giddyup health的端口停掉,giddyup probe會如何?
除了開啟health port功能外,還可以sleep等待service內(nèi)所有容器都啟動,比如剛才的service,我在main上做wait操作,同時在UI上對service擴(kuò)容,可以看到為了等待完成擴(kuò)容差不多sleep了3s:
更多功能可以去看一看giddyup項目的README文檔,另外也可以看看catalog中的一些項目是怎么使用giddyup的,參考:https://github.com/rancher/ca...
Rancher CLI 工具項目地址: https://github.com/rancher/cli
現(xiàn)在我們管理Rancher的方式包括UI、API方式,為了能夠和其他工具更好的融合Rancher開發(fā)了CLI工具,可以非常輕量級的嵌入到其他工具中。CLI將會在Rancher 1.2-pre2版本中正式放出,兼容性上目前來看沒有支持老版本的計劃,所以在老版本上出現(xiàn)各種問題也是正常的。
直接在 https://github.com/rancher/cl... 下載最新版本即可試用,將rancher cli放到PATH中,正式使用前需要初始化:
然后便可以執(zhí)行各種犀利的操作,比如針對某個service進(jìn)行scale操作,這比之前需要用rancher-compose cli要簡潔的多:
再比如可以實時監(jiān)聽rancher events,可以即時查看Rancher中正在發(fā)生的各種任務(wù),對協(xié)助排查問題,分析系統(tǒng)運行情況都非常有用:
后語小工具中內(nèi)含著大智慧,工具文化是工程師Team高效協(xié)作的重要標(biāo)志,高質(zhì)量的工具能讓項目開發(fā)有事半功倍之效,其背后也蘊藏著深厚的團(tuán)隊文化理念,就是不計項目KPI利用個人業(yè)余時間為團(tuán)隊做貢獻(xiàn)的和諧氛圍。其實國內(nèi)很多互聯(lián)網(wǎng)公司都是有專門設(shè)立工具開發(fā)工程師的崗位,對工具帶來的生產(chǎn)效率提升,其重視程度不言而喻!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/27961.html
摘要:扒一扒淘票票界面淘票票界面寫的挺美觀的,但是最近看了看淘票票的命名方式,覺得稍有不妥。命名與頁面內(nèi)容掛鉤,代碼復(fù)用性低。 BEM解析 BEM是一套CSS國際命名規(guī)范,是一個非常有用的功能強(qiáng)大且簡單的命名約定,它能使前端代碼更易讀,易于理解易于擴(kuò)展。BEM是塊(block)、元素(element)、修飾符(modifier)的縮寫。 B:Block是塊,一個獨立的組件,將所有東西都劃分...
摘要:有了之前的簡述的使用,大致了解了的使用。今天我們就來扒一扒的源碼。好了,整個和就關(guān)聯(lián)在一起了。注下篇文章我們再來扒一扒源碼當(dāng)把事件廣播出去后,我們就開始執(zhí)行該事件的各個監(jiān)聽了。 有了之前的《簡述 Laravel Model Events 的使用》https://mp.weixin.qq.com/s/XrhDq1S5RC9UdeULVVksoA,大致了解了 Event 的使用。 今天我們...
摘要:年成立的為互聯(lián)網(wǎng)提供真正的隨機(jī)數(shù)。在年,隨機(jī)數(shù)市場發(fā)生了一個巨大的變化,在其芯片組上集成了芯片級的隨機(jī)數(shù)生成器。 作者:Alon Zakai 編譯:胡子大哈 翻譯原文:http://huziketang.com/blog/posts/detail?postId=58cfc3dda6d8a07e449fdd29 英文原文:A Brief History of Random Number...
摘要:注本文首發(fā)在我的個人博客最近有個項目使用了,本來一直使用的是來進(jìn)行開發(fā),可是遇到了很多問題。此外,還有很多規(guī)范是幫助我們寫出更加優(yōu)雅而不容易出錯的代碼的。,終于基本搞定了,可以愉快地開發(fā)應(yīng)用了。 注:本文首發(fā)在 我的個人博客 最近有個項目使用了 Vue.js ,本來一直使用的是 PHPStorm 來進(jìn)行開發(fā),可是遇到了很多問題。 后來,果斷放棄收費的 PHPStorm ,改用 vsco...
閱讀 2328·2021-11-24 10:33
閱讀 1392·2019-08-30 15:43
閱讀 3285·2019-08-29 17:24
閱讀 3495·2019-08-29 14:21
閱讀 2233·2019-08-29 13:59
閱讀 1746·2019-08-29 11:12
閱讀 2820·2019-08-28 18:00
閱讀 1859·2019-08-26 12:17