热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Qutrunk具有GUI的开源REST/gRPC接口

I've just open


I've just open sourced our internal project - Qutrunk. It is a simple REST API interface for interacting with queues. It supports multiple backends (RabbitMQ, MongoDB, Redis at the moment), access tokens for each queues, message logs & statistics. The app comes with GUI accessible via webrowser.
Github: https://github.com/spinache/qutrunk-api
Website & SaaS app: https://qutrunk.com

特征 5分钟的设置 PUSH and PULL messages with simple GET & POST 通过Web GUI管理队列 用第一条消息创建队列 多个后端(当前为MongoDB,RabbitMQ,Redis) 多种摄取/消化协议(当前为HTTP(S),gRPC) 队列使用情况统计和审核(消息日志) 具有用于推/拉/创建队列的访问控制的访问令牌 StatsD指标导出 用法示例 您只需使用单个命令即可推送消息

curl --request POST \
--url 'https://app.qutrunk.Com/api/v1/core/push/{QUEUE_NAME}?access_token=ACCESS_TOKEN' \
--data 'hello world'
and pull it with another

curl --request GET --url 'https://app.qutrunk.Com/api/v1/core/pull/{QUEUE_NAME}?access_token={ACCESS_TOKEN}'
More examples in Golang, Node.js, Java, PHP in docs

接收/消化消息的受支持协议 HTTP(S) gRPC 不久:

网络套接字 AMQP 缺少您喜欢的协议? 提出问题以告知我们。

支持的后端 MongoDB 兔子MQ 雷迪斯 不久:

PostgreSQL的 玛丽亚数据库 没有首选的后端? 提交问题以告知我们或编写您自己的集成并创建请求请求。

Installation & configuration 要安装Qutrunk,只需克隆存储库并安装所有必需的依赖项:

git clone Git@github.com:spinache/qutrunk-api.git
cd qutrunk-api;
npm install;
cp config.js.dist config.js;
For in-depth configuration please refer to documentation

跑步 我们建议至少启动两个侦听HTTP请求的Node.js进程。 您可以在也会处理SSL握手的进程之前设置像Nginx这样的反向代理。 有关更多详细信息,请参阅文档。

pm2 start --name=app_3001 app.js -- --port=3001
pm2 start --name=app_3002 app.js -- --port=3002
Hosted version
You can use our hosted version of Qutrunk: https://qutrunk.com/

它带有每月约25,000条消息的少量配额,但适用于任何宠物/小型项目。

If you need a higher quota, please contact us: contact@qutrunk.com

动机 Qutrunk被创建为一种内部工具,用于在数十个内部服务需要队列的情况下进行集成。 我们需要跟踪使用情况并跨所有访问情况进行访问,并使用HTTP与队列进行交互。 另一个原因是物联网,我们使用Qutrunk作为具有HTTP接口的队列提供程序,可以在Raspberry,称为NodeMCU的ESP8266和其他小型开发板上使用。

关于在IoT中使用Qutrunk和C中的示例代码的博客文章

毕竟,我们找不到任何可以使用从GUI管理的多个后端的类似工具。 当然,Qutrunk并不是要成为像Kafka或RabbitMQ这样的项目的竞争者,它更像是为队列提供附加功能的覆盖界面。

当前,我们在3节点集群(每个集群有1个vCPU,2gb RAM,20 GB HDD)上进行单个部署,其中MongoDB作为副本,RabbitMQ具有复制。 每天处理超过1 500 000条消息(约17 msg / s),为我们其他几个内部项目提供队列服务。

Contact: contact@quturnk.com

该项目由Code Fibers创建和维护

from: https://dev.to//spinache/qutrunk-open-source-rest-grpc-interface-with-gui-39il


推荐阅读
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • loader资源模块加载器webpack资源模块加载webpack内部(内部loader)默认只会处理javascript文件,也就是说它会把打包过程中所有遇到的 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Firefox火狐浏览器关闭到http://detectportal.firefox.com的流量问题解决办法
    本文介绍了使用Firefox火狐浏览器时出现关闭到http://detectportal.firefox.com的流量问题,并提供了解决办法。问题的本质是因为火狐默认开启了Captive portal技术,当连接需要认证的WiFi时,火狐会跳出认证界面。通过修改about:config中的network.captive-portal-service.en的值为false,可以解决该问题。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • python中安装并使用redis相关的知识
    本文介绍了在python中安装并使用redis的相关知识,包括redis的数据缓存系统和支持的数据类型,以及在pycharm中安装redis模块和常用的字符串操作。 ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
author-avatar
叶治样
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有