5 • Beef up your blog
Add an RSS feed
Get ready to…
- Install an Astro package for creating an RSS feed for your website
- Create a feed that can be subscribed to and read by RSS feed readers
Install Astro’s RSS package
Section titled Install Astro’s RSS packageAstro provides a custom package to quickly add an RSS feed to your website.
This official package generates a non-HTML document with information about all of your blog posts that can be read by feed readers like Feedly, The Old Reader, and more. This document is updated every time your site is rebuilt.
Individuals can subscribe to your feed in a feed reader, and receive a notification when you publish a new blog post on your site, making it a popular blog feature.
- 
Quit the Astro development server and run the following command in the terminal to install Astro’s RSS package. Terminal window npm install @astrojs/rssTerminal window pnpm add @astrojs/rssTerminal window yarn add @astrojs/rss
- 
Restart the dev server to begin working on your Astro project again. Terminal window npm run devTerminal window pnpm run devTerminal window yarn run dev
Create an .xml feed document
Section titled Create an .xml feed document- 
Create a new file in src/pages/calledrss.xml.js
- 
Copy the following code into this new document. Customize the titleanddescriptionproperties, and if necessary, specify a different language incustomData:src/pages/rss.xml.js import rss, { pagesGlobToRssItems } from '@astrojs/rss';export async function GET(context) {return rss({title: 'Astro Learner | Blog',description: 'My journey learning Astro',site: context.site,items: await pagesGlobToRssItems(import.meta.glob('./**/*.md')),customData: `<language>en-us</language>`,});}
- 
Add the siteproperty to the Astro config with your site’s own unique Netlify URL.astro.config.mjs import { defineConfig } from "astro/config";export default defineConfig({site: "https://example.com"});
- 
This rss.xmldocument is only created when your site is built, so you won’t be able to see this page in your browser during development. Quit the dev server and run the following commands to first, build your site locally and then, view a preview of your build:Terminal window npm run buildnpm run previewTerminal window pnpm run buildpnpm run previewTerminal window yarn run buildyarn run preview
- 
Visit http://localhost:4321/rss.xmland verify that you can see (unformatted) text on the page with anitemfor each of your.mdfiles. Each item should contain blog post information such astitle,url, anddescription.
- 
Be sure to quit the preview and restart the dev server when you want to view your site in development mode again.