Managing non-partitioned topics
You can use Pulsar's admin API to create and manage non-partitioned topics.
In all of the instructions and commands below, the topic name structure is:
persistent://tenant/namespace/topic
Non-Partitioned topics resources
Create
Non-partitioned topics in Pulsar must be explicitly created. When creating a new non-partitioned topic you need to provide a name for the topic.
By default, after 60 seconds of creation, topics are considered inactive and deleted automatically to prevent from generating trash data.
To disable this feature, set brokerDeleteInactiveTopicsEnabled  to false.
To change the frequency of checking inactive topics, set brokerDeleteInactiveTopicsFrequencySeconds to your desired value.
For more information about these two parameters, see here.
pulsar-admin
You can create non-partitioned topics using the create
command and specifying the topic name as an argument.
Here's an example:
$ bin/pulsar-admin topics create \
  persistent://my-tenant/my-namespace/my-topic
It's only allowed to create non partitioned topic of name contains suffix '-partition-' followed by numeric value like 'xyz-topic-partition-10', if there's already a partitioned topic with same name, in this case 'xyz-topic', and has number of partition larger then that numeric value in this case 11(partition index is start from 0). Else creation of such topic will fail.
REST API
PUT /admin/v2/:schema/:tenant/:namespace/:topic
Java
String topicName = "persistent://my-tenant/my-namespace/my-topic";
admin.topics().createNonPartitionedTopic(topicName);