4994
Комментарий:
|
11622
|
Удаления помечены так. | Добавления помечены так. |
Строка 1: | Строка 1: |
= Документация в веб серверу Tornado = | = Документация к веб серверу Tornado = |
Строка 38: | Строка 38: |
Tornado тестировался на Python 2.5 и 2.6. Для того, чтобы использовать все функции Tornado, вам нужны библиотеки !PycURL !JSON, например ''simplejson''. Полные инструкции по установке на Mac OS X и Ubuntu показаны ниже. '''Mac OS X 10.5/10.6''' {{{#!highlight bash sudo easy_install setuptools pycurl==7.16.2.1 simplejson }}} '''Ubuntu Linux''' {{{#!highlight bash sudo apt-get install python-dev python-pycurl python-simplejson }}} |
|
Строка 39: | Строка 53: |
Наиболее важный модуль - ''web'', который является фреймворком, включающим в себя большую часть функционала пакета Tornado. Другие модули - это инструменты, которые делают модуль ''web'' богаче. Смотрите [[#Руководство|Руководство по Tornado]] ниже для более полной информации о пакете ''web''. |
|
Строка 42: | Строка 58: |
* [[http://github.com/facebook/tornado/blob/master/tornado/web.py|web]] - веб фреймворк, на котором построен !FriendFeed. '''web''' содержит большинство важных функций Tornado * [[http://github.com/facebook/tornado/blob/master/tornado/escape.py|escape]] - методы кодирование/декодирование XHTML, JSON и URL * [[http://github.com/facebook/tornado/blob/master/tornado/database.py|database]] - Простая обертка вокруг !MySQLdb для упрощения спользования СУБД MySQL * [[http://github.com/facebook/tornado/blob/master/tornado/template.py|template]] - язык шаблонов, в основе которого находится язык Python * [[http://github.com/facebook/tornado/blob/master/tornado/httpclient.py|httpclient]] - неблокирующий HTTP клиент созданный для работы с модулями '''web''' и '''httpserver''' * [[http://github.com/facebook/tornado/blob/master/tornado/auth.py|auth]] - реализация схем аутентификации и авторизации от третих разработчиков (Google OpenID/OAuth, Facebook Platform, Yahoo BBAuth, !FriendFeed OpenID/OAuth, Twitter OAuth) * [[http://github.com/facebook/tornado/blob/master/tornado/locale.py|locale]] - поддержка локализации/интернационализации * [[http://github.com/facebook/tornado/blob/master/tornado/options.py|options]] - синтаксический анализатор файлов настроек и аргументов коммандной строки, оптимизированный для использования в среде сервера |
|
Строка 44: | Строка 69: |
* [[http://github.com/facebook/tornado/blob/master/tornado/httpserver.py|httpserver]] - очень простой HTTP сервер, на основе которого построен модуль '''web''' * [[http://github.com/facebook/tornado/blob/master/tornado/iostream.py|iostream]] - простая обертка вокруг неблокирующих сокетов для обеспечения общих шаблонов считывания и записи * [[http://github.com/facebook/tornado/blob/master/tornado/ioloop.py|ioloop]] - основная петля ввода/вывода |
|
Строка 45: | Строка 74: |
* [[http://github.com/facebook/tornado/blob/master/tornado/s3server.py|s3server]] - веб сервер, который реализует большую часть интерфейса Amazon S3, с локальным файловым хранилищем данных |
|
Строка 49: | Строка 80: |
Веб Приложение Tornado отображает (maps) URL или шаблоны URL в подклассы '''tornado.web.!RequestHandler'''. Эти классы определяют '''get()''' и '''post()''' методы для обработки запросов HTTP GET и POST по этому URL. Этот код отображает корневой URL '''/''' в '''!MainHandler''', а шаблон URL '''/story/([0-9]+)''' в '''!StoryHandler'''. Регулярные выражения передаются в качестве аргументов методам класс '''!RequestHandler''': {{{#!highlight python class MainHandler(tornado.web.RequestHandler): def get(self): self.write("You requested the main page") class StoryHandler(tornado.web.RequestHandler): def get(self, story_id): self.write("You requested the story " + story_id) application = tornado.web.Application([ (r"/", MainHandler), (r"/story/([0-9]+)", StoryHandler), ]) }}} С помощью метода get_argument() вы можете получить аргументы строки запроса и распарсить тело POST запроса: {{{#!highlight python class MainHandler(tornado.web.RequestHandler): def get(self): self.write('<html><body><form action="/" method="post">' '<input type="text" name="message">' '<input type="submit" value="Submit">' '</form></body></html>') def post(self): self.set_header("Content-Type", "text/plain") self.write("You wrote " + self.get_argument("message")) }}} Если вы хотите отправить сообщение об ошибке клиенту, например, 403 Unauthorized, вам достаточно вызвать исключение '''tornado.web.HTTPError''': {{{#!highlight python if not self.user_is_logged_in(): raise tornado.web.HTTPError(403) }}} Обработчик запросов имеет доступ к объекту, который отражает состояние текущего запроса через атрибут '''self.request'''. Объект HTTPRequest object содержит ряд полезных атрибутов, среди них: * arguments - все аргументы GET и POST запроса * files - все загруженные файлы (через запросы '''multipart/form-data POST''') * path - путь запроса (все, что находится в строке запроса перед '''?''') * headers - заголовки запроса Смотрите определение класса HTTPRequest в модуле '''httpserver''' для получения полного списка атрибутов. |
Документация к веб серверу Tornado
Tornado - открытая версия масштабируемого, неблокирующего сервера и инструментов, которые используются сервисом FriendFeed. Приложение FriendFeed написано с использованием фреймворка, который выглядит как web.py или веб приложение Google, но имеет ряд дополнительных инструментов и оптимизаций с целью получения всех выгод от низлежащей неблокирующей инфраструктуры.
Содержание
Обзор
Веб сервер, который обслуживает сервис FriendFeed относительно простой, неблокирующий веб сервер, написанный на языке Python. Приложение FriendFeed написано с использованием веб фреймворка written using a web framework that looks a bit like web.py or Google's webapp, but with additional tools and optimizations to take advantage of the non-blocking web server and tools.
Tornado - открытая версия масштабируемого, неблокирующего сервера и инструментов, которые используются сервисом FriendFeed. Данный фреймворк отличается от большинства мейнстримовских (и, определенно, большинства Python фреймворков), потому что использование неблокирующего принципа дает достаточную быстроту. Благодаря этому, а также благодаря использованию epoll, он может обрабатывать тысячи одновременных соединений, что значит, этот фреймворк идеален для создания веб сервисов реального времени. Мы построили веб сервер специфиWe built the web server конкретно для того, чтобы обрабатывать функции сервиса FriendFeed в реальном времени — каждый активный пользователь сервися поддерживает открытое соединение с серверами. (Для получения дополнительной информации о масштабировании серверов для поддержки тисяч клиентов, прочитайте о проблеме C10K.)
Загрузка
Загрузите последнюю версию Tornado с GitHub:
На GitHub Вы также можете просмореть исходники. Чтобы установить Tornado:
После установки, вы получите возможность запустить любое из демонстрационных приложений из папки demos, которые включены в пакет Tornado.
1 ./demos/helloworld/helloworld.py
Подготовка
Tornado тестировался на Python 2.5 и 2.6. Для того, чтобы использовать все функции Tornado, вам нужны библиотеки !PycURL !JSON, например simplejson. Полные инструкции по установке на Mac OS X и Ubuntu показаны ниже.
Mac OS X 10.5/10.6
1 sudo easy_install setuptools pycurl==7.16.2.1 simplejson
Ubuntu Linux
1 sudo apt-get install python-dev python-pycurl python-simplejson
Список модулей
Наиболее важный модуль - web, который является фреймворком, включающим в себя большую часть функционала пакета Tornado. Другие модули - это инструменты, которые делают модуль web богаче. Смотрите Руководство по Tornado ниже для более полной информации о пакете web.
Основные модули
web - веб фреймворк, на котором построен FriendFeed. web содержит большинство важных функций Tornado
escape - методы кодирование/декодирование XHTML, JSON и URL
database - Простая обертка вокруг !MySQLdb для упрощения спользования СУБД MySQL
template - язык шаблонов, в основе которого находится язык Python
httpclient - неблокирующий HTTP клиент созданный для работы с модулями web и httpserver
auth - реализация схем аутентификации и авторизации от третих разработчиков (Google OpenID/OAuth, Facebook Platform, Yahoo BBAuth, FriendFeed OpenID/OAuth, Twitter OAuth)
locale - поддержка локализации/интернационализации
options - синтаксический анализатор файлов настроек и аргументов коммандной строки, оптимизированный для использования в среде сервера
Низкоуровневые модули
httpserver - очень простой HTTP сервер, на основе которого построен модуль web
iostream - простая обертка вокруг неблокирующих сокетов для обеспечения общих шаблонов считывания и записи
ioloop - основная петля ввода/вывода
Другие модули
s3server - веб сервер, который реализует большую часть интерфейса Amazon S3, с локальным файловым хранилищем данных
Руководство
Обработчики и параметры запросов
Веб Приложение Tornado отображает (maps) URL или шаблоны URL в подклассы tornado.web.RequestHandler. Эти классы определяют get() и post() методы для обработки запросов HTTP GET и POST по этому URL.
Этот код отображает корневой URL / в MainHandler, а шаблон URL /story/([0-9]+) в StoryHandler. Регулярные выражения передаются в качестве аргументов методам класс RequestHandler:
1 class MainHandler(tornado.web.RequestHandler):
2 def get(self):
3 self.write("You requested the main page")
4
5 class StoryHandler(tornado.web.RequestHandler):
6 def get(self, story_id):
7 self.write("You requested the story " + story_id)
8
9 application = tornado.web.Application([
10 (r"/", MainHandler),
11 (r"/story/([0-9]+)", StoryHandler),
12 ])
С помощью метода get_argument() вы можете получить аргументы строки запроса и распарсить тело POST запроса:
1 class MainHandler(tornado.web.RequestHandler):
2 def get(self):
3 self.write('<html><body><form action="/" method="post">'
4 '<input type="text" name="message">'
5 '<input type="submit" value="Submit">'
6 '</form></body></html>')
7
8 def post(self):
9 self.set_header("Content-Type", "text/plain")
10 self.write("You wrote " + self.get_argument("message"))
Если вы хотите отправить сообщение об ошибке клиенту, например, 403 Unauthorized, вам достаточно вызвать исключение tornado.web.HTTPError:
Обработчик запросов имеет доступ к объекту, который отражает состояние текущего запроса через атрибут self.request. Объект HTTPRequest object содержит ряд полезных атрибутов, среди них:
- arguments - все аргументы GET и POST запроса
files - все загруженные файлы (через запросы multipart/form-data POST)
path - путь запроса (все, что находится в строке запроса перед ?)
- headers - заголовки запроса
Смотрите определение класса HTTPRequest в модуле httpserver для получения полного списка атрибутов.
Шаблоны
Cookies и защищенные cookies
Аутентификация пользователей
Защита от CSRF
Статические файлы и агрессивное кеширование файлов
Локализация
Модули пользовательского интерфейса
Неблокирующие, асинхронные запросы
Аутентификация от третих разработчиков
Производительность
Запуск Tornado на производстве
WSGI и Google AppEngine
Предостережения и поддержка
Перевод: Ростислав Дзинько