• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<!DOCTYPE html>
2<html lang="en">
3<head>
4  <meta charset="utf-8">
5  <meta name="viewport" content="width=device-width">
6  <meta name="nodejs.org:node-version" content="v14.19.1">
7  <title>Diagnostics Channel | Node.js v14.19.1 Documentation</title>
8  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Lato:400,700,400italic&display=fallback">
9  <link rel="stylesheet" href="assets/style.css">
10  <link rel="stylesheet" href="assets/hljs.css">
11  <link rel="canonical" href="https://nodejs.org/api/diagnostics_channel.html">
12</head>
13<body class="alt apidoc" id="api-section-diagnostics_channel">
14  <div id="content" class="clearfix">
15    <div id="column2" class="interior">
16      <div id="intro" class="interior">
17        <a href="/" title="Go back to the home page">
18          Node.js
19        </a>
20      </div>
21      <ul>
22<li><a href="documentation.html" class="nav-documentation">About this documentation</a></li>
23<li><a href="synopsis.html" class="nav-synopsis">Usage and example</a></li>
24</ul>
25<hr class="line">
26<ul>
27<li><a href="assert.html" class="nav-assert">Assertion testing</a></li>
28<li><a href="async_hooks.html" class="nav-async_hooks">Async hooks</a></li>
29<li><a href="buffer.html" class="nav-buffer">Buffer</a></li>
30<li><a href="addons.html" class="nav-addons">C++ addons</a></li>
31<li><a href="n-api.html" class="nav-n-api">C/C++ addons with Node-API</a></li>
32<li><a href="embedding.html" class="nav-embedding">C++ embedder API</a></li>
33<li><a href="child_process.html" class="nav-child_process">Child processes</a></li>
34<li><a href="cluster.html" class="nav-cluster">Cluster</a></li>
35<li><a href="cli.html" class="nav-cli">Command-line options</a></li>
36<li><a href="console.html" class="nav-console">Console</a></li>
37<li><a href="corepack.html" class="nav-corepack">Corepack</a></li>
38<li><a href="crypto.html" class="nav-crypto">Crypto</a></li>
39<li><a href="debugger.html" class="nav-debugger">Debugger</a></li>
40<li><a href="deprecations.html" class="nav-deprecations">Deprecated APIs</a></li>
41<li><a href="diagnostics_channel.html" class="nav-diagnostics_channel active">Diagnostics Channel</a></li>
42<li><a href="dns.html" class="nav-dns">DNS</a></li>
43<li><a href="domain.html" class="nav-domain">Domain</a></li>
44<li><a href="errors.html" class="nav-errors">Errors</a></li>
45<li><a href="events.html" class="nav-events">Events</a></li>
46<li><a href="fs.html" class="nav-fs">File system</a></li>
47<li><a href="globals.html" class="nav-globals">Globals</a></li>
48<li><a href="http.html" class="nav-http">HTTP</a></li>
49<li><a href="http2.html" class="nav-http2">HTTP/2</a></li>
50<li><a href="https.html" class="nav-https">HTTPS</a></li>
51<li><a href="inspector.html" class="nav-inspector">Inspector</a></li>
52<li><a href="intl.html" class="nav-intl">Internationalization</a></li>
53<li><a href="modules.html" class="nav-modules">Modules: CommonJS modules</a></li>
54<li><a href="esm.html" class="nav-esm">Modules: ECMAScript modules</a></li>
55<li><a href="module.html" class="nav-module">Modules: <code>module</code> API</a></li>
56<li><a href="packages.html" class="nav-packages">Modules: Packages</a></li>
57<li><a href="net.html" class="nav-net">Net</a></li>
58<li><a href="os.html" class="nav-os">OS</a></li>
59<li><a href="path.html" class="nav-path">Path</a></li>
60<li><a href="perf_hooks.html" class="nav-perf_hooks">Performance hooks</a></li>
61<li><a href="policy.html" class="nav-policy">Policies</a></li>
62<li><a href="process.html" class="nav-process">Process</a></li>
63<li><a href="punycode.html" class="nav-punycode">Punycode</a></li>
64<li><a href="querystring.html" class="nav-querystring">Query strings</a></li>
65<li><a href="readline.html" class="nav-readline">Readline</a></li>
66<li><a href="repl.html" class="nav-repl">REPL</a></li>
67<li><a href="report.html" class="nav-report">Report</a></li>
68<li><a href="stream.html" class="nav-stream">Stream</a></li>
69<li><a href="string_decoder.html" class="nav-string_decoder">String decoder</a></li>
70<li><a href="timers.html" class="nav-timers">Timers</a></li>
71<li><a href="tls.html" class="nav-tls">TLS/SSL</a></li>
72<li><a href="tracing.html" class="nav-tracing">Trace events</a></li>
73<li><a href="tty.html" class="nav-tty">TTY</a></li>
74<li><a href="dgram.html" class="nav-dgram">UDP/datagram</a></li>
75<li><a href="url.html" class="nav-url">URL</a></li>
76<li><a href="util.html" class="nav-util">Utilities</a></li>
77<li><a href="v8.html" class="nav-v8">V8</a></li>
78<li><a href="vm.html" class="nav-vm">VM</a></li>
79<li><a href="wasi.html" class="nav-wasi">WASI</a></li>
80<li><a href="worker_threads.html" class="nav-worker_threads">Worker threads</a></li>
81<li><a href="zlib.html" class="nav-zlib">Zlib</a></li>
82</ul>
83<hr class="line">
84<ul>
85<li><a href="https://github.com/nodejs/node" class="nav-https-github-com-nodejs-node">Code repository and issue tracker</a></li>
86</ul>
87    </div>
88
89    <div id="column1" data-id="diagnostics_channel" class="interior">
90      <header>
91        <div class="header-container">
92          <h1>Node.js v14.19.1 documentation</h1>
93          <button class="theme-toggle-btn" id="theme-toggle-btn" title="Toggle dark mode/light mode" aria-label="Toggle dark mode/light mode" hidden>
94            <svg xmlns="http://www.w3.org/2000/svg" class="icon dark-icon" height="24" width="24">
95              <path fill="none" d="M0 0h24v24H0z" />
96              <path d="M11.1 12.08c-2.33-4.51-.5-8.48.53-10.07C6.27 2.2 1.98 6.59 1.98 12c0 .14.02.28.02.42.62-.27 1.29-.42 2-.42 1.66 0 3.18.83 4.1 2.15A4.01 4.01 0 0111 18c0 1.52-.87 2.83-2.12 3.51.98.32 2.03.5 3.11.5 3.5 0 6.58-1.8 8.37-4.52-2.36.23-6.98-.97-9.26-5.41z"/>
97              <path d="M7 16h-.18C6.4 14.84 5.3 14 4 14c-1.66 0-3 1.34-3 3s1.34 3 3 3h3c1.1 0 2-.9 2-2s-.9-2-2-2z"/>
98            </svg>
99            <svg xmlns="http://www.w3.org/2000/svg" class="icon light-icon" height="24" width="24">
100              <path d="M0 0h24v24H0z" fill="none" />
101              <path d="M6.76 4.84l-1.8-1.79-1.41 1.41 1.79 1.79 1.42-1.41zM4 10.5H1v2h3v-2zm9-9.95h-2V3.5h2V.55zm7.45 3.91l-1.41-1.41-1.79 1.79 1.41 1.41 1.79-1.79zm-3.21 13.7l1.79 1.8 1.41-1.41-1.8-1.79-1.4 1.4zM20 10.5v2h3v-2h-3zm-8-5c-3.31 0-6 2.69-6 6s2.69 6 6 6 6-2.69 6-6-2.69-6-6-6zm-1 16.95h2V19.5h-2v2.95zm-7.45-3.91l1.41 1.41 1.79-1.8-1.41-1.41-1.79 1.8z"/>
102            </svg>
103          </button>
104        </div>
105        <div id="gtoc">
106          <ul>
107            <li>
108              <a href="index.html">Index</a>
109            </li>
110            <li>
111              <a href="all.html">View on single page</a>
112            </li>
113            <li>
114              <a href="diagnostics_channel.json">View as JSON</a>
115            </li>
116
117    <li class="version-picker">
118      <a href="#">View another version <span>&#x25bc;</span></a>
119      <ol class="version-picker"><li><a href="https://nodejs.org/docs/latest-v17.x/api/diagnostics_channel.html">17.x</a></li>
120<li><a href="https://nodejs.org/docs/latest-v16.x/api/diagnostics_channel.html">16.x <b>LTS</b></a></li>
121<li><a href="https://nodejs.org/docs/latest-v15.x/api/diagnostics_channel.html">15.x</a></li>
122<li><a href="https://nodejs.org/docs/latest-v14.x/api/diagnostics_channel.html">14.x <b>LTS</b></a></li></ol>
123    </li>
124
125            <li class="edit_on_github"><a href="https://github.com/nodejs/node/edit/master/doc/api/diagnostics_channel.md">Edit on GitHub</a></li>
126          </ul>
127        </div>
128        <hr>
129      </header>
130
131      <details id="toc" open><summary>Table of contents</summary><ul>
132<li><span class="stability_1"><a href="#diagnostics_channel_diagnostics_channel">Diagnostics Channel</a></span>
133<ul>
134<li><a href="#diagnostics_channel_public_api">Public API</a>
135<ul>
136<li><a href="#diagnostics_channel_overview">Overview</a>
137<ul>
138<li><a href="#diagnostics_channel_diagnostics_channel_hassubscribers_name"><code>diagnostics_channel.hasSubscribers(name)</code></a></li>
139<li><a href="#diagnostics_channel_diagnostics_channel_channel_name"><code>diagnostics_channel.channel(name)</code></a></li>
140</ul>
141</li>
142<li><a href="#diagnostics_channel_class_channel">Class: <code>Channel</code></a>
143<ul>
144<li><a href="#diagnostics_channel_channel_hassubscribers"><code>channel.hasSubscribers</code></a></li>
145<li><a href="#diagnostics_channel_channel_publish_message"><code>channel.publish(message)</code></a></li>
146<li><a href="#diagnostics_channel_channel_subscribe_onmessage"><code>channel.subscribe(onMessage)</code></a></li>
147<li><a href="#diagnostics_channel_channel_unsubscribe_onmessage"><code>channel.unsubscribe(onMessage)</code></a></li>
148</ul>
149</li>
150</ul>
151</li>
152</ul>
153</li>
154</ul></details>
155
156      <div id="apicontent">
157        <h2>Diagnostics Channel<span><a class="mark" href="#diagnostics_channel_diagnostics_channel" id="diagnostics_channel_diagnostics_channel">#</a></span></h2>
158
159<p></p><div class="api_stability api_stability_1"><a href="documentation.html#documentation_stability_index">Stability: 1</a> - Experimental</div><p></p>
160<p><strong>Source Code:</strong> <a href="https://github.com/nodejs/node/blob/v14.19.1/lib/diagnostics_channel.js">lib/diagnostics_channel.js</a></p>
161<p>The <code>diagnostics_channel</code> module provides an API to create named channels
162to report arbitrary message data for diagnostics purposes.</p>
163<p>It can be accessed using:</p>
164<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);</code></pre>
165<p>It is intended that a module writer wanting to report diagnostics messages
166will create one or many top-level channels to report messages through.
167Channels may also be acquired at runtime but it is not encouraged
168due to the additional overhead of doing so. Channels may be exported for
169convenience, but as long as the name is known it can be acquired anywhere.</p>
170<p>If you intend for your module to produce diagnostics data for others to
171consume it is recommended that you include documentation of what named
172channels are used along with the shape of the message data. Channel names
173should generally include the module name to avoid collisions with data from
174other modules.</p>
175<section><h3>Public API<span><a class="mark" href="#diagnostics_channel_public_api" id="diagnostics_channel_public_api">#</a></span></h3>
176<h4>Overview<span><a class="mark" href="#diagnostics_channel_overview" id="diagnostics_channel_overview">#</a></span></h4>
177<p>Following is a simple overview of the public API.</p>
178<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
179
180<span class="hljs-comment">// Get a reusable channel object</span>
181<span class="hljs-keyword">const</span> channel = diagnostics_channel.<span class="hljs-title function_">channel</span>(<span class="hljs-string">'my-channel'</span>);
182
183<span class="hljs-comment">// Subscribe to the channel</span>
184channel.<span class="hljs-title function_">subscribe</span>(<span class="hljs-function">(<span class="hljs-params">message, name</span>) =></span> {
185  <span class="hljs-comment">// Received data</span>
186});
187
188<span class="hljs-comment">// Check if the channel has an active subscriber</span>
189<span class="hljs-keyword">if</span> (channel.<span class="hljs-property">hasSubscribers</span>) {
190  <span class="hljs-comment">// Publish data to the channel</span>
191  channel.<span class="hljs-title function_">publish</span>({
192    <span class="hljs-attr">some</span>: <span class="hljs-string">'data'</span>
193  });
194}</code></pre>
195<h5><code>diagnostics_channel.hasSubscribers(name)</code><span><a class="mark" href="#diagnostics_channel_diagnostics_channel_hassubscribers_name" id="diagnostics_channel_diagnostics_channel_hassubscribers_name">#</a></span></h5>
196<ul>
197<li><code>name</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type" class="type">&#x3C;string></a> | <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Symbol_type" class="type">&#x3C;symbol></a> The channel name</li>
198<li>Returns: <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Boolean_type" class="type">&#x3C;boolean></a> If there are active subscribers</li>
199</ul>
200<p>Check if there are active subscribers to the named channel. This is helpful if
201the message you want to send might be expensive to prepare.</p>
202<p>This API is optional but helpful when trying to publish messages from very
203performance-sensitive code.</p>
204<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
205
206<span class="hljs-keyword">if</span> (diagnostics_channel.<span class="hljs-title function_">hasSubscribers</span>(<span class="hljs-string">'my-channel'</span>)) {
207  <span class="hljs-comment">// There are subscribers, prepare and publish message</span>
208}</code></pre>
209<h5><code>diagnostics_channel.channel(name)</code><span><a class="mark" href="#diagnostics_channel_diagnostics_channel_channel_name" id="diagnostics_channel_diagnostics_channel_channel_name">#</a></span></h5>
210<ul>
211<li><code>name</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type" class="type">&#x3C;string></a> | <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Symbol_type" class="type">&#x3C;symbol></a> The channel name</li>
212<li>Returns: <a href="diagnostics_channel.html#diagnostics_channel_class_channel" class="type">&#x3C;Channel></a> The named channel object</li>
213</ul>
214<p>This is the primary entry-point for anyone wanting to interact with a named
215channel. It produces a channel object which is optimized to reduce overhead at
216publish time as much as possible.</p>
217<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
218
219<span class="hljs-keyword">const</span> channel = diagnostics_channel.<span class="hljs-title function_">channel</span>(<span class="hljs-string">'my-channel'</span>);</code></pre>
220<h4>Class: <code>Channel</code><span><a class="mark" href="#diagnostics_channel_class_channel" id="diagnostics_channel_class_channel">#</a></span></h4>
221<p>The class <code>Channel</code> represents an individual named channel within the data
222pipeline. It is use to track subscribers and to publish messages when there
223are subscribers present. It exists as a separate object to avoid channel
224lookups at publish time, enabling very fast publish speeds and allowing
225for heavy use while incurring very minimal cost. Channels are created with
226<a href="#diagnostics_channel_diagnostics_channel_channel_name"><code>diagnostics_channel.channel(name)</code></a>, constructing a channel directly
227with <code>new Channel(name)</code> is not supported.</p>
228<h5><code>channel.hasSubscribers</code><span><a class="mark" href="#diagnostics_channel_channel_hassubscribers" id="diagnostics_channel_channel_hassubscribers">#</a></span></h5>
229<ul>
230<li>Returns: <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Boolean_type" class="type">&#x3C;boolean></a> If there are active subscribers</li>
231</ul>
232<p>Check if there are active subscribers to this channel. This is helpful if
233the message you want to send might be expensive to prepare.</p>
234<p>This API is optional but helpful when trying to publish messages from very
235performance-sensitive code.</p>
236<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
237
238<span class="hljs-keyword">const</span> channel = diagnostics_channel.<span class="hljs-title function_">channel</span>(<span class="hljs-string">'my-channel'</span>);
239
240<span class="hljs-keyword">if</span> (channel.<span class="hljs-property">hasSubscribers</span>) {
241  <span class="hljs-comment">// There are subscribers, prepare and publish message</span>
242}</code></pre>
243<h5><code>channel.publish(message)</code><span><a class="mark" href="#diagnostics_channel_channel_publish_message" id="diagnostics_channel_channel_publish_message">#</a></span></h5>
244<ul>
245<li><code>message</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Data_types" class="type">&#x3C;any></a> The message to send to the channel subscribers</li>
246</ul>
247<p>Publish a message to any subscribers to the channel. This will trigger
248message handlers synchronously so they will execute within the same context.</p>
249<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
250
251<span class="hljs-keyword">const</span> channel = diagnostics_channel.<span class="hljs-title function_">channel</span>(<span class="hljs-string">'my-channel'</span>);
252
253channel.<span class="hljs-title function_">publish</span>({
254  <span class="hljs-attr">some</span>: <span class="hljs-string">'message'</span>
255});</code></pre>
256<h5><code>channel.subscribe(onMessage)</code><span><a class="mark" href="#diagnostics_channel_channel_subscribe_onmessage" id="diagnostics_channel_channel_subscribe_onmessage">#</a></span></h5>
257<ul>
258<li><code>onMessage</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function" class="type">&#x3C;Function></a> The handler to receive channel messages
259<ul>
260<li><code>message</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Data_types" class="type">&#x3C;any></a> The message data</li>
261<li><code>name</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type" class="type">&#x3C;string></a> | <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Symbol_type" class="type">&#x3C;symbol></a> The name of the channel</li>
262</ul>
263</li>
264</ul>
265<p>Register a message handler to subscribe to this channel. This message handler
266will be run synchronously whenever a message is published to the channel. Any
267errors thrown in the message handler will trigger an <a href="process.html#process_event_uncaughtexception"><code>'uncaughtException'</code></a>.</p>
268<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
269
270<span class="hljs-keyword">const</span> channel = diagnostics_channel.<span class="hljs-title function_">channel</span>(<span class="hljs-string">'my-channel'</span>);
271
272channel.<span class="hljs-title function_">subscribe</span>(<span class="hljs-function">(<span class="hljs-params">message, name</span>) =></span> {
273  <span class="hljs-comment">// Received data</span>
274});</code></pre>
275<h5><code>channel.unsubscribe(onMessage)</code><span><a class="mark" href="#diagnostics_channel_channel_unsubscribe_onmessage" id="diagnostics_channel_channel_unsubscribe_onmessage">#</a></span></h5>
276<div class="api_metadata">
277<details class="changelog"><summary>History</summary>
278<table>
279<tbody><tr><th>Version</th><th>Changes</th></tr>
280<tr><td>v14.19.0</td>
281<td><p>Added return value. Added to channels without subscribers.</p></td></tr>
282<tr><td>v14.17.0</td>
283<td><p><span>Added in: v14.17.0</span></p></td></tr>
284</tbody></table>
285</details>
286</div>
287<ul>
288<li><code>onMessage</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function" class="type">&#x3C;Function></a> The previous subscribed handler to remove</li>
289<li>Returns: <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Boolean_type" class="type">&#x3C;boolean></a> <code>true</code> if the handler was found, <code>false</code> otherwise.</li>
290</ul>
291<p>Remove a message handler previously registered to this channel with
292<a href="#diagnostics_channel_channel_subscribe_onmessage"><code>channel.subscribe(onMessage)</code></a>.</p>
293<pre><code class="language-js"><span class="hljs-keyword">const</span> diagnostics_channel = <span class="hljs-built_in">require</span>(<span class="hljs-string">'diagnostics_channel'</span>);
294
295<span class="hljs-keyword">const</span> channel = diagnostics_channel.<span class="hljs-title function_">channel</span>(<span class="hljs-string">'my-channel'</span>);
296
297<span class="hljs-keyword">function</span> <span class="hljs-title function_">onMessage</span>(<span class="hljs-params">message, name</span>) {
298  <span class="hljs-comment">// Received data</span>
299}
300
301channel.<span class="hljs-title function_">subscribe</span>(onMessage);
302
303channel.<span class="hljs-title function_">unsubscribe</span>(onMessage);</code></pre></section>
304        <!-- API END -->
305      </div>
306    </div>
307  </div>
308  <script>
309    'use strict';
310    {
311      const kCustomPreference = 'customDarkTheme';
312      const userSettings = sessionStorage.getItem(kCustomPreference);
313      const themeToggleButton = document.getElementById('theme-toggle-btn');
314      if (userSettings === null && window.matchMedia) {
315        const mq = window.matchMedia('(prefers-color-scheme: dark)');
316        if ('onchange' in mq) {
317          function mqChangeListener(e) {
318            document.body.classList.toggle('dark-mode', e.matches);
319          }
320          mq.addEventListener('change', mqChangeListener);
321          if (themeToggleButton) {
322            themeToggleButton.addEventListener('click', function() {
323              mq.removeEventListener('change', mqChangeListener);
324            }, { once: true });
325          }
326        }
327        if (mq.matches) {
328          document.body.classList.add('dark-mode');
329        }
330      } else if (userSettings === 'true') {
331        document.body.classList.add('dark-mode');
332      }
333      if (themeToggleButton) {
334        themeToggleButton.hidden = false;
335        themeToggleButton.addEventListener('click', function() {
336          sessionStorage.setItem(
337            kCustomPreference,
338            document.body.classList.toggle('dark-mode')
339          );
340        });
341      }
342    }
343  </script>
344</body>
345</html>
346