1*1c60b9acSAndroid Build Coastguard Worker /* 2*1c60b9acSAndroid Build Coastguard Worker * lws System Metrics 3*1c60b9acSAndroid Build Coastguard Worker * 4*1c60b9acSAndroid Build Coastguard Worker * Copyright (C) 2021 Andy Green <[email protected]> 5*1c60b9acSAndroid Build Coastguard Worker * 6*1c60b9acSAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a copy 7*1c60b9acSAndroid Build Coastguard Worker * of this software and associated documentation files (the "Software"), to 8*1c60b9acSAndroid Build Coastguard Worker * deal in the Software without restriction, including without limitation the 9*1c60b9acSAndroid Build Coastguard Worker * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 10*1c60b9acSAndroid Build Coastguard Worker * sell copies of the Software, and to permit persons to whom the Software is 11*1c60b9acSAndroid Build Coastguard Worker * furnished to do so, subject to the following conditions: 12*1c60b9acSAndroid Build Coastguard Worker * 13*1c60b9acSAndroid Build Coastguard Worker * The above copyright notice and this permission notice shall be included in 14*1c60b9acSAndroid Build Coastguard Worker * all copies or substantial portions of the Software. 15*1c60b9acSAndroid Build Coastguard Worker * 16*1c60b9acSAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17*1c60b9acSAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18*1c60b9acSAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19*1c60b9acSAndroid Build Coastguard Worker * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20*1c60b9acSAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 21*1c60b9acSAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 22*1c60b9acSAndroid Build Coastguard Worker * IN THE SOFTWARE. 23*1c60b9acSAndroid Build Coastguard Worker */ 24*1c60b9acSAndroid Build Coastguard Worker 25*1c60b9acSAndroid Build Coastguard Worker /* 26*1c60b9acSAndroid Build Coastguard Worker * Const struct that describes a policy for processing raw metrics to turn them 27*1c60b9acSAndroid Build Coastguard Worker * into events. 28*1c60b9acSAndroid Build Coastguard Worker * 29*1c60b9acSAndroid Build Coastguard Worker * Typically although we want to monitor every event, the data produced can be 30*1c60b9acSAndroid Build Coastguard Worker * too large, and many events that are "normal" just need to be counted as such; 31*1c60b9acSAndroid Build Coastguard Worker * outliers or change-to-continuous outliers may deserve closer recording as 32*1c60b9acSAndroid Build Coastguard Worker * events in their own right. 33*1c60b9acSAndroid Build Coastguard Worker * 34*1c60b9acSAndroid Build Coastguard Worker * Mean computation must "decay" as it ages, we do this by halving the sum and 35*1c60b9acSAndroid Build Coastguard Worker * count after .us_decay_unit us. 36*1c60b9acSAndroid Build Coastguard Worker * 37*1c60b9acSAndroid Build Coastguard Worker * We don't acknowledge outliers until there are at least .min_contributors 38*1c60b9acSAndroid Build Coastguard Worker * in the current mean (which is subject to decaying) 39*1c60b9acSAndroid Build Coastguard Worker * 40*1c60b9acSAndroid Build Coastguard Worker * We decide something is an outlier event if it deviates from the mean by 41*1c60b9acSAndroid Build Coastguard Worker * .pc_outlier_deviation %. 42*1c60b9acSAndroid Build Coastguard Worker */ 43*1c60b9acSAndroid Build Coastguard Worker 44*1c60b9acSAndroid Build Coastguard Worker /* 45*1c60b9acSAndroid Build Coastguard Worker * The dynamic counterpart for each static metric policy, this is on heap 46*1c60b9acSAndroid Build Coastguard Worker * one per const lws_metric_policy_t. It's listed in context->owner_mtr_dynpol 47*1c60b9acSAndroid Build Coastguard Worker */ 48*1c60b9acSAndroid Build Coastguard Worker 49*1c60b9acSAndroid Build Coastguard Worker typedef struct lws_metric_policy_dyn { 50*1c60b9acSAndroid Build Coastguard Worker const lws_metric_policy_t *policy; 51*1c60b9acSAndroid Build Coastguard Worker /**< the static part of the policy we belong to... can be NULL if no 52*1c60b9acSAndroid Build Coastguard Worker * policy matches or the policy was invalidated */ 53*1c60b9acSAndroid Build Coastguard Worker 54*1c60b9acSAndroid Build Coastguard Worker lws_dll2_owner_t owner; 55*1c60b9acSAndroid Build Coastguard Worker /**< list of metrics that are using this policy */ 56*1c60b9acSAndroid Build Coastguard Worker 57*1c60b9acSAndroid Build Coastguard Worker lws_dll2_t list; 58*1c60b9acSAndroid Build Coastguard Worker /**< context owns us */ 59*1c60b9acSAndroid Build Coastguard Worker 60*1c60b9acSAndroid Build Coastguard Worker lws_sorted_usec_list_t sul; 61*1c60b9acSAndroid Build Coastguard Worker /**< schedule periodic reports for metrics using this policy */ 62*1c60b9acSAndroid Build Coastguard Worker } lws_metric_policy_dyn_t; 63*1c60b9acSAndroid Build Coastguard Worker 64*1c60b9acSAndroid Build Coastguard Worker /* 65*1c60b9acSAndroid Build Coastguard Worker * A metrics private part, encapsulating the public part 66*1c60b9acSAndroid Build Coastguard Worker */ 67*1c60b9acSAndroid Build Coastguard Worker 68*1c60b9acSAndroid Build Coastguard Worker typedef struct lws_metric { 69*1c60b9acSAndroid Build Coastguard Worker 70*1c60b9acSAndroid Build Coastguard Worker lws_dll2_t list; 71*1c60b9acSAndroid Build Coastguard Worker /**< owned by either 1) ctx.lws_metric_policy_dyn_t.owner, or 72*1c60b9acSAndroid Build Coastguard Worker * 2) ctx.owner_mtr_no_pol */ 73*1c60b9acSAndroid Build Coastguard Worker 74*1c60b9acSAndroid Build Coastguard Worker struct lws_context *ctx; 75*1c60b9acSAndroid Build Coastguard Worker 76*1c60b9acSAndroid Build Coastguard Worker /* public part overallocated */ 77*1c60b9acSAndroid Build Coastguard Worker } lws_metric_t; 78*1c60b9acSAndroid Build Coastguard Worker 79*1c60b9acSAndroid Build Coastguard Worker 80*1c60b9acSAndroid Build Coastguard Worker #if defined(LWS_WITH_SYS_METRICS) 81*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv(_mt, _name) \ 82*1c60b9acSAndroid Build Coastguard Worker lws_metrics_hist_bump_(lws_metrics_priv_to_pub(_mt), _name) 83*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_wsi(_wsi, _hist, _name) \ 84*1c60b9acSAndroid Build Coastguard Worker lws_metrics_hist_bump_(lws_metrics_priv_to_pub(_wsi->a.context->_hist), _name) 85*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_ss(_ss, _hist, _name) \ 86*1c60b9acSAndroid Build Coastguard Worker lws_metrics_hist_bump_(lws_metrics_priv_to_pub(_ss->context->_hist), _name) 87*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_priv_to_pub(_x) ((lws_metric_pub_t *)&(_x)[1]) 88*1c60b9acSAndroid Build Coastguard Worker #else 89*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv(_mt, _name) 90*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_wsi(_wsi, _hist, _name) 91*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_ss(_ss, _hist, _name) 92*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_priv_to_pub(_x) ((lws_metric_pub_t *)NULL) 93*1c60b9acSAndroid Build Coastguard Worker #endif 94*1c60b9acSAndroid Build Coastguard Worker 95*1c60b9acSAndroid Build Coastguard Worker #if defined(LWS_WITH_SECURE_STREAMS_PROXY_API) 96*1c60b9acSAndroid Build Coastguard Worker /* 97*1c60b9acSAndroid Build Coastguard Worker * sspc-specific version that also appends the tag value to the lifecycle tag 98*1c60b9acSAndroid Build Coastguard Worker * used for logging the sspc identity 99*1c60b9acSAndroid Build Coastguard Worker */ 100*1c60b9acSAndroid Build Coastguard Worker int 101*1c60b9acSAndroid Build Coastguard Worker lws_metrics_tag_sspc_add(struct lws_sspc_handle *ss, const char *name, const char *val); 102*1c60b9acSAndroid Build Coastguard Worker #endif 103*1c60b9acSAndroid Build Coastguard Worker 104*1c60b9acSAndroid Build Coastguard Worker int 105*1c60b9acSAndroid Build Coastguard Worker lws_metrics_register_policy(struct lws_context *ctx, 106*1c60b9acSAndroid Build Coastguard Worker const lws_metric_policy_t *head); 107*1c60b9acSAndroid Build Coastguard Worker 108*1c60b9acSAndroid Build Coastguard Worker void 109*1c60b9acSAndroid Build Coastguard Worker lws_metrics_destroy(struct lws_context *ctx); 110*1c60b9acSAndroid Build Coastguard Worker 111*1c60b9acSAndroid Build Coastguard Worker void 112*1c60b9acSAndroid Build Coastguard Worker lws_metric_event(lws_metric_t *mt, char go_nogo, u_mt_t val); 113*1c60b9acSAndroid Build Coastguard Worker 114*1c60b9acSAndroid Build Coastguard Worker lws_metric_t * 115*1c60b9acSAndroid Build Coastguard Worker lws_metric_create(struct lws_context *ctx, uint8_t flags, const char *name); 116*1c60b9acSAndroid Build Coastguard Worker 117*1c60b9acSAndroid Build Coastguard Worker int 118*1c60b9acSAndroid Build Coastguard Worker lws_metric_destroy(lws_metric_t **mt, int keep); 119*1c60b9acSAndroid Build Coastguard Worker 120*1c60b9acSAndroid Build Coastguard Worker void 121*1c60b9acSAndroid Build Coastguard Worker lws_metric_policy_dyn_destroy(lws_metric_policy_dyn_t *dm, int keep); 122*1c60b9acSAndroid Build Coastguard Worker 123*1c60b9acSAndroid Build Coastguard Worker void 124*1c60b9acSAndroid Build Coastguard Worker lws_metric_rebind_policies(struct lws_context *ctx); 125