RSS, a love letter and walkthrough for my Eleventy site

I love RSS (Really Simply Syndication). It's a pretty old specification in Internet years, first created in 1999. Even the newest release of the specification is 11 years old. At it's core, an RSS feed is a plain text XML file that is updated with new posts, pages, or whatever a web master wants to publish.

I love the open nature of the specification. If my personal site has an RSS feed, then you, as a person interested in what I have to say, can subscribe to my feed using an RSS reader. That's all you have to do. Then, the things I have to say come directly to your RSS feed. No company or algorithm inserting themselves between that interaction to serve ads or to rejigger your timeline.

I love RSS because it's not cool. All the cool kids are talking about React and serverless and serverless react cloud containers and etc. The topic of RSS seems to be an afterthought for many web masters. My personal antidote is about twenty-five percent of the personal sites I visit, do not even publish a feed at all. That makes me sad. Intrepid reader, lets us not make the same mistake. Let's configure RSS on our Eleventy site!

Install the plugin

I'm going to install eleventy-plugin-rss to get my main feed up and going.

Let's install the package in the directory.

npm install @11ty/eleventy-plugin-rss

Now let's configure the software by putting this into our configuration file.

// .eleventy.js

const pluginRss = require("@11ty/eleventy-plugin-rss");
module.exports = function(eleventyConfig) {

Configure the layout file

Ok, everything is hooked up; it's time to setup our nunjucks layout file. Below is the one I landed on.

Note: I changed the demo template from the documentation site. Instead of showing the full content of my posts in my feed, I want to just show the summary. I'd like for readers to come to my site to read my content.

permalink: "feed/feed.xml"
eleventyExcludeFromCollections: true
<?xml version="1.0" encoding="utf-8"?>
<feed xmlns="">
<title>{{ metadata.title }}</title>
<subtitle>{{ metadata.feed.subtitle }}</subtitle>
<link href="{{ metadata.feed.feedUrl }}" rel="self"/>
<link href="{{ metadata.url }}/"/>
<updated>{{ collections.posts | rssLastUpdatedDate }}</updated>
<id>{{ metadata.url }}/</id>
<name>{{ }}</name>
<email>{{ }}</email>
{%- for post in collections.posts %}
{% set absolutePostUrl %}{{ post.url | url | absoluteUrl(metadata.url) }}{% endset %}
<title>{{ }}</title>
<link href="{{ absolutePostUrl }}"/>
<published>{{ | rssDate }}</published>
<updated>{{ | rssDate }}</updated>
<id>{{ absolutePostUrl }}</id>
<content type="html">{{ | htmlToAbsoluteUrls(absolutePostUrl) }}</content>
{%- endfor %}

Now when I build the site, our feed.xml file is generated. Yay!

Finally, I added the feed URL to the head of base.njk. This allows people to put the top level URL into their RSS readers to find our feed. Sweet.

<!-- src/_includes/base.njk -->

<!-- RSS feeds -->
<link rel="alternate" href="" type="application/atom+xml"
title="Michael Harley /">



There's a validator service for RSS. I like validators. Would recommend everyone validate! W3C Feed Validation Service.

Ok that's it for now. Thanks for reading this far!

Discuss on Twitter