国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 web前端 js教程 如何使用docker使用node.js

如何使用docker使用node.js

Feb 08, 2025 am 11:49 AM

本教程演示了將docker容器用于node.js應(yīng)用程序的優(yōu)點,并建立了有效的開發(fā)工作流程。

> node.js在服務(wù)器和客戶端端都使用JavaScript來創(chuàng)建快速,可擴展的Web應(yīng)用程序。 盡管您的應(yīng)用程序可能會在開發(fā)機上完美運行,但它在不同的環(huán)境(同事的機器,生產(chǎn)服務(wù)器)上的性能始終如一。 考慮以下這些潛在問題:

  • >>操作系統(tǒng)變化:您的開發(fā)環(huán)境可能是MacOS,而同事使用Windows,而Production Server則運行Linux。
  • node.js版本不一致:您可以使用node.js 20,但其他人則使用各種版本。
  • >依賴關(guān)系差異:數(shù)據(jù)庫和其他依賴關(guān)系在不同的平臺上可能會有所不同或不可用。
  • 安全問題:
  • 在將代碼部署到各種操作系統(tǒng)時可能會出現(xiàn)不可預(yù)見的安全風險。
  • 密鑰益處

跨平臺兼容性:
    docker通過啟用node.js應(yīng)用程序在孤立的容器環(huán)境中運行來解決“它在我的計算機上工作”問題。 Docker中的Simply Node.js App部署:我們將通過創(chuàng)建基本node.js腳本并在Docker容器中執(zhí)行它。>>>>>
  • >>增強node.js開發(fā)工作流程:我們將展示Docker如何簡化Node.js應(yīng)用程序的開發(fā)過程。
  • > docker的解決方案
  • docker有效地解決了上述兼容性挑戰(zhàn)。您無需直接安裝應(yīng)用程序,而是在輕巧的,孤立的虛擬機式環(huán)境中運行,稱為容器。
與模擬整個PC硬件和操作系統(tǒng)的虛擬機不同,Docker仿真了操作系統(tǒng),使您可以直接安裝應(yīng)用程序。 每個基于Linux的容器運行一個應(yīng)用程序并通過虛擬網(wǎng)絡(luò)進行HTTP通信是常見的做法。

優(yōu)點很多:>

一致的環(huán)境:您的Docker設(shè)置鏡像您的生產(chǎn)Linux服務(wù)器,簡化了部署。

How to Use Node.js with Docker 簡化的依賴關(guān)系管理:

在幾分鐘內(nèi)下載,安裝和配置依賴項。

跨平臺一致性:

您的容器化應(yīng)用程序在所有平臺上的行為相同。>
    >
  • 增強的安全性:>如果您的應(yīng)用程序在容器中發(fā)生故障,它不會影響您的主機機器;您可以輕松重新啟動容器。
  • >使用Docker,在本地安裝Node.js或使用NVM(例如NVM)的運行時管理器變得不必要。>

    您的第一個node.js腳本

    >安裝Docker桌面(Windows,MacOS或Linux)。創(chuàng)建一個名為version.js的簡單腳本:

    >
    console.log(`Node.js version: ${process.version}`);

    如果Node.js是本地安裝的,請運行它以查看版本。 現(xiàn)在,在Docker容器中運行(使用最新的LTS Node.js版本)

    $ docker run --rm --name version -v $PWD:/home/node/app -w /home/node/app node:lts-alpine version.js

    (Windows PowerShell)

    > docker run --rm --name version -v ${PWD}:/home/node/app -w /home/node/app node:lts-alpine version.js
    docker下載依賴項可能需要花費一些時間。隨后的運行速度要快得多。 您可以輕松地切換node.js版本(例如,

    )。 該腳本在具有特定node.js版本的Linux容器中執(zhí)行。 node:21-alpine

    命令分解:

    :從圖像啟動一個容器。
    • docker run:終止時卸下容器。
    • --rm:為容器分配一個名稱。
    • >
    • --name version:將當前目錄安裝為容器內(nèi)部的音量。
    • :設(shè)置容器內(nèi)的工作目錄。> -v $PWD:/home/node/app
    • :指定Docker Image(Alpine Linux上的LTS node.js)。
    • -w /home/node/app
    • :執(zhí)行的命令。
    • Docker圖像可在Docker Hub上獲得,提供的各種版本標記了node:lts-alpine,
    • >的標識符。 Alpine Linux是簡單項目的輕量級發(fā)行版。
    • version.js>
    • 運行更復(fù)雜的應(yīng)用程序

    對于具有依賴關(guān)系和構(gòu)建步驟的應(yīng)用程序(使用NPM),必須進行自定義Docker映像。此示例使用express.js::lts-alpine 20-bullseye-slim創(chuàng)建一個名為latest的目錄,add

    > >和

    創(chuàng)建simplepackage.json

    {
      "name": "simple",
      "version": "1.0.0",
      "description": "simple Node.js and Docker example",
      "type": "module",
      "main": "index.js",
      "scripts": {
        "debug": "node --watch --inspect=0.0.0.0:9229 index.js",
        "start": "node index.js"
      },
      "license": "MIT",
      "dependencies": {
        "express": "^4.18.2"
      }
    }
    構(gòu)建圖像:

    index.js>

    運行容器:
    // Express application
    import express from 'express';
    
    // configuration
    const cfg = {
      port: process.env.PORT || 3000
    };
    
    // initialize Express
    const app = express();
    
    // home page route
    app.get('/:name?', (req, res) => {
      res.send(`Hello ${req.params.name || 'World'}!`);
    });
    
    // start server
    app.listen(cfg.port, () => {
      console.log(`server listening at http://localhost:${cfg.port}`);
    });

    > Dockerfile>在

    >。
    # base Node.js LTS image
    FROM node:lts-alpine
    
    # define environment variables
    ENV HOME=/home/node/app
    ENV NODE_ENV=production
    ENV NODE_PORT=3000
    
    # create application folder and assign rights to the node user
    RUN mkdir -p $HOME && chown -R node:node $HOME
    
    # set the working directory
    WORKDIR $HOME
    
    # set the active user
    USER node
    
    # copy package.json from the host
    COPY --chown=node:node package.json $HOME/
    
    # install application modules
    RUN npm install && npm cache clean --force
    
    # copy remaining files
    COPY --chown=node:node . .
    
    # expose port on the host
    EXPOSE $NODE_PORT
    
    # application launch command
    CMD [ "node", "./index.js" ]
    上訪問該應(yīng)用程序

    adocker image build -t simple .文件可以防止不必要的文件被復(fù)制到圖像中。

    >

    改進了Docker組成的開發(fā)工作流程docker run -it --rm --name simple -p 3000:3000 simple

    >

    先前的方法效率低下。 Docker組成提供了更好的解決方案。創(chuàng)建http://localhost:3000/

    .dockerignore

    開始。 更改為觸發(fā)自動重新啟動。 使用VS Code的調(diào)試器(附加到端口9229)進行增強調(diào)試。 停止使用

    >。

    結(jié)論

    docker-compose.yml

    雖然Docker需要初始設(shè)置,但可靠,可分發(fā)代碼的長期收益很重要。 本教程涵蓋了基本面;探索進一步的資源以進行高級使用。 這些圖像是為了簡潔而保留的。

以上是如何使用docker使用node.js的詳細內(nèi)容。更多信息請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權(quán)歸原作者所有,本站不承擔相應(yīng)法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

Java vs. JavaScript:清除混亂 Java vs. JavaScript:清除混亂 Jun 20, 2025 am 12:27 AM

Java和JavaScript是不同的編程語言,各自適用于不同的應(yīng)用場景。Java用于大型企業(yè)和移動應(yīng)用開發(fā),而JavaScript主要用于網(wǎng)頁開發(fā)。

JavaScript評論:簡短說明 JavaScript評論:簡短說明 Jun 19, 2025 am 12:40 AM

JavascriptconcommentsenceenceEncorenceEnterential gransimenting,reading and guidingCodeeXecution.1)單inecommentsareusedforquickexplanations.2)多l(xiāng)inecommentsexplaincomplexlogicorprovideDocumentation.3)

掌握JavaScript評論:綜合指南 掌握JavaScript評論:綜合指南 Jun 14, 2025 am 12:11 AM

評論arecrucialinjavascriptformaintainingclarityclarityandfosteringCollaboration.1)heelpindebugging,登機,andOnderStandingCodeeVolution.2)使用林格forquickexexplanations andmentmentsmmentsmmentsmments andmmentsfordeffordEffordEffordEffordEffordEffordEffordEffordEddeScriptions.3)bestcractices.3)bestcracticesincracticesinclud

JavaScript數(shù)據(jù)類型:深度潛水 JavaScript數(shù)據(jù)類型:深度潛水 Jun 13, 2025 am 12:10 AM

JavaScripthasseveralprimitivedatatypes:Number,String,Boolean,Undefined,Null,Symbol,andBigInt,andnon-primitivetypeslikeObjectandArray.Understandingtheseiscrucialforwritingefficient,bug-freecode:1)Numberusesa64-bitformat,leadingtofloating-pointissuesli

JavaScript與Java:開發(fā)人員的全面比較 JavaScript與Java:開發(fā)人員的全面比較 Jun 20, 2025 am 12:21 AM

JavaScriptIspreferredforredforwebdevelverment,而Javaisbetterforlarge-ScalebackendsystystemsandSandAndRoidApps.1)JavascriptexcelcelsincreatingInteractiveWebexperienceswebexperienceswithitswithitsdynamicnnamicnnamicnnamicnnamicnemicnemicnemicnemicnemicnemicnemicnemicnddommanipulation.2)

如何在JS中與日期和時間合作? 如何在JS中與日期和時間合作? Jul 01, 2025 am 01:27 AM

JavaScript中的日期和時間處理需注意以下幾點:1.創(chuàng)建Date對象有多種方式,推薦使用ISO格式字符串以保證兼容性;2.獲取和設(shè)置時間信息可用get和set方法,注意月份從0開始;3.手動格式化日期需拼接字符串,也可使用第三方庫;4.處理時區(qū)問題建議使用支持時區(qū)的庫,如Luxon。掌握這些要點能有效避免常見錯誤。

JavaScript:探索用于高效編碼的數(shù)據(jù)類型 JavaScript:探索用于高效編碼的數(shù)據(jù)類型 Jun 20, 2025 am 12:46 AM

javascripthassevenfundaMentalDatatypes:數(shù)字,弦,布爾值,未定義,null,object和symbol.1)numberSeadUble-eaduble-ecisionFormat,forwidevaluerangesbutbecautious.2)

為什么要將標簽放在的底部? 為什么要將標簽放在的底部? Jul 02, 2025 am 01:22 AM

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

See all articles