当前位置: 首页 > news >正文

金华网站建设电话北湖区网站建设公司哪家好

金华网站建设电话,北湖区网站建设公司哪家好,营销型单页网站,大连优化排名推广Node.js 语言特定指南 本 Node.js 语言特定指南将教您如何使用 Docker 容器化 Node.js 应用程序。在本指南中,您将学习如何: 容器化并运行一个 Node.js 应用程序设置一个本地环境以使用容器开发 Node.js 应用程序使用容器为 Node.js 应用程序运行测试使…

Node.js 语言特定指南

本 Node.js 语言特定指南将教您如何使用 Docker 容器化 Node.js 应用程序。在本指南中,您将学习如何:

  • 容器化并运行一个 Node.js 应用程序
  • 设置一个本地环境以使用容器开发 Node.js 应用程序
  • 使用容器为 Node.js 应用程序运行测试
  • 使用 GitHub Actions 配置一个用于容器化 Node.js 应用程序的 CI/CD 流水线
  • 将容器化的 Node.js 应用程序部署到本地 Kubernetes 以测试和调试您的部署

首先,从容器化一个现有的 Node.js 应用程序开始。

容器化并运行 Node.js 应用程序

1. 准备现有的 Node.js 应用程序

确保您的项目结构类似于以下内容:

my-node-app/
├── node_modules/
├── public/
├── src/
├── views/
├── .gitignore
├── package.json
└── server.js

2. 创建 Dockerfile

在项目根目录下创建一个名为 Dockerfile 的文件,并添加以下内容:

# 使用官方 Node.js 镜像作为基础镜像
FROM node:14# 设置工作目录
WORKDIR /usr/src/app# 复制 package.json 和 package-lock.json
COPY package*.json ./# 安装依赖
RUN npm install# 复制应用源代码
COPY . .# 暴露应用端口
EXPOSE 3000# 定义运行容器时的启动命令
CMD ["node", "server.js"]

3. 构建 Docker 镜像

在项目根目录下运行以下命令以构建 Docker 镜像:

docker build -t my-node-app .

4. 运行容器

使用以下命令运行容器:

docker run -d -p 3000:3000 my-node-app

现在,您可以通过浏览器访问 http://localhost:3000 来查看您的应用程序。

设置本地开发环境

使用 Docker 容器来设置本地开发环境有助于确保开发环境与生产环境一致。

1. 创建 docker-compose.yml 文件

在项目根目录下创建一个名为 docker-compose.yml 的文件,并添加以下内容:

version: '3.8'
services:app:image: node:14working_dir: /usr/src/appvolumes:- .:/usr/src/app- /usr/src/app/node_modulesports:- "3000:3000"command: npm start

2. 运行 Docker Compose

在项目根目录下运行以下命令启动开发环境:

docker-compose up

现在,您的应用程序将在 http://localhost:3000 上运行,您可以进行开发并实时查看更改。

使用容器运行测试

1. 安装测试依赖

确保在 package.json 中添加必要的测试依赖,例如:

"devDependencies": {"mocha": "^8.3.2","chai": "^4.3.4"
}

2. 创建测试脚本

在项目中创建一个测试目录和测试脚本,例如 test/test.js

const { expect } = require('chai');describe('Sample Test', () => {it('should return true', () => {expect(true).to.be.true;});
});

3. 更新 Dockerfile

更新 Dockerfile 以安装开发依赖:

# 使用官方 Node.js 镜像作为基础镜像
FROM node:14# 设置工作目录
WORKDIR /usr/src/app# 复制 package.json 和 package-lock.json
COPY package*.json ./# 安装依赖,包括开发依赖
RUN npm install# 复制应用源代码
COPY . .# 暴露应用端口
EXPOSE 3000# 定义运行容器时的启动命令
CMD ["npm", "test"]

4. 构建测试镜像并运行测试

在项目根目录下运行以下命令构建测试镜像并运行测试:

docker build -t my-node-app-test .
docker run my-node-app-test

配置 CI/CD 流水线

使用 GitHub Actions 配置 CI/CD 流水线以自动化测试和部署过程。

1. 创建 GitHub Actions 工作流文件

在项目根目录下创建 .github/workflows/ci.yml 并添加以下内容:

name: CI/CD Pipelineon:push:branches:- mainpull_request:branches:- mainjobs:build:runs-on: ubuntu-lateststeps:- name: Checkout codeuses: actions/checkout@v2- name: Set up Node.jsuses: actions/setup-node@v2with:node-version: '14'- name: Install dependenciesrun: npm install- name: Run testsrun: npm test- name: Build Docker imagerun: docker build -t my-node-app .- name: Push Docker imageenv:DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}run: |echo $DOCKER_PASSWORD | docker login -u $DOCKER_USERNAME --password-stdindocker tag my-node-app $DOCKER_USERNAME/my-node-app:latestdocker push $DOCKER_USERNAME/my-node-app:latest

确保在 GitHub 仓库中添加 Docker Hub 凭据作为秘密(secrets)。

部署到 Kubernetes

使用 Kubernetes 部署和管理容器化的 Node.js 应用程序。

1. 创建 Kubernetes 部署文件

在项目根目录下创建 k8s/deployment.yml 并添加以下内容:

apiVersion: apps/v1
kind: Deployment
metadata:name: my-node-app
spec:replicas: 3selector:matchLabels:app: my-node-apptemplate:metadata:labels:app: my-node-appspec:containers:- name: my-node-appimage: <DOCKER_USERNAME>/my-node-app:latestports:- containerPort: 3000
---
apiVersion: v1
kind: Service
metadata:name: my-node-app-service
spec:type: NodePortselector:app: my-node-appports:- port: 3000targetPort: 3000nodePort: 30001

2. 部署到 Kubernetes

使用 kubectl 命令将应用程序部署到 Kubernetes 集群:

kubectl apply -f k8s/deployment.yml

您可以通过访问 http://<NODE_IP>:30001 查看应用程序。

通过上述步骤,您已经学会了如何容器化并运行一个 Node.js 应用程序,设置本地开发环境,使用容器运行测试,配置 CI/CD 流水线,并将应用程序部署到 Kubernetes。

http://www.yayakq.cn/news/118399/

相关文章:

  • 台州网站建设优化案例河北做网站找谁
  • 外贸推广网站哪家网络营销策略的制定
  • 深圳做网站的公司哪家最好wordpress 主题viewpoint
  • 如何让百度搜索到自己的网站东莞新闻最新消息今天
  • 有创意的婚纱网站模板下载wordpress主题模板收费会员系统
  • 个人搭建网站互联网装修公司加盟
  • 个人可以建设哪些网站中牟网站建设
  • 南充市住房与城乡建设网站网站的备案流程
  • 网站js特效番禺人才网招聿
  • 广西网站建设路网络游戏推广平台
  • 成都网站内容策划关键词优化排名系统
  • 富阳网站公司江津网站建设效果好不好
  • dw做网站字体 别人电脑显示怎么做域名网站
  • 网站备案全国合作拍照点 腾讯云宜春网站建设公司哪家好
  • 做网站先学美工廊坊关键词排名推广
  • html网站建设新手用什么框架做网站比较好
  • 网站建设制作公司知道万维科技长沙企业建网站费用
  • jsp网站开发存在的问题WordPress切换中英文
  • 淮南网站建设全包大连网页网站制作
  • 怎样做才能提升自己的网站微信公众号官网登录
  • 网站建设的好处危机公关处理
  • 十堰网站建设有哪些公司网站开发文档撰写模板
  • 备案网站名称怎么写个人网页制作自我介绍源代码
  • 网站建设源代码怎么搭建wordpress插件 标签页
  • 国外前端 网站设计公司logo大概需要多少钱
  • 七台河建网站百度网站提交收录
  • 博客网站开发教程一级a做爰片就在线手机看韩国网站
  • 做公寓酒店跟网站合作有什么技巧织梦怎么更新网站html
  • 个人可以网站备案吗猎聘招聘官方网站
  • seo网站怎么做做相册的网站 ppt