From: Dmitry Volyntsev Date: Fri, 30 Jun 2023 03:44:14 +0000 (-0700) Subject: Modules: introduced ngx.worker_id. X-Git-Tag: 0.8.0~8 X-Git-Url: http://www.kaiwu.me/postgresql/commit/?a=commitdiff_plain;h=5e2a0b4c7f0f5de1b33ab86025f1282e988f7a3c;p=njs.git Modules: introduced ngx.worker_id. worker_id corresponds to an nginx internal worker id. The value is between 0 and worker_processes - 1. --- diff --git a/nginx/ngx_js.c b/nginx/ngx_js.c index 27800f31..8973f9f6 100644 --- a/nginx/ngx_js.c +++ b/nginx/ngx_js.c @@ -25,6 +25,8 @@ static njs_int_t ngx_js_ext_prefix(njs_vm_t *vm, njs_object_prop_t *prop, njs_value_t *value, njs_value_t *setval, njs_value_t *retval); static njs_int_t ngx_js_ext_version(njs_vm_t *vm, njs_object_prop_t *prop, njs_value_t *value, njs_value_t *setval, njs_value_t *retval); +static njs_int_t ngx_js_ext_worker_id(njs_vm_t *vm, njs_object_prop_t *prop, + njs_value_t *value, njs_value_t *setval, njs_value_t *retval); static void ngx_js_cleanup_vm(void *data); static njs_int_t ngx_js_core_init(njs_vm_t *vm); @@ -149,6 +151,15 @@ static njs_external_t ngx_js_ext_core[] = { } }, + { + .flags = NJS_EXTERN_PROPERTY, + .name.string = njs_str("worker_id"), + .enumerable = 1, + .u.property = { + .handler = ngx_js_ext_worker_id, + } + }, + }; @@ -452,6 +463,15 @@ ngx_js_ext_version(njs_vm_t *vm, njs_object_prop_t *prop, njs_value_t *value, } +njs_int_t +ngx_js_ext_worker_id(njs_vm_t *vm, njs_object_prop_t *prop, njs_value_t *value, + njs_value_t *setval, njs_value_t *retval) +{ + njs_value_number_set(retval, ngx_worker); + return NJS_OK; +} + + njs_int_t ngx_js_ext_log(njs_vm_t *vm, njs_value_t *args, njs_uint_t nargs, njs_index_t level, njs_value_t *retval) diff --git a/ts/ngx_core.d.ts b/ts/ngx_core.d.ts index 02aa6a41..42fce1b6 100644 --- a/ts/ngx_core.d.ts +++ b/ts/ngx_core.d.ts @@ -311,6 +311,12 @@ interface NgxObject { * @since 0.5.1 */ readonly WARN: number; + /** + * A number corresponding to the current worker process id. + * Can have values from 0 to worker_processes - 1. + * @since 0.8.0 + */ + readonly worker_id: number; }