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

nodejs 服务器实现负载均衡

server.js

const express = require('express');
const { createProxyMiddleware } = require('http-proxy-middleware');
const axios = require('axios');const app = express();// 定义后端服务列表
const services = [{ target: 'http://localhost:3001' },{ target: 'http://localhost:3002' }
];// 检查服务存活性
async function isServiceAlive(target) {try {const response = await axios.get(target, { timeout: 2000 });return response.status === 200;} catch (error) {console.error(`Service at ${target} is not alive:`, error.message);return false;}
}// 获取活跃的服务
async function getActiveServices() {const checkPromises = services.map(async (service) => {const isAlive = await isServiceAlive(service.target);return isAlive ? service : null;});const results = await Promise.all(checkPromises);return results.filter(service => service);
}// 使用负载均衡中间件
app.use(async (req, res, next) => {const activeServices = await getActiveServices();if (activeServices.length > 0) {const randomService = activeServices[Math.floor(Math.random() * activeServices.length)];createProxyMiddleware({target: randomService.target,changeOrigin: true,onError: (err, req, res) => {console.error(`Proxy error: ${err.message}`);res.status(502).send('Bad Gateway');}})(req, res, next);} else {res.status(503).send('No available services');}
});// 启动负载均衡服务器
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {console.log(`Load balancer is running on http://localhost:${PORT}`);
});

server1.js

const express = require('express');
const app = express();
const path = require("path")
app.use(express.static(path.join(__dirname, 'public')));const PORT = 3001;
app.listen(PORT, () => {console.log(`Server 1 is running on http://localhost:${PORT}`);
});

 server2.js

const express = require('express');
const app = express();
const path = require("path")
app.use(express.static(path.join(__dirname, 'public')));const PORT = 3002;
app.listen(PORT, () => {console.log(`Server 2 is running on http://localhost:${PORT}`);
});

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

相关文章:

  • 今日总结10.29
  • 使用 FastGPT 工作流实现 AI 赛博算卦,一键生成卦象图
  • vue3+ts实时播放视频,视频分屏
  • 【网页设计】学成在线案例
  • 一篇文章总结 SQL 基础知识点
  • vue Element U 解决表格数据不更新问题
  • PeView 命令行PE文件解析工具
  • 微信小程序25__实现卡片变换
  • 使用Git进行团队协作开发
  • 期货跟单、量化交易模拟演示系统
  • Python小白学习教程从入门到入坑------第十八课 异常模块与包【下】(语法基础)
  • arcgis pro 3.3.1安装教程
  • Spring 获取Cookie/Session
  • 小红书接口数据查询优化指南
  • 数据结构 - 图
  • 如何在Linux系统中管理和优化Swap空间
  • 瑞格智慧心理服务平台 NPreenSMSList.asmx sql注入漏洞复现
  • 大模型是否具备推理能力?解读苹果新论文:GSM-Symbolic和GSM8K
  • 自动化部署-02-jenkins部署微服务
  • HTB:Analytics[WriteUP]
  • 【每日题解】3211. 生成不含相邻零的二进制字符串
  • Nginx、Tomcat等项目部署问题及解决方案详解
  • 【PythonWeb开发】Flask-RESTful参数解析
  • gcc与mingw64版本介绍
  • CSS3新增长度单位
  • 【Spring】创建Spring项目前的配置工作
  • docker 安装部署 nginx
  • 黑马数据库学习笔记
  • MYSQL-SQL-03-DQL(Data Query Language,数据查询语言)(单表查询)
  • 【数据结构和算法】三、动态规划原理讲解与实战演练