Во второй половине «девяностых» индустрия «сайтостроения» переживала расцвет. Каждая компания стремилась заявить о себе в интернете, каждый пользователь мечтал завести личную «домашнюю страничку». На помощь веб-мастерам приходили всевозможные программы вроде FrontPage и Dreamweaver, но большинство сайтов все еще представляли собой набор статических HTML-страниц, иногда — с вкраплением CSS. Чуть позже появилась технология Server Side Includes, позволявшая динамически собирать сайт на сервере из стандартных блоков: «шапки», панели меню, «подвала» и, собственно, полезного содержимого. После этого оставался только один шаг до внедрения баз данных и систем управления контентом, значительно упростивших жизнь как разработчикам, так и владельцам ресурсов.
Взгляд в прошлое
Кое-кто из нас еще застал времена, когда любой «интерактив» вроде пресловутой «гостевой книги» или чата прикручивался к сайту с помощью CGI-скриптов (чаще всего написанных на Perl), а для выкладки новой публикации или редактирования уже имеющихся приходилось привлекать веб-мастера. Притом сам процесс зачастую напоминал сеанс ритуальной магии с обязательными жертвоприношениями. Появление языка PHP, который поначалу расшифровывали как Personal Home Page Tools, значительно упростило процесс разработки и поддержки сайтов: как грибы после дождя стали появляться PHP-скрипты для администрирования и публикации контента, некоторые даже поддерживали примитивные HTML-шаблоны. Поскольку далеко не все хостинг-провайдеры предлагали в те времена доступ к СУБД на бесплатных и дешевых тарифах, встраиваемое в веб-страницы содержимое такие скрипты зачастую хранили в обычных текстовых файлах. Примерно в то же время получили распространение технологии Active Server Pages (ASP) от Micrsoft и JavaServer Pages (JSP), но вторая в итоге так и не прижилась.
Однако поворотным моментом в зарождении CMS стало не повсеместное внедрение интерпретируемых скриптовых языков вроде PHP и JavaScript, а появление в 1998 году объектной модели документа (Document Object Model, DOM). Упрощая, можно сказать, что DOM — это своего рода API, предоставляющий скриптам доступ к содержимому HTML-документов и позволяющий динамически менять контент без перезагрузки веб-страницы. Собственно, этот принцип и лег в основу веб-приложений, известных теперь, как системы управления контентом.
С точки зрения архитектуры CMS решает несколько практических задач, и динамическая генерация веб-страниц — далеко не главная из них. Одна из основных — разграничение доступа, то есть, разделение пользователей на администраторов, имеющих возможность создавать и изменять контент на всем сайте или в определенных разделах, и простых «читателей», а также управление группами юзеров. Вторая — компоновка страниц и доставка контента по клиентскому запросу. Есть и другие функции: обработка и хранение служебных данных, резервное копирование, обновление компонентов — эти модули бэкенда обычно скрыты от пользователей, но не менее важны. Условно можно сказать, что современные CMS состоят из двух наборов веб-приложений: программ управления контентом (Content Management Application, CMA), и приложений для доставки контента пользователю (Content Delivery Application, CDA). Они работают совместно, как единая комплексная система.
Первую в истории систему управления контентом вывела на рынок входящая в холдинг IBM компания FileNet — этот коммерческий продукт базировался на созданной ранее системе электронного документооборота и был всего лишь адаптирован для публикации веб-страниц. В 1995-96 году появилось еще несколько подобных коммерческих программ, но настоящий расцвет у систем управления контентом наступил с появлением CMS c открытым исходным кодом. Вокруг таких платформ быстро сформировались сообщества, развивающие и поддерживающие код самих систем, а также создающие для них дополнительные модули. И первым в этой когорте стал Drupal, релиз которого состоялся 15 января 2001 года.
Drupal
Автор Drupal — студент факультета информатики Университета Антверпена Дрис Байтарт: популярная CMS выросла из написанной им на PHP доски объявлений, с использованием которой могли обмениваться сообщениями учащиеся магистратуры. Позже Байтарт выложил свое детище вместе с исходным кодом в интернет на зарегистрированный им сайт Drop.org. Вообще, изначально он планировал назвать этот ресурс «Dorp», что на голландском означает «деревня», но опечатался в процессе регистрации домена, а после решил, что «Drop» звучит даже лучше. Само название движка является «англифицированным» словом «Druppel», означающем на голландском «капля воды». Да и логотип CMS символизирует эту самую каплю.
Первая версия движка могла похвастаться довольно ограниченным набором функций: она поддерживала регистрацию новых пользователей, публикацию сообщений на форумах с возможностью их администрирования, и импорт контента в формат RSS. Позже, в 2002 году, были добавлены другие возможности, превратившие Drupal в полноценную CMS: публикация статей, настройка шаблонов отображения сайта и поддержка подключаемых модулей.
До 2003 года Drupal оставался малоизвестным проектом, пока штаб кандидата в президенты США от Демократической партии Говарда Дина не создал на нем предвыборный сайт «DeanSpace», а также более 50 сайтов-сателлитов в поддержку кандидата. Это подстегнуло популярность Drupal — предвыборная гонка показала, что на основе этой CMS можно довольно быстро и без значительных усилий разворачивать веб-сайты с разным оформлением и контентом. Когда выборы завершились, бывшие технические сотрудники штаба Говарда Дина основали компанию CivicSpace Labs, основным бизнесом которой стала разработка сайтов на базе Drupal.
С тех пор популярность этой CMS только росла: сегодня Drupal входит в тройку наиболее распространенных CMS, хотя и уступает по этому показателю WordPress. По данным на март 2022 года сообщество Drupal насчитывало более 1,39 миллионов участников, а модульная архитектура движка делает его подходящим для сайтов любого размера, от небольших блогов до приложений корпоративного уровня. Ресурсы под управлением Drupal способны выдерживать высокую нагрузку в силу наличия механизмов кеширования, оптимизирующих производительность. А благодаря встроенной многоязычной поддержке Drupal позволяет легко переводить и локализовать веб-сайты, что делает его подходящим выбором для компаний, ориентированных на глобальную аудиторию.
WordPress
Хронологически второй CMS с открытым исходным кодом на основе PHP и MySQL, завоевавшей даже большую популярность по сравнению с конкурирующими проектами, стал WordPress. Разработку этого движка в 2001 году начал программист-самоучка Мишель Валдрихи: изначально он назвал своей поект b2/cafelog. Спустя два года на базе этой платформы, предназначенной, прежде всего, для ведения блогов, работало несколько тысяч сайтов. Тогда ей заинтересовался американский программист и предприниматель Мэтт Мюлленвег: он как раз искал подходящий скрипт для личного сайта, на котором мог бы размещать фотографии. Создав блог на основе b2/cafelog, 24 января 2003 года Мэтт опубликовал в нем пост, где высказал ряд идей по дальнейшему развитию функций CMS. Первым этот пост прокомментировал программист Майк Литтл, выразивший желание присоединиться к разработке, а девушка Мэтта, Кристин Саллек, придумала название для нового проекта — WordPress. Так на свет появилась платформа, по праву считающаяся на сегодняшний день самой популярной CMS в мире. А первая бета-версия WordPress 0.70 увидела свет спустя всего лишь четыре месяца — 27 мая 2003 года.
Основная движущая сила популярности WordPress — огромное комьюнити, создающее для этого движка шаблоны оформления и модули. Ассортимент этих расширений поистине велик: среди них есть как коммерческие, так и бесплатные. Официальный каталог WordPress насчитывает сотни тысяч тем оформления для сайтов любой тематики (неофициальные — еще больше), кроме того, создатели интернет-проектов на базе WordPress могут отыскать плагины и модули с абсолютно разным функционалом: он онлайн-библиотек, интернет-магазинов и коллекций софта, до систем он-лайн обучения. Существует множество вполне успешных коммерческих компаний, основной бизнес которых заключается в разработке платных шаблонов и плагинов для WordPress.
С момента своего создания в 2003 году WordPress превратился из простой платформы для ведения блогов в надежную CMS, на которой работают сайты от персональных страниц до приложений корпоративного уровня. По данным за 2021 год, более 42% сайтов в интернете работают под управлением именно этой CMS.
Основным достоинством системы считается интерфейс управления сайтом, по задумке создателей — понятный и доступный пользователям даже без технического бекграунда. Правда, с годами этот интерфейс оброс большим количеством элементов, среди которых немудрено запутаться и заблудиться даже человеку с опытом. Со мной можно поспорить, но лично мне кажется, что от былого удобства и легковесности уже давно не осталось и следа. Порой приходится подолгу гуглить, чтобы понять, как отключить ту или иную функцию или пофиксить какой-нибудь мелкий косячок в шаблоне. В общем, из довольно удобного и простого движка для сайта WordPress с годами мутировал в гигантского неповоротливого монстра, который сегодня представляет собой уже скорее не CMS, а среду для разработки и запуска различных веб-приложений. При этом — довольно тормозную среду: чем больше плагинов установлено и включено в админке, тем медленнее работает сайт (и включение оптимизации, сжатия картинок и кеширования далеко не всегда помогает, а если помогает, то не надолго).
Однако огромный ассортимент модулей и плагинов с лихвой компенсирует все недостатки WordPress — сайт на этом движке можно в буквальном смысле превратить во что угодно. А если задачу неспособен решить один плагин, ничто не мешает установить несколько. В конце концов, недостающие функции можно написать самому на PHP или нанять для этого специалиста — профессиональных разработчиков под WordPress, благодаря популярности платформы, довольно много.
Joomla!
Этой CMS я также активно пользовался на протяжении многих лет параллельно с WordPress, и потому могу сравнивать их на основе личного опыта. Если раньше интерфейсы админки WordPress и Joomla (официально название движка пишется с восклицательным знаком, но я его, с вашего позволения, в дальнейшем опущу) кардинально различались, то теперь они похожи как близнецы-братья, разве что в админке Joomla помимо боковой панели имеется верхнее меню. Кому как, а лично мне старый интерфейс со значками наподобие Windows нравился больше. В какой-то момент в архитектуре Joomla исчезла казавшаяся вечной путаница с «разделами» и «категориями» материалов, после чего работать с ней стало даже относительно удобно.
Joomla появилась в 2005 году как форк коммерческой CMS Mambo от компании Miro International, и первые версии этого движка даже поддерживали нативные расширения Mambo — так называемые «мамботы». Но затем эволюция Joomla, как водится, пошла своим путем. Лидер проекта Эндрю Эдди учредил компанию Open Source Matters, Inc. (OSM), которая и занялась дальнейшим развитием этой CMS. Название для движка предложило сообщество, быстро перекочевавшее под крыло OSM с Mambo — это адаптированное под английское произношение слово «jumla», которое на суахили означает «все вместе». Сообщество также выбрало путем голосования логотип, который затем стал зарегистрированным товарным знаком OSM.
Как и в случае с WordPress, Joomla распространяется бесплатно, в то время как деньги приносят коммерческие компоненты — шаблоны, плагины, модули и техническая поддержка. Численность комьюнити у Joomla более скромная по сравнению с WordPress, однако выбор расширений достаточно велик, и этот ассортимент позволяет закрыть большинство потребностей создателей сайтов. Кроме того, у Joomla имеется возможность интеграции с другими специализированными CMS — различными реализациями интернет-магазинов, социальных сетей, систем онлайн-образования.
Сейчас можно назвать Joomla второй по популярности (после WordPress) CMS в интернете: благодаря поддержке сообщества, большому ассортименту плагинов и мультиязычности этот движок активно используют для создания сайтов во всем мире. У этой CMS имеется коллектив приверженцев не только среди пользователей, но также среди многочисленных разработчиков, тестировщиков и дизайнеров, обеспечивающих регулярное обновление, исправление ошибок и расширение возможностей.
Что выбрать?
Помимо этой «великолепной троицы» существует множество других CMS, как общего назначения, так и специализированных, созданных под конкретные задачи. Как говорится, на вкус и цвет —фломастеры разные: все перечисленные в этой заметке движки написаны на языке PHP, все используют СУБД MySQL (Drupal умеет работать также с MariaDB, Percona Server, PosgreSQL, SQLite, WordPress — с MariaDB, а Joomla — c PostgreSQL). Подобным требованиям отвечают услуги виртуального хостинга практически любого современного хостинг-провайдера, причем, если поискать, можно найти и бесплатную площадку для размещения сайта на одном из этих движков. Более того: в панели управления VPS/VDS многих хостеров можно установить WordPress, Joomla или Drupal нажатием одной кнопки («быстрая установка менее популярных CMS тоже встречается, но реже).
Универсальный совет, какую CMS выбрать для своего проекта, дать практически невозможно — эти движки хороши каждый по-своему. Лично я использую все три для разных целей: на связке WordPress+WooCommerce у меня крутятся несколько интернет-магазинов, а Joomla и Drupal задействованы в проектах попроще. Каждая CMS имеет как свои достоинства, так и недостатки, но в целом можно сказать, что использование готового движка, для которого есть куча плагинов и адаптивные шаблоны, корректно отображающие сайт как на десктопах, так и на мобильных устройствах, экономит кучу времени.
Правда, сдается мне, время монолитных CMS понемногу уходит: им на пятки наступают более гибкие и фреймворки, и микросервисные системы доставки веб-контента, адаптированные под современные реалии и устройства: смарт-часы, «умные» колонки с голосовыми ассистентами, игровые консоли. На сцену понемногу выходит необходимость обеспечивать многоканальность в доставке контента (с чем классические CMS справляются, прямо скажем, неважно). Ведущую роль в этом, по всей видимости, будут играть так называемые API-First CMS, объединяющие целый набор инструментов управления контентом через API, часто на основе микросервисов. Приживутся они так же, как прижились «классические» монолитные движки — покажет время.
Источники
A brief history of the Content Management System, History of Content Management Systems and Rise of Headless CMS, FileNet, Content management system, Document Object Model, Drupal, WordPress, Joomla.
Комментарии (16)
Polaris99
01.06.2023 10:57+2большинство сайтов все еще представляли собой набор статических HTML-страниц, иногда — с вкраплением CSS. Чуть позже появилась технология Server Side Includes
Все было ровно наоборот, SSI появилась в 1995 году, а первый релиз CSS - в 1996. И я очень подозреваю, что технология SSI вплоть до начала нулевых была куда популярнее CSS
CyberPaul Автор
01.06.2023 10:57Спасибо за замечание, просто лично я осваивал их именно в таком порядке, видимо, потому и отложилось в памяти. SSI вообще выглядел по тем временам космической технологией: можно поправить меню сайта или копирайты в подвале в одном-единственном файлике, и оно изменится сразу на всем сайте. Фантастика!
skepticalpatient
01.06.2023 10:57Интересно, не могут ли как-то "санкции", "ограничения" и проч. повлиять на работу зарубежных CMS в России?
CyberPaul Автор
01.06.2023 10:57+1А кстати, было уже. У меня на Joomla где-то с год назад (точнее не помню) отвалились все сервера обновлений, потому что "Роскомнадзор" заблочил айпишники облачного провайдера, где оно хостилось. Пришлось в срочном порядке зеркала прописывать. Потом разблокировали обратно, но нервные клетки, как известно, не восстанавливаются.
skepticalpatient
01.06.2023 10:57Меня больше волнует обратное, не заблочат ли что-то для россиян..?
CyberPaul Автор
01.06.2023 10:57Так сами движки Open Source, WP, Joomla! и Drupal распространяются под GPLv2, их не заблочишь, лицензия не позволяет. Вот коммерческие плагины - теоретически могут. Но я пока не сталкивался с чем-то подобным.
skepticalpatient
01.06.2023 10:57Да, но вот история про "свободный" антивирус ClamAV, например:
"Блокировка в РоссииС марта 2022 года разработчик запретил доступ ко всему своему сайту, включая обновления, для российских IP-адресов. Обновление антивирусных баз возможно с альтернативных «зеркал», репозиториев".
Лишний гемор.
https://ru.wikipedia.org/wiki/ClamAV
Хотя у меня сейчас почему-то начал открываться) Раньше не открывался.CyberPaul Автор
01.06.2023 10:57+1Так доступ закрыт к сайту, а не к продукту. Сам антивирус по-прежнему можно скачать с сайта разработчика через proxy/VPN, или с зеркал, или загрузить исходники с GitHub и собрать, нарушением лицензии это не будет. Вот с обновлениями - да, проблема, особенно, если продукт вшит в другой продукт (сталкивался с этим в межсетевом шлюзе, где встроенный в прошивку ClamAV под Linux тупо перестал обновляться).
В общем, если нам захотят доставить проблем, их таки доставят, но с опенсорсными продуктами большинство из сложностей так или иначе решаемо. Вот с проприетарными - сложнее, там у правообладателя возможностей больше.
Vseved
01.06.2023 10:57+4Вот по поводу будущего CMS, а именно, абзац про API-First CMS было бы неплохо развернуть в отдельную статью. Очень интересная и актуальная тема на самом деле, нужны подробности.
alexiusp
01.06.2023 10:57Не знаю как конкуренты, но Wordpress уже довольно давно продвигает версию своего продукта как Headless (или api-first) CMS.
Но вообще в последнее время популярность набирают headless варианты: облачные CMS (SaaS, где панель управления предоставляется сторонней компанией, например Contentful) и SSG-фреймворки типа Gatsby. В обоих случаях хостить нужно только статический сайт - html, картинки и т.п. И работает это конечно существенно быстрее чем любая CMS. Но такого обширного коммьюнити и различных плагинов, конечно, пока нет. Ну и дизайн нужно самому пилить, готового тут тоже мало. В общем не для личного бложика системы.
ContentProvider
01.06.2023 10:57Когда-то давно активно работал с Друпалом 6, сделал под сотню сайтов, считал её одной из лучших CMS (выбирал между Друпалом, Вордпрессом, Джумлой и Битриксом).
Сейчас полностью перешёл на Битрикс и обратно возвращаться к Друпалу желания нет.
Последний опыт взаимодействия с Друпал 8 оказался крайне негативным.
sergeytolkachyov
01.06.2023 10:57Использовать Joomla для "проектов попроще", имхо, странно. Обратите внимание, например, на статью История взлёта и падения новостного сайта от 10 тысяч до 1 млн уников в сутки и обратно и при чём тут Joomla!.
А насчет магазинов: если поставить чистый WordPress c чистым WooCommerce - это около 200 мб кода (180+ кажется). В то время, как любой компонент электронной коммерции для Joomla + сам движок занимают меньше 30мб. Где проще разобраться? Я наслышан, что для того, чтобы "сделать на WordPress что угодно" туда под капот засовывают кто Laravel, кто Symphony.
Один из плюсов WordPress (и одновременно недостатков) это то, что он много лет хранит обратную совместимость. Принципиально ядро не менялось, в то время как и Joomla, и Drupal теряли пользователей и разработчиков из-за потери обратной совместимости. А это ставило разработчиков различных расширений для CMS перед выбором: переписывать ли код на новый манер, вместо дальнейшего развития или бросить всё нафиг ))
CyberPaul Автор
01.06.2023 10:57К слову, а какой компонент ИМ для Джумлы версии 4 Вы бы посоветовали? Я смотрел несколько: либо нет поддержки отечественных платежных систем вроде ЮКассы, либо не прикрутить купоны и промо-коды, либо не руссифицировано и посреди русскоязычного сайта полезут надписи на латинице. Оптимального варианта не нашел.
sergeytolkachyov
01.06.2023 10:57Ну, как минимум JoomShopping в русскоязычном Joomla -сегменте почти каждая собака знает. И решений под него полно как бесплатных, так и платных. Для проектов посерьёзнее RadicalMart.
Ну и в целом Joomla - это не тот вариант, когда можно накупить варезных плагинов по 300 рублей и сляпать на них магазин. Почитайте Joomla-дайджесты на Хабре, приходите в телеграм чат Joomla-сообщества. Joomla сильно выросла с начала 2010х, когда многие её видели в последний раз.
Holmogorov
По поводу тормознутости WP готов согласиться. Более неповоротливого движка на чем-то сложнее одностраничника я не видел, а лендинг можно соорудить и на статическом html.