PageRenderTime 30ms CodeModel.GetById 15ms RepoModel.GetById 0ms app.codeStats 0ms

/blog/2012/01/15/django-logging/index.html

https://github.com/pfarmer/pfarmer.github.com
HTML | 239 lines | 202 code | 35 blank | 2 comment | 0 complexity | a5700043049a5301dc670b69d0f27cba MD5 | raw file
  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <title>Django logging &mdash; projectchilli.com</title>
  6. <link rel="stylesheet" href="../../../../../_static/basic.css" type="text/css" />
  7. <link rel="stylesheet" href="../../../../../_static/pygments.css" type="text/css" />
  8. <link rel="stylesheet" href="../../../../../_static/my-styles.css" type="text/css" />
  9. <link rel="stylesheet" href="../../../../../_static/bootswatch-3.3.6/united/bootstrap.min.css" type="text/css" />
  10. <link rel="stylesheet" href="../../../../../_static/bootstrap-sphinx.css" type="text/css" />
  11. <script type="text/javascript">
  12. var DOCUMENTATION_OPTIONS = {
  13. URL_ROOT: '../../../../../',
  14. VERSION: '0.4.9',
  15. COLLAPSE_INDEX: false,
  16. FILE_SUFFIX: '.html',
  17. HAS_SOURCE: true
  18. };
  19. </script>
  20. <script type="text/javascript" src="../../../../../_static/jquery.js"></script>
  21. <script type="text/javascript" src="../../../../../_static/underscore.js"></script>
  22. <script type="text/javascript" src="../../../../../_static/doctools.js"></script>
  23. <script type="text/javascript" src="../../../../../_static/js/jquery-1.11.0.min.js"></script>
  24. <script type="text/javascript" src="../../../../../_static/js/jquery-fix.js"></script>
  25. <script type="text/javascript" src="../../../../../_static/bootstrap-3.3.6/js/bootstrap.min.js"></script>
  26. <script type="text/javascript" src="../../../../../_static/bootstrap-sphinx.js"></script>
  27. <link rel="author" title="About these documents" href="../../../../../about.html" />
  28. <link rel="top" title="projectchilli.com" href="../../../../../index.html" />
  29. <meta charset='utf-8'>
  30. <meta http-equiv='X-UA-Compatible' content='IE=edge,chrome=1'>
  31. <meta name='viewport' content='width=device-width, initial-scale=1.0, maximum-scale=1'>
  32. <meta name="apple-mobile-web-app-capable" content="yes">
  33. </head>
  34. <body>
  35. <div id="navbar" class="navbar navbar-default navbar-fixed-top">
  36. <div class="container">
  37. <div class="navbar-header">
  38. <!-- .btn-navbar is used as the toggle for collapsed navbar content -->
  39. <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".nav-collapse">
  40. <span class="icon-bar"></span>
  41. <span class="icon-bar"></span>
  42. <span class="icon-bar"></span>
  43. </button>
  44. <a class="navbar-brand" href="../../../../../index.html">
  45. projectchilli.com</a>
  46. <!-- <span class="navbar-text navbar-version pull-left"><b>0.4.9</b></span> -->
  47. </div>
  48. <div class="collapse navbar-collapse nav-collapse">
  49. <ul class="nav navbar-nav">
  50. <li class="dropdown globaltoc-container">
  51. <a role="button"
  52. id="dLabelGlobalToc"
  53. data-toggle="dropdown"
  54. data-target="#"
  55. href="../../../../../index.html">Site <b class="caret"></b></a>
  56. <ul class="dropdown-menu globaltoc"
  57. role="menu"
  58. aria-labelledby="dLabelGlobalToc"></ul>
  59. </li>
  60. <li class="dropdown">
  61. <a role="button"
  62. id="dLabelLocalToc"
  63. data-toggle="dropdown"
  64. data-target="#"
  65. href="#">Page <b class="caret"></b></a>
  66. <ul class="dropdown-menu localtoc"
  67. role="menu"
  68. aria-labelledby="dLabelLocalToc"><ul>
  69. <li><a class="reference internal" href="#">Django logging</a><ul>
  70. <li><a class="reference internal" href="#set-debug-to-false-in-your-settings-py-file">1. Set DEBUG to False in your settings.py file:</a></li>
  71. <li><a class="reference internal" href="#update-the-logging-section-in-settings-py">2. Update the logging section in settings.py:</a></li>
  72. <li><a class="reference internal" href="#make-sure-you-have-a-500-html-template-in-place">3. Make sure you have a 500.html template in place.</a></li>
  73. <li><a class="reference internal" href="#the-added-bonus">4. The added bonus....</a></li>
  74. <li><a class="reference internal" href="#then-use-code-like-this-to-log-messages">5. Then use code like this to log messages:</a></li>
  75. </ul>
  76. </li>
  77. </ul>
  78. </ul>
  79. </li>
  80. <li class="hidden-sm">
  81. <div id="sourcelink">
  82. <a href="../../../../../_sources/blog/2012/01/15/django-logging/index.txt"
  83. rel="nofollow">Source</a>
  84. </div></li>
  85. </ul>
  86. <form class="navbar-form navbar-right" action="../../../../../search.html" method="get">
  87. <div class="form-group">
  88. <input type="text" name="q" class="form-control" placeholder="Search" />
  89. </div>
  90. <input type="hidden" name="check_keywords" value="yes" />
  91. <input type="hidden" name="area" value="default" />
  92. </form>
  93. </div>
  94. </div>
  95. </div>
  96. <div class="container">
  97. <div class="row">
  98. <div class="col-md-12 content">
  99. <div class="section" id="django-logging">
  100. <h1>Django logging</h1>
  101. <p>Date: <strong>2012-01-15</strong></p>
  102. <div class="admonition note">
  103. <p class="first admonition-title">Note</p>
  104. <p class="last"><strong>2016-06-29</strong> - I&#8217;ll be writing an updated version of this post very soon.</p>
  105. </div>
  106. <p>I frequently write small APIs using a python web framework called django, but when making test calls to the API with curl (or even urllib2) getting the massive DEBUG=True exception page back can be pain. So by using the logging framework you can set DEBUG to False and watch for your exceptions in a log. Here&#8217;s how:</p>
  107. <div class="section" id="set-debug-to-false-in-your-settings-py-file">
  108. <h2>1. Set DEBUG to False in your settings.py file:</h2>
  109. <div class="code python highlight-python"><div class="highlight"><pre><span></span><span class="n">DEBUG</span><span class="o">=</span><span class="bp">False</span>
  110. </pre></div>
  111. </div>
  112. </div>
  113. <div class="section" id="update-the-logging-section-in-settings-py">
  114. <h2>2. Update the logging section in settings.py:</h2>
  115. <div class="code python highlight-python"><div class="highlight"><pre><span></span><span class="n">APPHOME</span><span class="o">=</span><span class="s2">&quot;/home/pfarmer/projectname&quot;</span>
  116. <span class="n">LOGGING</span> <span class="o">=</span> <span class="p">{</span>
  117. <span class="s1">&#39;version&#39;</span><span class="p">:</span> <span class="mi">1</span><span class="p">,</span>
  118. <span class="s1">&#39;disable_existing_loggers&#39;</span><span class="p">:</span> <span class="bp">True</span><span class="p">,</span>
  119. <span class="s1">&#39;formatters&#39;</span><span class="p">:</span> <span class="p">{</span>
  120. <span class="s1">&#39;standard&#39;</span><span class="p">:</span> <span class="p">{</span>
  121. <span class="s1">&#39;format&#39;</span><span class="p">:</span> <span class="s1">&#39;</span><span class="si">%(asctime)s</span><span class="s1"> [</span><span class="si">%(levelname)s</span><span class="s1">] </span><span class="si">%(name)s</span><span class="s1">: </span><span class="si">%(message)s</span><span class="s1">&#39;</span>
  122. <span class="p">},</span>
  123. <span class="p">},</span>
  124. <span class="s1">&#39;handlers&#39;</span><span class="p">:</span> <span class="p">{</span>
  125. <span class="s1">&#39;default&#39;</span><span class="p">:</span> <span class="p">{</span>
  126. <span class="s1">&#39;level&#39;</span><span class="p">:</span><span class="s1">&#39;DEBUG&#39;</span><span class="p">,</span>
  127. <span class="s1">&#39;class&#39;</span><span class="p">:</span><span class="s1">&#39;logging.handlers.RotatingFileHandler&#39;</span><span class="p">,</span>
  128. <span class="s1">&#39;filename&#39;</span><span class="p">:</span> <span class="s1">&#39;</span><span class="si">%s</span><span class="s1">/logs/default.log&#39;</span> <span class="o">%</span> <span class="n">APPHOME</span><span class="p">,</span>
  129. <span class="s1">&#39;maxBytes&#39;</span><span class="p">:</span> <span class="mi">1024</span><span class="o">*</span><span class="mi">1024</span><span class="o">*</span><span class="mi">5</span><span class="p">,</span> <span class="c1"># 5 MB</span>
  130. <span class="s1">&#39;backupCount&#39;</span><span class="p">:</span> <span class="mi">5</span><span class="p">,</span>
  131. <span class="s1">&#39;formatter&#39;</span><span class="p">:</span><span class="s1">&#39;standard&#39;</span><span class="p">,</span>
  132. <span class="p">},</span>
  133. <span class="s1">&#39;request_handler&#39;</span><span class="p">:</span> <span class="p">{</span>
  134. <span class="s1">&#39;level&#39;</span><span class="p">:</span><span class="s1">&#39;DEBUG&#39;</span><span class="p">,</span>
  135. <span class="s1">&#39;class&#39;</span><span class="p">:</span><span class="s1">&#39;logging.handlers.RotatingFileHandler&#39;</span><span class="p">,</span>
  136. <span class="s1">&#39;filename&#39;</span><span class="p">:</span> <span class="s1">&#39;</span><span class="si">%s</span><span class="s1">/logs/django_request.log&#39;</span> <span class="o">%</span> <span class="n">APPHOME</span><span class="p">,</span>
  137. <span class="s1">&#39;maxBytes&#39;</span><span class="p">:</span> <span class="mi">1024</span><span class="o">*</span><span class="mi">1024</span><span class="o">*</span><span class="mi">5</span><span class="p">,</span> <span class="c1"># 5 MB</span>
  138. <span class="s1">&#39;backupCount&#39;</span><span class="p">:</span> <span class="mi">5</span><span class="p">,</span>
  139. <span class="s1">&#39;formatter&#39;</span><span class="p">:</span><span class="s1">&#39;standard&#39;</span><span class="p">,</span>
  140. <span class="p">},</span>
  141. <span class="p">},</span>
  142. <span class="s1">&#39;loggers&#39;</span><span class="p">:</span> <span class="p">{</span>
  143. <span class="s1">&#39;&#39;</span><span class="p">:</span> <span class="p">{</span>
  144. <span class="s1">&#39;handlers&#39;</span><span class="p">:</span> <span class="p">[</span><span class="s1">&#39;default&#39;</span><span class="p">],</span>
  145. <span class="s1">&#39;level&#39;</span><span class="p">:</span> <span class="s1">&#39;DEBUG&#39;</span><span class="p">,</span>
  146. <span class="s1">&#39;propagate&#39;</span><span class="p">:</span> <span class="bp">True</span>
  147. <span class="p">},</span>
  148. <span class="s1">&#39;django.request&#39;</span><span class="p">:</span> <span class="p">{</span> <span class="c1"># Stop SQL debug from logging to main logger</span>
  149. <span class="s1">&#39;handlers&#39;</span><span class="p">:</span> <span class="p">[</span><span class="s1">&#39;request_handler&#39;</span><span class="p">],</span>
  150. <span class="s1">&#39;level&#39;</span><span class="p">:</span> <span class="s1">&#39;DEBUG&#39;</span><span class="p">,</span>
  151. <span class="s1">&#39;propagate&#39;</span><span class="p">:</span> <span class="bp">False</span>
  152. <span class="p">},</span>
  153. <span class="p">}</span>
  154. <span class="p">}</span>
  155. </pre></div>
  156. </div>
  157. <p>Now when some code causes an exception, the traceback should appear in &lt;span class=&#8221;bold&#8221;&gt;django_request.log&lt;/span&gt;</p>
  158. </div>
  159. <div class="section" id="make-sure-you-have-a-500-html-template-in-place">
  160. <h2>3. Make sure you have a 500.html template in place.</h2>
  161. </div>
  162. <div class="section" id="the-added-bonus">
  163. <h2>4. The added bonus....</h2>
  164. <p>The added bonus is you can use the standard python logging module to log during view execution, add the following to each of your views.py:</p>
  165. <div class="code python highlight-python"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="nn">logging</span>
  166. <span class="n">log</span> <span class="o">=</span> <span class="n">logging</span><span class="o">.</span><span class="n">getLogger</span><span class="p">(</span><span class="n">__name__</span><span class="p">)</span>
  167. </pre></div>
  168. </div>
  169. </div>
  170. <div class="section" id="then-use-code-like-this-to-log-messages">
  171. <h2>5. Then use code like this to log messages:</h2>
  172. <div class="code python highlight-python"><div class="highlight"><pre><span></span>log.debug(&quot;API login attempt for %s&quot; request.GET[&#39;user&#39;])
  173. </pre></div>
  174. </div>
  175. <p>This will appear in the log like this::</p>
  176. <div class="highlight-python"><div class="highlight"><pre><span></span>2011-11-16 23:02:32,339 [DEBUG] api.views: API login attempt for pfarmer
  177. </pre></div>
  178. </div>
  179. </div>
  180. </div>
  181. </div>
  182. </div>
  183. </div>
  184. <footer class="footer">
  185. <div class="container">
  186. <p class="pull-right">
  187. <a href="#">Back to top</a>
  188. </p>
  189. <p>
  190. &copy; Copyright 2011-2016, Peter Farmer.<br/>
  191. Created using <a href="http://sphinx-doc.org/">Sphinx</a> 1.2.1.<br/>
  192. </p>
  193. </div>
  194. </footer>
  195. <script>
  196. (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
  197. (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
  198. m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
  199. })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
  200. ga('create', 'UA-322710-20', 'auto');
  201. ga('send', 'pageview');
  202. </script>
  203. </body>
  204. </html>