Third-party components
FLOWX.AI uses a number of third-party software components:
Open-sourceβ
- Keycloak
- Kafka / ZooKeeper
- Jaeger
- AKHQ
- PostgreSQL
- MongoDB
- Redis
- NGINX
- EFK (Elastic Search, Fluentd, Kibana)
- S3 (MinIO)
- RabbitMQ (for OCR plugin)
Not open-sourceβ
Third-party open-source components supported/tested versionsβ
FLOWX.AI Platform Version | Component name | Supported/tested versions |
---|---|---|
2.3.0 β 2.14 | Keycloak | 18.0.x |
2.3.0 β 2.14 | Kafka / Zookeeper | 2.8.0 (3.5.9) |
2.3.0 β 2.14 | Jaeger | 1.34.1 |
2.3.0 β 2.14 | AKHQ | 0.17.0 |
2.3.0 β 2.14 | PostgreSQL | 14.3.0 |
2.3.0 β 2.14 | MongoDB | 5.0.8 |
2.3.0 β 2.14 | Redis | 6.2.6 |
2.3.0 β 2.14 | NGINX Ingress Controller | 1.2.0 |
2.3.0 β 2.14 | Elasticsearch | 7.17 |
2.3.0 β 2.14 | Fluentd | 3.3.0 |
2.3.0 β 2.14 | Kibana | 7.9.3 |
2.3.0 β 2.14 | S3 (Min.IO) / minio-operator | 2022-05-26T05-48-41Z / 4.5.4 |
2.3.0 β 2.14 | RabbitMQ | 3.11.2 |
Third-party components supported/tested versionsβ
FLOWX.AI Platform version | Component name | Supported/tested versions |
---|---|---|
2.3.0 β 2.14 | OracleDB | 12C / 18-XE |
Summaryβ
Keycloakβ
Keycloak is an open-source software product to allow single sign-on with Identity and Access Management aimed at modern applications and services.
Β»Keycloak documentationKafkaβ
Apache Kafka is an open-source distributed event streaming platform that can handle a high volume of data and enables you to pass messages from one end-point to another.
Kafka is a unified platform for handling all the real-time data feeds. Kafka supports low latency message delivery and gives a guarantee for fault tolerance in the presence of machine failures. It has the ability to handle a large number of diverse consumers.
Kafka is very fast and performs 2 million writes/sec. Kafka persists all data to the disk, which essentially means that all the writes go to the page cache of the OS (RAM). This makes it very efficient to transfer data from a page cache to a network socket.
Β»Intro to KafkaΒ»Kafka documentationZooKeeperβ
ZooKeeper is a centralized service for maintaining configuration information, naming, providing distributed synchronization, and providing group services. All of these kinds of services are used in some form or another by distributed applications.
Β»Zookeeper documentationJaegerβ
Jaeger is a popular open-source distributed tracing tool that is used to monitor and troubleshoot applications based on microservices architecture.
Β»Jaeger documentationAKHQβ
AKHQ is a tool used by FLOWX.AI to manage and display the data inside the Apache Kafka cluster.
Β»AKHQ documentationPostrgreSQLβ
PostgreSQL, also known as Postgres, is a free and open-source relational database management system emphasizing extensibility and SQL compliance.
Β»PostgreSQL documentationMongoDBβ
MongoDB is a source-available cross-platform document-oriented database program. Classified as a NoSQL database program, MongoDB uses JSON-like documents with optional schemas.
Used by FLOWX.AI to store business process data and configuration information on the core/plugin components.
Β»MongoDB documentationRedisβ
Redis is a fast, open-source, in-memory key-value data store that is commonly used as a cache to store frequently accessed data in memory so that applications can be responsive to users.
It delivers sub-millisecond response times enabling millions of requests per second for applications.
It is also be used as a Pub/Sub messaging solution, allowing messages to be passed to channels and for all subscribers to that channel to receive that message. This feature enables information to flow quickly through the platform without using up space in the database as messages are not stored.
It is used by FLOWX.AI for caching the process definitions-related data.
Β»Intro to RedisΒ»Redis documentationNGINXβ
Nginx Is a web server that can also be used as a reverse proxy, load balancer, mail proxy and HTTP cache.
FLOWX utilizes the Nginx engine as a load balancer and for routing the web traffic (API calls) from the SPA (single page application) to the backend service, to the engine, and to various plugins.
The FLOWX.AI Designer SPA will use the backend service to manage the platform via REST calls, will use API calls to manage specific content for the plugins, and will use REST and WebSocket calls to connect to the engine.
Β»Intro to NGINXΒ»NGINX documentationEFK (Kibana, fluentd, Elastic Search)β
Elasticsearch is a distributed, RESTful search and analytics engine capable of addressing a growing number of use cases.
As the heart of the Elastic Stack, it centrally stores your data for lightning-fast search, fineβtuned relevancy, and powerful analytics that scale with ease.
Used by FLOWX.AI in the core component and optionally to allow searching for business process transaction data.
Β»Elastic stack documentationΒ»Fluentd documentationS3 (MinIO)β
FLOWX.AI uses Min.IO as a cloud storage solution.
Β»MIN.IO documentationΒ»Docker available hereRabbitMQβ
RabbitMQ is a messaging broker - an intermediary for messaging. It gives your applications a common platform to send and receive messages, and your messages a safe place to live until received.
Β»RabbitMQ documentationOracle DBβ
Oracle Database is a relational database management system (RDBMS).
Β»Oracle DB documentationSupersetβ
Apache Superset is a business intelligence web application. It helps users to explore and visualize their data, from simple pie charts to detailed dashboards.
Β»Superset