基于git的deployment和rollback方法

一種devops實踐方法的總結(jié)献起。

remote repos

  • 推薦放置于github
  • 最新可部署代碼放置于master分支投慈。由項目代碼的code master掌管奕翔,其他人不允許直接push到這個分支哟冬。
  • spec design. architecture(如果不是獨(dú)立的role念赶,那么所有承擔(dān)此角色的人要一起來討論spec的設(shè)計)。
  • developer開新分支怖竭,根據(jù)spec編寫unit-test和implementation code锥债。此處可以采用Test-driven development。自行進(jìn)行功能測試痊臭,包含unit-test以及end-2-end test哮肚。撰寫部署腳本。git push广匙。然后到github創(chuàng)建pull request并請求code master進(jìn)行1-to-1 code review允趟,review通過由master merge代碼。

spec design

spec design要由architecturer role / group來完成鸦致,包含:

  • api定義
    • 函數(shù)名稱(名稱的自解釋性非常重要3奔簟!)
    • 業(yè)務(wù)邏輯分唾,即函數(shù)應(yīng)該完成的功能
    • 入?yún)⒚Q抗碰,數(shù)據(jù)結(jié)構(gòu)定義,默認(rèn)值等
    • 返回結(jié)果的數(shù)據(jù)結(jié)構(gòu)鳍寂,數(shù)據(jù)結(jié)構(gòu)中的每個字段的名字改含、屬性、默認(rèn)值等
    • 異常定義迄汛,異常代碼捍壤,異常信息
    • 特性定義,比如冪等性(應(yīng)該冪等還是不冪等鞍爱?)鹃觉、健壯性(是否應(yīng)該積極拋出異常,還是默默容錯睹逃?)盗扇、副作用(是否應(yīng)該是pure的祷肯?是否應(yīng)該stateless?)疗隶,等等
  • model定義
    • model的命名
    • 數(shù)據(jù)結(jié)構(gòu)定義佑笋,數(shù)據(jù)結(jié)構(gòu)中的每個字段的名字、屬性斑鼻、默認(rèn)值等
    • 數(shù)據(jù)遷移定義(比如django的migrations)

架構(gòu)師最好統(tǒng)一把migrations生成(避免硬分叉沖突)蒋纬,并把prototype也落實成代碼,以便dev直接在其中補(bǔ)齊邏輯實現(xiàn)即可坚弱。

補(bǔ)充:對于存在ORM migrate的架構(gòu)蜀备,推薦把model升級和code升級分成兩步,先migrate model(形成一個commit point)荒叶,確保沒問題之后再upgrade code碾阁,這樣,如果第二步失敗需要回滾些楣,則只需要回滾到第一步的commit point脂凶。
建議由architecturer (dev arch)來做。

deployment

  • 由devops完成(或分擔(dān)此角色的人共同完成愁茁,結(jié)對)
  • 規(guī)劃代碼部署位置艰猬,推薦在/opt/{APP_NAME}
  • git pull
  • 重啟服務(wù),比如對于systemd守護(hù)的服務(wù)埋市,使用sudo service SERVICE_NAME restart
  • 查看服務(wù)狀態(tài),包括但不限于:
    • service XXX status 查看systemd service的狀態(tài)
    • ps aux | grep XXX 查看進(jìn)程運(yùn)行否
    • netstat -na | grep XXX 查看服務(wù)是否正在監(jiān)聽相關(guān)端口
    • APP自身的status查看方法
  • 最后一定要做一次生產(chǎn)環(huán)境的end-2-end test命贴!

rollback

如果部署失敗需要回滾道宅,可以使用git,具體方法是:

  1. git log找到上一次部署的commit
  2. git checkout LAST_COMMIT -b rollback
  3. 此時代碼切換到rollback分支胸蛛,且filesystem上的code files回復(fù)到LAST_COMMIT的狀態(tài)
  4. 重啟服務(wù)污茵。檢查狀態(tài)。做end-2-end test葬项。確迸⒌保回滾成功。

然后民珍,開始騰出手來仔細(xì)檢查為何master的code部署失敗襟士。fix并重新部署。
成功后嚷量,刪除rollback分支陋桂。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蝶溶,隨后出現(xiàn)的幾起案子嗜历,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件梨州,死亡現(xiàn)場離奇詭異痕囱,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)暴匠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門鞍恢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人巷查,你說我怎么就攤上這事有序。” “怎么了岛请?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵旭寿,是天一觀的道長。 經(jīng)常有香客問我崇败,道長盅称,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任后室,我火速辦了婚禮缩膝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘岸霹。我一直安慰自己疾层,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布贡避。 她就那樣靜靜地躺著痛黎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪刮吧。 梳的紋絲不亂的頭發(fā)上湖饱,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機(jī)與錄音杀捻,去河邊找鬼井厌。 笑死,一個胖子當(dāng)著我的面吹牛致讥,可吹牛的內(nèi)容都是我干的仅仆。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼拄踪,長吁一口氣:“原來是場噩夢啊……” “哼蝇恶!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起惶桐,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤撮弧,失蹤者是張志新(化名)和其女友劉穎潘懊,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贿衍,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡授舟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了贸辈。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片释树。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖擎淤,靈堂內(nèi)的尸體忽然破棺而出奢啥,到底是詐尸還是另有隱情,我是刑警寧澤嘴拢,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布桩盲,位于F島的核電站,受9級特大地震影響席吴,放射性物質(zhì)發(fā)生泄漏赌结。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一孝冒、第九天 我趴在偏房一處隱蔽的房頂上張望柬姚。 院中可真熱鬧,春花似錦庄涡、人聲如沸量承。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽宴合。三九已至,卻和暖如春迹鹅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背贞言。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工斜棚, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人该窗。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓弟蚀,卻偏偏與公主長得像,于是被迫代替她去往敵國和親酗失。 傳聞我的和親對象是個殘疾皇子义钉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)规肴,斷路器捶闸,智...
    卡卡羅2017閱讀 134,601評論 18 139
  • 1.git的安裝 1.1 在Windows上安裝Git msysgit是Windows版的Git夜畴,從https:/...
    落魂灬閱讀 12,649評論 4 54
  • 弟弟今年17歲,中專休學(xué)在家删壮。昨天晚上爸爸去他房間看他睡了沒發(fā)現(xiàn)2點(diǎn)多鐘了還在玩手機(jī)贪绘,就罵了他,結(jié)果我弟就把門給鎖...
    heallen閱讀 473評論 0 0
  • 愿蒼天 風(fēng)調(diào)雨順央碟,愿大地 山崇川暢税灌。愿世間 萬物皆宜,愿你我 感恩常在亿虽。天災(zāi)還要 再家園菱涤,地震祈求 災(zāi)減少。人間有...
    甘朝武閱讀 337評論 0 0
  • 敢問路在何方 理想很豐滿洛勉,現(xiàn)實很骨感粘秆。那么,路在哪里坯认?這是許多人的困惑所在翻擒。上個世紀(jì)八十年代,曾經(jīng)有一個叫潘曉...
    宏磊閱讀 220評論 0 0