Tornado is a Python web framework and asynchronous networking library, originally developed at FriendFeed.
Go to file
Ben Darnell b9eb764264 ioloop: Deprecate add_callback_from_signal
I don't believe this method is currently working as intended, and I'm
not sure it ever has since the move to asyncio. I think this is
responsible for occasional test failures in CI.

Fixes #3225
2023-05-02 13:09:18 -04:00
.github/workflows ci: Only run pypi actions from the main repo 2023-04-23 21:04:56 -04:00
demos docs: Point to stable branch for all demo links 2023-02-21 21:34:38 +00:00
docs web: Restore case-insensitivity of set_cookie args 2023-04-21 15:53:30 -04:00
maint ioloop: Deprecate add_callback_from_signal 2023-05-02 13:09:18 -04:00
tornado ioloop: Deprecate add_callback_from_signal 2023-05-02 13:09:18 -04:00
.coveragerc Add .coveragerc for test coverage reporting. 2012-01-21 14:10:00 -08:00
.flake8 *: Adopt black as code formatter 2018-10-06 23:03:26 -04:00
.gitattributes test: Add gitattributes for test data files 2020-01-18 14:18:50 -05:00
.gitignore Add .mypy_cache to gitignore 2016-04-24 12:17:21 -04:00
.readthedocs.yaml Consolidate maint and docs requirements files 2023-01-20 19:52:40 +00:00
LICENSE Add top level LICENSE file 2013-08-22 19:28:35 -04:00
MANIFEST.in setup: Blacken the file 2018-10-06 23:13:06 -04:00
README.rst all: Support lazy imports of submodules 2022-11-27 15:41:27 -05:00
SECURITY.md Create security policy document 2023-01-05 11:40:24 -05:00
codecov.yml Disable intrusive codecov features 2016-05-21 18:51:33 -04:00
pyproject.toml ci: Update build workflow 2023-04-09 21:31:38 +00:00
requirements.in Update tox to v4 2023-01-20 20:35:23 +00:00
requirements.txt Update tox to v4 2023-01-20 20:35:23 +00:00
runtests.sh Remove some vestigial references to 2to3. 2014-01-19 18:55:53 -05:00
setup.cfg setup: Drop support for python 3.7 2022-11-19 17:22:36 -05:00
setup.py Use SPDX license identifier 2023-03-31 15:26:28 +02:00
tox.ini test: Streamline test configurations 2023-05-01 17:58:04 -04:00

README.rst

Tornado Web Server
==================

.. image:: https://badges.gitter.im/Join%20Chat.svg
   :alt: Join the chat at https://gitter.im/tornadoweb/tornado
   :target: https://gitter.im/tornadoweb/tornado?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge

`Tornado <http://www.tornadoweb.org>`_ is a Python web framework and
asynchronous networking library, originally developed at `FriendFeed
<http://friendfeed.com>`_.  By using non-blocking network I/O, Tornado
can scale to tens of thousands of open connections, making it ideal for
`long polling <http://en.wikipedia.org/wiki/Push_technology#Long_Polling>`_,
`WebSockets <http://en.wikipedia.org/wiki/WebSocket>`_, and other
applications that require a long-lived connection to each user.

Hello, world
------------

Here is a simple "Hello, world" example web app for Tornado:

.. code-block:: python

    import asyncio
    import tornado

    class MainHandler(tornado.web.RequestHandler):
        def get(self):
            self.write("Hello, world")

    def make_app():
        return tornado.web.Application([
            (r"/", MainHandler),
        ])

    async def main():
        app = make_app()
        app.listen(8888)
        await asyncio.Event().wait()

    if __name__ == "__main__":
        asyncio.run(main())

This example does not use any of Tornado's asynchronous features; for
that see this `simple chat room
<https://github.com/tornadoweb/tornado/tree/stable/demos/chat>`_.

Documentation
-------------

Documentation and links to additional resources are available at
https://www.tornadoweb.org