Skip to content

Commit

Permalink
output: use unique instance id, no mask_id
Browse files Browse the repository at this point in the history
Signed-off-by: Eduardo Silva <[email protected]>
  • Loading branch information
edsiper committed Apr 5, 2019
1 parent 34378f7 commit 964ac6a
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 11 deletions.
1 change: 1 addition & 0 deletions include/fluent-bit/flb_output.h
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,7 @@ struct flb_output_plugin {
*/
struct flb_output_instance {
uint64_t mask_id; /* internal bitmask for routing */
int id; /* instance id */
char name[32]; /* numbered name (cpu -> cpu.0) */
char *alias; /* alias name for the instance */
int flags; /* inherit flags from plugin */
Expand Down
23 changes: 12 additions & 11 deletions src/flb_output.c
Original file line number Diff line number Diff line change
Expand Up @@ -176,21 +176,17 @@ void flb_output_exit(struct flb_config *config)
}
}

static inline int instance_id(struct flb_output_plugin *p,
struct flb_config *config) \
static inline int instance_id(struct flb_config *config)
{
int c = 0;
struct mk_list *head;
struct flb_output_instance *entry;

mk_list_foreach(head, &config->outputs) {
entry = mk_list_entry(head, struct flb_output_instance, _head);
if (entry->p == p) {
c++;
}
if (mk_list_size(&config->outputs) == 0) {
return 0;
}

return c;
entry = mk_list_entry_last(&config->filters, struct flb_output_instance,
_head);
return (entry->id + 1);
}

/*
Expand Down Expand Up @@ -247,6 +243,8 @@ struct flb_output_instance *flb_output_new(struct flb_config *config,
* output instance that is used later to set in an 'unsigned 64
* bit number' where a specific task (buffer/records) should be
* routed.
*
* note: This value is different than instance id.
*/
if (mask_id == 0) {
instance->mask_id = 1;
Expand All @@ -255,9 +253,12 @@ struct flb_output_instance *flb_output_new(struct flb_config *config,
instance->mask_id = (mask_id * 2);
}

/* Retrieve an instance id for the output instance */
instance->id = instance_id(config);

/* format name (with instance id) */
snprintf(instance->name, sizeof(instance->name) - 1,
"%s.%i", plugin->name, instance_id(plugin, config));
"%s.%i", plugin->name, instance->id);
instance->p = plugin;

if (plugin->type == FLB_OUTPUT_PLUGIN_CORE) {
Expand Down

0 comments on commit 964ac6a

Please sign in to comment.