筆者搞了一年多微前端項目,一個團隊管理十個微應用,換成docker鏡像部署后,發布操作一下從原來的腳本直連服務器的1分鐘變成了幾十分鐘,尤其上傳每個應用到各自的阿里云倉庫。這里就再寫個腳本一鍵打包docker鏡像并上傳阿里云。
創新互聯公司是一家集網站建設,玄武企業網站建設,玄武品牌網站建設,網站定制,玄武網站建設報價,網絡營銷,網絡優化,玄武網站推廣為一體的創新建站企業,幫助傳統企業提升企業形象加強企業競爭力。可充分滿足這一群體相比中小企業更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們為更多的企業打造出實用型網站。
本文只講怎么制作一個腳本幫助去減輕開發人員負擔,關于docker-compose的配置見:
效果圖直接上代碼/** * @name docker鏡像打包上傳腳本 * @author weilan * @time 2021.02.22 */const fs = require('fs');const path = require('path');const util = require('util');const { log } = require('../utils/log');const exec = util.promisify(require('child_process').exec);const sub_app_ath = path.resolve();let sub_apps = fs.readdirSync(sub_app_ath).filter(i => /^subapp|master/.test(i));const inquirer = require('inquirer'); // 用于命令行交互/** * @name 命令行交互配置項 */const question = [ { type: 'confirm', name: 'dist', message: '是否需要打包前端靜態資源?', }, { type: 'confirm', name: 'env', message: '請選擇是否需要打包成不聯網的內網部署', when: function (answers) { // 當answer為true的時候才會提問當前問題 return answers.dist } }, { type: 'checkbox', name: 'apps', message: '請選擇要發布的模塊', choices: sub_apps, validate: function (val) { if (val.length) { // 校驗 return true; } return "選擇不能為空"; } },]/** * @name 根據命令交互配置結果做邏輯處理 */inquirer.prompt(question).then(async (answer) => { let subApps = answer.apps; let buildScript = answer.env ? 'yarn build --Intranet' : 'yarn build'; let needDist = answer.dist; let now = +new Date(); // 登錄阿里云 const { error: loginError } = await exec('docker login --username=哈哈哈 --password=嘿嘿 registry.cn-zhangjiakou.aliyuncs.com'); if (loginError) { log.red(loginError, '登錄鏡像中心失敗') return; } console.log(`開始依次處理 ${JSON.stringify(subApps)} ......`); subApps.reduce((chain, item) => { return chain.then(() => publishIamge(item, now, needDist, buildScript)) }, Promise.resolve())});/** * @name 打包鏡像并推送阿里云 * @param {String} moduleName 模塊名 * @param {String} now 當前版本時間戳 * @param {Boolean} needDist 是否需要打包前端靜態資源 * @param {String} buildScript 前端靜態資源打包命令 */async function publishIamge(moduleName, now, needDist, buildScript) { // 打包前端靜態資源 if (needDist) { console.log('開始打包前端靜態資源' + moduleName); const { error } = await exec(buildScript, { cwd: path.resolve(moduleName) }); if (error) { log.red(moduleName, '前端代碼打包錯誤:', error) return; } log.green(moduleName + '前端代碼打包成功') } // 打包鏡像 console.log(`開始打包鏡像 ${moduleName} ......`); const { stdout: buildStdout, error: buildError } = await exec('docker-compose build ' + moduleName); if (buildError) { log.red(buildError, '鏡像打包錯誤') return; } log.cyan(buildStdout) log.green('鏡像打包完成,開始制作鏡像標簽') // 更新鏡像標簽 const imageName = 'ibp2fe_' + moduleName; const { error: tagError } = await exec(`docker tag ${imageName} registry.cn-zhangjiakou.aliyuncs.com/futureweb/${imageName}:${now}`); if (tagError) { log.red(tagError, '鏡像標簽異常') return; } log.green('鏡像版本標簽更新完畢,開始更新last標簽') // 更新鏡像標簽last版本 const { error: tagLastError } = await exec(`docker tag ${imageName} registry.cn-zhangjiakou.aliyuncs.com/futureweb/${imageName}`); if (tagLastError) { log.red(tagError, '鏡像last標簽異常') return; } log.green('鏡像last標簽更新完畢,開始上傳') const { stdout: pushStdout, error: pushError } = await exec('docker push registry.cn-zhangjiakou.aliyuncs.com/futureweb/' + imageName); if (pushError) { log.red(pushError, '鏡像上傳失敗') return; } log.cyan(pushStdout) log.green('鏡像上傳成功')}process.on('unhandledRejection', (reason, p) => { console.log('Unhandled Rejection at: Promise', p, 'reason:', reason); // application specific logging, throwing an error, or other logic here});實現思路和注意事項 首先考慮命令行交互的方式,將需要做的配置以選擇的方式讓開發人員確認,最后選擇要發布的模塊 提前登錄阿里云賬號 這里可以選擇并發執行所選全部模塊,但是這樣日志輸出會無序,且電腦壓力極大會暫時死機;因此這里我用依次處理的方式 打包所選模塊的前端靜態資源 執行docker-compose build xxx 打包所選模塊鏡像這里有個需要注意的點,因為是工具函數處理,每個模塊的路徑由node讀取,因此你的模塊名和docker-compose.yml里的服務名、容器名最好都一致;另外注意你的鏡像打包后是你docker-compose.yml外的根目錄下劃線連接你的docker-compose服務名,因此你的阿里云鏡像倉庫命名最好和這個組合后鏡像名一致;以上都是為了方便工具函數能夠通用處理各個模塊鏡像。
制作鏡像標簽。這里我會制作一個本次發布時間戳的版本和一個lastet版本,前面方便回退,后面方便運維部署時無需關心標簽版本。也可以拉取git tag來做鏡像的tag。 制作鏡像后上傳至阿里云鏡像中心
網站標題:使用腳本一鍵打包并上傳docker鏡像的實現代碼
URL鏈接:http://vcdvsql.cn/article42/ihec.html
成都網站建設公司_創新互聯,為您提供網站建設、營銷型網站建設、建站公司、網站導航、ChatGPT、做網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯