Links
Though links are an important part of documentation, they also have their own maintenance cost.
We have a few strategies we use to make link maintenance easier.
There are 3 types of links:
- External: To other resources, such as www.cloudflare.com ↗.
- Internal: To other pages in the docs, such as Workers.
- Anchor: To specific parts of other pages in our docs, such as Proxied records.
For each type of link, we think through a few different aspects of the experience.
- External:
- Source of truth: Another site.
- Why does it break: Another site changed its content.
- Customer experience of a break: 404page on another site.
 
- Internal:
- Source of truth: Your site.
- Why does it break: Your site changed its content.
- Customer experience of a break: 404page on your site.
 
- Anchor:
- Source of truth: Your site.
- Why does it break: Your site changed its content.
- Customer experience of a break: Page load on your site. Content might be further down the page or have been moved to another page.
 
Of these three link types, only Internal links:
- Happen within the context of a change to your site's content.
- Universally lead to a bad customer experience (a 404page).
- Are easily auditable within the current context.
For these reasons, we choose to make a build fail based on broken internal links. For our implementation, we rely on the Starlight link validator plugin ↗.
      plugins: [        ...(runLinkCheck          ? [              starlightLinksValidator({                errorOnInvalidHashes: false,                errorOnLocalLinks: false,                exclude: [                  "/api/",                  "/api/**",                  "/changelog/**",                  "/http/resources/**",                  "{props.*}",                  "/",                  "/glossary/",                  "/products/",                  "/rules/snippets/examples/?operation=*",                  "/rules/transform/examples/?operation=*",                  "/ruleset-engine/rules-language/fields/reference/**",                  "/workers/examples/?languages=*",                  "/workers/examples/?tags=*",                  "/workers-ai/models/**",                ],              }),            ]          : []),Whether or not we run the link validation depends an environmental variable that we set in our CI build process ↗.
We also make two intentional decisions about this link auditing:
- Absolute links, not relative: We enforce absolute links (/style-guide/how-we-docs/metadata/) and fail on relative links (../metadata/) to avoid time-consuming maintenance in the future. This decision also helps with find/replace work and any future platform migrations.
- No redirects: We do not consider redirects when evaluating links. We have the current source of truth, so we should utilize that truth to its fullest (as well as helping us avoid redirect chains and future maintenance).
Though external links are not good for the customer experience, they also don't change within the context of a change to your site's content. Additionally, external link checking can be time consuming and error prone, which can slow down contributions.
We use an external SEO tool to help flag these broken external links for us, addressing them as needed (instead of making a build fail because of them).
Anchor links do not have as dramatic as consequences of being wrong as internal links. If you have a broken anchor link, a customer will either need to manually scroll to the header or - in some cases - go to another page.
Because of these characteristics, we run periodic, background checks ↗ to flag broken anchor links, using the htmltest library.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark