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的微服务的起点。

相关推荐
欧先生^_^4 小时前
Node.js 源码架构详解
架构·node.js
沐土Arvin6 小时前
从零开始认识 Node.js:异步非阻塞的魅力
node.js
TE-茶叶蛋6 小时前
Node.js中的洋葱模型
node.js
Q_Q19632884758 小时前
python的漫画网站管理系统
开发语言·spring boot·python·django·flask·node.js·php
outstanding木槿8 小时前
react中安装依赖时的问题 【集合】
前端·javascript·react.js·node.js
张耘华10 小时前
nosqlbooster pojie NoSQLBooster for MongoDB
node.js
Chris馒头10 小时前
Node打包报错:Error: error:0308010C:digital envelope routines::unsupported
node.js
隐含10 小时前
webpack打包,把png,jpg等文件按照在src目录结构下的存储方式打包出来。解决同一命名的图片资源在打包之后,重复命名的图片就剩下一个图片了。
前端·webpack·node.js
lightYouUp10 小时前
windows系统中下载好node无法使用npm
前端·npm·node.js
Dontla10 小时前
npm cross-env工具包介绍(跨平台环境变量设置工具)
前端·npm·node.js