Blog Refresh: Now With Less

Monday, May 01, 2017.

To readers who enjoyed the 3-column layout, the Edgar Allen Poe quote, and the engraving of the fragile rowboat disappearing into the mighty maelstrom: I'm sorry. It's all gone. To me, minimalism is less an aesthetic than it is the search for time invariants, and well...here we are some years later.

It's actually a bit more practical than all that. After porting this blog from jekyll to tinysite, I discovered that the very problem I set out to solve -- fast incremental site rebuilds -- was still a problem. No comment on why this seems to be a common failure mode for shiny two-point-oh-y things.

The culprit? That index of posts in the right column. The simple act of fixing a typo on a single page would cause posts.json to rebuild, and then every post would be rebuilt in a cascade, since the right column of every post depended on posts.json. Other static site generators probably learned to avoid this years ago. I finally came around to it this weekend.

In the interim, editing posts has been pretty unpleasant. Doubly so because I had no one to blame but myself. Now incremental site rebuilds are quick and can be accelerated with make -j as before.

With that out of the way, I decided to take advantage of the "let's optimize the shit out of everything" mental state I was in and see what could be done to speed up the publishing side of things. I really like the Heroku / Github Pages approach of "just git push and we'll do the rest," and have spent the last few years building systems to make everything at Endcrawl work like that. Maybe those years would have been better spent learning docker or kube. Maybe the people who regard deploying-via-git as an antipattern are right. But I can't shake the idea that we're overengineering the hell out of this problem right now. As one HN commenter put it:

In the long term I predict that base OS everywhere will improve support for deployment, workload scheduling, resource allocation, endpoint discovery, and dependency management. These will match and eventually surpass the additional capabilities that containers offer, and then we can all go back to putting files on a server and restarting a process, which is all that 99% of us actually need.

There's a bit more to the story than the part I emphasized, but that's one for another day. Suffice to say there's tooling now that fully realizes the "dream deploys" idea, this site uses it, and who knows, maybe it'll get opensourced one day.

I also took a stab at the horribly clunky {% highlight lang %} template syntax this blog used for code highlighting. When I started there was no good standard for this kind of thing, but now it seems fenced code blocks have won. Good for them, they're awesome. Switching tinysite to fenced code turned out to be trivial (diff), mainly because the original approach was a small regex hack rather than a more evolved approach. That Yagni guy they're always invoking knows what's up!

Oh yeah. The Disqus comments section is gone. Good riddance. It's been broken for years, ever since I migrated from acg.github.io to this domain. I probably made a mistake somewhere in the Disqus migration tool but never could figure it out. If you feel a burning desire to rebutt or high-five something, hit me up on twitter and I may link to it. Better yet, open a github issue against this blog.

Posted by Alan on Monday, May 01, 2017.