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

NodeJS全栈开发面试题讲解——P7 DevOps 与部署和跨域等

7.1 如何部署 Node.js 项目到生产环境?用过哪些工具?

面试官您好,我部署 Node.js 项目通常分为 构建 → 上传 → 启动服务 三步,常用工具包括 PM2、Nginx、Docker、Git Hooks、CI/CD 工具


🛠️ 主要部署步骤:

  1. 构建前端(如 Next.js/Vue)

    npm run build

  2. 部署后端(NestJS/Express)

    • 生产环境配置 .env.production

    • 安装依赖 npm ci(锁定版本)

    • 启动服务(如使用 PM2)

  3. 通过 Nginx 配置反向代理

    • 实现负载均衡、跨域处理、HTTPS 代理等

  4. 使用 Git + CI 工具部署上线

    • 如 GitHub Actions + Docker/服务器


🧰 工具经验:

工具作用
PM2Node.js 进程管理与守护进程
Nginx反向代理、负载均衡、跨域处理
Docker环境一致性部署
Git Hooks提交/部署自动化
GitHub Actions / GitLab CI持续集成部署


7.2 用过 PM2 吗?它和 cluster 模块有什么不同?

是的,生产环境我常使用 PM2,它底层基于 cluster,但更强大且易用。


🧱 cluster 模块

  • Node.js 内建模块,支持多进程复用 CPU 核心

  • 每个子进程共享同一个端口,通过 IPC 与主进程通信

if (cluster.isMaster) {for (let i = 0; i < cpuCount; i++) cluster.fork();
} else {app.listen(3000);
}

🛡️ PM2 的优势:

功能clusterPM2
多进程支持
日志管理
崩溃自动重启
热重载、部署脚本
状态监控(Web UI)✅(pm2 monit / pm2-plus)

✅ 使用示例:

pm2 start dist/main.js --name my-api -i max
pm2 save
pm2 startup  # 开机自启

7.3 前后端部署在不同域名下时如何处理跨域?

我会从服务端和前端两个层面解决 CORS 问题:


🌍 场景:前端部署在 https://frontend.com,后端是 https://api.backend.com


✅ 后端处理方式(以 Express 为例):

使用 cors 中间件:

app.use(cors({origin: 'https://frontend.com',credentials: true, // 允许携带 cookie
}));

NestJS 中可在 main.ts

app.enableCors({origin: 'https://frontend.com',credentials: true,
});

✅ 前端请求配置(Axios):

axios.get('/api/data', {withCredentials: true // 携带 cookie
});

7.4 如何实现持续集成?你知道哪些 CI 工具?

我配置过 GitHub Actions 来自动执行 构建 → 测试 → 部署 的流程。


CI(Continuous Integration)核心目标:

  • 代码合并自动化检查、测试、打包、部署

  • 减少人为操作错误,提升上线效率


✅ 常用 CI 工具:

工具优点
GitHub Actions原生支持 GitHub,文档全
GitLab CI/CD与 GitLab 深度集成
Jenkins功能强大,可插件化
CircleCI / Travis云平台集成,轻量快速


✅ 示例(GitHub Actions 配置 .github/workflows/deploy.yml):

name: Deploy Node APIon:push:branches: [main]jobs:build:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v2- name: Install depsrun: npm ci- name: Run Testsrun: npm test- name: Deploy via SSHrun: ssh ubuntu@xxx 'cd /app && git pull && pm2 restart my-api'

7.5 如何用 Docker 部署一个全栈项目?

我实际操作过使用 Docker + Docker Compose 一键部署前后端 + DB 环境。


🚢 Docker 部署好处:

  • 环境一致性

  • 一键构建镜像,便于扩展、迁移、CI/CD

  • 可结合 K8s 实现微服务架构


✅ 示例结构(全栈项目):

.
├── docker-compose.yml
├── backend/
│   └── Dockerfile
├── frontend/
│   └── Dockerfile
└── nginx/└── default.conf

✅ docker-compose.yml

version: "3.8"
services:frontend:build: ./frontendports:- "80:80"backend:build: ./backendports:- "3000:3000"environment:- NODE_ENV=productionnginx:image: nginx:latestvolumes:- ./nginx/default.conf:/etc/nginx/conf.d/default.confports:- "8080:80"depends_on:- frontend- backend

✅ 后端 Dockerfile 示例

FROM node:18
WORKDIR /app
COPY . .
RUN npm ci && npm run build
CMD ["node", "dist/main.js"]

✅ 总结一图

编号问题核心回答要点
7.1Node 项目如何部署构建 + 上传 + 启动服务(PM2/Nginx/Docker)
7.2PM2 与 cluster 区别PM2 是 cluster 的增强版,支持守护/日志/UI 等
7.3跨域怎么处理后端加 CORS 中间件,前端配置 withCredentials
7.4持续集成的工具和流程GitHub Actions / GitLab CI / Jenkins,触发构建测试
7.5Docker 部署全栈项目前后端 + DB 容器编排,使用 docker-compose 管理


http://www.lryc.cn/news/2395440.html

相关文章:

  • 中国高分辨率高质量地面CO数据集(2013-2023)
  • GO——内存逃逸分析
  • MinVerse 3D触觉鼠标的技术原理与创新解析
  • Spring Boot整活指南:从Helo World到“真香”定律
  • Python-Selenium报错截图
  • 数论——质数和合数及求质数
  • nc 命令示例
  • 乾元通渠道商中标青海省自然灾害应急能力提升工程基层防灾项目
  • Ubuntu取消开机用户自动登录
  • 用 Spring Boot 静态资源映射 vs 用 Nginx 提供静态文件服务总结
  • openssl-aes-ctr使用openmp加速
  • PHP+MySQL开发语言 在线下单订水送水小程序源码及搭建指南
  • 计算机网络第1章(上):网络组成与三种交换方式全解析
  • Android studio进阶开发(七)---做一个完整的登录系统(前后端连接)
  • 计算机网络第1章(下):网络性能指标与分层模型全面解析
  • 恶意软件清理工具,让Mac电脑安全更简单
  • HackMyVM-Jabita
  • 112 Gbps 及以上串行链路的有效链路均衡
  • Mac 版不能连接华为 GaussDB 吗?我看 Windows 版可以连接?
  • Python-13(永久存储)
  • 《关于有序推动绿电直连发展有关事项的通知》核心内容
  • 数据结构-排序(1)
  • 记录一次session安装应用recyclerview更新数据的bug
  • 大数据-274 Spark MLib - 基础介绍 机器学习算法 剪枝 后剪枝 ID3 C4.5 CART
  • 力扣面试150题--二叉树的锯齿形层序遍历
  • 如何在 CentOS / RHEL 上修改 MySQL 默认数据目录 ?
  • 网页前端开发(基础进阶2)
  • 简历制作要精而不简
  • SPA-RL:通过Stepwise Progress Attribution训练LLM智能体
  • 【深度学习】9. CNN性能提升-轻量化模型专辑:SqueezeNet / MobileNet / ShuffleNet / EfficientNet