Permalink
Cannot retrieve contributors at this time
Fetching contributors…
| /* | |
| * Copyright (c) 2013 Red Hat. | |
| * | |
| * This program is free software; you can redistribute it and/or modify it | |
| * under the terms of the GNU General Public License as published by the | |
| * Free Software Foundation; either version 2 of the License, or (at your | |
| * option) any later version. | |
| * | |
| * This program is distributed in the hope that it will be useful, but | |
| * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY | |
| * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
| * for more details. | |
| */ | |
| #include <pcp/pmapi.h> | |
| #include <pcp/mmv_stats.h> | |
| static mmv_instances_t products[] = { | |
| { .internal = 0, .external = "Anvils" }, | |
| { .internal = 1, .external = "Rockets" }, | |
| { .internal = 2, .external = "Giant_Rubber_Bands" }, | |
| }; | |
| #define ACME_PRODUCTS_INDOM 61 | |
| #define ACME_PRODUCTS_COUNT (sizeof(products)/sizeof(products[0])) | |
| static mmv_indom_t indoms[] = { | |
| { .serial = ACME_PRODUCTS_INDOM, | |
| .count = ACME_PRODUCTS_COUNT, | |
| .instances = products, | |
| .shorttext = "Acme products", | |
| .helptext = "Most popular products produced by the Acme Corporation", | |
| }, | |
| }; | |
| static mmv_metric_t metrics[] = { | |
| { .name = "products.count", | |
| .item = 7, | |
| .type = MMV_TYPE_U64, | |
| .semantics = MMV_SEM_COUNTER, | |
| .dimension = MMV_UNITS(0,0,1,0,0,PM_COUNT_ONE), | |
| .indom = ACME_PRODUCTS_INDOM, | |
| .shorttext = "Acme factory product throughput", | |
| .helptext = | |
| "Monotonic increasing counter of products produced in the Acme Corporation\n" | |
| "factory since starting the Acme production application. Quality guaranteed.", | |
| }, | |
| { .name = "products.time", | |
| .item = 8, | |
| .type = MMV_TYPE_U64, | |
| .semantics = MMV_SEM_COUNTER, | |
| .dimension = MMV_UNITS(0,1,0,0,PM_TIME_USEC,0), | |
| .indom = ACME_PRODUCTS_INDOM, | |
| .shorttext = "Machine time spent producing Acme products", | |
| .helptext = | |
| "Machine time spent producing Acme Corporation products. Does not include\n" | |
| "time in queues waiting for production machinery.", | |
| }, | |
| { .name = "products.queuetime", | |
| .item = 10, | |
| .type = MMV_TYPE_U64, | |
| .semantics = MMV_SEM_COUNTER, | |
| .dimension = MMV_UNITS(0,1,0,0,PM_TIME_USEC,0), | |
| .indom = ACME_PRODUCTS_INDOM, | |
| .shorttext = "Queued time while producing Acme products", | |
| .helptext = | |
| "Time spent in the queue waiting to build Acme Corporation products,\n" | |
| "while some other Acme product was being built instead of this one.", | |
| }, | |
| }; | |
| #define INDOM_COUNT (sizeof(indoms)/sizeof(indoms[0])) | |
| #define METRIC_COUNT (sizeof(metrics)/sizeof(metrics[0])) | |
| #define ACME_CLUSTER 321 /* PMID cluster identifier */ | |
| int | |
| main(int argc, char * argv[]) | |
| { | |
| void *base; | |
| pmAtomValue *count[ACME_PRODUCTS_COUNT]; | |
| pmAtomValue *machine[ACME_PRODUCTS_COUNT]; | |
| pmAtomValue *inqueue[ACME_PRODUCTS_COUNT]; | |
| unsigned int working; | |
| unsigned int product; | |
| unsigned int i; | |
| base = mmv_stats_init("acme", ACME_CLUSTER, 0, | |
| metrics, METRIC_COUNT, indoms, INDOM_COUNT); | |
| if (!base) { | |
| perror("mmv_stats_init"); | |
| return 1; | |
| } | |
| for (i = 0; i < ACME_PRODUCTS_COUNT; i++) { | |
| count[i] = mmv_lookup_value_desc(base, | |
| "products.count", products[i].external); | |
| machine[i] = mmv_lookup_value_desc(base, | |
| "products.time", products[i].external); | |
| inqueue[i] = mmv_lookup_value_desc(base, | |
| "products.queuetime", products[i].external); | |
| } | |
| while (1) { | |
| /* choose a random number between 0-N -> product */ | |
| product = rand() % ACME_PRODUCTS_COUNT; | |
| /* assign a time spent "working" on this product */ | |
| working = rand() % 50000; | |
| /* pretend to "work" so process doesn't burn CPU */ | |
| usleep(working); | |
| /* update the memory mapped values for this one: */ | |
| /* one more product produced and work time spent */ | |
| mmv_inc_value(base, machine[product], working); /* API */ | |
| count[product]->ull += 1; /* or direct mmap update */ | |
| /* all other products are "queued" for this time */ | |
| for (i = 0; i < ACME_PRODUCTS_COUNT; i++) | |
| if (i != product) | |
| mmv_inc_value(base, inqueue[i], working); | |
| } | |
| mmv_stats_stop("acme", base); | |
| return 0; | |
| } |