在經(jīng)歷了6,7個項目同時開工,頻繁發(fā)布測試 ,不得不學(xué)會一點偷懶的小技巧來提高效率了,所以這篇文章要講的就是如何更加優(yōu)化發(fā)布流程。
工作以來,經(jīng)歷了build后,然后用FileZilla上傳服務(wù)器完成部署。再到前端打包后 ,在build倉庫執(zhí)行g(shù)it push,后端在自動部署。后端的自動部署的確簡化了很多操作,不過對于前端來說 ,每次發(fā)布還需要去build倉庫執(zhí)行push操作,特別是發(fā)布頻繁的時候,難免會減低效率 ,這種重復(fù)操作還是讓腳本來執(zhí)行比較合適。所以接下來就是圍繞如何只需要執(zhí)行npm run build 就完成項目發(fā)布。
(本文所講的都是基于windows系統(tǒng)和node環(huán)境,各個系統(tǒng)的腳本語言可能有所誤差,基本思路不變)
本文分為兩部分,第一部分主要講的是前端的打包發(fā)布的優(yōu)化過程 ,第二部分簡單介紹一下后端的自動部署原理。
一:前端發(fā)布優(yōu)化
首先要明確的是目前大部分前端項目的build過程都是基于node環(huán)境,所以優(yōu)化流程的主要思路就是利用node和操作系統(tǒng)交互,調(diào)用系統(tǒng)腳本完成文件copy和git操作。在這我們要明白在執(zhí)行npm run build 的時候發(fā)生了什么 ,npm run build 只是一個語法糖 ,
在package.json里面可以看到其實是用node 執(zhí)行了build/build.js文件,下面我們就來改寫build文件,為了方便對比,我在這貼一下改寫前后的build文件,改寫前:
改寫后:
我們其實不用全部讀懂build.js里面做了什么 ,我們只需要知道再build成功后在何處執(zhí)行我們的腳本就可以了, 可以很清楚的看到webpack打包后的回調(diào)函數(shù),找到位置后,我們需要引入children_process,關(guān)于這個模塊這里說明兩點:
1.children_process這個模塊提供了衍生子進(jìn)程的功能,熟悉shell操作童鞋可以利用這個模塊做一些有意思的事情,我們這兒主要利用children_process.exec(commad,options,callback), 主要功能就是創(chuàng)建一個shell,然后在shell里執(zhí)行命令。執(zhí)行完成后,將stdout、stderr作為參數(shù)傳入回調(diào)方法。想要詳細(xì)了解到童鞋可以去node文檔看一看
2.就是關(guān)于process.argv , 這個提供了獲取命令行參數(shù)的方法,這個參數(shù)就是在執(zhí)行node命令時后面接的參數(shù) ,比如執(zhí)行 node build.js a b c , 那么process.argv[1]就是build.js ,process.argv[2]就是a,以內(nèi)類推。
知道了這兩點后,我們就可以設(shè)計我們的自定義命令了 , 因為優(yōu)化的目的就是簡化操作 ,所以在build的時候我們接上我們的自定義參數(shù),這關(guān)系到后面我們的腳本編寫,我設(shè)計的命令是 npm run build (push)(commit) (branch) ,這里括號包裹是為了方便表達(dá)這是一個自定義變量,實際是沒有括號的,三個參數(shù)的意思如下:
1.push表示是否打包完直接push到遠(yuǎn)程;
2.commit 表示push到遠(yuǎn)程執(zhí)行git commit -m ‘(提交信息)",的這里的提交的信息;
3,branch表示git push origin (branch)的那條分支 , 意味著是發(fā)布到正式服務(wù)器還是測試服務(wù)器
自定義完參數(shù)后我們在回調(diào)里面利用exec()執(zhí)行我們的腳本
這時候我們編寫我們的腳本了 ,我們新建一個autopush.bat的文件 ,放在我們的根目錄就可以了,腳本內(nèi)容很簡單,大概就是執(zhí)行了復(fù)制粘貼刪除和git操作,腳本如下
cd D:uild est /* 進(jìn)入build的倉庫*/ git checkout %2 /* 切換build倉庫的分支*/ rd /s/q D:uild eststatic /* 刪除build倉庫的static文件夾*/ xcopy D:source estdist D:uild est /E/I/Y /*從源碼倉庫的打包后dist的文件夾拷貝并覆蓋掉build倉庫的文件*/ git add .git commit -m %1 /*提交代碼*/ git push origin %2 /*push到遠(yuǎn)程,后端執(zhí)行自動部署*/ cd D:myFolder31abc_admin
這里說明三點:
1.先執(zhí)行刪除build倉庫的static,在拷貝并覆蓋 , 是因為改動后每次打包后的js文件名都會變動 , 不刪除的話,不會覆蓋重名文件,所以會導(dǎo)致js文件累積;
2.window腳本參數(shù)是通過%1獲得的,例如%1就是獲取第一個參數(shù),%2就是獲取第二個參數(shù),這樣就可以獲取我們在build.js中執(zhí)行腳本的時候傳入的關(guān)于commit和branch的參數(shù)了。
3.關(guān)于刪除和拷貝中參數(shù)的意思 ,
rd /s/q
/S 表示刪除該目錄下所有遍歷的子目錄和文件 /Q 刪除目錄時不提示確認(rèn),直接刪除
xcopy 后面的/E/I/Y
/E 復(fù)制所有子目錄,包括空目錄。 /I 如果“Source”是一個目錄或包含通配符,而“Destination”不存在,“xcopy”會假定“destination”指定目錄名并創(chuàng)建一個新目錄。然后,“xcopy”會將所有指定文件復(fù)制到新目錄中。默認(rèn)情況下,“xcopy”將提示您指定“Destination”是文件還是目錄 /y 禁止提示確認(rèn)要覆蓋已存在的目標(biāo)文件。
通過以上操作我們就可以 ,通過npm run build push fix master 一行命令完成打包到push的操作了, 這個時候后端要是設(shè)置了自動部署的話,那么,就直接上線了。
二:后端自動部署
關(guān)于自動部署的文章,網(wǎng)上已經(jīng)一大把了,在這兒為了配合這篇文章就簡單介紹了自動部署的原理 , 自動部署的關(guān)鍵就在于webhook ,主流的代碼托管平臺都有這個功能,包括coding , github等,在倉庫里可以設(shè)置,以github為例,大概在這個位置
這里可以填寫一個自己服務(wù)器的接口地址和一個seret用于驗證 , 填寫完了倉庫會監(jiān)聽push操作 , 一旦有push操作,webhook就會發(fā)出一個post請求到你設(shè)置的接口,然后在服務(wù)器端執(zhí)行腳本進(jìn)行git pull操作,把最新的代碼拉下來,就完成了部署。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96816.html
摘要:實現(xiàn)輸入一行命令,執(zhí)行兩條指令,分別打包線上生產(chǎn)環(huán)境和線上測試環(huán)境的代碼。這樣配置好之后,只要執(zhí)行,它會自動先執(zhí)行正式環(huán)境構(gòu)建打包,完成之后再自動執(zhí)行測試環(huán)境的構(gòu)建打包,是方便接著再配置自動壓縮,這里就需要使用到一個的插件。 需求 首先介紹一下本項目的背景,是基于 vue-cli3.1.1 的單頁應(yīng)用,目前測試環(huán)境和生產(chǎn)環(huán)境都在線上,并且都在同一個域名下,其中生產(chǎn)環(huán)境部署在根目錄下,測...
摘要:本文將結(jié)合馬蜂窩容器化平臺賦能前端應(yīng)用構(gòu)建的實踐經(jīng)驗,介紹整個平臺背后的設(shè)計和實現(xiàn)原理,取得的一些效果及問題的優(yōu)化方案。如果使用容器化平臺就不會出現(xiàn)這方面的擔(dān)憂。 容器對前端開發(fā)真的有用嗎?答案是肯定的。 最初當(dāng)我向公司的前端同學(xué)「安利」容器技術(shù)的時候,很多人都會說:「容器?這不是用在后端的技術(shù)嗎?我不懂啊,而且前端開發(fā)用不上吧?!?showImg(https://segmentfau...
摘要:本文將結(jié)合馬蜂窩容器化平臺賦能前端應(yīng)用構(gòu)建的實踐經(jīng)驗,介紹整個平臺背后的設(shè)計和實現(xiàn)原理,取得的一些效果及問題的優(yōu)化方案。如果使用容器化平臺就不會出現(xiàn)這方面的擔(dān)憂。 容器對前端開發(fā)真的有用嗎?答案是肯定的。 最初當(dāng)我向公司的前端同學(xué)「安利」容器技術(shù)的時候,很多人都會說:「容器?這不是用在后端的技術(shù)嗎?我不懂啊,而且前端開發(fā)用不上吧。」 showImg(https://segmentfau...
摘要:本文將結(jié)合馬蜂窩容器化平臺賦能前端應(yīng)用構(gòu)建的實踐經(jīng)驗,介紹整個平臺背后的設(shè)計和實現(xiàn)原理,取得的一些效果及問題的優(yōu)化方案。如果使用容器化平臺就不會出現(xiàn)這方面的擔(dān)憂。 容器對前端開發(fā)真的有用嗎?答案是肯定的。 最初當(dāng)我向公司的前端同學(xué)「安利」容器技術(shù)的時候,很多人都會說:「容器?這不是用在后端的技術(shù)嗎?我不懂啊,而且前端開發(fā)用不上吧。」 showImg(https://segmentfau...
摘要:從到再到搭建編寫構(gòu)建一個前端項目選擇現(xiàn)成的項目模板還是自己搭建項目骨架搭建一個前端項目的方式有兩種選擇現(xiàn)成的項目模板自己搭建項目骨架。使用版本控制系統(tǒng)管理源代碼項目搭建好后,需要一個版本控制系統(tǒng)來管理源代碼。 從 0 到 1 再到 100, 搭建、編寫、構(gòu)建一個前端項目 1. 選擇現(xiàn)成的項目模板還是自己搭建項目骨架 搭建一個前端項目的方式有兩種:選擇現(xiàn)成的項目模板、自己搭建項目骨架。 ...
閱讀 3767·2021-11-24 09:39
閱讀 2968·2021-11-16 11:49
閱讀 2087·2019-08-30 13:54
閱讀 1111·2019-08-30 13:03
閱讀 1100·2019-08-30 11:10
閱讀 729·2019-08-29 17:10
閱讀 1255·2019-08-29 15:04
閱讀 1223·2019-08-29 13:02