以 Serverfull 方式运行无服务器服务

news/2024/5/20 8:17:50 标签: serverless, 云原生, docker

当前 IT 架构中最流行的用例是从 Serverfull 转向 Serverless 设计。在某些情况下,我们可能需要以 Serverfull 方式设计服务或迁移到 Serverfull 作为运营成本的一部分。

在本文中,我们将展示如何将 Kumologica flow 作为 Docker 容器运行。通常,在 Kumologica 上构建的应用程序专注于无服务器计算,例如 AWS Lambda、Azure 函数或 Google 函数,但在这里我们将构建与在容器内运行的 NodeJS Express 应用程序非常相似的服务。

计划

我们将使用低代码集成工具构建一个简单的 hello world API 服务并将其包装为 docker 镜像。然后,我们将使用本地计算机中的映像运行 docker 容器。然后使用外部客户端测试 API。

先决条件

要开始开发,我们需要准备好以下实用程序和访问权限。

1.NodeJS安装

2. Kumologica Designer

3.安装Docker

执行

创建服务

首先,我们通过打开设计器来开始Hello World服务的开发。要打开设计器,请使用以下命令kl open。

打开设计器后,将EvenListener 节点拖放到画布上。单击打开配置并提供以下详细信息。

Provider : NodeJSVerb : GETPath : /helloDisplay Name : [GET] /hello

图片

现在将记录器 节点从托盘拖放到画布上,并将其连接到 EventListener 节点之后。

Display name : Log_Entrylevel : INFOMessage : Inside the serviceLog Format : String

图片

将EventListenerEnd 节点拖放到画布上,将其连接到 Logger 节点并提供以下配置。​​​​​​​

Display Name : SuccessPayload : {"status" : "HelloWorld"}ContentType : application/json

图片

该流程现已完成。让我们将其docker化。

Docker化流程

要对流程进行 docker 化,请打开项目文件夹,并将以下Docker 文件放置在根项目文件夹中(与 package.json 处于同一级别)。​​​​​​​

FROM node:16-alpine WORKDIR /app COPY package*.json ./ RUN npm install ENV PATH /app/node_modules/.bin:$PATH COPY . . EXPOSE 1880CMD ["node","index.js"]

注意:上面的Dockerfile是非常基本的,可以根据您的需要进行修改。

现在我们需要添加另一个文件,将 Kumologica 流视为 NodeJS Express 应用程序运行。

使用以下 Javascript 内容创建一个index.js文件。将“your-flow.json”替换为项目文件夹中 flow.json 的名称。​​​​​​​

const { NodeJsFlowBuilder } = require('@kumologica/runtime');new NodeJsFlowBuilder('your-flow.json').listen();

现在,我们通过从Postman或您选择的任何 REST 客户端调用端点来在本地测试流程。

curl http://localhost:1880/hello

您将收到以下回复:

{"status" : "HelloWorld"} 

当我们完成本地测试后,现在我们将基于 Docker 文件构建一个镜像。

要构建映像,请转到项目文件夹的根目录,然后从 Windows 中的命令行或 Mac 中的终端运行以下命令。

docker build . -t hello-kl-docker-app

现在,案卷图像已构建。让我们通过运行以下命令在本地检查图像。

docker images

让我们通过执行以下命令来测试本地运行图像的图像。

docker images

通过运行以下命令检查容器

docker ps -a

您现在应该会看到列出的容器名称和 ID。现在我们已准备好将映像推送到您选择的任何注册表。


作者:Pranav K

更多技术干货请关注公号【云原生数据库

squids.cn,云数据库RDS,迁移工具DBMotion,云备份DBTwin等数据库生态工具。

irds.cn,多数据库管理平台(私有云)。


http://www.niftyadmin.cn/n/5308301.html

相关文章

SpringBoot-Redis

依赖 <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId>配置 # 服务器连接端口 spring.redis.port6379 # 服务器地址 spring.redis.host127.0.0.1 # 数据库索引&#xff08;默认为0&#xff09…

QT c++和qml交互实例

文章目录 一、demo效果图二、c和qml交互的基本方式1、qml访问C类对象 三、关键代码1、工程结构图2、c代码MainWindow.cppMainQuickView.cppStudentInfoView.cppStudentInfoModel.cpp 3、qml代码main.qmlMainQuickTopRect.qmlMainQuickMiddleRect.qmlMainQuickMiddleTableRect.q…

netcore html to pdf

一、新建项目&#xff1a;QuestPDFDemo <PackageReference Include"NReco.PdfGenerator" Version"1.2.1" /> 二、上代码 using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging;using QuestPDFDemo.Models; using System; using Sys…

AI与5G、IDC等成为数字经济的重要基础设施

AI与5G、IDC等已经成为数字经济的重要基础设施&#xff0c;它们的影响和作用不容忽视。随着技术的迅速发展&#xff0c;AI在各行各业都得到了广泛应用&#xff0c;并成为数字经济的核心驱动力之一。 首先&#xff0c;AI的兴起为数字经济带来了巨大的机遇。AI技术可以帮助企业从…

Flink的检查点算法

Flink的恢复机制基于应用状态的一致检查点。在有状态的流应用中&#xff0c;一个一致性检查点是&#xff1a;在所有tasks处理了一个&#xff08;相同的&#xff09;输入后&#xff0c;当前时间点每个task的state副本。 在为application做一个一致性检查点时&#xff0c;一个基…

C语言基础知识(6):UDP网络编程

UDP 是不具有可靠性的数据报协议。细微的处理它会交给上层的应用去完成。在 UDP 的情况下&#xff0c;虽然可以确保发送消息的大小&#xff0c;却不能保证消息一定会到达。因此&#xff0c;应用有时会根据自己的需要进行重发处理。 1.UDP协议的主要特点&#xff1a; &#xf…

Zookeeper三节点搭建

一、安装前准备 安装JDK&#xff08;之前已经安装了&#xff09; 拷贝apache-zookeeper-3.5.7-bin.tar.gz安装包到Linux系统下 解压到指定目录 在/opt/module/zookeeper-3.5.7/这个目录下创建zkData&#xff0c;在/opt/module/zookeeper-3.5.7/zkData目录下创建一个myid的…

[设计模式 Go实现] 结构型~装饰模式

装饰模式使用对象组合的方式动态改变或增加对象行为。 Go语言借助于匿名组合和非入侵式接口可以很方便实现装饰模式。 使用匿名组合&#xff0c;在装饰器中不必显式定义转调原对象方法。 decorator.go package decoratortype Component interface {Calc() int }type Concre…