File: tornado_change_stream_example.rst

package info (click to toggle)
python-motor 3.7.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,572 kB
  • sloc: python: 12,252; javascript: 137; makefile: 74; sh: 8
file content (59 lines) | stat: -rw-r--r-- 1,943 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
.. _tornado_change_stream_example:

Tornado Change Stream Example
=============================

.. warning:: Motor will be deprecated on May 14th, 2026, one year after the production release of the PyMongo Async driver. Critical bug fixes will be made until May 14th, 2027.
  We strongly recommend that Motor users migrate to the PyMongo Async driver while Motor is still supported.
  To learn more, see `the migration guide <https://www.mongodb.com/docs/languages/python/pymongo-driver/current/reference/migration/>`_.


.. currentmodule:: motor.motor_tornado

Watch a collection for changes with :meth:`MotorCollection.watch` and display
each change notification on a web page using web sockets.

Instructions
------------

Start a MongoDB server on its default port and run this script. Then visit:

http://localhost:8888

Open a ``mongo`` shell in the terminal and perform some operations on the
"test" collection in the "test" database:

.. code-block:: text

  > use test
  switched to db test
  > db.test.insertOne({})
  > db.test.updateOne({}, {$set: {x: 1}})
  > db.test.deleteOne({})

The application receives each change notification and displays it as JSON on
the web page:

.. code-block:: text

  Changes

  {'documentKey': {'_id': ObjectId('5a2a6967ea2dcf7b1c721cfb')},
   'fullDocument': {'_id': ObjectId('5a2a6967ea2dcf7b1c721cfb')},
   'ns': {'coll': 'test', 'db': 'test'},
   'operationType': 'insert'}

  {'documentKey': {'_id': ObjectId('5a2a6967ea2dcf7b1c721cfb')},
   'ns': {'coll': 'test', 'db': 'test'},
   'operationType': 'update',
   'updateDescription': {'removedFields': [], 'updatedFields': {'x': 1.0}}}

  {'documentKey': {'_id': ObjectId('5a2a6967ea2dcf7b1c721cfb')},
   'ns': {'coll': 'test', 'db': 'test'},
   'operationType': 'delete'}

Display change notifications over a web socket
----------------------------------------------

.. literalinclude:: tornado_change_stream_example.py
  :language: python3