|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- Title: На пути к долговечным приложениям
- Date: 2019-08-05 00:00
- Category: News
- Slug: on-the-way-to-durable-applications
- Lang: ru
-
- ![Псковское вече][screenshot]
-
- В этой статье мы расскажем о нашем первом долговечном приложении для настольных ПК - генераторе статических сайтов ПСКОВ.
-
- **Долговечность**
-
- Под долговечным приложением мы понимаем такое приложение, которое работает без единого изменения на операционных системах, выпущенных в период 2010-2030 годов. Иными словами, долговечное приложение обладает 10-летней обратной совместимостью и 10-летней прочностью. Впрочем, [ПСКОВ][pskov] работает даже на Windows 2000, так что у него 19-летняя обратная совместимость.
-
- Технически ПСКОВ представляет из себя один файл HTML с упакованными в нём разметкой (HTML), стилями (CSS) и кодом (JavaScript). ПСКОВ исполняется строго в веб-браузере без взаимодействия с сервером.
-
- Подобная организация даёт ПСКОВУ следующие возможности:
-
- * его можно копировать без ограничений
- * его можно размещать на любом хостинге
- * его можно запускать локально
- * он может работать без Интернета
-
- 10-летнюю прочность мы гарантировать не можем, т.к. будущим не владеем. Вместе с тем, история развития HTML, CSS, JavaScript говорит о том, что указанные технологии развиваются с максимально возможной обратной совместимостью. Во-первых, новые возможности JavaScript не отменяют старые. Во-вторых, производители веб-браузеров заинтересованы в том, чтобы их веб-браузеры работали с как можно большим числом сайтов. В результате, например, [тэг <center>][center-tag], объявленный устаревшим в 2014-м году, без проблем работает 5 лет спустя в 2019-м.
-
- В то же время у любого приложения в веб-браузере есть серьёзное ограничение - клетка, обманчиво именуемая песочницей. Эта клетка запрещает доступ как к локальной файловой системе пользователя, так и почти ко всем ресурсам в Интернете без санкции владельца ресурса (CORS). В итоге что-либо отдать приложение может либо определённому серверу, либо пользователю в виде файла для скачивания. Файлы скачивать по одному или архивом неудобно, поэтому в мире нынче преобладает серверный подход, проблем которого мы коснёмся чуть позже.
-
- Для освобождения ПСКОВА из клетки пришлось создать [ЛФСД][lfsa], крошечный скрипт на Python, который необходимо запускать руками на время работы ПСКОВА. ЛФСД даёт возможность ПСКОВУ работать с локальной файловой системой пользователя. Python выбран ввиду его наличия по умолчанию на Linux и macOS, а также возможности поставить на Windows (даже Windows 2000).
-
- **Послужной список**
-
- ПСКОВ успешно опробован для создания следующих небольших сайтов:
-
- * [сайт проекта по созданию открытых игр][ogs]
- * [сам ПСКОВ][pskov]
- * [ЛФСД][lfsa]
- * [пример простейшего блога][pskov-sample]
-
- Теперь о причинах создания ПСКОВА именно в виде долговечного приложения для веб-браузера.
-
- **Причина №1: накопление и сохранение знаний в доступном виде**
-
- Уже не первый год мы трудимся над созданием удобных средств разработки игр. До недавнего времени накопленные знания представляли из себя [родные приложения][ogs-mahjong-1] для настольных ПК, [обучающие статьи][osgcpg] по смежным технологиям либо [видео результатов][showcase]. Указанные виды накопленных знаний отличает то, что знания эти по сути мертвы:
-
- * единицы людей скачают себе неизвестное приложение
- * единицы людей прочтут хотя бы часть статей
- * единицы людей посмотрят хотя бы часть видео
-
- Во многом эта смерть обусловлена недоступностью: нужно приложить неизвестное количество усилий для достижения неизвестного результата. Врядли таким можно кого-либо нынче заманить. Совсем иначе дело обстоит с приложением в браузере, которое потенциально работает везде: необходимо приложить известное усилие - открыть ссылку - для достижения неизвестного результата. История проведения [твиттер-революций][twitter-revolutions] говорит о том, что открывать ссылки и ставить лайки за смену "кровавого режима" умеют практически все.
-
- **Причина №2: народовластие**
-
- Нынче любой чих в Интернете осуществляется посредством сервисов, которые почти всегда принадлежат какой-то компании: [сообщения][msg], [карты][map], [поиск][search], [музыка][music], [исходный код][src] и т.д.. Следствием подобной узурпации власти становится [закрытие][shutdown-01] тех [сервисов][shutdown-02], которые контролирующая компания считает нерентабельными. Причём без какого-либо обсуждения с теми пользователям, без которых этот сервис никогда бы не взлетел.
-
- В других случаях компания может просто запретить конкурирующему браузеру использовать свой сервис, как это недавно [случилось с веб-версией Скайпа][skype-block]. Вместе с тем, существуют люди, не согласные с такой политикой. Благодаря им появляются [инструменты отключения][skype-free] блокировок.
-
- На наш взгляд, подобное положение вещей недопустимо. Однако, вина в этом лежит не только лишь на одичавшем бизнесе, но и простых пользователях, каждом из нас. Вы можете возразить, что у пользователей нет выбора, что кто-то другой (власть, рептилоиды, нужное подчеркнуть) сделал этот мир несправедливым. Кто-то может даже прямо винить власть/рептилоидов и веровать в то, что вот без них-то мы заживём. К сожалению, история человечества [говорит обратное][story]: "**государство** — это не какая-то вражья орда, оккупировавшая общество, а то, что **растет из общества и зеркально его отражает**".
-
- Будучи частью народа, мы начали с себя и решили употребить свою власть во благо: создавать необходимые нам приложения так, чтобы они работали для всех везде и всегда. ПСКОВ является первой попыткой, которая более чем превзошла наши ожидания. Конечно, у ПСКОВА есть свои ограничения в виде ЛФСД и работы по HTTP без шифрования; предстоит ещё многое сделать для увеличения доступности ПСКОВА, но уже сейчас мы готовы поспорить с любым: ПСКОВ через 10 лет будет работать без единого изменения. Как говорится, запомните этот твит.
-
- На этом мы заканчиваем рассказ о нашем первом долговечном приложении для настольных ПК - генераторе статических сайтов ПСКОВ.
-
- [screenshot]: ../../images/2019-08-05_on-the-way-to-durable-applications.jpg
-
- [pskov]: http://opengamestudio.org/pskov/ru
- [center-tag]: https://www.w3schools.com/tags/tag_center.asp
- [lfsa]: http://opengamestudio.org/lfsa/ru
- [ogs]: http://opengamestudio.org/ru
- [pskov-sample]: http://opengamestudio.org/pskov/sample/03.Blog/ru/blog/index.html
- [ogs-mahjong-1]: ../game/ogs-mahjong-1.html
- [osgcpg]: https://github.com/OGStudio/openscenegraph-cross-platform-guide
- [showcase]: https://youtu.be/_t8TGhSgJG4
- [twitter-revolutions]: https://ru.wikipedia.org/wiki/%D0%A2%D0%B2%D0%B8%D1%82%D1%82%D0%B5%D1%80-%D1%80%D0%B5%D0%B2%D0%BE%D0%BB%D1%8E%D1%86%D0%B8%D1%8F
- [msg]: http://twitter.com
- [map]: http://2gis.ru
- [search]: http://google.com
- [music]: http://music.yandex.ru
- [src]: http://github.com
- [shutdown-01]: https://techcrunch.com/2015/03/13/google-kills-off-google-code/
- [shutdown-02]: https://www.reddit.com/r/sysadmin/comments/62orq9/codeplex_shutting_down_and_fosshub_is_sad/
- [skype-block]: https://www.reddit.com/r/firefox/comments/aw1umv/skype_web_is_now_blocked_in_firefox/
- [skype-free]: https://addons.mozilla.org/ru/firefox/addon/firefox-web-skype/
- [story]: https://ria.ru/20190723/1556775012.html
|