Configure SEO metadata
When you want to customize how your pages appear in search results or social previews, you can set defaults at the site level or override them on individual pages.
Fern automatically generates all SEO metadata for every page in your documentation site. Search engines and social media previews work out of the box with no configuration required.
When you do want to customize SEO settings, you can set defaults at the site level or override them on individual pages. Keep titles between 50-60 characters and descriptions between 150-160 characters for optimal display.
The metadata configurations on this page are for SEO and social tags that aren’t visible to users. For visible footer links, see footer links configuration.
How it works
Fern looks for metadata values in this order:
- Page frontmatter — Custom SEO values for a specific page
- Site-level
docs.yml— Default SEO values for all pages - Automatic defaults — Generated from your page’s existing
title,description,subtitle, orexcerptfields
Example
og:image is the image that appears in social media previews. If you don’t set og:image in a page’s frontmatter, Fern uses the site-wide og:image from docs.yml. If neither is configured, the tag is omitted entirely.
Site-wide defaults
Set default SEO metadata for your entire site in docs.yml. These apply to all pages unless overridden by page-specific metadata.
Core metadata
Identity and descriptive fields used by search engines and shared across social platforms. Keep titles between 50–60 characters and descriptions between 150–160 characters for optimal display. Set canonical-host if your docs are accessible at multiple URLs (e.g., a custom domain and a buildwithfern.com subdomain) to tell search engines which URL is authoritative.
metadata.og:site_name
The name of your website for Open Graph tags.
metadata.og:title
The title shown in social media previews.
metadata.og:description
The description shown in social media previews.
metadata.og:url
The canonical URL of your documentation.
metadata.og:locale
The locale of your content (e.g., en_US).
metadata.canonical-host
The host of your documentation website. Used to set the canonical URL for metadata tags and documents like the sitemap. Defaults to the URL defined in instances.
Social image
The image displayed when your docs are shared on LinkedIn, Slack, Discord, and other platforms. Use a 1200x630px image for the best display across platforms — this is the standard Open Graph size and will render correctly in most previews. Avoid embedding text in the image since it may be cropped on some platforms.
metadata.og:image
The image shown in social media previews. Recommended size is 1200x630 pixels.
metadata.og:image:width
The width of your Open Graph image in pixels.
metadata.og:image:height
The height of your Open Graph image in pixels.
metadata.og:logo
URL to your company logo.
Dynamic OG images Beta
Instead of using a single static image for all pages, you can enable dynamic OG image generation. When enabled, Fern automatically generates a unique og:image for each page that doesn’t have one set in frontmatter.
You can optionally provide a custom background image (og:background-image) for dynamically generated OG images.
metadata.og:dynamic
When true, enables dynamic OG image generation for pages that don’t have a custom og:image set.
metadata.og:background-image
A custom background image for dynamically generated OG images. Can be a URL or a relative file path. When set, this image is used as the background instead of a solid color.
Twitter / X
Controls how your docs appear in Twitter Card previews when shared on X.
metadata.twitter:title
The title shown in Twitter Card previews.
metadata.twitter:description
The description shown in Twitter Card previews.
metadata.twitter:handle
Your company’s Twitter handle.
metadata.twitter:image
The image shown in Twitter Card previews.
metadata.twitter:site
The Twitter handle for your website.
metadata.twitter:card
The Twitter Card type. Options are summary, summary_large_image, app, or player.
Page-level overrides
Configure SEO metadata in your page’s frontmatter to control how individual pages appear in search results and social shares. These settings override site-wide defaults.
Only the documented SEO fields are added to the HTML <head> as meta tags. Custom frontmatter fields won’t automatically appear in your page metadata. To add custom metadata, use custom JavaScript.
Basic metadata
Page title, URL, and keyword fields used by search engines. Use headline when you need a different title for search engines than what appears as the visible page heading.
headline
When set, the <title /> tag in the document head will use this value rather than the title property. For example, your title might be “Quickstart” (shown in the sidebar and as the H1), while headline could be “Quickstart | PlantStore API Docs” to give search engines more context. If not set, Fern uses title with your site name appended.
canonical-url
Overrides the canonical URL for this page. Must be a full URL including the protocol (e.g., https://buildwithfern.com/learn/docs/content/frontmatter).
keywords
Comma-separated keywords relevant to the page (e.g., plants, garden, nursery). Accepts only comma-separated strings, not arrays.
Open Graph
Controls how this page appears when shared on LinkedIn, Slack, Discord, and other platforms that support Open Graph. Keep titles between 50–60 characters and descriptions between 150–160 characters for optimal display.
og:site_name
The name of your website as it should appear when your content is shared.
og:title
The title of your page as it should appear when your content is shared.
og:description
The description of your page as it should appear when your content is shared.
og:url
The URL of your page.
og:image
The URL of the image displayed when your content is shared.
og:image:width
The width of the image in pixels.
og:image:height
The height of the image in pixels.
og:locale
The locale of the page, typically in the format language_TERRITORY (e.g., en_US).
og:logo
The URL of your logo image displayed when your content is shared.
Twitter / X
Controls how this page appears in Twitter Card previews when shared on X.
twitter:title
The title of your page as it should appear in a tweet.
twitter:description
The description of your page as it should appear in a tweet.
twitter:handle
The Twitter handle of the page creator or site.
twitter:image
The URL of the image displayed in a tweet.
twitter:site
The Twitter handle for your website.
twitter:url
The URL of your page.
twitter:card
The type of card used for sharing on Twitter. Options: summary, summary_large_image, app, player.
Indexing
Control whether search engines index this page or follow its links. These are distinct: noindex removes the page from search results entirely, while nofollow keeps the page in results but tells search engines not to pass ranking credit through its links.
Use noindex for internal-only pages, staging content, or pages you don’t want surfaced in search. You can also combine noindex with hidden: true in docs.yml to hide a page from both search engines and the sidebar — see Hiding content for details. Use nofollow sparingly — it’s rarely needed for documentation.
noindex
If true, the page won’t be indexed by search engines and will be excluded from llms.txt endpoints.
nofollow
If true, search engines won’t follow any links on the page.