Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

on-the-way-to-durable-applications.html 14KB

5 лет назад
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <!DOCTYPE html>
  2. <html>
  3. <meta charset="utf-8">
  4. <head>
  5. <link rel="stylesheet" href="../../style.css">
  6. </head>
  7. <body>
  8. <script data-goatcounter="https://services.opengamestudio.org:443/count" async src="//services.opengamestudio.org:443/count.js"></script>
  9. <div id="header">
  10. <div>
  11. <strong id="title">Open Game Studio</strong>
  12. <div id="lang">
  13. <a href="../../en/news/on-the-way-to-durable-applications.html">EN</a>
  14. <a href="../../ru/news/on-the-way-to-durable-applications.html">RU</a>
  15. </div>
  16. </div>
  17. <div class="header2">
  18. <div class="menu">
  19. <a href="../../ru/news/index.html">Новости</a>
  20. <a href="../../ru/game/index.html">Игры</a>
  21. <a href="../../ru/tool/index.html">Инструменты</a>
  22. <a href="../../ru/page/about.html">О нас</a>
  23. </div>
  24. <a class="discord" href="https://discord.gg/3A6THQabNf">
  25. <img src="../../images/discord.png"></img>
  26. </a>
  27. <div class="clear"></div>
  28. </div>
  29. </div>
  30. <h3 class="left_item_title">В новостях...</h3>
  31. <center>
  32. <div class="news_item">
  33. <h2 class="news_item_title">
  34. <a href="on-the-way-to-durable-applications.html">На пути к долговечным приложениям</a>
  35. </h2>
  36. <p class="news_item_date">
  37. 2019-08-05 00:00
  38. </p>
  39. <div class="news_item_contents">
  40. <p><img src="../../images/2019-08-05_on-the-way-to-durable-applications.jpg" alt="Псковское вече" /></p>
  41. <p>В этой статье мы расскажем о нашем первом долговечном приложении для настольных ПК - генераторе статических сайтов ПСКОВ.</p>
  42. <p><strong>Долговечность</strong></p>
  43. <p>Под долговечным приложением мы понимаем такое приложение, которое работает без единого изменения на операционных системах, выпущенных в период 2010-2030 годов. Иными словами, долговечное приложение обладает 10-летней обратной совместимостью и 10-летней прочностью. Впрочем, <a href="http://opengamestudio.org/pskov/ru">ПСКОВ</a> работает даже на Windows 2000, так что у него 19-летняя обратная совместимость.</p>
  44. <p>Технически ПСКОВ представляет из себя один файл HTML с упакованными в нём разметкой (HTML), стилями (CSS) и кодом (JavaScript). ПСКОВ исполняется строго в веб-браузере без взаимодействия с сервером.</p>
  45. <p>Подобная организация даёт ПСКОВУ следующие возможности:</p>
  46. <ul>
  47. <li>его можно копировать без ограничений</li>
  48. <li>его можно размещать на любом хостинге</li>
  49. <li>его можно запускать локально</li>
  50. <li>он может работать без Интернета</li>
  51. </ul>
  52. <p>10-летнюю прочность мы гарантировать не можем, т.к. будущим не владеем. Вместе с тем, история развития HTML, CSS, JavaScript говорит о том, что указанные технологии развиваются с максимально возможной обратной совместимостью. Во-первых, новые возможности JavaScript не отменяют старые. Во-вторых, производители веб-браузеров заинтересованы в том, чтобы их веб-браузеры работали с как можно большим числом сайтов. В результате, например, <a href="https://www.w3schools.com/tags/tag_center.asp">тэг &lt;center&gt;</a>, объявленный устаревшим в 2014-м году, без проблем работает 5 лет спустя в 2019-м.</p>
  53. <p>В то же время у любого приложения в веб-браузере есть серьёзное ограничение - клетка, обманчиво именуемая песочницей. Эта клетка запрещает доступ как к локальной файловой системе пользователя, так и почти ко всем ресурсам в Интернете без санкции владельца ресурса (CORS). В итоге что-либо отдать приложение может либо определённому серверу, либо пользователю в виде файла для скачивания. Файлы скачивать по одному или архивом неудобно, поэтому в мире нынче преобладает серверный подход, проблем которого мы коснёмся чуть позже.</p>
  54. <p>Для освобождения ПСКОВА из клетки пришлось создать <a href="http://opengamestudio.org/lfsa/ru">ЛФСД</a>, крошечный скрипт на Python, который необходимо запускать руками на время работы ПСКОВА. ЛФСД даёт возможность ПСКОВУ работать с локальной файловой системой пользователя. Python выбран ввиду его наличия по умолчанию на Linux и macOS, а также возможности поставить на Windows (даже Windows 2000).</p>
  55. <p><strong>Послужной список</strong></p>
  56. <p>ПСКОВ успешно опробован для создания следующих небольших сайтов:</p>
  57. <ul>
  58. <li><a href="http://opengamestudio.org/ru">сайт проекта по созданию открытых игр</a></li>
  59. <li><a href="http://opengamestudio.org/pskov/ru">сам ПСКОВ</a></li>
  60. <li><a href="http://opengamestudio.org/lfsa/ru">ЛФСД</a></li>
  61. <li><a href="http://opengamestudio.org/pskov/sample/03.Blog/ru/blog/index.html">пример простейшего блога</a></li>
  62. </ul>
  63. <p>Теперь о причинах создания ПСКОВА именно в виде долговечного приложения для веб-браузера.</p>
  64. <p><strong>Причина №1: накопление и сохранение знаний в доступном виде</strong></p>
  65. <p>Уже не первый год мы трудимся над созданием удобных средств разработки игр. До недавнего времени накопленные знания представляли из себя <a href="../game/ogs-mahjong-1.html">родные приложения</a> для настольных ПК, <a href="https://github.com/OGStudio/openscenegraph-cross-platform-guide">обучающие статьи</a> по смежным технологиям либо <a href="https://youtu.be/_t8TGhSgJG4">видео результатов</a>. Указанные виды накопленных знаний отличает то, что знания эти по сути мертвы:</p>
  66. <ul>
  67. <li>единицы людей скачают себе неизвестное приложение</li>
  68. <li>единицы людей прочтут хотя бы часть статей</li>
  69. <li>единицы людей посмотрят хотя бы часть видео</li>
  70. </ul>
  71. <p>Во многом эта смерть обусловлена недоступностью: нужно приложить неизвестное количество усилий для достижения неизвестного результата. Врядли таким можно кого-либо нынче заманить. Совсем иначе дело обстоит с приложением в браузере, которое потенциально работает везде: необходимо приложить известное усилие - открыть ссылку - для достижения неизвестного результата. История проведения <a href="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">твиттер-революций</a> говорит о том, что открывать ссылки и ставить лайки за смену "кровавого режима" умеют практически все.</p>
  72. <p><strong>Причина №2: народовластие</strong></p>
  73. <p>Нынче любой чих в Интернете осуществляется посредством сервисов, которые почти всегда принадлежат какой-то компании: <a href="http://twitter.com">сообщения</a>, <a href="http://2gis.ru">карты</a>, <a href="http://google.com">поиск</a>, <a href="http://music.yandex.ru">музыка</a>, <a href="http://github.com">исходный код</a> и т.д.. Следствием подобной узурпации власти становится <a href="https://techcrunch.com/2015/03/13/google-kills-off-google-code/">закрытие</a> тех <a href="https://www.reddit.com/r/sysadmin/comments/62orq9/codeplex_shutting_down_and_fosshub_is_sad/">сервисов</a>, которые контролирующая компания считает нерентабельным. Причём без какого-либо обсуждения с теми пользователям, без которых этот сервис никогда бы не взлетел.</p>
  74. <p>В других случаях компания может просто запретить конкурирующему браузеру использовать свой сервис, как это недавно <a href="https://www.reddit.com/r/firefox/comments/aw1umv/skype_web_is_now_blocked_in_firefox/">случилось с веб-версией Скайпа</a>. Вместе с тем, существуют люди, не согласные с такой политикой. Благодаря им появляются <a href="https://addons.mozilla.org/ru/firefox/addon/firefox-web-skype/">инструменты отключения</a> блокировок.</p>
  75. <p>На наш взгляд, подобное положение вещей недопустимо. Однако, вина в этом лежит не только лишь на одичавшем бизнесе, но и простых пользователях, каждом из нас. Вы можете возразить, что у пользователей нет выбора, что кто-то другой (власть, рептилоиды, нужное подчеркнуть) сделал этот мир несправедливым. Кто-то может даже прямо винить власть/рептилоидов и веровать в то, что вот без них-то мы заживём. К сожалению, история человечества <a href="https://ria.ru/20190723/1556775012.html">говорит обратное</a>: "<strong>государство</strong> — это не какая-то вражья орда, оккупировавшая общество, а то, что <strong>растет из общества и зеркально его отражает</strong>".</p>
  76. <p>Будучи частью народа, мы начали с себя и решили употребить свою власть во благо: создавать необходимые нам приложения так, чтобы они работали для всех везде и всегда. ПСКОВ является первой попыткой, которая более чем превзошла наши ожидания. Конечно, у ПСКОВА есть свои ограничения в виде ЛФСД и работы по HTTP без шифрования; предстоит ещё многое сделать для увеличения доступности ПСКОВА, но уже сейчас мы готовы поспорить с любым: ПСКОВ через 10 лет будет работать без единого изменения. Как говорится, запомните этот твит.</p>
  77. <p>На этом мы заканчиваем рассказ о нашем первом долговечном приложении для настольных ПК - генераторе статических сайтов ПСКОВ.</p>
  78. </div>
  79. </div>
  80. <div id="disqus_thread"></div>
  81. <script>
  82. var disqus_config = function () {
  83. this.page.url = "https://opengamestudio.org/ru/news/on-the-way-to-durable-applications.html";
  84. this.page.identifier = "on-the-way-to-durable-applications.html";
  85. };
  86. (function() { // DON'T EDIT BELOW THIS LINE
  87. var d = document, s = d.createElement('script');
  88. s.src = 'https://opengamestudio.disqus.com/embed.js';
  89. s.setAttribute('data-timestamp', +new Date());
  90. (d.head || d.body).appendChild(s);
  91. })();
  92. </script>
  93. <noscript>Пожалуйста, включите JavaScript для просмотра <a href="https://disqus.com/?ref_noscript">комментариев на платформе Disqus.</a></noscript>
  94. <div id="footer">
  95. Сайт сгенерирован <a href="http://opengamestudio.org/pskov/ru">ПСКОВОМ</a>
  96. из <a href="http://github.com/ogstudio/site-opengamestudio">этого исходного кода</a>.
  97. </div>
  98. </center>
  99. </body>
  100. </html>