Managing Brokers

Important

This page only shows some frequently used operations.

  • For the latest and complete information about Pulsar admin, including commands, flags, descriptions, and more information, see Pulsar admin doc.

  • For the latest and complete information about REST API, including parameters, responses, samples, and more, see REST API doc.

  • For the latest and complete information about Java admin API, including classes, methods, descriptions, and more, see Java admin API doc.

Pulsar brokers consist of two components:

  1. An HTTP server exposing a REST interface administration and topic lookup.
  2. A dispatcher that handles all Pulsar message transfers.

Brokers can be managed via:

  • The brokers command of the pulsar-admin tool
  • The /admin/v2/brokers endpoint of the admin REST API
  • The brokers method of the PulsarAdmin object in the Java API

In addition to being configurable when you start them up, brokers can also be dynamically configured.

See the Configuration page for a full listing of broker-specific configuration parameters.

Brokers resources

List active brokers

Fetch all available active brokers that are serving traffic.

  • pulsar-admin
  • REST API
  • JAVA
  1. $ pulsar-admin brokers list use
  1. broker1.use.org.com:8080

GET /admin/v2/brokers/:cluster

  1. admin.brokers().getActiveBrokers(clusterName)

Get the information of the leader broker

Fetch the information of the leader broker, for example, the service url.

  • pulsar-admin
  • REST API
  • JAVA
  1. $ pulsar-admin brokers leader-broker
  1. BrokerInfo(serviceUrl=broker1.use.org.com:8080)

GET /admin/v2/brokers/leaderBroker?version=2.10.0

  1. admin.brokers().getLeaderBroker()

For the detail of the code above, see here

list of namespaces owned by a given broker

It finds all namespaces which are owned and served by a given broker.

  • pulsar-admin
  • REST API
  • JAVA
  1. $ pulsar-admin brokers namespaces use \
  2. --url broker1.use.org.com:8080
  1. {
  2. "my-property/use/my-ns/0x00000000_0xffffffff": {
  3. "broker_assignment": "shared",
  4. "is_controlled": false,
  5. "is_active": true
  6. }
  7. }

GET /admin/v2/brokers/:cluster/:broker/ownedNamespaces

  1. admin.brokers().getOwnedNamespaces(cluster,brokerUrl);

Dynamic broker configuration

One way to configure a Pulsar broker is to supply a configuration when the broker is started up.

But since all broker configuration in Pulsar is stored in ZooKeeper, configuration values can also be dynamically updated while the broker is running. When you update broker configuration dynamically, ZooKeeper will notify the broker of the change and the broker will then override any existing configuration values.

  • The brokers command for the pulsar-admin tool has a variety of subcommands that enable you to manipulate a broker’s configuration dynamically, enabling you to update config values and more.
  • In the Pulsar admin REST API, dynamic configuration is managed through the /admin/v2/brokers/configuration endpoint.

Update dynamic configuration

  • pulsar-admin
  • REST API
  • JAVA

The update-dynamic-config subcommand will update existing configuration. It takes two arguments: the name of the parameter and the new value using the config and value flag respectively. Here’s an example for the brokerShutdownTimeoutMs parameter:

  1. $ pulsar-admin brokers update-dynamic-config --config brokerShutdownTimeoutMs --value 100

POST /admin/v2/brokers/configuration/:configName/:configValue

  1. admin.brokers().updateDynamicConfiguration(configName, configValue);

List updated values

Fetch a list of all potentially updatable configuration parameters.

  • pulsar-admin
  • REST API
  • JAVA
  1. $ pulsar-admin brokers list-dynamic-config
  2. brokerShutdownTimeoutMs

GET /admin/v2/brokers/configuration

  1. admin.brokers().getDynamicConfigurationNames();

List all

Fetch a list of all parameters that have been dynamically updated.

  • pulsar-admin
  • REST API
  • JAVA
  1. $ pulsar-admin brokers get-all-dynamic-config
  2. brokerShutdownTimeoutMs:100

GET /admin/v2/brokers/configuration/values

  1. admin.brokers().getAllDynamicConfigurations();