百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

5 分钟搭建 Node.js 微服务原型(node 微服务架构)

ccwgpt 2025-05-10 20:19 3 浏览 0 评论



微服务已成为在 Node.js 中构建可扩展且强大的云应用的主流方法。同时也存在一些门槛,其中一些难点需要你在以下方面做出决策:

  • 组织项目结构。
  • 将自定义服务连接到第三方服务(数据库,消息代理等)
  • 处理微服务之间共享的代码。
  • 将项目容器化。
  • 在本地运行和调试,然后将其部署到云中。

SMF 框架是开箱即用的解决方案:

https://github.com/krawa76/smf

让我们看看它如何帮你创建和部署微服务原型而 无需编写任何代码。

创建项目

安装框架,创建一个新项目并 cd 到项目目录:

1$ npm install -g sokyra-microservice-factory
2$ smf new test-stack
3$ cd test-stack

带有演示服务的样板代码已生成,我们可以轻松地运行该项目:

1$ smf up

这将生成 Docker工件(docker-compose 和环境变量文件),构建映像并在本地运行容器:

docker-compose 日志

如果在编辑器中打开项目,则会看到带有 main.ts 模块的自动生成的 demo 服务,该服务在上面的日志中生成了记录。其他的重要文件是 smf-stack.json (项目配置), smf-env.json (容器 env 变量),通用的 Dockerfile 和 smf-docker.yml (docker-compose):

演示服务,main 模块

要停止项目,请运行

1$ smf down

添加新服务

让我们添加一项服务,该服务可以通过消息代理发送和接收消息,并将某些内容保存到数据库中:

1$ smf add service service1

选择 RabbitMQ 和 MongoDB ,然后输入 “0” 退出菜单:

这将在 main 模块中创建新的带有样板代码的 service 子文件夹:

让我们再次运行该项目查看其运行情况:

1$ smf up

现在我们有 4 个容器在运行:RabbitMQ、MongoDB、demo 和 service1。后者通过 RabbitMQ 发送接收消息,并将模拟数据保存到 MongoDB:

docker-compose 日志

可以再次使用 smf down 命令停止该项目。

我们可以类似地添加更多服务,如果选择相同的消息代理服务,它们都会通过消息中心交换消息。

部署

将我们的项目部署到安装了 Docker 和 Docker-Compose 的远程服务器上很容易。如果你还没有,请按照以下简单说明在 Amazon AWS EC2 中创建它:

https://github.com/krawa76/smf/blob/master/README-provisioner.md

还需要 Docker Hub 帐户。如果丢失,你可以在这里免费注册:

https://hub.docker.com/

在编辑器中打开 smf-deploy.json 文件,并填写 Docker Hub 登录名及密码、主机地址和远程计算机 SSH 凭据(ssh密钥路径)。

运行以下命令部署项目:

1$ smf deploy

当该过程结束时,我们可以 ssh 到远程机器,并查看在那里运行的微服务:

1$ ssh -i "/Users/me/.ssh/aws-key.pem" ubuntu@ec2-x-x-x-x.compute1.amazonaws.com$ docker ps
2(gives the list of services)$ docker logs -f test-stack-service1
3(give the live log)

现在,我们在云中有了容器化微服务栈的有效原型。

下一步是什么?

开始添加更多逻辑。由于每个服务都是一个单独的NPM软件包,因此我们可以进入到 service 文件夹,安装其他软件包,在 main.ts 模块中编写模式代码,添加新的 JavaScript 模块,等等:

1$ cd services/service1
2$ npm install ...

编码愉快!

最后:更多相关资料私信【Java】就可以免费领取哒


上面都是自己整理好的!我就把资料贡献出来给有需要的人!顺便求一波关注,哈哈~各位小伙伴关注我后私信【Java】就可以免费领取哒

相关推荐

5 分钟搭建 Node.js 微服务原型(node 微服务架构)

微服务已成为在Node.js中构建可扩展且强大的云应用的主流方法。同时也存在一些门槛,其中一些难点需要你在以下方面做出决策:组织项目结构。将自定义服务连接到第三方服务(数据库,消息代理等)处理微服...

当前的前端,真的不配叫程序员吗?

今天看到一个比较令人震惊的帖子,说前端不配叫程序员,令我很吃鲸,是谁我就不说了,帖子出处是一个大龄程序员组里面的,想想也不觉得奇怪了,毕竟对于年龄比较大的程序员来说,前端起步比较晚,最开始就是一个切图...

聊聊asp.net中Web Api的使用(asp.net core web api教程)

扯淡随着app应用的崛起,后端服务开发的也越来越多,除了很多优秀的nodejs框架之外,微软当然也会在这个方面提供更便捷的开发方式。这是微软一贯的作风,如果从开发的便捷性来说的话微软是当之无愧的老大哥...

NodeJS中,listen Access:permission denied解决办法

错误描述:Win10系统,NodeJS程序。使用express框架开发的http服务器,启动时出现错误提示“listenAccess:permissiondenied"。错误原因:这是由于...

Hono — 下一代高性能web框架(天融信下一代vnp)

最近公司可能要有变革,要统计我们的技能。真的是很无语,但是有没有办法。哎,问豆包吧提起Hono大家可能很陌生,这是什么?但是我提到Expressjs、nodejs想必前端小伙伴很熟悉啊。那么Hon...

生活例子说明线程,简单明了(列举一个日常生活中的例子以程序的形式表示)

1.程序设计的目标在我看来单从程序的角度来看,一个好的程序的目标应该是性能与用户体验的平衡。当然一个程序是否能够满足用户的需求暂且不谈,这是业务层面的问题,我们仅仅讨论程序本身。围绕两点来展开,性能...

Node实战006:自定义模块的创建和使用详解

Node的应用是由模块组成的,每个文件的定义都是一个模块(module变量代表当前模块)并有自己的作用域。Node遵循commonjs的模块规范,用来隔离每个模块的作用域,使每一个模块在自身的命名空间...

Node.js基本内容和知识点(node.js的概念)

简单的说Node.js就是运行在服务端的JavaScript,起初段定位是后端开发语言,由于技术的不够成熟,一般小型项目会完全使用node.js作为后台支撑,大项目中,运行不够稳定,不会轻易使用...

干货 | 如何利用Node.js 构建分布式集群

引言在软件定义的世界里,企业通过Web应用和移动应用程序来提供大部分的服务,Node.js迅速成为时下最为流行的一个平台之一,就和它可以搭建响应速度快、易于扩展的web应用和移动应用有很大关系,并凭...

nodejs mongodb 实现简易留言板(node.js留言板)

一个朋友问了一下mongodb的一些操作问题我就做了下面这个简单的留言板给他做一个实例希望能帮助到他express的框架就不说了express的问题请移步nodejs之expressht...

nodejs mqtt 智能售货机系统物联网控制系统源码分享

智能售货机系统(Moleintelligentvendingmachinesystem)是一套物联网控制系统性的解决方案。主要涉及到的语言和库有c,c++,js,nodejs,vue.js,...

为什么 Node.js 这么火,而同样异步模式 Python 框架 Twisted 却十几年一直不温不火?

说nodejs只是靠营销的是否太天真了些?当初nodejs出来的时候各种BUG,我简单的测试其大文件传输都会出现各种问题。而同時期的其他阵营早就甩其几条街了。但是为什么却能一直不断发展壮大?...

2020年14个最有用的NodeJS库(node用什么数据库)

Express快速,简单,极简的节点Web框架对…有好处·易于处理多种类型的请求,例如GET,PUT,POST和DELETE请求·快速构建单页,多页和混合Web应用程序每周下载1100万Lice...

连载:2016年最好的JS框架和库(下)

继续上一期的介绍:Agility.jsAgility.js是专为JS服务的MVC库,你可以免费编写可再用和可维护的浏览器代码,Agility支持Js,样式(CSS)、内容(HTML)和行为(JS)。C...

awesome-nodejs 终极资源库:60K+星标的开发者宝藏

Node.js终极资源库:60K+星标的开发者宝藏引言在GitHub上,有一个备受瞩目的Node.js资源仓库,以其惊人的60.6k星标量和6kfork量,成为了Node.js开发者的必备参考。这个...

取消回复欢迎 发表评论: