<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: thatch</title>
    <description>The latest articles on DEV Community by thatch (@gnarzilla).</description>
    <link>https://dev.to/gnarzilla</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3376688%2F1430e8bb-14af-4d2b-9828-c96d4bb97b7b.png</url>
      <title>DEV Community: thatch</title>
      <link>https://dev.to/gnarzilla</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/gnarzilla"/>
    <language>en</language>
    <item>
      <title>How I Built a 150KB Blog Framework on Cloudflare’s Free Tier</title>
      <dc:creator>thatch</dc:creator>
      <pubDate>Mon, 21 Jul 2025 22:46:42 +0000</pubDate>
      <link>https://dev.to/gnarzilla/how-i-built-a-150kb-blog-framework-on-cloudflares-free-tier-16a5</link>
      <guid>https://dev.to/gnarzilla/how-i-built-a-150kb-blog-framework-on-cloudflares-free-tier-16a5</guid>
      <description>&lt;p&gt;I've always liked the idea of owning my content — but whispers of wordpress under my bed keeps me up at night, conversely the limitations of static sites are what they are. So I built &lt;strong&gt;Deadlight&lt;/strong&gt;, a minimalist blog/site framework that runs entirely on &lt;a href="https://developers.cloudflare.com/workers/" rel="noopener noreferrer"&gt;Cloudflare Workers&lt;/a&gt; + &lt;a href="https://developers.cloudflare.com/d1/" rel="noopener noreferrer"&gt;D1&lt;/a&gt; (SQLite) — &lt;strong&gt;all on the free tier&lt;/strong&gt;, with built-in auth, Markdown, and themes.&lt;/p&gt;




&lt;h2&gt;
  
  
  Why I Built It
&lt;/h2&gt;

&lt;p&gt;I wanted something that lived in the sweet spot between:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Static site generators (like Hugo or Eleventy)&lt;/li&gt;
&lt;li&gt;Full CMS platforms (like WordPress or Ghost)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Most "simple" blog solutions I tried still relied on multiple services (hosting + DB + backend). I wanted something &lt;strong&gt;all-in-one&lt;/strong&gt;, deployable in minutes, and ideally &lt;strong&gt;free&lt;/strong&gt; to run — even at scale.&lt;/p&gt;




&lt;h2&gt;
  
  
  What It Is
&lt;/h2&gt;

&lt;p&gt;Deadlight is a fully functional site/blog framework that includes:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Markdown content support&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Built-in authentication&lt;/strong&gt; (no 3rd-party auth required)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Dark/light themes&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;SQLite-backed database via Cloudflare D1&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;No build step&lt;/strong&gt; — dynamic but lightweight&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;&amp;lt;150KB total size&lt;/strong&gt; (HTML, CSS, routing, auth, and database logic)&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Deployed to the edge&lt;/strong&gt;, with no server/VPS to manage&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;a href="https://deadlight.boo" rel="noopener noreferrer"&gt;Live demo&lt;/a&gt;  &lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;a href="https://github.com/gnarzilla/deadlight-bootstrap" rel="noopener noreferrer"&gt;GitHub source code&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Architecture Overview
&lt;/h2&gt;

&lt;p&gt;Everything runs on Cloudflare’s edge network:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Cloudflare Workers&lt;/strong&gt; handle routing, rendering, auth, and API logic&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;D1&lt;/strong&gt; stores your posts, user credentials, and metadata&lt;/li&gt;
&lt;li&gt;No JS frameworks or client-side routing&lt;/li&gt;
&lt;li&gt;Pure CSS (with dark/light toggle), basic Markdown rendering&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;This is &lt;strong&gt;not&lt;/strong&gt; a static site generator. The content is dynamic — created, stored, and served live — but lightweight enough to load instantly.&lt;/p&gt;




&lt;h2&gt;
  
  
  Setup
&lt;/h2&gt;

&lt;p&gt;If you have a Cloudflare account and Wrangler installed:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;git clone https://github.com/gnarzilla/deadlight-bootstrap
&lt;span class="nb"&gt;cd &lt;/span&gt;deadlight-bootstrap
wrangler d1 create deadlight
wrangler publish
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That's it. Your blog is now live.&lt;/p&gt;

&lt;h2&gt;
  
  
  Design Philosophy
&lt;/h2&gt;

&lt;p&gt;Intentionally kept this small and opinionated:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No JavaScript framework&lt;/li&gt;
&lt;li&gt;No bloated admin interface (yet)&lt;/li&gt;
&lt;li&gt;No dependencies outside what Cloudflare offers (workers)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;But it's built to be built upon. Add an /admin dashboard, plug in image hosting, or integrate with KV/Queues - the world is your oyster. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fleq14sbzn7pgwoev86sl.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fleq14sbzn7pgwoev86sl.png" alt=" " width="800" height="723"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Feedback
&lt;/h2&gt;

&lt;p&gt;I'd love to hear your thoughts, or a good roast if that's more your speed. &lt;/p&gt;

</description>
      <category>selfhosted</category>
      <category>webdev</category>
      <category>programming</category>
      <category>javascript</category>
    </item>
  </channel>
</rss>
