Most known Web Content Management Systems (like Wordpress, Typo3, Drupal) are Web-Applications which integrate content editing and publication in one single application. With a static site generator, these process steps are divided: Content creation is done on your local computer, and content delivery is done by a static web server like nginx or apache.
Fowler and Parekh (Fowler 2012, Parekh and Fowler 2014) propose a separation between editing and publishing of web sites using two separate stacks - the content creation stack and the content delivery stack. I will use a terminology based on this differentiation. See the note about terminoloy below.
With CMS built as Web Apps, e.g. with the LAMP Stack (see note 3), Editing and Publishing is both done through the same App - the “CMS” like Wordpress, Typo3 etc.:
flowchart LR subgraph thecms["WebApp CMS"] direction LR subgraph Client["Client Side"] ed1((Editor)) re1((Reader)) re2((Reader)) browser1 browser2 browser3 end ed1 --> browser1["Browser"] re1 --> browser2["Browser"] re2 --> browser3["Browser"] subgraph Server["Server Side"] direction TB subgraph webserver["Webserver"] httpd["` **CMS** `"] templates[/HTML Templates/] httpd -..->templates httpd -..->|SQL|db db[("Database\n(Content)")] end end browser1 <-..->|http/HTML| httpd browser2 <-..->|http/HTML| httpd browser3 <-..->|http/HTML| httpd end
With a static site generator like hugo, these processes are split up. The Content Delivery can be done by a web server like nginx or apache directly (without executing any scripts), as only static sites need to be served by the web server.
flowchart subgraph ssg["Static Site Generator"] direction TB subgraph cd["content delivery"] subgraph Client["Client Side"] re1((Reader)) re2((Reader)) browser2 browser3 end subgraph Server["Server Side"] subgraph webserver["Webserver"] httpd["` **httpd** (nginx, apache) `"] httpd -..->pages pages[/"Complete Website with Content (HTML, CSS, JS)"/] end end re1 --> browser2["Browser"] re2 --> browser3["Browser"] browser2 <-..->|http/HTML| httpd browser3 <-..->|http/HTML| httpd end end
With a static site generator, content creation is done by editing text files on the editor’s local computer. Typical text file formats are markdown for content and HTML templates for the site structure - Go Templates within Hugo. Both can be edited with any Text editor or IDE.
flowchart TB subgraph cc["content creation"] ed1((Editor)) content[/"Site Content (Markdown)"/] structure[/"Site Structure (HTML, CSS, JS)"/] hugo["` **HUGO** ⚙️ `"] website[/"Complete Website with Content (HTML, CSS, JS)"/] content & structure --> hugo hugo --> website ed1 --> content ed1 --> structure end
To publish the site generated by the SSG (Hugo), it has to be copied to the web server. This can be done with a manual copy, but is usually done with some kind of automated build process. See the page on deployment.
flowchart TB subgraph ssg["Static Site Generator"] direction LR subgraph cc["content creation"] ed1((Editor)) content[/"Site Content (Markdown)"/] structure[/"Site Structure (HTML, CSS, JS)"/] hugo["` **HUGO** ⚙️ `"] website[/"Complete Website with Content (HTML, CSS, JS)"/] content & structure --> hugo hugo --> website ed1 --> content ed1 --> structure end website==>|DEPLOYMENT|pages subgraph cd["content delivery"] subgraph Client["Client Side"] re1((Reader)) re2((Reader)) browser2 browser3 end subgraph Server["Server Side"] subgraph webserver["Webserver"] httpd["` **httpd** (nginx, apache) `"] httpd -..->pages pages[/"Complete Website with Content (HTML, CSS, JS)"/] end end re1 --> browser2["Browser"] re2 --> browser3["Browser"] browser2 <-..->|http/HTML| httpd browser3 <-..->|http/HTML| httpd end end
Fowler (2012) also points out that some web pages - for example those with user generated content - will be edited by many users, as for instance Wikis. I use the following differentiation: A Web Site is a collection of Web Pages (single html files) that constitute a unit of published information, and are typically accessible under a specific (sub)domain. They are published by few people, sometimes only one person. Web Apps are Applications build with Web Tools, based on the Web Client-Server Model, but apart from this technological similarity, are closer to software (applications) in general. Thus, I would characterize Wikis, Shop Systems and the like as Web Apps, not Web Sites. As with most categorizations, the boundaries are not clear cut, but careful differentiations are necessary nonetheless. This website is concerned with the creation of Web Sites with the described characteristic of being edited by few and read by many, and content that will be more often read (hopefully) than changed after once being published.
Martin Fowler (2012) proposes the separation of web page editing and publishing. He characterizes content management systems (CMS) as a “worryingly invasive tool”, pointing out that CMS often handle the two processes of editing and publishing in one single system, while most web pages have a small group of editors and a larger group of readers, with content that, once it is published, will only rarely be changed again. (see also Note 1).
Parekh and Fowler (2024) use the terms “Content Creation Stack” and “Content Delivery Stack” for the two systems that should be built to handle these two concerns. This proposal addresses issues of large sites with significant traffic, which is different from the web sites I am concerned with here, but I will use their terminology nonetheless as it helps clarify the different architectures.
The acronym LAMP stands for Linux, Apache, MySQL, PHP (3) and is an often used open source stack for web applications. PHP runs within the Apache webserver and is connected to a MySQL database. Most common CMS are built on this stack - as for instance Wordpress, Typo3 or Drupal.
While this is a well-known and powerful stack, it has two main drawbacks for simple web sites:
flowchart LR subgraph thecms["WebApp CMS"] direction LR subgraph Client browser end subgraph Server direction TB subgraph webserver httpd["`**httpd** (e.g. nginx, apache)`"] CMS["CMS: php\n(executed within httpd)"] httpd -..->CMS end CMS -..->|SQL|db CMS -..->templates db[("Database\n(Content)")] templates[/HTML Templates/] end browser -..->|http| httpd httpd -..->|HTML| browser end
Own Deployment Diagram for a CMS like Wordpress, see also (WordPress 2024)
The diagram below shows one editor and two readers. With a WebApp CMS, editing and publishing is done through the same app, which also means that the editing possibility has to be kept open even if the site is not currently changed.
flowchart LR subgraph thecms["WebApp CMS"] direction LR subgraph Client["Client Side"] ed1((Editor)) re1((Reader)) re2((Reader)) browser1 browser2 browser3 end ed1 --> browser1["Browser"] re1 --> browser2["Browser"] re2 --> browser3["Browser"] subgraph Server["Server Side"] direction TB subgraph webserver["Webserver"] httpd["`**httpd** (e.g. nginx, apache)`"] CMS["CMS: php\n(executed within httpd)"] httpd -..->CMS end CMS -..->|SQL|db CMS -..->templates db[("Database\n(Content)")] templates[/HTML Templates/] end browser1 -..->|http| httpd browser2 -..->|http| httpd browser3 -..->|http| httpd end
(Fowler 2012): Fowler, Martin: Editing Publishing Separation. Blog Article, 24.4.2012, https://martinfowler.com/bliki/EditingPublishingSeparation.html, accessed 10.5.2024
(Parekh and Fowler 2014): Parekh, Sunit and Fowler, Martin: Two Stack CMS. Building a Two-stack CMS for a global product catalog. Slidedesk, 6.10.2014, https://martinfowler.com/articles/two-stack-cms/ , accessed 10.5.2024
(WordPress 2024): Advanced Administration Handbook. Technical Documentation 28.3.2023-21.2.2024, https://developer.wordpress.org/advanced-administration/ , accessed 10.5.2024