node express简单微服务

首先,安装所需的依赖项,可以使用npm或yarn进行安装:

复制代码
$ npm install express axios

接下来,创建一个名为service1.js的文件,用于实现第一个微服务:

javascript 复制代码
const express = require('express');
const axios = require('axios');

const app = express();
const port = 3001;

app.get('/service1', async (req, res) => {
  try {
    // 发起 HTTP 请求到另一个微服务
    const response = await axios.get('http://localhost:3002/service2');

    // 处理响应数据
    const data = response.data;

    // 返回响应给客户端
    res.json({ message: 'Hello from Service 1', data });
  } catch (error) {
    console.error(error);
    res.status(500).json({ error: 'Internal Server Error' });
  }
});

app.listen(port, () => {
  console.log(`Service 1 is running on http://localhost:${port}`);
});

然后,创建一个名为service2.js的文件,用于实现第二个微服务:

javascript 复制代码
const express = require('express');

const app = express();
const port = 3002;

app.get('/service2', (req, res) => {
  // 返回响应给客户端
  res.json({ message: 'Hello from Service 2' });
});

app.listen(port, () => {
  console.log(`Service 2 is running on http://localhost:${port}`);
});

现在,你可以启动这两个微服务,并通过访问http://localhost:3001/service1来测试:

复制代码
$ node service1.js
$ node service2.js

当你访问http://localhost:3001/service1时,Service 1将发起一个HTTP请求到Service 2,并将Service 2的响应返回给客户端。

这只是一个简单的示例,用于演示如何使用Node.js构建微服务。在实际的项目中,你可能需要处理更复杂的业务逻辑、使用数据库进行数据存储、实现身份验证和授权等功能。但这个示例可以作为你开始构建基于Node.js的微服务的起点。

相关推荐
muddjsv8 小时前
Node.js 概览:是什么、能做什么、从业价值与前景分析
node.js
Rain5099 小时前
mini-cc 技术栈:跟着 Claude Code 先选 TypeScript + React + Ink
前端·javascript·react.js·typescript·node.js·ai编程
Rain5099 小时前
架构解密:mini-cc 的核心设计思路
前端·架构·开源·node.js·ai编程
yantuguiguziPGJ10 小时前
WeMed:一个医疗垂直领域大模型 问答系统的 Taro 小程序
typescript·node.js
海上彼尚10 小时前
Nodejs也能写Agent - 9.Mastra篇 - Mastra客户端
开发语言·前端·javascript·人工智能·node.js
TechExplorer3651 天前
npm install 日志目录
前端·npm·node.js
Shirley~~1 天前
npm包发布与 dist-tag 管理指南
前端·npm·node.js
心.c1 天前
CommonJS和ES Module
javascript·后端·node.js
jike88ai2 天前
告别海外账号!OpenClaw+88api一站式配置:Claude/GPT/Gemini本地调用全流程
gpt·node.js·api·claude·openclaw·88api
独泪了无痕2 天前
CryptoJS:数据安全的JavaScript加密利器
前端·vue.js·node.js