- docs
- FlowFuse User Manuals
- Using FlowFuse
- Getting Started
- Static asset service
- FlowFuse Concepts
- Changing the Stack
- Custom Hostnames
- Device Groups
- DevOps Pipelines
- Environment Variables
- FlowFuse Assistant
- FlowFuse File Nodes
- FlowFuse Persistent Context
- FlowFuse Project Nodes
- High Availability mode
- HTTP Access Tokens
- Instance Settings
- Logging
- Shared Team Library
- Snapshots
- Teams
- User Settings
- FlowFuse API
- Migrating a Node-RED project to FlowFuse
- Device Agent
- Device Agent
- FlowFuse Device Agent Introduction
- Quick Start
- Installation
- Quick Start with Web UI
- Register your Device
- Running the Agent
- Deploying your Flows
- Hardware Guides
- FlowFuse Cloud
- FlowFuse Cloud
- FlowFuse Self-Hosted
- Installing FlowFuse
- Overview
- Configuring FlowFuse
- DNS Setup
- Docker install
- Docker from AWS Market Place
- Docker on Digital Ocean
- Add Project Stacks on Docker
- Docker Engine on Windows
- Email configuration
- First Run Setup
- FlowFuse File Storage
- Install FlowFuse on Kubernetes
- Upgrading FlowFuse
- Administering FlowFuse
- Administering FlowFuse
- Configuring Single Sign-On (SSO)
- Licensing
- Monitoring
- Telemetry
- User Management
- Support
- Community Support
- Premium Support
- Debugging Node-RED issues
- Contributing
- Contributing to FlowFuse
- Introduction
- Adding Template Settings
- API Design
- Creating debug stack containers
- Database migrations
- FlowFuse Architecture
- Local Install
- State Flows
- Device Editor
- Invite External Users
- User Login Flows
- Reset Password Flow
- Project Creation
- Instance states
- User Sign up Flow
- Team creation Flow
- Working with Feature Flags
# High Availability mode
High Availability mode allows you to run multiple copies of your Node-RED instance, with incoming work distributed between them.
The following requirements apply:
- FlowFuse 1.8+ running with an EE license and the kubernetes driver
- FlowFuse Cloud
Within FlowFuse Cloud it is currently free to use for all teams, but will become a chargeable feature in a future release.
# Restrictions
- Enabling or disabling HA mode requires a restart of the Instance.
- When in HA mode, two copies of the flows are run.
- Flows cannot be directly modified in an HA Instance; the editor is disabled. A DevOps Pipeline should be created to deploy new flows to the instance.
- Any internal state of the flows is not shared between the HA copies.
- The FlowFuse Persistent Context is not synchronised between the HA copies
- The logs view show combined logs of all copies. An identifier indicates which replica the log message originates from. You have the possibility to filter the messages.
More details of these restrictions are available below.
# Setting up High Availability mode
To make full use of the HA mode you will need two separate Node-RED instances.
The first will be your development instance. This is where you can build and test your flows.
The second will be your HA 'production' instance. This instance will run multiple copies of the flows and get updated from the development instance using a DevOps Pipeline between the two instances.
To enable HA mode on your production instance, open the settings page for your instance and go to the High Availability section. Click the 'Enable HA mode' button and confirm the choice in the dialog.
Once enabled the instance will be restarted to apply the settings. Once enabled, the editor will no longer be available.
# Editing an HA instance
As the editor is disabled for an HA instance the flows cannot be directly modified.
There are two options for updating the flows on an HA instance.
# Disabling HA mode
If you disable HA mode via the setting page, after the instance has been restarted the editor will be available and changes can be made. However, this will mean a period of downtime whilst the instance is brought in and out of HA mode.
# DevOps Pipeline
Create a DevOps pipeline from a 'development' Instance to push updates to your HA instance.
This allows you to free develop your flows in one instance and when you are happy with the results, use the pipeline to push the changes over to the HA instance.
# Building HA-ready flows
Whilst FlowFuse can help run multiple copies of your flows, and provide the necessary load balancing between those copies, it still requires the flows to have been created with HA in mind.
This guide provides some things to consider when building HA-ready flows. We'll continue to expand on this as we gather more feedback from our users.
There are two things to consider - how state is managed and how work is distributed between the copies.
# Managing state
The most well-suited flows for HA are those that do not depend on local state being maintain between individual messages coming into the flow. This is because, in an HA instance, the messages are distributed between the copies - none of them get to see every message.
When state is required, it needs to be stored somewhere that all instances can access it - for example an external database service.
FlowFuse provides a persistent context option - however this includes a local caching layer that means it doesn't fully synchronize between the instances in real time. This is something we'll be working on for a future iteration of the feature, as it will require some changes in Node-RED to unlock its full potential.
There is also the state that is implicitly maintained within the nodes of a flow. For example, the Smooth node can be used to calculate a running average value of messages passing through it. The node does that by keeping in memory the recent values so it can recalculate the average with each update. In an HA instance, the node will only be calculating the average for the messages it sees.
# Routing work
When HA is enabled, all HTTP traffic directed at the instance will be load-balanced between the copies automatically.
It gets a little more complicated where flows connect out to external systems to pull in work - for example, when using MQTT.
MQTT includes a feature called Shared Subscriptions that allows a broker to distribute messages between a group of subscribers. This provides the load balancing needed for an HA instance - but the flow must be configured to use the appropriate shared subscription topics, as well as to not set a ClientID on the connection to avoid conflicts between the connections.
The Project Nodes have been updated to support shared subscriptions automatically when running in HA mode.
There are lots of other nodes that can be used to trigger flows, whether by listening for events on an API, connecting to locally attached hardware and many things in between. Typically, those that are more cloud-aligned, such as messaging systems like Kafka and AMQP will have very well established ways of doing load balancing.