成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

使用 flow.ci 快速發(fā)布你的項(xiàng)目文檔

馬永翠 / 1619人閱讀

摘要:如何發(fā)布文檔最好的方式是把文檔發(fā)布為網(wǎng)站,這樣無需安裝任何工具即可查看文檔,更新時(shí)只需更新網(wǎng)站即可。在這里,用將文件快速生成為網(wǎng)站。拿文檔來看,持續(xù)部署就是內(nèi)容的持續(xù)測(cè)試與必要修改的歸并及部署。在此,部署意為發(fā)布。

軟件研發(fā)的協(xié)作過程中,文檔是必不可少的一環(huán),有需求文檔、接口文檔、使用文檔等等。當(dāng)開始寫文檔時(shí),首先會(huì)遇到兩個(gè)問題:

team members 之間如何協(xié)作?

文檔 OK 后如何分發(fā),去哪里看?如何更新?

很早的時(shí)候采用 word+ppt 做文檔,然后放到共享服務(wù)器(ftp,samba)上,這種方式會(huì)有文檔鎖定和覆蓋的問題,幾個(gè)人的小團(tuán)隊(duì)還可以,大不了更新的時(shí)喊一嗓子:“我要更新文檔了,大家都不要占用某某文件(使用windows共享文檔的童鞋應(yīng)該很熟悉)”。更新完了還要再喊一嗓子。除此之外,由于 word 文件格式(word文件其實(shí)是個(gè)壓縮包,由很多 xml 和其他文件構(gòu)成)太過于復(fù)雜,即便是借助 git 或者 svn 做版本控制,一旦產(chǎn)生沖突,很難通過肉眼合并和解決沖突。

那么如何解決上述問題呢?這篇文章我用 gitbook + flow.ci 進(jìn)行文檔的發(fā)布、集成和部署,希望給有需求的同學(xué)一些參考。

如何進(jìn)行文檔協(xié)作 & 版本控制 (git+markdown)

開發(fā)團(tuán)隊(duì)使用 git 或 svn 作為協(xié)作和版本控制工具已經(jīng)是很成熟的方案了,當(dāng)然也可以用于文檔,只是word文檔本身天然不太適合版本控制,markdown 是一種輕量級(jí)的標(biāo)記語言, 學(xué)習(xí)簡單,上手容易(具體語法參考 http://wowubuntu.com/markdown/) , 配合 git 幾乎能做到完美的文檔版本控制 。

如何發(fā)布文檔 (gitbook+nginx)

最好的方式是把文檔發(fā)布為 web 網(wǎng)站,這樣無需安裝任何工具即可查看文檔,更新時(shí)只需更新網(wǎng)站即可。在這里,用 gitbook 將 markdown 文件快速生成為網(wǎng)站。

什么是 gitbook 呢?官網(wǎng)上是這么介紹的:

GitBook is a modern publishing toolchain. Making both writing and collaboration easy.

簡單來說就是將 markdown 文檔轉(zhuǎn)換成 html、pdf、epub 等多種格式,很多開源軟件和書籍都是用 gitbook 發(fā)布的,
如:Elasticsearch 權(quán)威指南、 Docker — 從入門到實(shí)踐 等。

如果將 markdown 文檔生成靜態(tài) html 部署到服務(wù)器(nginx)上,不僅可以通過瀏覽器查看,而且一旦更新server,所有人看到的都是最新的文檔。

如何將文檔進(jìn)行持續(xù)集成 & 部署 (flow.ci)

CI(Continuous Integration)意為 “持續(xù)整合”,指代碼的持續(xù)測(cè)試及與其他代碼修改的整合與歸并。

CD(Continuous Deployment)意為 “持續(xù)部署”,指代碼與其補(bǔ)丁的持續(xù)部署于整個(gè)代碼庫。

拿文檔來看,持續(xù)部署就是內(nèi)容的持續(xù)測(cè)試、與必要修改的歸并及部署。在此,部署意為發(fā)布。舉例來說,“部署文檔”是指輸出文件被復(fù)制于web服務(wù)器為人閱覽。

關(guān)于持續(xù)集成、持續(xù)部署不是一兩句話能說清的,用于實(shí)現(xiàn) 持續(xù)集成、持續(xù)部署的工具鏈也五花八門,比如:最常見的 jenkins 、TravisCI 等,使用起來配置過于復(fù)雜。這篇文章里我將使用自家的持續(xù)集成服務(wù) —— flow.ci 來進(jìn)行文檔的集成和部署,僅供參考。

建一個(gè)git repo存儲(chǔ)文檔

首先,建一個(gè)git repo存儲(chǔ)文檔,此處以 flow.ci官方文檔 docs.flow.ci 為例, git repo 為

[email protected]:FIRHQ/flow.ci.git

目前 flow.ci 支持 github、bitbucket、國內(nèi)的coding 和 私有部署的Gitlab。只要文檔放在以上代碼倉庫的 git repo 都可以使用 flow.ci 進(jìn)行集成. 如何在 flow.ci 創(chuàng)建項(xiàng)目可以 參考文檔.

在 flow.ci 上創(chuàng)建 flow

接著,在 flow.ci 上建一個(gè)flow,語言模板選用 nodejs(使用 gitbook 需要用到node環(huán)境)。

同時(shí)刪除掉 Cache、Install、Test等 step,這幾個(gè) step 是為 nodejs 項(xiàng)目提供的,我們此處只需要 nodejs 運(yùn)行時(shí)環(huán)境及 npm 工具。

添加自定義腳本step

刪除完之后添加自定義腳本step, 如何添加自定義腳本step可參考文檔。 此處要添加兩個(gè)自定義腳本,一個(gè)用于安裝gitbook,一個(gè)用于編譯文檔并發(fā)布。

安裝 gitbook 的自定義腳本 step 內(nèi)容

flow_cmd "npm install gitbook-cli -g" --echo --retry --assert

此處的 flow_cmd 是 flow.ci 提供的一個(gè)函數(shù),如果執(zhí)行命令失敗會(huì)進(jìn)行重試

生成靜態(tài)文件 && 部署 的自定義腳本step 內(nèi)容

if [ "$FLOW_GIT_BRANCH" == "gitbook" ]; then # 只部署 gitbook分支
  source get_commits_from_last.sh
  bash -x ./deploy.sh 
fi;

$FLOW_GIT_BRANCH 是一個(gè)環(huán)境變量,用來存儲(chǔ)當(dāng)前的git分支

get_commits_from_last.sh 會(huì)獲取上次發(fā)布的日期以及git commit id

deploy.sh會(huì)調(diào)用gitbook命令編譯markdown文檔,并在首頁head里面添加本次commit id號(hào)以及時(shí)間戳,并發(fā)布到服務(wù)器,腳本會(huì)為文末放出

由于deploy.sh會(huì)將gitbook生成的靜態(tài)文件使用scp的方式copy到服務(wù)器, 所以 服務(wù)器必須添加 rsa key 信任 , rsa-key可以在項(xiàng)目的設(shè)置頁找到,將其添加倒對(duì)應(yīng)user的~/.ssh/authorized_keys中即可

添加郵件通知的step,文檔部署成功后觸發(fā)

Email Sender插件需要三個(gè)參數(shù),分別是郵件接受者、郵件主題、郵件內(nèi)容模板,如下:

總結(jié)

至此,使用 flow.ci 快速發(fā)布文檔的步驟已經(jīng)全部完成。flow.ci 不只是持續(xù)集成,持續(xù)部署的工具,也幫助我們用自動(dòng)化的視角審視手頭繁瑣的工作,將更多的時(shí)間用在新鮮事物上。

有任何疑問發(fā)郵件到 [email protected],分享你的觀點(diǎn):)

附上所有 step 中涉及的腳本:

get_commits_from_last.sh

#!/usr/bin/env bash
# usage: sh get_commits_from_last.sh
# 會(huì)export 2個(gè)環(huán)境變量:
#    DEPLOY_DIFF 與上次部署的時(shí)間差
#    DEPLOY_LOG  與上次部署的變化

set -e

STAGE="docs"
URL="${STAGE}.flow.ci"
HTML=`eval curl -sS ${URL}` # 獲取首頁html

# 從首頁html中提取上次 部署的ID 和 部署時(shí)間
LAST_ID=`echo $HTML | awk "match($0, /-[0-9a-f]{7}/) { print substr( $0, RSTART+1, RLENGTH-1 )}"`
LAST_TIME=`echo $HTML | awk "match($0, /[0-9]{4}-[0-9]{2}-[0-9]{2}T[0-9]{2}:[0-9]{2}:[0-9]{2}/) { print substr( $0, RSTART, RLENGTH )}"`"Z"


FMT="%Y-%m-%dT%H:%M:%SZ"
currDate=`date -u +"$FMT"`

if [[ `uname` == "Darwin" ]]; then
  ts=$(date -j -f "$FMT" "${currDate}" "+%s")
  ts2=$(date -j -f "$FMT" "${LAST_TIME}" "+%s")
else
  ts=$(date --date="${currDate}" +"%s")
  ts2=$(date --date="${LAST_TIME}" +"%s")
fi

(( diff=(ts-ts2)/60 ))

export DEPLOY_DIFF=$diff
echo "Last $1 version : $LAST_ID @ ${LAST_TIME} (${DEPLOY_DIFF} minutes ago)"
echo "-----------------------------------------"
export DEPLOY_LOG=`git log --oneline $LAST_ID..HEAD`
echo "${DEPLOY_LOG}"

deploy.sh

#!/bin/bash

set -e

# VARS
DEPLOY_TIME=`date +%Y%m%d%H%M%S`
REMOTE_DIR="/var/www/flow-doc"
RELEASE_DIR="${REMOTE_DIR}/release"
DEPLOY_DIR="${RELEASE_DIR}/${DEPLOY_TIME}"
LATEST_DIR="${REMOTE_DIR}/latest"

TARGET=prod
USER=deploy # 需添加 rsa key 信任
HOST="此處修改為server的ip"
PORT=22 # ssh端口

# 使用gitbook 生成靜態(tài)文件
gitbook build docs dist

# 獲取當(dāng)前時(shí)間
FMT="%Y-%m-%dT%H:%M:%SZ"
currDate=`date -u +"$FMT"`
if [[ `uname` == "Darwin" ]]; then
  ts=$(date -j -f "$FMT" "${currDate}" "+%s") 
else
  ts=$(date --date="${currDate}" +"%s")
fi

# 獲取當(dāng)前分支
branch=$(git rev-parse --abbrev-ref HEAD)
if [ -n "$FLOW_GIT_BRANCH" ] ; then
  branch=$FLOW_GIT_BRANCH
fi

# 獲取commit log
commit=$(git rev-parse --short HEAD)

# 將本次部署的時(shí)間和COMMIT ID 嵌入倒首頁html中
sed -i "/author/a " ./dist/index.html
sed -i "/author/a " ./dist/index.html

sed -i "s/COMMIT-TAG/${branch}-${commit}/g" ./dist/index.html
sed -i "s/UPDATE-TIME/${currDate}/g" ./dist/index.html

# 開始部署
echo "########## Deploy to ${TARGET} ##########"
ssh ${USER}@${HOST} -p ${PORT} "mkdir -p ${DEPLOY_DIR}"
ssh ${USER}@${HOST} -p ${PORT} "rm -rfv ${LATEST_DIR}"

scp -P ${PORT}  -rv ./dist/* ${USER}@${HOST}:${DEPLOY_DIR}
ssh ${USER}@${HOST} -p ${PORT} bash -x <           
               
                                           
                       
                 

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/39464.html

相關(guān)文章

  • 基于 flow.ci 實(shí)現(xiàn) PHP 項(xiàng)目自動(dòng)化持續(xù)集成

    摘要:在,我們把項(xiàng)目的開發(fā)工作流稱為,每個(gè)由觸發(fā)器和插件構(gòu)成。系統(tǒng)根據(jù)不同的語言和環(huán)境提供對(duì)應(yīng)的模版,觸發(fā)器和插件。圖為跑完整個(gè)持續(xù)集成流程,健康的項(xiàng)目狀態(tài)。 高效程序員的習(xí)慣之一——讓開發(fā)流程自動(dòng)化。Automating shapes smarter future. 這是一個(gè)關(guān)于如何快速實(shí)現(xiàn) PHP 項(xiàng)目自動(dòng)化持續(xù)集成的快速指導(dǎo)。無論你是否使用過持續(xù)集成,或在苦心尋找一款合適的持續(xù)集成工具...

    james 評(píng)論0 收藏0
  • 幾分鐘看完 flow.ci 全部功能

    摘要:正式內(nèi)測(cè)月初,上線,正式進(jìn)入開發(fā)者的視野。公測(cè)注冊(cè)取消邀請(qǐng)碼限制,用戶可直接注冊(cè)使用。支持持續(xù)部署相比持續(xù)集成,持續(xù)部署的工作流程更受關(guān)注。 從 0 到 1,從邀請(qǐng)式內(nèi)測(cè)到收費(fèi)上線,flow.ci 經(jīng)歷了十個(gè)多月的沉淀與打磨。這期間,flow.ci 工程師們奮力趕工,進(jìn)行了一系列的大功能更新,Bug 修復(fù),功能優(yōu)化。 這篇文章記錄了 flow.ci 內(nèi)測(cè)期間的大功能更新和相關(guān)的實(shí)踐教程...

    yuanzhanghu 評(píng)論0 收藏0
  • 新一代 CI 持續(xù)集成工具 flow.ci 正式開源

    摘要:很高興地宣布在協(xié)議下正式開源了。是國內(nèi)首套開源持續(xù)集成解決方案,幫助企業(yè)團(tuán)隊(duì)實(shí)現(xiàn)開發(fā)流程自動(dòng)化,快速持續(xù)交付高質(zhì)量軟件。官方網(wǎng)站開源地址以此,你可以將功能完整的持續(xù)集成服務(wù)部署到內(nèi)網(wǎng)使用。 很高興地宣布 flow.ci 在 Apache-2.0 協(xié)議下正式開源了。flow.ci 是國內(nèi)首套開源持續(xù)集成(CI) 解決方案,幫助企業(yè)團(tuán)隊(duì)實(shí)現(xiàn)開發(fā)流程(build-test-deploy)自動(dòng)...

    endless_road 評(píng)論0 收藏0
  • 新一代 CI 持續(xù)集成工具 flow.ci 正式開源

    摘要:很高興地宣布在協(xié)議下正式開源了。是國內(nèi)首套開源持續(xù)集成解決方案,幫助企業(yè)團(tuán)隊(duì)實(shí)現(xiàn)開發(fā)流程自動(dòng)化,快速持續(xù)交付高質(zhì)量軟件。官方網(wǎng)站開源地址以此,你可以將功能完整的持續(xù)集成服務(wù)部署到內(nèi)網(wǎng)使用。 很高興地宣布 flow.ci 在 Apache-2.0 協(xié)議下正式開源了。flow.ci 是國內(nèi)首套開源持續(xù)集成(CI) 解決方案,幫助企業(yè)團(tuán)隊(duì)實(shí)現(xiàn)開發(fā)流程(build-test-deploy)自動(dòng)...

    jayzou 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<