Skip to main content

Migrating to v6

In this chapter we help to migrate from Centrifugo v5 to Centrifugo v6.

Migrating server configuration

Server configuration refactoring was the main focus of Centrifugo v6 development, and below we concentrate on helping you with the process of adopting the new configuration layout in your application.

Configuration file converter

The number of changes in configuration is too big to describe, so to help you with the migration process of configuration file we provide a configuration converter tool.

Paste the JSON config of Centrifugo v5 in the textarea below – and you will get the JSON config for Centrifugo v6.

caution

Do not blindly deploy things to production – test your system first, go through the possible usage scenarios, run test cases. The converter is best-effort and does not cover some configuration cases.

tip

If you are using TOML or YAML configuration formats – you can transform them to JSON using some third-party converters, then put JSON here, then convert the new configuration back to YAML or TOML.

There are many online converters. For example, convert YAML to JSON or TOML to JSON.

tip

This converter is fully client-side: your data won't be sent anywhere.

Here will be configuration for v6
Here will be log of changes made in your config

Environment variable converter

In addition to configuration file converter we are trying to help migrating environment configuration using the converter below. The converter is also just a best-effort (it can convert things only partly for you, please follow the new docs and do tests), fully client-side.

Insert environment configuration in a format:

CENTRIFUGO_OPTION1="value"
CENTRIFUGO_OPTION2="value"
Here will be configuration for v6
Here will be log of changes made in your config

Alternative way to get environment vars

One alternative way to get environment variables in Centrifugo v6 is to use new defaultenv configuration command and use config file as a base.

In this case, you follow Centrifugo v6 docs which contains many config examples, create config.json file, and then you can run defaultenv command with --base and --base-non-zero-only options to only output environment variables for values which were non zero in base config file. For example, let's say you have Centrifugo v6 configuration:

config.json
{
"client": {
"allowed_origins": ["http://localhost:8000"]
},
"engine": {
"type": "redis",
"redis": {
"address": "redis://localhost:6379"
}
}
}

Running:

centrifugo defaultenv --base config.json --base-non-zero-only

Will output only variables set in config file:

CENTRIFUGO_CLIENT_ALLOWED_ORIGINS="http://localhost:8000"
CENTRIFUGO_ENGINE_REDIS_ADDRESS="redis://localhost:6379"
CENTRIFUGO_ENGINE_TYPE="redis"

SockJS transport migration

Deprecated SockJS transport was removed in Centrifugo v6, you need to switch to supported transports. Note, Centrifugo also provides its own WebSocket emulation layer (which is more effective than SockJS and natively supported by our Javascript SDK without third-party requirements) – so you still have an option for automatic WebSocket fallback with Centrifugo.

To enable Centrifugo built-in bidirectional emulation you need to enable HTTP streaming or SSE transports in server configuration, then configure centrifuge-js to use those as described here:

const transports = [
{
transport: 'websocket',
endpoint: 'ws://localhost:8000/connection/websocket'
},
{
transport: 'http_stream',
endpoint: 'http://localhost:8000/connection/http_stream'
},
{
transport: 'sse',
endpoint: 'http://localhost:8000/connection/sse'
}
];
const centrifuge = new Centrifuge(transports);
centrifuge.connect()

Tarantool engine migration

Tarantool experimental engine was removed in Centrifugo v6, so you need to migrate to supported engines described in Engines and Scalability doc, i.e. choose from:

  • In memory Engine – ultrafast, but keeps data in Centrifugo process memory so publication history is lost on restart. And only one Centrifugo node can be used.
  • Redis Engine (Redis-compatible storages are supported also) - allows scaling Centrifugo nodes, data is kept in Redis so survives Centrifugo restarts.
  • Nats broker (supports at most once PUB/SUB, but does not support history/recovery features of Centrifugo).