A guide explaining how to create, view, and manage topics within your Vultr Managed Apache Kafka® instance.
Vultr Managed Apache Kafka® allows customers to create and manage topics within their Kafka database. Users can easily define topic configurations, including partitioning and replication settings, to suit their data streaming needs. This straightforward interface enables efficient organization of data streams, ensuring customers can scale their applications and optimize performance while maintaining control over their topics.
Follow this guide to manage Topics for Vultr Managed Apache Kafka® with Vultr Customer Portal, API, or CLI.
List all the databases by sending a GET request to the List Managed Databases endpoint and note the target database's ID.
$ curl "https://api.vultr.com/v2/databases" \
    -X GET \
    -H "Authorization: Bearer ${VULTR_API_KEY}"
Send a POST request to the Create Database Topic endpoint to create a topic for your database.
$ curl "https://api.vultr.com/v2/databases/<database-id>/topics" \
    -X POST \
    -H "Authorization: Bearer ${VULTR_API_KEY}" \
    -H "Content-Type: application/json" \
    --data '{
        "name" : "some_new_topic",
        "partitions" : 3,
        "replication" : 3,
        "retention_hours" : 160,
        "retention_bytes" : -1
}'
Send a GET request to the List Database Topics endpoint to list all the topics.
$ curl "https://api.vultr.com/v2/databases/<database-id>/topics" \            
    -X GET \                                   
    -H "Authorization: Bearer ${VULTR_API_KEY}"
List all databases and note the target database's ID.
$ vultr-cli database list --summarize
Create a database topic for the target database.
$  vultr-cli database topic create <database-id> --name <string> --partitions <int> --retention-bytes <int> --retention-hours <int>
Run vultr-cli database topic create --help to understand and view all options.
List and confirm the topic created.
$ vultr-cli database topic list <database-id>
Delete a topic for the target database.
$ vultr-cli database topic delete <database-id> <topic-name>