summaryrefslogtreecommitdiffstats
path: root/Doc/howto
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2024-04-04 13:19:10 (GMT)
committerGitHub <noreply@github.com>2024-04-04 13:19:10 (GMT)
commit663e7bc2eed89c72e795d7b855c7ff283c0264c1 (patch)
treee2ae65f1a9481139f5b15184183f87e92a0701dc /Doc/howto
parentb5e12aa9ff581dd677d9b5f7adeb672cfb52068e (diff)
downloadcpython-663e7bc2eed89c72e795d7b855c7ff283c0264c1.zip
cpython-663e7bc2eed89c72e795d7b855c7ff283c0264c1.tar.gz
cpython-663e7bc2eed89c72e795d7b855c7ff283c0264c1.tar.bz2
[3.12] [doc] Update logging documentation to improve grammar and elucidate an example. (GH-117541) (GH-117542)
(cherry picked from commit df912c913a3d94995b379f1e19fe0a79acab6169)
Diffstat (limited to 'Doc/howto')
-rw-r--r--Doc/howto/logging-cookbook.rst68
1 files changed, 64 insertions, 4 deletions
diff --git a/Doc/howto/logging-cookbook.rst b/Doc/howto/logging-cookbook.rst
index fe13a7c..d7b282a 100644
--- a/Doc/howto/logging-cookbook.rst
+++ b/Doc/howto/logging-cookbook.rst
@@ -1915,7 +1915,7 @@ In a similar way to the above section, we can implement a listener and handler
using `pynng <https://pypi.org/project/pynng/>`_, which is a Python binding to
`NNG <https://nng.nanomsg.org/>`_, billed as a spiritual successor to ZeroMQ.
The following snippets illustrate -- you can test them in an environment which has
-``pynng`` installed. Juat for variety, we present the listener first.
+``pynng`` installed. Just for variety, we present the listener first.
Subclass ``QueueListener``
@@ -1923,6 +1923,7 @@ Subclass ``QueueListener``
.. code-block:: python
+ # listener.py
import json
import logging
import logging.handlers
@@ -1955,7 +1956,7 @@ Subclass ``QueueListener``
break
except pynng.Timeout:
pass
- except pynng.Closed: # sometimes hit when you hit Ctrl-C
+ except pynng.Closed: # sometimes happens when you hit Ctrl-C
break
if data is None:
return None
@@ -1988,6 +1989,7 @@ Subclass ``QueueHandler``
.. code-block:: python
+ # sender.py
import json
import logging
import logging.handlers
@@ -2015,9 +2017,10 @@ Subclass ``QueueHandler``
logging.getLogger('pynng').propagate = False
handler = NNGSocketHandler(DEFAULT_ADDR)
+ # Make sure the process ID is in the output
logging.basicConfig(level=logging.DEBUG,
handlers=[logging.StreamHandler(), handler],
- format='%(levelname)-8s %(name)10s %(message)s')
+ format='%(levelname)-8s %(name)10s %(process)6s %(message)s')
levels = (logging.DEBUG, logging.INFO, logging.WARNING, logging.ERROR,
logging.CRITICAL)
logger_names = ('myapp', 'myapp.lib1', 'myapp.lib2')
@@ -2031,7 +2034,64 @@ Subclass ``QueueHandler``
delay = random.random() * 2 + 0.5
time.sleep(delay)
-You can run the above two snippets in separate command shells.
+You can run the above two snippets in separate command shells. If we run the
+listener in one shell and run the sender in two separate shells, we should see
+something like the following. In the first sender shell:
+
+.. code-block:: console
+
+ $ python sender.py
+ DEBUG myapp 613 Message no. 1
+ WARNING myapp.lib2 613 Message no. 2
+ CRITICAL myapp.lib2 613 Message no. 3
+ WARNING myapp.lib2 613 Message no. 4
+ CRITICAL myapp.lib1 613 Message no. 5
+ DEBUG myapp 613 Message no. 6
+ CRITICAL myapp.lib1 613 Message no. 7
+ INFO myapp.lib1 613 Message no. 8
+ (and so on)
+
+In the second sender shell:
+
+.. code-block:: console
+
+ $ python sender.py
+ INFO myapp.lib2 657 Message no. 1
+ CRITICAL myapp.lib2 657 Message no. 2
+ CRITICAL myapp 657 Message no. 3
+ CRITICAL myapp.lib1 657 Message no. 4
+ INFO myapp.lib1 657 Message no. 5
+ WARNING myapp.lib2 657 Message no. 6
+ CRITICAL myapp 657 Message no. 7
+ DEBUG myapp.lib1 657 Message no. 8
+ (and so on)
+
+In the listener shell:
+
+.. code-block:: console
+
+ $ python listener.py
+ Press Ctrl-C to stop.
+ DEBUG myapp 613 Message no. 1
+ WARNING myapp.lib2 613 Message no. 2
+ INFO myapp.lib2 657 Message no. 1
+ CRITICAL myapp.lib2 613 Message no. 3
+ CRITICAL myapp.lib2 657 Message no. 2
+ CRITICAL myapp 657 Message no. 3
+ WARNING myapp.lib2 613 Message no. 4
+ CRITICAL myapp.lib1 613 Message no. 5
+ CRITICAL myapp.lib1 657 Message no. 4
+ INFO myapp.lib1 657 Message no. 5
+ DEBUG myapp 613 Message no. 6
+ WARNING myapp.lib2 657 Message no. 6
+ CRITICAL myapp 657 Message no. 7
+ CRITICAL myapp.lib1 613 Message no. 7
+ INFO myapp.lib1 613 Message no. 8
+ DEBUG myapp.lib1 657 Message no. 8
+ (and so on)
+
+As you can see, the logging from the two sender processes is interleaved in the
+listener's output.
An example dictionary-based configuration