Pulsar command-line tools
Pulsar offers several command-line tools that you can use for managing Pulsar installations, performance testing, using command-line producers and consumers, and more.
All Pulsar command-line tools can be run from the bin
directory of your installed Pulsar package. The following tools are currently documented:
ヘルプの表示
You can get help for any CLI tool, command, or subcommand using the
--help
flag, or-h
for short. Here's an example:
$ bin/pulsar broker --help
## `pulsar`
The pulsar tool is used to start Pulsar components, such as bookies and ZooKeeper, in the foreground.
These processes can also be started in the background, using nohup, using the pulsar-daemon tool, which has the same command interface as pulsar.
使い方:
```bash
$ pulsar command
Commands:
bookie
broker
compact-topic
discovery
configuration-store
initialize-cluster-metadata
proxy
standalone
websocket
zookeeper
zookeeper-shell
例:
$ PULSAR_BROKER_CONF=/path/to/broker.conf pulsar broker
The table below lists the environment variables that you can use to configure the pulsar
tool.
変数 | Description | Default |
---|---|---|
PULSAR_LOG_CONF | Log4j configuration file | conf/log4j2.yaml |
PULSAR_BROKER_CONF | Configuration file for broker | conf/broker.conf |
PULSAR_BOOKKEEPER_CONF | description: Configuration file for bookie | conf/bookkeeper.conf |
PULSAR_ZK_CONF | Configuration file for zookeeper | conf/zookeeper.conf |
PULSAR_CONFIGURATION_STORE_CONF | Configuration file for the configuration store | conf/global_zookeeper.conf |
PULSAR_DISCOVERY_CONF | Configuration file for discovery service | conf/discovery.conf |
PULSAR_WEBSOCKET_CONF | Configuration file for websocket proxy | conf/websocket.conf |
PULSAR_STANDALONE_CONF | Configuration file for standalone | conf/standalone.conf |
PULSAR_EXTRA_OPTS | Extra options to be passed to the jvm | |
PULSAR_EXTRA_CLASSPATH | Extra paths for Pulsar's classpath | |
PULSAR_PID_DIR | Folder where the pulsar server PID file should be stored | |
PULSAR_STOP_TIMEOUT | Wait time before forcefully killing the Bookie server instance if attempts to stop it are not successful |
bookie
Starts up a bookie server
使い方:
$ pulsar bookie options
オプション
オプション | Description | Default |
---|---|---|
-readOnly | Force start a read-only bookie server | false |
-withAutoRecovery | Start auto-recover service bookie server | false |
Example
$ PULSAR_BOOKKEEPER_CONF=/path/to/bookkeeper.conf pulsar bookie \
-readOnly \
-withAutoRecovery
broker
Starts up a Pulsar broker
使い方
$ pulsar broker options
オプション
オプション | Description | Default |
---|---|---|
-bc , --bookie-conf | Configuration file for BookKeeper | |
-rb , --run-bookie | Run a BookKeeper bookie on the same host as the Pulsar broker | false |
-ra , --run-bookie-autorecovery | Run a BookKeeper autorecovery daemon on the same host as the Pulsar broker | false |
Example
$ PULSAR_BROKER_CONF=/path/to/broker.conf pulsar broker
compact-topic
Run compaction against a Pulsar topic (in a new process)
使い方
$ pulsar compact-topic options
オプション
Flag | Description | Default |
---|---|---|
-t , --topic | The Pulsar topic that you would like to compact |
Example
$ pulsar compact-topic --topic topic-to-compact
discovery
Run a discovery server
使い方
$ pulsar discovery
Example
$ PULSAR_DISCOVERY_CONF=/path/to/discovery.conf pulsar discovery
configuration-store
Starts up the Pulsar configuration store
使い方
$ pulsar configuration-store
Example
$ PULSAR_CONFIGURATION_STORE_CONF=/path/to/configuration_store.conf pulsar configuration-store
initialize-cluster-metadata
One-time cluster metadata initialization
使い方
$ pulsar initialize-cluster-metadata options
オプション
Flag | Description | Default |
---|---|---|
-ub , --broker-service-url | The broker service URL for the new cluster | |
-tb , --broker-service-url-tls | The broker service URL for the new cluster with TLS encryption | |
-c , --cluster | Cluster name | |
--configuration-store | The configuration store quorum connection string | |
-uw , --web-service-url | The web service URL for the new cluster | |
-tw , --web-service-url-tls | The web service URL for the new cluster with TLS encryption | |
-zk , --zookeeper | The local ZooKeeper quorum connection string |
proxy
Manages the Pulsar proxy
使い方
$ pulsar proxy options
オプション
Flag | Description | Default |
---|---|---|
--configuration-store | Configuration store connection string | |
-zk , --zookeeper-servers | Local ZooKeeper connection string |
Example
$ PULSAR_PROXY_CONF=/path/to/proxy.conf pulsar proxy \
--zookeeper-servers zk-0,zk-1,zk2 \
--configuration-store zk-0,zk-1,zk-2
standalone
Run a broker service with local bookies and local ZooKeeper
使い方
$ pulsar standalone options
オプション
Flag | Description | Default |
---|---|---|
-a , --advertised-address | The standalone broker advertised address | |
--bookkeeper-dir | Local bookies’ base data directory | data/standalone/bookeeper |
--bookkeeper-port | Local bookies’ base port | 3181 |
--no-broker | Only start ZooKeeper and BookKeeper services, not the broker | false |
--num-bookies | The number of local bookies | 1 |
--only-broker | Only start the Pulsar broker service (not ZooKeeper or BookKeeper) | |
--wipe-data | Clean up previous ZooKeeper/BookKeeper data | |
--zookeeper-dir | Local ZooKeeper’s data directory | data/standalone/zookeeper |
--zookeeper-port | Local ZooKeeper’s port | 2181 |
Example
$ PULSAR_STANDALONE_CONF=/path/to/standalone.conf pulsar standalone
websocket
使い方
$ pulsar websocket
Example
$ PULSAR_WEBSOCKET_CONF=/path/to/websocket.conf pulsar websocket
zookeeper
Starts up a ZooKeeper cluster
使い方
$ pulsar zookeeper
Example
$ PULSAR_ZK_CONF=/path/to/zookeeper.conf pulsar zookeeper
zookeeper-shell
Connects to a running ZooKeeper cluster using the ZooKeeper shell
使い方
$ pulsar zookeeper-shell options
オプション
Flag | Description | Default |
---|---|---|
-c , --conf | Configuration file for ZooKeeper |
pulsar-client
The pulsar-client tool
使い方
$ pulsar-client command
Commands
produce
consume
オプション
Flag | Description | Default |
---|---|---|
--auth-params | Authentication parameters, whose format is determined by the implementation of method configure in authentication plugin class, for example "key1:val1,key2:val2" or "{"key1":"val1","key2":"val2"}" | {"saslJaasClientSectionName":"PulsarClient", "serverType":"broker"} |
--auth-plugin | Authentication plugin class name | org.apache.pulsar.client.impl.auth.AuthenticationSasl |
--url | Broker URL to which to connect | pulsar://localhost:6650/ |
produce
Send a message or messages to a specific broker and topic
使い方
$ pulsar-client produce topic options
オプション
Flag | Description | Default |
---|---|---|
-f , --files | Comma-separated file paths to send; either -m or -f must be specified | [] |
-m , --messages | Comma-separated string of messages to send; either -m or -f must be specified | [] |
-n , --num-produce | The number of times to send the message(s); the count of messages/files * num-produce should be below 1000 | 1 |
-r , --rate | Rate (in messages per second) at which to produce; a value 0 means to produce messages as fast as possible | 0.0 |
consume
Consume messages from a specific broker and topic
使い方
$ pulsar-client consume topic options
オプション
Flag | Description | Default |
---|---|---|
--hex | Display binary messages in hexadecimal format. | false |
-n , --num-messages | Number of messages to consume, 0 means to consume forever. | 1 |
-r , --rate | Rate (in messages per second) at which to consume; a value 0 means to consume messages as fast as possible | 0.0 |
-s , --subscription-name | Subscription name | |
-t , --subscription-type | The type of the subscription. Possible values: Exclusive, Shared, Failover, Key_Shared. | Exclusive |
pulsar-daemon
A wrapper around the pulsar tool that’s used to start and stop processes, such as ZooKeeper, bookies, and Pulsar brokers, in the background using nohup.
pulsar-daemon has a similar interface to the pulsar command but adds start and stop commands for various services. For a listing of those services, run pulsar-daemon to see the help output or see the documentation for the pulsar command.
使い方
$ pulsar-daemon command
Commands
start
stop
start
Start a service in the background using nohup.
使い方
$ pulsar-daemon start service
stop
Stop a service that’s already been started using start.
使い方
$ pulsar-daemon stop service options
オプション
Flag | Description | Default |
---|---|---|
-force | Stop the service forcefully if not stopped by normal shutdown. | false |
pulsar-perf
A tool for performance testing a Pulsar broker.
使い方
$ pulsar-perf command
Commands
consume
produce
read
websocket-producer
managed-ledger
monitor-brokers
simulation-client
simulation-controller
help
Environment variables
The table below lists the environment variables that you can use to configure the pulsar-perf tool.
変数 | Description | Default |
---|---|---|
PULSAR_LOG_CONF | Log4j configuration file | conf/log4j2.yaml |
PULSAR_CLIENT_CONF | Configuration file for the client | conf/client.conf |
PULSAR_EXTRA_OPTS | Extra options to be passed to the JVM | |
PULSAR_EXTRA_CLASSPATH | Extra paths for Pulsar's classpath |
consume
Run a consumer
使い方
$ pulsar-perf consume options
オプション
Flag | Description | Default |
---|---|---|
--auth_params | Authentication parameters, whose format is determined by the implementation of method configure in authentication plugin class, for example "key1:val1,key2:val2" or "{"key1":"val1","key2":"val2"}. | |
--auth_plugin | Authentication plugin class name | |
--acks-delay-millis | Acknowlegments grouping delay in millis | 100 |
-k , --encryption-key-name | The private key name to decrypt payload | |
-v , --encryption-key-value-file | The file which contains the private key to decrypt payload | |
-h , --help | Help message | false |
--conf-file | Configuration file | |
-c , --max-connections | Max number of TCP connections to a single broker | 100 |
-n , --num-consumers | Number of consumers (per topic) | 1 |
-t , --num-topic | The number of topics | 1 |
-r , --rate | Simulate a slow message consumer (rate in msg/s) | 0 |
-q , --receiver-queue-size | Size of the receiver queue | 1000 |
-u , --service-url | Pulsar service URL | |
-i , --stats-interval-seconds | Statistics interval seconds. If 0, statistics will be disabled | 0 |
-s , --subscriber-name | Subscriber name prefix | sub |
-st , --subscription-type | Subscriber name prefix. Possible values are Exclusive, Shared, Failover. | Exclusive |
--trust-cert-file | Path for the trusted TLS certificate file |
produce
Run a producer
使い方
$ pulsar-perf produce options
オプション
Flag | Description | Default |
---|---|---|
--auth_params | Authentication parameters, whose format is determined by the implementation of method configure in authentication plugin class, for example "key1:val1,key2:val2" or "{"key1":"val1","key2":"val2"}. | |
--auth_plugin | Authentication plugin class name | |
-b , --batch-time-window | Batch messages in a window of the specified number of milliseconds | 1 |
-z , --compression | Compress messages’ payload. Possible values are NONE, LZ4, ZLIB, ZSTD or SNAPPY. | |
--conf-file | Configuration file | |
-k , --encryption-key-name | The public key name to encrypt payload | |
-v , --encryption-key-value-file | The file which contains the public key to encrypt payload | |
-h , --help | Help message | false |
-c , --max-connections | Max number of TCP connections to a single broker | 100 |
-o , --max-outstanding | Max number of outstanding messages | 1000 |
-p , --max-outstanding-across-partitions | Max number of outstanding messages across partitions | 50000 |
-m , --num-messages | Number of messages to publish in total. If set to 0, it will keep publishing. | 0 |
-n , --num-producers | The number of producers (per topic) | 1 |
-t , --num-topic | The number of topics | 1 |
-f , --payload-file | Use payload from an UTF-8 encoded text file and a payload will be randomly selected when publishing messages | |
-e , --payload-delimiter | The delimiter used to split lines when using payload from a file | \n |
-r , --rate | Publish rate msg/s across topics | 100 |
-u , --service-url | Pulsar service URL | |
-s , --size | Message size (in bytes) | 1024 |
-i , --stats-interval-seconds | Statistics interval seconds. If 0, statistics will be disabled. | 0 |
-time , --test-duration | Test duration in secs. If set to 0, it will keep publishing. | 0 |
--trust-cert-file | Path for the trusted TLS certificate file | |
--warmup-time | Warm-up time in seconds | 1 |
read
Run a topic reader
使い方
$ pulsar-perf read options
オプション
Flag | Description | Default |
---|---|---|
--auth_params | Authentication parameters, whose format is determined by the implementation of method configure in authentication plugin class, for example "key1:val1,key2:val2" or "{"key1":"val1","key2":"val2"}. | |
--auth_plugin | Authentication plugin class name | |
--conf-file | Configuration file | |
-h , --help | Help message | false |
-c , --max-connections | Max number of TCP connections to a single broker | 100 |
-t , --num-topic | The number of topics | 1 |
-r , --rate | Simulate a slow message reader (rate in msg/s) | 0 |
-q , --receiver-queue-size | Size of the receiver queue | 1000 |
-u , --service-url | Pulsar service URL | |
-m , --start-message-id | Start message id. This can be either 'earliest', 'latest' or a specific message id by using 'lid:eid' | earliest |
-i , --stats-interval-seconds | Statistics interval seconds. If 0, statistics will be disabled. | 0 |
--trust-cert-file | Path for the trusted TLS certificate file | |
--use-tls | Use TLS encryption on the connection | false |
websocket-producer
Run a websocket producer
使い方
$ pulsar-perf websocket-producer options
オプション
Flag | Description | Default |
---|---|---|
--auth_params | Authentication parameters, whose format is determined by the implementation of method configure in authentication plugin class, for example "key1:val1,key2:val2" or "{"key1":"val1","key2":"val2"}. | |
--auth_plugin | Authentication plugin class name | |
--conf-file | Configuration file | |
-h , --help | Help message | false |
-m , --num-messages | Number of messages to publish in total. If 0, it will keep publishing | 0 |
-t , --num-topic | The number of topics | 1 |
-f , --payload-file | Use payload from a file instead of empty buffer | |
-u , --proxy-url | Pulsar Proxy URL, e.g., "ws://localhost:8080/" | |
-r , --rate | Publish rate msg/s across topics | 100 |
-s , --size | Message size in byte | 1024 |
-time , --test-duration | Test duration in secs. If 0, it will keep publishing | 0 |
managed-ledger
Write directly on managed-ledgers
使い方
$ pulsar-perf managed-ledger options
オプション
Flag | Description | Default |
---|---|---|
-a , --ack-quorum | Ledger ack quorum | 1 |
-dt , --digest-type | BookKeeper digest type. Possible Values: [CRC32, MAC, CRC32C, DUMMY] | CRC32C |
-e , --ensemble-size | Ledger ensemble size | 1 |
-h , --help | Help message | false |
-c , --max-connections | Max number of TCP connections to a single bookie | 1 |
-o , --max-outstanding | Max number of outstanding requests | 1000 |
-m , --num-messages | Number of messages to publish in total. If 0, it will keep publishing | 0 |
-t , --num-topic | Number of managed ledgers | 1 |
-r , --rate | Write rate msg/s across managed ledgers | 100 |
-s , --size | Message size in byte | 1024 |
-time , --test-duration | Test duration in secs. If 0, it will keep publishing | 0 |
--threads | Number of threads writing | 1 |
-w , --write-quorum | Ledger write quorum | 1 |
-zk , --zookeeperServers | ZooKeeper connection string |
monitor-brokers
Continuously receive broker data and/or load reports
使い方
$ pulsar-perf monitor-brokers options
オプション
Flag | Description | Default |
---|---|---|
--connect-string | A connection string for one or more ZooKeeper servers | |
-h , --help | Help message | false |
simulation-client
Run a simulation server acting as a Pulsar client. Uses the client configuration specified in conf/client.conf
.
使い方
$ pulsar-perf simulation-client options
オプション
Flag | Description | Default |
---|---|---|
--port | Port to listen on for controller | 0 |
--service-url | Pulsar Service URL | |
-h , --help | Help message | false |
simulation-controller
Run a simulation controller to give commands to servers
使い方
$ pulsar-perf simulation-controller options
オプション
Flag | Description | Default |
---|---|---|
--client-port | The port that the clients are listening on | 0 |
--clients | Comma-separated list of client hostnames | |
--cluster | The cluster to test on | |
-h , --help | Help message | false |
help
This help message
使い方
$ pulsar-perf help
bookkeeper
A tool for managing BookKeeper.
使い方
$ bookkeeper command
Commands
auto-recovery
bookie
localbookie
upgrade
shell
Environment variables
The table below lists the environment variables that you can use to configure the bookkeeper tool.
変数 | Description | Default |
---|---|---|
BOOKIE_LOG_CONF | Log4j configuration file | conf/log4j2.yaml |
BOOKIE_CONF | BookKeeper configuration file | conf/bk_server.conf |
BOOKIE_EXTRA_OPTS | Extra options to be passed to the JVM | |
BOOKIE_EXTRA_CLASSPATH | Extra paths for BookKeeper's classpath | |
ENTRY_FORMATTER_CLASS | The Java class used to format entries | |
BOOKIE_PID_DIR | Folder where the BookKeeper server PID file should be stored | |
BOOKIE_STOP_TIMEOUT | Wait time before forcefully killing the Bookie server instance if attempts to stop it are not successful |
auto-recovery
Runs an auto-recovery service daemon
使い方
$ bookkeeper auto-recovery options
オプション
Flag | Description | Default |
---|---|---|
-c , --conf | Configuration for the auto-recovery daemon |
bookie
Starts up a BookKeeper server (aka bookie)
使い方
$ bookkeeper bookie options
オプション
Flag | Description | Default |
---|---|---|
-c , --conf | Configuration for the auto-recovery daemon | |
-readOnly | Force start a read-only bookie server | false |
-withAutoRecovery | Start auto-recovery service bookie server | false |
localbookie
Runs a test ensemble of N bookies locally
使い方
$ bookkeeper localbookie N
upgrade
Upgrade the bookie’s filesystem
使い方
$ bookkeeper upgrade options
オプション
Flag | Description | Default |
---|---|---|
-c , --conf | Configuration for the auto-recovery daemon | |
-u , --upgrade | Upgrade the bookie’s directories |
shell
Run shell for admin commands. To see a full listing of those commands, run bookkeeper shell without an argument.
使い方
$ bookkeeper shell
Example
$ bookkeeper shell bookiesanity