当前位置: 首页 > Web前端 > vue.js

从零到部署:使用Vue和Express实现迷你全栈电商应用(完结)

时间:2023-03-31 18:32:59 vue.js

鏈枃鐢卞浘闆€绀惧尯鎴愬憳mRc鎾板啓锛屾杩庡姞鍏ュ浘闆€绀惧尯锛屼竴璧峰垱閫犵簿褰╃殑鍏嶈垂鎶€鏈暀绋?缂栫▼琛屼笟鐨勫彂灞曘€傚鏋滄偍瑙夊緱鎴戜滑鐨勬枃杩樹笉閿欙紝璁板緱杩炴寜涓夐亶鐐硅禐+鍏虫敞+璇勮锛岄紦鍔辨垜浠啓鍑烘洿濂界殑鏁欑▼銆傛妸浣犵殑搴旂敤瀹瑰櫒鍖栵紝鐒跺悗鏁欎綘閰嶇疆MongoDB閴存潈鏈哄埗锛岀粰浣犵殑鏁版嵁搴撳姞涓畨鍏ㄥ崼澹紝鏈€鍚庡甫浣犵敤闃块噷浜戠殑瀹瑰櫒闀滃儚鏈嶅姟鎶婃暣涓叏鏍堝簲鐢ㄩ儴缃插埌浜戠锛屾偍Internet涓婄殑鐢ㄦ埛鍙互璁块棶鎮ㄧ殑缃戠珯銆傚笇鏈涙湰鏁欑▼鑳借В鍐冲洶鎵板ぇ瀹跺緢涔呯殑閮ㄧ讲涓婁簯闂锛佹杩庢潵鍒般€婁粠闆跺埌閮ㄧ讲锛氱敤 Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤銆嬬郴鍒楋細銆?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堜竴锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堜簩锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堜笁锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堝洓锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堜簲锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堝叚锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堜竷锛夈€嬨€?浠庨浂鍒伴儴缃诧細鐢?Vue 鍜?Express 瀹炵幇杩蜂綘鍏ㄦ爤鐢靛晢搴旂敤锛堢粓绡囷級銆嬶紙鍗虫湰绡囷級搴旂敤瀹瑰櫒鍖栦笌DockerCompose閰嶇疆棣栧厛锛屽鏋滀綘涓€璺窡鐫€鍓嶉潰涓冪瘒鏁欑▼锛岄偅涔堟妸鏁翠釜Vue鍓嶇椤圭洰鏀惧埌鏂板缓鐨勫湪client鐩綍涓嬶紝灏嗘暣涓狤xpress鍚庣宸ョ▼鏀惧埌鏂板缓鐨剆erver鐩綍涓嬨€傚鏋滀綘鎵撶畻鐩存帴浠庢湰鏂囧紑濮嬪涔犻儴缃诧紝鍙互鐩存帴涓嬭浇鎴戜滑鎻愪緵鐨勪唬鐮侊細gitclone-bdeploy-starthttps://github.com/tuture-dev/vue-online-shop-frontend.git杩欎釜article娑夊強鐨勬簮鐮佹斁鍦℅ithub涓娿€傚鏋滀綘瑙夊緱鎴戜滑鍐欑殑涓嶉敊锛屽笇鏈涗綘鑳界粰杩欑瘒鏂囩珷鐐硅禐+starGithub浠撳簱銆傛垜浠€氳繃涓€寮犲浘姊崇悊涓€涓嬫€濊矾锛氬ぇ瀹跺彲浠ョ湅鍒帮紝鎴戜滑浼氱敤鍒颁笁涓鍣細nginx瀹瑰櫒鍖呮嫭Nginx鏈嶅姟鍣紙瀛樻斁Vue妗嗘灦瀹炵幇鐨勫墠绔潤鎬侀〉闈級锛宎pi瀹瑰櫒鍖呮嫭鎴戜滑鐨凟xpress妗嗘灦.APIserver鐨刣b瀹瑰櫒鏄疢ongoDB鏁版嵁搴撱€傛垜浠€氳繃Nginx鏉ュ疄鐜版暣涓簲鐢ㄧ殑鍙嶅悜浠g悊銆備篃灏辨槸璇达紝鐢ㄦ埛瑕佽闂垜浠殑搴旂敤锛岄鍏堣缁忚繃Nginx銆傝€屼笖鎵€鏈夎幏鍙栧墠绔祫婧愶紙濡侶TML銆丆SS銆丣S绛夐潤鎬佹枃浠惰祫婧愶級鐨勮姹傞兘鍙互鐩存帴鐢盢ginx杩斿洖锛涙墍鏈夎幏鍙朅PI绔偣锛堝/api/v1/products锛夌殑璇锋眰閮戒細杞彂缁橝PI鏈嶅姟鍣紝鐒跺悗灏咥PI鏈嶅姟鍣ㄨ繑鍥炵殑JSON鏁版嵁杩斿洖缁欑敤鎴枫€傝繖绉嶇粡鍏告灦鏋勬湁浠ヤ笅浼樼偣锛氬彲浠ラ€氳繃Nginx瀹炵幇璁块棶鎺у埗锛岃繃婊ゆ帀闈炴硶璇锋眰锛岃В鍐冲墠鍚庣璺ㄥ煙闂锛屽洜涓烘棤璁烘槸鍓嶇椤甸潰杩樻槸鍚庡彴绔疉PI閫氳繃鍚屼竴涓鐐硅闂暣涓簲鐢ㄦ灦鏋勶紝瀵圭敤鎴烽€忔槑锛屽彲鏂逛究閰嶇疆鍜屾墿灞曪紝Nginx鑷甫璐熻浇鍧囪 銆傚墠绔簲鐢ㄥ鍣ㄥ寲棣栧厛锛屾垜浠妸涔嬪墠鐢╒ue瀹屾垚鐨勫墠绔簲鐢ㄥ鍣ㄥ寲銆傝繘鍏lient鐩綍锛岀劧鍚庡皢vue鍓嶇宸ョ▼鏋勫缓鎴愰潤鎬侀〉闈細npmrunbuild#鎴栬€厃arnbuild鐒跺悗娣诲姞client/config/nginx.conf閰嶇疆鏂囦欢锛屼唬鐮佸涓嬶細server{listen80;鏍?www;绱㈠紩index.html锛涘彂閫佹枃浠讹紱鍙戦€佹枃浠舵渶澶у潡1M锛泃cp_nopush涓婏紱gzip_static寮€鍚紱浣嶇疆/api/v1{proxy_passhttp://api:3000;}location/{try_files$uri$uri//index.html;绗竴鏉ocation瑙勫垯锛氬鏋滆闂?api/v1锛岃姹傛€绘槸浼氫紶閫掔粰api瀹瑰櫒銆傚鏋滆闂?锛屼細鐩存帴杩斿洖鍓嶇闈欐€侀〉闈紙index.html锛夛紝閭d箞鎴戜滑闇€瑕佸鍓嶇璁块棶鍚庣鐨勪唬鐮佸仛涓€鐐规敼鍔ㄣ€傛墦寮€client/src/store/actions.js鏂囦欢锛屼慨鏀笰PI_BASE甯搁噺濡備笅锛?/...import{Message}from'element-ui';constAPI_BASE='/api/v1';exportconstproductActions={//...};exportconstmanufacturerActions={//...}缁忚繃杩欐淇敼锛屽墠绔疄闄呰闂殑API渚濊禆浜庡綋鍓嶉〉闈㈢殑URL锛岃€屼笉鏄‖缂栫爜鐨刲ocalhost:3000銆傚仛濂藉噯澶囧伐浣滃悗锛屾垜浠氨瑕佹寮忓紑濮嬪鍣ㄥ寲浜嗐€俆ip濡傛灉浣犱笉鐔熸倝Docker鐨勬牳蹇冩蹇碉紝寤鸿鍘绘垜浠浘瀹㈢ぞ鍖哄涓€娉€婁竴鏉尪鐨勬椂闂达紝涓婃墜 Docker銆嬶紝甯姪浣犲揩閫熸帉鎻¢暅鍍忓拰瀹瑰櫒杩欎袱涓噸瑕佹蹇碉紝鎸囧浣犳妸浣犵殑绗竴涓簲鐢ㄥ鍣ㄥ寲.鍦ㄥ鎴风鐩綍涓嬪垱寤轰竴涓狣ockerfile鏂囦欢锛屼唬鐮佸涓嬶細FROMnginx:1.13#鍒犻櫎Nginx榛樿閰嶇疆RUNrm/etc/nginx/conf.d/default.conf#娣诲姞鑷畾涔塏ginx閰嶇疆COPYconfig/nginx.confconf/etc/nginx/conf.d/#灏嗗墠绔潤鎬佹枃浠跺鍒跺埌瀹瑰櫒鐨?www鐩綍涓婥OPYdist/www鍒涘缓client/.dockerignore鏂囦欢锛岀‘淇濆湪鏋勫缓闀滃儚鏃跺拷鐣ode_modules:containerizedcontainerizednode_modules鍚庣搴旂敤鐨勫墠绔簲鐢ㄤ箣鍚庯紝涓嬩竴姝ュ氨鏄负鍚庣搴旂敤鐨勫鍣ㄥ寲鍋氬噯澶囥€傞鍏堬紝鎴戜滑蹇呴』鏇存敼瑕侀€氳繃鐜鍙橀噺娉ㄥ叆鐨勭‖缂栫爜MongoDB杩炴帴瀛楃涓层€備慨鏀箂erver/app.js鏂囦欢锛屼唬鐮佸涓嬶細//...//viewenginesetupapp.set('views',path.join(__dirname,'views'));app.set('viewengine','ejs');//Datbase杩炴帴杩欓噷mongoose.connect(process.env.MONGO_URI||`mongodb://localhost:27017/test`);//...鐒跺悗鍒涘缓server/Dockerfile锛屼唬鐮佷负濡備笅锛欶ROMnode:10#鎸囧畾宸ヤ綔鐩綍涓?usr/src/app锛屽悗缁墍鏈夊懡浠ら兘鍦ㄨ鐩綍涓嬫搷浣淲ORKDIR/usr/src/app#澶嶅埗package.json鍒板伐浣滅洰褰旵OPYpackage.json.#瀹夎npm渚濊禆RUNnpmconfigsetregistryhttps://registry.npm.taobao.org&&npminstall#澶嶅埗婧愮爜COPY銆?#璁剧疆鐜鍙橀噺ENVNODE_ENV=productionENVMONGO_URI=mongodb://db:27017/testENVHOST=0.0.0.0ENVPORT=3000#寮€鏀?000绔彛EXPOSE3000#璁剧疆闀滃儚杩愯鍛戒护CMD["node","./bin/www"]鍜屽墠绔竴鏍凤紝鍒涘缓涓€涓猻erver/.dockerignore鏂囦欢锛屼繚璇乶ode_modules涓嶄細琚墦鍖呭埌闀滃儚涓細node_modulesDockerComposeConfigureDockerCompose鏄竴涓己澶х殑澶氬鍣ㄧ鐞嗗伐鍏枫€傞€氳繃YAML鏂囦欢閰嶇疆瀹屾垚鍚庯紝鍙渶涓€鏉″懡浠ゅ嵆鍙惎鍔ㄦ墍鏈夊鍣紙鏈嶅姟锛夈€傚湪椤圭洰鏍圭洰褰曚笅鍒涘缓docker-compose.yml锛屼唬鐮佸涓嬶細version:'3'services:db:image:mongorestart:alwaysapi:build:serverrestart:alwaysnginx:build:clientrestart:alwaysports:-8080:80鍙互鐪嬪埌鎴戜滑鍒涘缓浜嗕笁涓湇鍔★紝鍒嗗埆瀵瑰簲鎴戜滑鐨勪笁涓鍣紙db銆乤pi鍜宯ginx锛夛細db鏈嶅姟鎸囧畾闀滃儚涓簃ongo锛岀劧鍚庤缃畆estart:always淇濊瘉api鏈嶅姟鏄洜鏁呭仠姝㈠悗鑷姩閲嶅惎鎸囧畾闀滃儚閫氳繃server鐩綍鏋勫缓锛岀鍙f槧灏勮鍒欎负3000:3000nginx鏈嶅姟鎸囧畾闀滃儚閫氳繃client鐩綍鏋勫缓锛岀鍙f槧灏勮鍒欎负8080:80娉ㄦ剰褰撴寚瀹氬悇涓湇鍔★紝濡傛灉浣跨敤image瀛楁鎸囧畾闀滃儚锛岄偅涔堜細鐩存帴浠庨暅鍍忎粨搴撴媺鍙栭暅鍍忥紝涔熷氨鏄垜浠繖閲岀殑db鏈嶅姟銆傚鏋滀娇鐢╞uild瀛楁鎸囧畾闀滃儚锛屽垯闀滃儚浼氭牴鎹寚瀹氱洰褰曚笅鐨凞ockerfile鏋勫缓銆傛瘮濡傝繖閲屾垜浠寚瀹歴erver鐩綍鍜宑lient鐩綍鍒嗗埆鏋勫缓api鍜宯ginx銆俆ipDockerCompose榛樿涓烘墍鏈夋湇鍔″垱寤轰竴涓狣ocker缃戠粶锛岃瀹瑰櫒涔嬮棿鍙互閫氳繃鏈嶅姟鍙戠幇鏈哄埗锛堣€屼笉鏄€氳繃鍥哄畾IP锛夎繘琛岄€氫俊锛岃繖灏辨槸涓轰粈涔堝彲浠ュ湪Nginx閰嶇疆涓洿鎺ユ寚瀹歨ttp://api:3000锛屽苟灏哅ongoDB杩炴帴瀛楃涓茶缃负mongodb://db:27017/test銆傚鏋滀綘鎯虫繁鍏ヤ簡瑙ocker缃戠粶锛屽彲浠ユ祻瑙堜箣鍓嶇殑甯栧瓙銆婃ⅵ澧冧害鐩搁€氾細鐢?Network 瀹炵幇瀹瑰櫒浜掕仈銆嬨€備竴鍒囧噯澶囧氨缁紝鎴戜滑鍦ㄧ數鍟嗘牴鐩綍涓嬬敤涓€鏉″懡浠ゆ瀯寤哄苟杩愯鏁翠釜搴旂敤锛歞ocker-composeup--build鍒濆鏋勫缓锛堟媺鍙栧熀纭€闀滃儚锛夊彲鑳介渶瑕佸緢闀挎椂闂达紝鎵€浠ヤ綘涓嶅Θ缁欒嚜宸辩偣鏉挅鍟♀槙锔忥紝闈欓潤绛夊緟缁撴灉~濡傛灉鍦ㄦ帶鍒跺彴鐪嬪埌濡備笅杈撳嚭锛岃鏄庨暅鍍忓凡缁忔瀯寤哄畬鎴愶細鐒跺悗姣忎釜闀滃儚閮戒細杈撳嚭鑷繁鐨勬棩蹇椾俊鎭€傛垜浠€氳繃dockerps鍛戒护杩涗竴姝ョ‘璁や笁涓鍣ㄧ殑鐘舵€侊細OK锛屾垜浠彲浠ラ€氳繃localhost:8080璁块棶鎴戜滑鐨勭珯鐐逛簡锛佽€屼笖鎴戜滑涔熼€氳繃鍐呯綉璁块棶鎴戜滑鐨勭綉绔欙紙姣斿鍚屼竴涓猈iFi涓嬬殑鍏朵粬璁惧锛夛紝閫氳繃鏌ヨ鏈満鐨勫唴缃慖P锛堟瘮濡?92.168.1.1锛夛紝鐒跺悗鍦ㄦ墜鏈虹殑娴忚鍣ㄤ腑杈撳叆杩欎釜IP鍦板潃,浣犲彲浠ラ€氳繃192.168.1.1:8080璁块棶銆傚彲浠ュ幓鎼滅储寮曟搸鎵剧瓟妗堟煡璇㈡湰鏈虹殑鍐呯綉IP銆傚皬缁撳湪杩欎竴鑺備腑锛屾垜浠簡瑙e埌锛氶€氳繃Nginx瀹瑰櫒鎻愪緵鍓嶇闈欐€侀〉闈紝灏嗗悗绔姹傝浆鍙戠粰API瀹瑰櫒瀹瑰櫒鍖栫殑鍚庣搴旂敤锛屼笌鏁版嵁搴撳缓绔嬭繛鎺ワ紝鏋勫缓骞跺惎鍔ㄥ簲鐢ㄧ偣鍑婚€氳繃DockerCompose锛岄厤缃甅ongoDB鍦ㄤ箣鍓嶇殑閮ㄧ讲閰嶇疆涓紝瀛樺湪涓€涓噸澶х殑瀹夊叏闅愭偅锛氭垜浠殑MongoDB鏁版嵁搴撴病鏈夐厤缃换浣曡璇佹帾鏂斤紝杩欐剰鍛崇潃浠讳綍鍙互璁块棶鏁版嵁搴撶殑璇锋眰閮藉彲浠ュ鏁版嵁搴撹繘琛屼换浣曟洿鏀癸紒鎺ヤ笅鏉ユ垜浠潵淇MongoDB鐨勯壌鏉冿紝淇濇姢鎴戜滑鐨勬暟鎹畨鍏ㄣ€備慨鏀筂ongoDB杩炴帴璁剧疆棣栧厛锛屾垜浠慨鏀箂erver/app.js涓殑MongoDB杩炴帴璁剧疆锛屼唬鐮佸涓嬶細//...//Datbaseconnectionheremongoose.connect(process.env.MONGO_URI||`mongodb://localhost:27017/test`,{useNewUrlParser:true,useUnifiedTopology:true,user:process.env.MONGO_USER,pass:process.env.MONGO_PASSWORD,});//鍥涗釜閫夐」鐨勫惈涔夊涓嬶細useNewUrlParser:use鏂扮殑MongoDBdriverURLparseruseUnifiedTopology锛氫娇鐢ㄦ柊鐨勮繛鎺ョ鐞嗗紩鎿庯紝鍙互澶уぇ鎻愰珮杩炴帴鐨勭ǔ瀹氭€э紝鏀寔閲嶈繛user锛氳繛鎺ョ敤鎴峰悕锛宨njectpassthroughenvironmentvariable锛氳繛鎺ュ瘑鐮侊紝閫氳繃鐜鍙橀噺灏嗙幆澧冨彉閲忔敞鍏ockerfile鐒跺悗鍦ㄦ湇鍔″櫒/Dockerfile涓坊鍔犺繖浜涚幆澧冨彉閲忥細//...#璁剧疆鐜鍙橀噺ENVNODE_ENV=productionENVMONGO_URI=mongodb://db:27017/adminENVMONGO_USER=mongoadminENVMONGO_PASSWORD=secretENVHOST=0.0.0.0ENVPORT=3000//...娉ㄦ剰鎴戜滑璋冩暣浜哅ONGO_URI锛屽皢鏁版嵁搴搕est璁剧疆涓洪粯璁ょ敓鎴愮殑admin锛岃繖鏄娇鐢╝dmin浣滀负璁よ瘉鏁版嵁搴擄紙AuthenticationDatabase锛夈€傚湪DockerCompose涓厤缃垵濮嬪瘑鐮侊紝鏈€鍚庡湪docker-compose.yml涓坊鍔燿b鏈嶅姟鐨勫垵濮嬪瘑鐮佺幆澧冨彉閲忥細//...db:image:mongorestart:alwaysenvironment:MONGO_INITDB_ROOT_USERNAME:mongoadminMONGO_INITDB_ROOT_PASSWORD:secretapi:build:serverrestart:always//...OK锛屼竾浜嬩勘澶囷紝棣栧厛褰诲簳鍒犻櫎涔嬪墠鍒涘缓鐨勫鍣ㄧ粍锛歞ocker-composedown--volumesdown鍛戒护鐨勬剰鎬濆拰涔嬪墠鐨剈p鍒氬ソ鐩稿弽锛屾墍鏈夌殑闀滃儚up鍒涘缓鐨勫鍣ㄣ€佺綉缁滐紝鎵€鏈夋暟鎹嵎閮借鍒犻櫎锛屾垜浠€氳繃--volumes鍙傛暟鍒犻櫎MongoDB瀹瑰櫒鍒涘缓鐨勬暟鎹嵎銆傛敞鎰忥紝濡傛灉涓嶅垹闄や箣鍓嶇殑MongoDB瀹瑰櫒鐨勬暟鎹嵎锛屼笅娆″垱寤哄甫璁よ瘉鐨凪ongoDB瀹瑰櫒鏃讹紝浼氬鐢ㄤ箣鍓嶇殑鏁版嵁鍗凤紝璺宠繃鍒濆鍖栫敤鎴风殑杩囩▼锛堣繖涓湴鏂逛綔鑰呰俯浜嗗皢杩戜袱涓皬鏃?鍧戯級銆傚鏋滄媴蹇冩暟鎹嵎娌℃湁琚垹闄わ紝鍙互杩愯dockervolumeprune銆傜劧鍚庨噸寤哄苟鍚姩瀹瑰櫒缁勶細docker-composeup--build鐒跺悗鍐嶆妫€鏌ユ垜浠殑搴旂敤绋嬪簭锛堣闂甽ocalhost:8080锛夛紝浣犲簲璇ョ湅鍒颁竴鍒囨甯搞€備笉杩囦竴棰楁偓鐫€鐨勫績缁堜簬鏀句笅浜嗏€斺€旇繖娆℃垜浠殑鏁版嵁搴撲笉鍐嶆槸鈥滆8濂斺€濈姸鎬佷簡锛佹€荤粨鍦ㄦ湰鑺備腑锛屾垜浠粙缁嶄簡濡備綍涓篗ongoDB瀹瑰櫒閰嶇疆韬唤楠岃瘉銆備笉杩囷紝骞冲績鑰岃锛屾垜浠噰鐢ㄧ殑鏂规硶鐩稿綋鍘熷锛屽皢鏈哄瘑淇℃伅浠ユ槑鏂囧舰寮忓啓鍏ヤ唬鐮佹枃浠躲€傚湪澶у瀷瀹瑰櫒缂栨帓绯荤粺锛堝Kubernetes銆丏ockerSwarm锛変腑锛岄泦鎴愪簡瀹屾暣鐨勪紒涓氱骇鏈哄瘑淇℃伅绠$悊鏂规銆傜敱浜庢湰绯诲垪鏁欑▼鐨勪粙缁嶆€ц川锛屾垜浠皢鍒版涓烘銆傚彟澶栵紝鎴戜滑娌℃湁璁插埌MongoDB鏁版嵁搴撳浠藉拰鎭㈠鐨勭粏鑺傘€傚鏋滀綘鎯充簡瑙e拰瀛︿範锛屽彲浠ョ湅鎴戜滑涔嬪墠鐨勩€婃嫆缁濆垹搴撹窇璺紒涓婃墜 Docker 瀹瑰櫒鏁版嵁绠$悊銆嬨€備娇鐢ㄩ暅鍍忎粨搴撴湇鍔″埌姝や负姝紝鍏跺疄鎴戜滑鍙互寰堟柟渚跨殑閮ㄧ讲搴旂敤銆傞€氳繃SSH锛堟垨鍏朵粬鏂瑰紡锛夎繛鎺ュ埌杩滅▼涓绘満鍚庯紝杩愯浠ヤ笅鍛戒护锛?鎶撳彇浠撳簱gitclonehttps://github.com/tuture-dev/vue-online-shop-frontend.gitcdvue-online-shop-frontend#鏋勫缓鍓嶇浠g爜cdclient&&npminstall&&npmrunbuild&&cd..#閫氳繃DockerCompose鍚姩鎵€鏈夊鍣紝杩涘叆daemon鐘舵€佽繍琛宒ocker-composeup-d--build姝ゆ椂锛岄€氳繃杩滅▼涓绘満鐨処P锛堟垨鍩熷悕锛夊姞涓婄鍙e彿锛堣繖閲屾槸8080锛屽綋鐒朵綘鍙互鍦╠ocker-compose.yml涓嚜琛屼慨鏀筺ginx鏈嶅姟鐨勭鍙i厤缃級銆傛瘮濡傛垜浠繙绋嬩富鏈虹殑IP鏄?.2.3.4锛岄偅涔堟垜浠氨鍙互閫氳繃1.2.3.4:8080鏉ヨ闂垜浠殑缃戠珯浜嗭紒鍏跺疄鎴戜滑杩樺彲浠ラ€氳繃涓€绉嶆洿楂樻晥鐨勬柟寮忓垎鍙戦儴缃查暅鍍忊€斺€斾簯闀滃儚浠撳簱鏈嶅姟銆侱ockerHub鍜岄暅鍍忓懡鍚嶈鍒欏疄闄呬笂锛孌ocker宸茬粡鍒涘缓浜嗕竴涓悕涓篋ockerHub鐨勯暅鍍忎粨搴擄紝瀹冩彁渚涗簡涓板瘜鐨勫畼鏂圭淮鎶ら暅鍍忥紝浠ュ強鑷畾涔夐暅鍍忕殑瀛樺偍鍜屽垎鍙戙€傛垜浠钩鏃朵娇鐢ㄧ殑闀滃儚锛堝mongo銆乶ginx銆乶ode绛夛級閮芥槸DockerHub锛堟垨鍏朵粬浠g悊鍔犻€熷櫒锛変笂鐨勫畼鏂归暅鍍忋€傞暅鍍忕殑鍛藉悕瑙勫垯濡備笅锛?registry_name>//鍏朵腑锛歳egistry_name琛ㄧず闀滃儚浠撳簱鐨勫悕绉帮紝鐪佺暐鍒欎负DockerHubusername琛ㄧず闀滃儚浠撳簱鐨勭敤鎴峰悕锛屽拰濡傛灉鍜宺egistry_name涓€璧风渷鐣ワ紝鍒欎负Docker瀹樻柟闀滃儚image_name涓洪暅鍍忓悕绉般€侱ockerHub铏界劧姝e紡鍑哄搧锛屼絾瀹為檯涓婂瓨鍦ㄤ互涓嬮棶棰橈細鍏嶈垂鐢ㄦ埛鏀寔1涓鏈夐暅鍍忎笂浼犳媺閫燂紝鍦ㄥ浗鍐呬笉绋冲畾銆傛病鏈夐暅鍍忓畨鍏ㄦ壂鎻忓姛鑳斤紝鎺ヤ笅鏉ユ垜浠浣撻獙鐨勯樋閲屼簯闀滃儚浠撳簱鏈嶅姟鍙互寰堝ソ鐨勮В鍐充互涓婇棶棰樸€備綋楠岄樋閲岀殑浜戦暅鍍忎粨搴撴湇鍔$敱浜庢煇浜涘師鍥狅紝鏌愬浜戝巶鍟嗙殑鍚嶅瓧鍦ㄨ仛鍏ㄤ腑鏄笉鍏佽鍑虹幇鐨勶紝鎵€浠ヤ笅闈㈢敤闃块噷鐨勪簯鏉ヤ唬鎸囥€傞鍏堬紝鎴戜滑璁块棶闀滃儚浠撳簱鏈嶅姟瀹樼綉锛屽湪浜у搧鍒楄〃涓壘鍒扳€滈暅鍍忎粨搴撴湇鍔♀€濓紝鐐瑰嚮婵€娲汇€傛縺娲诲悗锛岃繘鍏ユ帶鍒跺彴锛屽垱寤洪暅鍍忓懡鍚嶇┖闂达紝濡備笅鍥撅細鍚嶅瓧闅忎究濉紝杩欓噷鎴戜滑濉玽ue-online-shop銆傚垱寤哄畬鎴愬悗濡備笅鍥炬墍绀猴細鍛藉悕绌洪棿鍒涘缓瀹屾垚鍚庯紝鎴戜滑灏卞彲浠ヤ负鎴戜滑搴旂敤鐨勬瘡涓€涓暅鍍忓垱寤哄搴旂殑闀滃儚浠撳簱锛圡ongoDB鏁版嵁搴撻暅鍍忛櫎澶栵級銆傜偣鍑烩€滃垱寤洪暅鍍忎粨搴撯€濇寜閽紝濡備笅鍥撅細Step1锛屽~鍐欓暅鍍忎粨搴撶殑鐩稿叧淇℃伅锛歋tep2锛岄€夋嫨浠g爜婧愶紝杩欓噷鎴戜滑閫夋嫨鈥滄湰鍦颁粨搴撯€濓細鍒涘缓涓や釜闀滃儚浠撳簱锛坅pi鍜宯ginx锛変箣鍚庯紝鍙互鐪嬪埌闀滃儚鍒楄〃濡備笅锛歄K锛岀劧鍚庣偣鍑诲崟涓粨搴撶殑鈥滅鐞嗏€濇寜閽紝鎸夌収鎻愮ず涓婁紶闀滃儚銆傝繖閲岃创鍑虹ず渚嬩唬鐮侊紙瀹為檯鎿嶄綔鏃舵牴鎹嚜宸辨帶鍒跺彴鐨勬彁绀猴級锛?鐧诲綍闃块噷宸村反浜戦暅鍍忎粨搴擄紝灏哸liyunUser淇敼涓鸿嚜宸辩殑璐﹀彿鍚峝ockerlogin--username=aliyunUserregistry.cn-shanghai銆俛liyuncs.com#鏋勫缓骞舵帹閫乤pi闀滃儚dockerbuild-tregistry.cn-shanghai.aliyuncs.com/vue-online-shop/apiserverdockerpushregistry.cn-shanghai.aliyuncs.com/vue-online-shop/api#鏋勫缓骞舵帹閫乶ginx闀滃儚dockerbuild-tregistry.cn-shanghai.aliyuncs.com/vue-online-shop/nginxclientdockerpushregistry.cn-shanghai.aliyuncs.com/vue-online-shop/nginx褰撴彁绀哄疄闄呴儴缃叉椂锛屽缓璁负姣忎釜闀滃儚娣诲姞鏍囩銆傛帹鑽愪娇鐢℅it鎻愪氦鐨刪ash锛屼緥濡傦細dockerbuild-tregistry.cn-shanghai.aliyuncs.com/vue-online-shop/api:9ca500aserver闀滃儚鎺ㄩ€佸畬鎴愬悗锛屾垜浠洿鏀逛簡api鍜宯ginx鏈嶅姟鍦╠ocker-compose.yml涓娇鐢ㄤ簯闀滃儚锛堜笅闈㈡槸鎴戠殑闀滃儚浠撳簱鍦板潃锛岃寰楁敼鎴愪綘鑷繁鐨勶級锛?/...MONGO_INITDB_ROOT_USERNAME:mongoadminMONGO_INITDB_ROOT_PASSWORD:secretapi:image:registry.cn-shanghai.aliyuncs.com/vue-online-shop/apirestart:alwaysnginx:image:registry.cn-shanghai.aliyuncs.com/vue-online-shop/nginxrestart:alwaysports:-8080:80瀹屾垚鍚庯紝鎴戜滑鍙渶瑕佸皢杩欎釜docker-compose.yml鏂囦欢鏀惧埌杩滅▼涓绘満涓婏紝鐒跺悗鍦ㄥ叾鎵€鍦ㄧ洰褰曞惎鍔―ockerCompose瀹瑰櫒缁勫嵆鍙細#鎷夊彇鎵€鏈夐暅鍍忕殑鏈€鏂扮増鏈琩ocker-composepull#鍚姩鎵€鏈夊鍣╠ocker-composeup-d鎬荤粨杩欎竴姝ユ垜浠細鍏堝涔犱簡濡備綍閫氳繃Git鎶撳彇浠g爜鍦ㄨ繙绋嬩富鏈轰笂閮ㄧ讲锛岀劧鍚庡涔犱簡DockerHub鐨勮鍒欏拰闀滃儚鍛藉悕锛屽垎鏋愪簡涓€娉ockerHub鐨勭己闄凤紝鐒跺悗stepbystep甯︿綘浣撻獙浣跨敤闃块噷宸村反浜戦暅鍍忎粨搴撴湇鍔★紝杞绘澗瀹炵幇闀滃儚鐨勫垎鍙戦儴缃层€傚湪鍏釜瀹屾暣鏁欑▼涔嬪悗锛屾垜浠殑杩蜂綘鍏ㄦ爤鐢靛瓙鍟嗗姟绯诲垪涔熷憡涓€娈佃惤銆傝嚜2019骞?2鏈?1鏃ヤ笂鏄犱互鏉ワ紝鍘嗘椂86澶╋紝骞垮彈璇昏€呭枩鐖憋紝鏈変汉瑕佹眰鍥鹃泙绀惧尯璧跺揩鏇存柊锛岀湅瀹屽叏鍓у氨鍙互鍘婚噰璁夸簡锛岃繕鏈変汉鐩存帴鍔犲叆浜嗗浘闆€绀惧尯鐨勫涔犱氦娴佺兢璁ㄨ鎶€鏈€︹€︿笉绠℃€庢牱锛屾垜浠》蹇冨笇鏈涙偍鑳借交鏉炬剦蹇湴瀛︿範鏈郴鍒楁暀绋嬶紝鑾峰緱瀹炵敤鐨勭煡璇嗐€傜粓浜庯紝鎴戜滑鐨勮糠浣犲叏鏍堢數鍟嗙郴鍒楀埌姝ょ粨鏉熷暒馃帀馃帀锛屾劅璋㈠ぇ瀹朵竴璺湅瀹岀殑鍧氭寔鍜屽瀛︿範鐨勭儹鐖别煒橈紒璁╂垜浠湪涓嬩竴绡囨洿绮惧僵鐨勬枃绔犱腑瑙侌煈媬鎯冲涔犳洿澶氱簿褰╁疄鐢ㄧ殑鎶€鏈暀绋嬪悧锛熷揩鏉ュ弬瑙傚浘鍏嬬ぞ鍖恒€傛湰鏂囨秹鍙婄殑婧愮爜鏀惧湪Github涓娿€傚鏋滄偍瑙夊緱鎴戜滑鐨勬枃绗旇繕涓嶉敊锛屽笇鏈涙偍鑳界粰鉂わ笍杩欑瘒鏂囩珷鐐逛釜璧?Github浠撳簱star鉂わ笍