|  | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | 
|  | <html xmlns="http://www.w3.org/1999/xhtml"> | 
|  | <head> | 
|  | <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> | 
|  | <meta http-equiv="X-UA-Compatible" content="IE=9"/> | 
|  | <meta name="generator" content="Doxygen 1.8.14"/> | 
|  | <meta name="viewport" content="width=device-width, initial-scale=1"/> | 
|  | <title>Paho Asynchronous MQTT C Client Library: Tracing</title> | 
|  | <link href="tabs.css" rel="stylesheet" type="text/css"/> | 
|  | <script type="text/javascript" src="jquery.js"></script> | 
|  | <script type="text/javascript" src="dynsections.js"></script> | 
|  | <link href="search/search.css" rel="stylesheet" type="text/css"/> | 
|  | <script type="text/javascript" src="search/searchdata.js"></script> | 
|  | <script type="text/javascript" src="search/search.js"></script> | 
|  | <link href="doxygen.css" rel="stylesheet" type="text/css" /> | 
|  | </head> | 
|  | <body> | 
|  | <div id="top"><!-- do not remove this div, it is closed by doxygen! --> | 
|  | <div id="titlearea"> | 
|  | <table cellspacing="0" cellpadding="0"> | 
|  | <tbody> | 
|  | <tr style="height: 56px;"> | 
|  | <td id="projectlogo"><img alt="Logo" src="pahologo.png"/></td> | 
|  | <td id="projectalign" style="padding-left: 0.5em;"> | 
|  | <div id="projectname">Paho Asynchronous MQTT C Client Library | 
|  | </div> | 
|  | </td> | 
|  | </tr> | 
|  | </tbody> | 
|  | </table> | 
|  | </div> | 
|  | <!-- end header part --> | 
|  | <!-- Generated by Doxygen 1.8.14 --> | 
|  | <script type="text/javascript"> | 
|  | /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ | 
|  | var searchBox = new SearchBox("searchBox", "search",false,'Search'); | 
|  | /* @license-end */ | 
|  | </script> | 
|  | <script type="text/javascript" src="menudata.js"></script> | 
|  | <script type="text/javascript" src="menu.js"></script> | 
|  | <script type="text/javascript"> | 
|  | /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ | 
|  | $(function() { | 
|  | initMenu('',true,false,'search.php','Search'); | 
|  | $(document).ready(function() { init_search(); }); | 
|  | }); | 
|  | /* @license-end */</script> | 
|  | <div id="main-nav"></div> | 
|  | <!-- window showing the filter options --> | 
|  | <div id="MSearchSelectWindow" | 
|  | onmouseover="return searchBox.OnSearchSelectShow()" | 
|  | onmouseout="return searchBox.OnSearchSelectHide()" | 
|  | onkeydown="return searchBox.OnSearchSelectKey(event)"> | 
|  | </div> | 
|  |  | 
|  | <!-- iframe showing the search results (closed by default) --> | 
|  | <div id="MSearchResultsWindow"> | 
|  | <iframe src="javascript:void(0)" frameborder="0" | 
|  | name="MSearchResults" id="MSearchResults"> | 
|  | </iframe> | 
|  | </div> | 
|  |  | 
|  | </div><!-- top --> | 
|  | <div class="header"> | 
|  | <div class="headertitle"> | 
|  | <div class="title">Tracing </div>  </div> | 
|  | </div><!--header--> | 
|  | <div class="contents"> | 
|  | <div class="textblock"><p>Runtime tracing can be controlled by environment variables or API calls.</p> | 
|  | <h4>Environment variables</h4> | 
|  | <p>Tracing is switched on by setting the MQTT_C_CLIENT_TRACE environment variable. A value of ON, or stdout, prints to stdout, any other value is interpreted as a file name to use.</p> | 
|  | <p>The amount of trace detail is controlled with the MQTT_C_CLIENT_TRACE_LEVEL environment variable - valid values are ERROR, PROTOCOL, MINIMUM, MEDIUM and MAXIMUM (from least to most verbose).</p> | 
|  | <p>The variable MQTT_C_CLIENT_TRACE_MAX_LINES limits the number of lines of trace that are output to a file. Two files are used at most, when they are full, the last one is overwritten with the new trace entries. The default size is 1000 lines.</p> | 
|  | <h4>Trace API calls</h4> | 
|  | <p><a class="el" href="_m_q_t_t_async_8h.html#a65aba1caeae9b5af5d5b6c5598a75b02">MQTTAsync_traceCallback()</a> is used to set a callback function which is called whenever trace information is available. This will be the same information as that printed if the environment variables were used to control the trace.</p> | 
|  | <p>The <a class="el" href="_m_q_t_t_async_8h.html#ac7fbab13a0b2e5dd4ee11efbbb9f6a3a">MQTTAsync_setTraceLevel()</a> calls is used to set the maximum level of trace entries that will be passed to the callback function. The levels are:</p><ol type="1"> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5af684f42971cced68693ce993703548c1">MQTTASYNC_TRACE_MAXIMUM</a></li> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5a133c380b84d75477ff31a2ad732133ce">MQTTASYNC_TRACE_MEDIUM</a></li> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5a7a45c26816b1cac1fde02d79a9f4337b">MQTTASYNC_TRACE_MINIMUM</a></li> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5a6a719b2b7fc4dfc41494370ff96fec3e">MQTTASYNC_TRACE_PROTOCOL</a></li> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5ac428f74ca453dacb7b8271ca741266e8">MQTTASYNC_TRACE_ERROR</a></li> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5a3084770185f384398cefe4aaba533d40">MQTTASYNC_TRACE_SEVERE</a></li> | 
|  | <li><a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5a0b91d2213ebb6655e41a7f6ce1a42295">MQTTASYNC_TRACE_FATAL</a></li> | 
|  | </ol> | 
|  | <p>Selecting <a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5af684f42971cced68693ce993703548c1">MQTTASYNC_TRACE_MAXIMUM</a> will cause all trace entries at all levels to be returned. Choosing <a class="el" href="_m_q_t_t_async_8h.html#a5de816f986b318947709a34e0787eda5ac428f74ca453dacb7b8271ca741266e8">MQTTASYNC_TRACE_ERROR</a> will cause ERROR, SEVERE and FATAL trace entries to be returned to the callback function.</p> | 
|  | <h3>MQTT Packet Tracing</h3> | 
|  | <p>A feature that can be very useful is printing the MQTT packets that are sent and received. To achieve this, use the following environment variable settings: </p><div class="fragment"><div class="line">MQTT_C_CLIENT_TRACE=ON</div><div class="line">MQTT_C_CLIENT_TRACE_LEVEL=PROTOCOL</div></div><!-- fragment --><p> The output you should see looks like this: </p><div class="fragment"><div class="line">20130528 155936.813 3 stdout-subscriber -> CONNECT cleansession: 1 (0)</div><div class="line">20130528 155936.813 3 stdout-subscriber <- CONNACK rc: 0</div><div class="line">20130528 155936.813 3 stdout-subscriber -> SUBSCRIBE msgid: 1 (0)</div><div class="line">20130528 155936.813 3 stdout-subscriber <- SUBACK msgid: 1</div><div class="line">20130528 155941.818 3 stdout-subscriber -> DISCONNECT (0)</div></div><!-- fragment --><p> where the fields are:</p><ol type="1"> | 
|  | <li>date</li> | 
|  | <li>time</li> | 
|  | <li>socket number</li> | 
|  | <li>client id</li> | 
|  | <li>direction (-> from client to server, <- from server to client)</li> | 
|  | <li>packet details</li> | 
|  | </ol> | 
|  | <h3>Default Level Tracing</h3> | 
|  | <p>This is an extract of a default level trace of a call to connect: </p><div class="fragment"><div class="line">19700101 010000.000 (1152206656) (0)> MQTTClient_connect:893</div><div class="line">19700101 010000.000 (1152206656)  (1)> MQTTClient_connectURI:716</div><div class="line">20130528 160447.479 Connecting to serverURI localhost:1883</div><div class="line">20130528 160447.479 (1152206656)   (2)> MQTTProtocol_connect:98</div><div class="line">20130528 160447.479 (1152206656)    (3)> MQTTProtocol_addressPort:48</div><div class="line">20130528 160447.479 (1152206656)    (3)< MQTTProtocol_addressPort:73</div><div class="line">20130528 160447.479 (1152206656)    (3)> Socket_new:599</div><div class="line">20130528 160447.479 New socket 4 <span class="keywordflow">for</span> localhost, port 1883</div><div class="line">20130528 160447.479 (1152206656)     (4)> Socket_addSocket:163</div><div class="line">20130528 160447.479 (1152206656)      (5)> Socket_setnonblocking:73</div><div class="line">20130528 160447.479 (1152206656)      (5)< Socket_setnonblocking:78 (0)</div><div class="line">20130528 160447.479 (1152206656)     (4)< Socket_addSocket:176 (0)</div><div class="line">20130528 160447.479 (1152206656)     (4)> Socket_error:95</div><div class="line">20130528 160447.479 (1152206656)     (4)< Socket_error:104 (115)</div><div class="line">20130528 160447.479 Connect pending</div><div class="line">20130528 160447.479 (1152206656)    (3)< Socket_new:683 (115)</div><div class="line">20130528 160447.479 (1152206656)   (2)< MQTTProtocol_connect:131 (115)</div></div><!-- fragment --><p> where the fields are:</p><ol type="1"> | 
|  | <li>date</li> | 
|  | <li>time</li> | 
|  | <li>thread id</li> | 
|  | <li>function nesting level</li> | 
|  | <li>function entry (>) or exit (<)</li> | 
|  | <li>function name : line of source code file</li> | 
|  | <li>return value (if there is one)</li> | 
|  | </ol> | 
|  | <h3>Memory Allocation Tracing</h3> | 
|  | <p>Setting the trace level to maximum causes memory allocations and frees to be traced along with the default trace entries, with messages like the following: </p><div class="fragment"><div class="line">20130528 161819.657 Allocating 16 bytes in heap at file /home/icraggs/workspaces/mqrtc/mqttv3c/src/MQTTPacket.c line 177 ptr 0x179f930</div><div class="line"></div><div class="line">20130528 161819.657 Freeing 16 bytes in heap at file /home/icraggs/workspaces/mqrtc/mqttv3c/src/MQTTPacket.c line 201, heap use now 896 bytes</div></div><!-- fragment --><p> When the last MQTT client object is destroyed, if the trace is being recorded and all memory allocated by the client library has not been freed, an error message will be written to the trace. This can help with fixing memory leaks. The message will look like this: </p><div class="fragment"><div class="line">20130528 163909.208 Some memory not freed at shutdown, possible memory leak</div><div class="line">20130528 163909.208 Heap scan start, total 880 bytes</div><div class="line">20130528 163909.208 Heap element size 32, line 354, file /home/icraggs/workspaces/mqrtc/mqttv3c/src/MQTTPacket.c, ptr 0x260cb00</div><div class="line">20130528 163909.208   Content</div><div class="line">20130528 163909.209 Heap scan end</div></div><!-- fragment --> </div></div><!-- contents --> | 
|  | <!-- start footer part --> | 
|  | <hr class="footer"/><address class="footer"><small> | 
|  | Generated on Thu Sep 13 2018 13:40:20 for Paho Asynchronous MQTT C Client Library by  <a href="http://www.doxygen.org/index.html"> | 
|  | <img class="footer" src="doxygen.png" alt="doxygen"/> | 
|  | </a> 1.8.14 | 
|  | </small></address> | 
|  | </body> | 
|  | </html> |