Docker部署Nuxt.js項(xiàng)目的實(shí)現(xiàn)
Docker官方文檔: https://docs.docker.com/
Docker 是一個(gè)開源的應(yīng)用容器引擎,讓開發(fā)者可以打包他們的應(yīng)用以及依賴包到一個(gè)可移植的鏡像中,然后發(fā)布到任何流行的 Linux或Windows 機(jī)器上,也可以實(shí)現(xiàn)虛擬化。容器是完全使用沙箱機(jī)制,相互之間不會(huì)有任何接口。
使用 docker 部署 nuxt.js 項(xiàng)目
1、構(gòu)建 node 鏡像
FROM node:alpine
為啥使用 alpine 版本?
相比于其他 Docker 鏡像,它的容量非常小,僅僅只有 5 MB 左右(對(duì)比 Ubuntu 系列鏡像接近 200 MB),且擁有非常友好的包管理機(jī)制。官方鏡像來自 docker-alpine 項(xiàng)目。 目前 Docker 官方已開始推薦使用 Alpine 替代之前的 Ubuntu 做為基礎(chǔ)鏡像環(huán)境。這樣會(huì)帶來多個(gè)好處。包括鏡像下載速度加快,鏡像安全性提高,主機(jī)之間的切換更方便,占用更少磁盤空間等。
2、設(shè)置項(xiàng)目保存目錄
RUN mkdir -p /app/src
3、復(fù)制項(xiàng)目代碼到鏡像
COPY ./src /app/src
4、指定命令執(zhí)行的目錄
WORKDIR /app/src
5、設(shè)置 host
ENV HOST 0.0.0.0
6、執(zhí)行項(xiàng)目安裝及編譯
RUN npm install RUN npm run build RUN npm cache clean --force
7、設(shè)置外部訪問端口
EXPOSE 3000
8、執(zhí)行 nuxt 項(xiàng)目運(yùn)行命令
CMD ["npm", "start"]
完整的 Dockerfile 文件
FROM node:alpine RUN mkdir -p /app/src COPY ./src /app/src WORKDIR /app/src ENV HOST "0.0.0.0" RUN sed -i "s/dl-cdn.alpinelinux.org/${ALPINE_REPOSITORIES}/g" /etc/apk/repositories RUN apk add --no-cache make gcc g++ python RUN npm install RUN npm run build RUN npm cache clean --force RUN apk del make gcc g++ python EXPOSE 3000 CMD ["npm", "start"]
當(dāng)在項(xiàng)目中使用 sass 或者 scss 時(shí),需依賴 python 環(huán)境,所以需要安裝 python,當(dāng)然在編譯相關(guān)資源后,可以刪除相應(yīng)的依賴以減小鏡像體積。
運(yùn)行 Docker
1、構(gòu)建鏡像
docker build -t nuxt-demo
2、啟動(dòng)容器
docker run -dt -p 3000:3000 nuxt-demo
3、訪問
打開瀏覽器,訪問 127.0.0.1:3000
1、可以用 Docker Compose 對(duì)容器進(jìn)行編排,快速的部署多容器應(yīng)用。
2、可以用 nginx 對(duì)容器進(jìn)行代理,避免直接以端口的形式訪問容器。
到此這篇關(guān)于Docker部署Nuxt.js項(xiàng)目的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Docker部署Nuxt.js內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。