Python.
И веб-разработка.
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
data:image/s3,"s3://crabby-images/0aa91/0aa9194fbc7f51baccb0bc937a3df623dd388b02" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Что это?
Веб-разработка
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Составные части
data:image/s3,"s3://crabby-images/0e005/0e005d6223515cd6c87b596410ce082be2319b59" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Фронтенд
data:image/s3,"s3://crabby-images/cff92/cff9213187d19a72b704c5eeaf6fcdc7279e0b8b" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
HTML
<!DOCTYPE html>
<html>
<head>
<title>My title</title>
</head>
<body>
<h1>Heading</h1>
<p>Paragraph.</p>
</body>
</html>
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
CSS
h1 {
color: blue;
font-family: verdana;
font-size: 300%;
}
p {
color: red;
font-family: courier;
font-size: 160%;
}
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
JavaScript
function myFunction() {
var x = document.getElementById("form");
var text = "";
var i;
for (i = 0; i < x.length; i++) {
text += x.elements[i].value + "<br>";
}
document.getElementById("output").innerHTML = text;
}
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Подходы к организации web-приложений
- Отдельные ресурсы для каждого адреса
- Single-page applications (SPA)
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Популярные js-библиотеки
- Angular JS
- ReactJS
- Миллион других
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Темная сторона бекенда
Почему Python?
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Темная сторона бекенда
"Чистый" Python или фреймворк?
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Что должен уметь бекенд
- Бизнес-логика приложения, работа с базой данных
- Входные точки - обработка HTTP запросов
- Подготовка ответа - сериализованные данные (JSON) или server-side шаблонизация
- Авторизация
- Кеширование, логирование, отказоустойчивость, производительность
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Python web-фреймворки
- Django
- Flask
- Bottle
- Tornado
- Многие другие
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
WSGI
https://www.python.org/dev/peps/pep-0333/
data:image/s3,"s3://crabby-images/0253d/0253d5fe544e283e40aeae6ebdb229d82ede2b3c" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Bottle
from bottle import route, run, template
@route('/hello/<name>')
def index(name):
return template('<b>Hello {{name}}</b>!', name=name)
run(host='localhost', port=8080)
data:image/s3,"s3://crabby-images/66a07/66a07c30923b29a81711850d01b3f1f038a5873c" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Flask
from flask import Flask
app = Flask(__name__)
@app.route("/")
def hello():
return "Hello World!"
if __name__ == "__main__":
app.run()
data:image/s3,"s3://crabby-images/14ca5/14ca5358e4995fad8d5504b1f68908e691caa624" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Tornado
import tornado.ioloop
import tornado.web
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.write("Hello, world")
def make_app():
return tornado.web.Application([
(r"/", MainHandler),
])
if __name__ == "__main__":
app = make_app()
app.listen(8888)
tornado.ioloop.IOLoop.current().start()
data:image/s3,"s3://crabby-images/e35ca/e35ca54ab6a2e28acbaa70428e4886219e4bb2d7" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
MVC
data:image/s3,"s3://crabby-images/11c2a/11c2ac2f544779c0387c27f8efb9ed0c4c95a322" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Django
- ORM, абстракция над несколькими RDBMS
- Аутентификация, сессии
- Авторизация
- Роутинг
- Шаблоны
- Миграции
- Админка
- Формы
- Интернациолизация и локализация
- Кеширование
- Многое другое
data:image/s3,"s3://crabby-images/07b1e/07b1ed86e7c95e59020d88ccda352cbb698d90bf" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
WSGI-совместимые веб-серверы
- Gunicorn
- uWSGI
- Chaussette
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Python и real-time web
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
data:image/s3,"s3://crabby-images/202d3/202d367b579d7f9263fb7b79a5e8af90e172a86a" alt=""
data:image/s3,"s3://crabby-images/7b834/7b8344d2dca2433f1885e36b1a36b778d9fc9434" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Зачем?
data:image/s3,"s3://crabby-images/ed2ec/ed2ec45d388622fc928b4000cfb04896ff322612" alt=""
data:image/s3,"s3://crabby-images/8b233/8b2338dfa8ab6022caff0cf73d2468b84b8f4a5f" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Как доставить контент моментально?
- Long-polling
- XHR-streaming
- Eventsource (SSE)
- Websockets
data:image/s3,"s3://crabby-images/1a9e4/1a9e4631e4c05652c7ace1fbdc2b3fe8dcf9a819" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Библиотеки-полифиллы
data:image/s3,"s3://crabby-images/a94f1/a94f1e5fc0a749565c0c4f5f4f719d0d803ec2a0" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Если на бекенде Python
- Асинхронный фреймворк (Tornado, Asyncio)
- Gevent - патчим стандартную библиотеку
- Nginx-push-stream module
- Hosted-сервер c API (LightStreamer, Centrifugo)
- Облачный сервис с API (pusher.com, pubnub.com)
- Django-channels
data:image/s3,"s3://crabby-images/84294/84294906f34cb8a12dbe1a527e446fcc674d966a" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
data:image/s3,"s3://crabby-images/ea241/ea2416337baf279a61d04c964093529bec7178ff" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Схема работы
data:image/s3,"s3://crabby-images/0df17/0df174f4a0116c955e9b030b8f1e8cc9fbc721c9" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Использование в браузере
data:image/s3,"s3://crabby-images/c432f/c432f4cc8e7899ca85b2e723e6e4464820fd170f" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Особенности
- Информация о подключениях в канале
- События подписки на канал/отписки от канала
- История сообщений в канале
- Восстановление пропущенных сообщений
- Разные типы каналов
- Масштабирование с помощью Redis
- Метрики
- Административный веб-интерфейс
- RPM и DEB пакеты, Docker-контейнер
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
API и клиентские библиотеки
- Клиентские - браузер, Android, iOS
- HTTP API - Python, PHP, Go, NodeJS, Ruby
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Ссылки
- Код - https://github.com/centrifugal/centrifugo
- Документация
- Демо-инстанс на Heroku (пароль demo)
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Спасибо!
Python_12
By Emelin Alexander
Python_12
- 1,022