Complete guide to robots.txt: creating, configuring, testing

calendar icon
22 Aug
27 Sep
scroll

Clever management of website crawling and indexing is the ultimate skill for webmasters and SEO specialists alike. And there are a number of ways to attract search bots to a site or restrict access to it. In this article, we’ll explore how to do it all with the help of the robots.txt file.

What is robots.txt?

Robots.txt is a text file that contains crawling recommendations for the bots. It is part of the robots exclusion protocol (REP), a group of web standards that regulates how bots view, access, index, and present content to the users. The file contains instructions (directives) through which you can restrict the bots from accessing specific sections, pages and files or specify the Sitemap address.

Most major search engines such as Google, Bing, and Yahoo start crawling websites by checking the robots.txt file and following the prescribed recommendations.

Why is robots.txt important?

The majority of websites geared mainly toward Google may not need the robots.txt file. This is due to the fact that Google considers them purely as recommendations, with Googlebot usually finding and indexing all important pages regardless.

Robots.txt contains recommendations for search bots on how to navigate the site
Robots.txt contains recommendations for search bots on how to navigate the site

Therefore if this file isn’t created, it will not be a critical mistake. In that case, the search bots will assume that there are no restrictions and they can scan away freely.

Despite that, there are 3 main reasons why you should actually use robots.txt:

  1. It optimizes the crawl budget. If you have a large site, it is important that search bots crawl all the important pages. However, sometimes crawlers find and index auxiliary pages, such as filter pages, while ignoring the main ones. You can address that situation by blocking the non-essential pages through robots.txt.
  2. It hides non-public pages. Not everything on your site needs to be indexed. One good example is the authorization or testing pages. While objectively they should exist, you can block them with robots.txt, keeping them out of search engine index and out of the reach of random people.
  3. It prevents the indexing of images and PDFs. There are a couple of ways to prevent the indexing of pages without using robots.txt. However, none of them work great when it comes to media files. So if you don’t want search engines to index images or PDFs on your site, the easiest way is to block them through robots.txt.

File requirements

For search bots to correctly handle the file, you need to follow the rules:

  1. It has to be located in the site’s root directory.
  2. It has to be named "robots.txt" and be available at https://yoursite.com/robots.txt.
  3. Only one such file per site is allowed.
  4. UTF-8 encoding.

Robots.txt syntax

Directives

The robots.txt file includes two main directives — User-agent and Disallow, but there are also additional ones, such as Allow and Sitemap. Let’s take a closer look at what information they convey and how to add it properly.

With the right directives, you can block the individual pages or the entire site
With the right directives, you can block the individual pages or the entire site

User-agent

This is a mandatory directive. It defines which search bots the rules apply to.

There are many robots that can scan websites, with search engine bots being the most common ones.

Some of the Google bots include:

  • Googlebot;
  • Googlebot-Image;
  • Googlebot-News.

You can find the complete User-Agent list used by search engines in their documentation. For Google, it looks like this.

Be aware that some crawlers can have more than one user agent token. For the rule to be applied correctly, it is important that the marker corresponds to only one crawler.

To address a particular bot, such as Googlebot Image, you need to enter its name in the User-agent line:

User-agent: Googlebot-Image

If you want to apply the rules to all the bots, use the asterisk (*). Example:

User-agent: *

Disallow

This indicates a page and directory of the root domain that the specified User-agent cannot scan. Use the Disallow directive to deny access to the entire site, directory, or a specific page.

1. If you want to restrict access to the entire site, add a slash (/). For example, to prohibit all robots from accessing the entire site, you must indicate the following in your robots.txt file:

User-agent: *
Disallow: /

You might need to use such a combination if your site is in the early stages of development when you want it to appear in search results fully completed.

2. To restrict access to the contents of a directory, use its name followed by a slash. For example, to prevent all bots from accessing the blog directory, you need to write the following in the file:

User-agent: *
Disallow: /blog/

3. If you need to close a specific page, you should specify its URL without the host. For example, to close the https://yoursite.com/blog/website.html page, you should write the following in your file:

User-agent: *
Disallow: /blog/website.html

Allow

This indicates the page and directory of the root domain that can be scanned by the specified User-agent and is considered to be an optional directive. If no restriction is specified, then by default, bots can scan the site unhindered. Thus the following is entirely optional:

User-agent: *
Allow: /

However, you will need to use this directive to override the restriction of the Disallow directive. Basically, it can be used to allow the scanning of a part of a restricted section or site. For example, if you want to restrict access to all the pages in the /blog/ directory except for https://yoursite.com/blog/website.html, you will need to specify the following:

User-agent: *
Disallow: /blog/
Allow: /blog/website.html/

Sitemap

This optional directive serves to specify the location of the site’s Sitemap.xml file. If your site has multiple Sitemaps, you can specify them all.

Make sure to indicate the complete URL of the Sitemap.xml file. The directive can be placed anywhere in the file, but often it is done at the very end. The robots.txt file with links to several Sitemap.xml would look like this:

User-agent: *
Sitemap: https://yoursite.com.com/sitemap1.xml
Sitemap: https://yoursite.com.com/sitemap2.xml

Special characters $, *, /, #

1. The asterisk character (*) stands for any sequence of characters. In the example below, using an asterisk will deny access to all URLs containing the word website:

User-agent: *
Disallow: /*website

This special character is added at the end of each line by default. So the two examples below would essentially mean the same thing:

User-agent: *
Disallow: /website*
User-agent: *
Disallow: /website

2. To override the asterisk (*), you must include the dollar sign ($) character at the end of the rule.

For example, to disallow access to /website but allow it to /website.html, you can write:

User-agent: *
Disallow: /website$

3. Slash is a basic character usually found in every Allow and Disallow directive. With it, you can deny access to the /blog/ folder and its contents or all pages that begin with /blog.

Example of a directive denying access to the entire /blog/ category:

User-agent: *
Disallow: /blog/

Example of a directive denying access to all the pages beginning with /blog:

User-agent: *
Disallow: /blog

4. The number sign (#) is used to add comments inside the file for yourself, users, or other webmasters. The search bots will disregard this information.

User-agent: *
Disallow: /blog
#it’s not as hard as one might seem :) 

A step-by-step guide to creating robots.txt

1. Create the robots.txt file

For this, you can use any text editor, such as notepad. If your text editor prompts you to choose the encoding when saving the file, be sure to select UTF-8.

2. Add rules for the robots

Rules are the instructions for the search bots, indicating which sections of a site can be scanned. In its guidelines, Google recommends considering the following:

  • The robots.txt file includes one or multiple groups.
  • Each group starts with the User-agent line. This determines which robot the rules are addressed to.
  • Each group can include several directives, but one per line.
  • Search engine robots process groups from top to bottom. The user agent can follow only one set of rules that is most suitable for it, which will be processed first.
  • By default, the user agent is allowed to scan any pages and directories that are not blocked by the disallow rule.
  • The rules are case-sensitive.
  • Lines that do not match any of the directives will be ignored.

3. Upload your robots.txt file to the root directory

Once created, save your robots.txt file on the computer, then upload it to your site’s root directory and make it available to search engines.

4. Test the availability and correctness of the robots.txt file

To verify whether the file is available, you need to open your browser in incognito mode and visit https://yoursite.com/robots.txt. If you see the content and it corresponds to what you’ve specified, you can proceed with checking the correctness of directives.

You can test robots.txt with a special tool found in Google Search Console. Keep in mind that it can only be used for robots.txt files that are already available on your site.

By checking Google Search Console, you can ensure all the directives were added correctly
By checking Google Search Console, you can ensure all the directives were added correctly

Robots.txt templates for various CMS

If your site has a CMS, pay attention to the pages it generates, especially those that should not be indexed by search engines. To prevent this from happening, you need to close them in robots.txt. Since this is a common problem, there are file templates for sites using various popular CMS. Here are some of them.

Robots.txt for WordPress

User-Agent: * 
Disallow: /wp-login.php 
Disallow: /wp-register.php 
Disallow: /xmlrpc.php 
Disallow: /template.html 
Disallow: /wp-admin 
Disallow: /wp-includes 
Disallow: /wp-content 
Allow: /wp-content/uploads/ 
Disallow: /tag 
Disallow: /category 
Disallow: /archive 
Disallow: */trackback/ 
Disallow: */feed/ 
Disallow: */comments/ 
Disallow: /?feed= 
Disallow: /?s= 
Allow: /wp-content/*.css* 
Allow: /wp-content/*.jpg 
Allow: /wp-content/*.gif 
Allow: /wp-content/*.png 
Allow: /wp-content/*.js* 
Allow: /wp-includes/js/ 
Sitemap: http://yoursite.com/sitemap.xml

Robots.txt for Joomla

User-agent: * 
Disallow: /administrator/ 
Disallow: /cache/ 
Disallow: /components/ 
Disallow: /images/ 
Disallow: /includes/ 
Disallow: /installation/ 
Disallow: /language/ 
Disallow: /libraries/ 
Disallow: /media/ 
Disallow: /modules/ 
Disallow: /plugins/ 
Disallow: /templates/ 
Disallow: /tmp/ 
Disallow: /xmlrpc/ 
Allow: /templates/*.css 
Allow: /templates/*.js 
Allow: /media/*.png 
Allow: /media/*.js 
Allow: /modules/*.css 
Allow: /modules/*.js 
Sitemap: http://yoursite.com/sitemap.xml

Robots.txt for Bitrix

User-agent: * 
Disallow: /*index.php$ 
Disallow: /bitrix/ 
Disallow: /auth/ 
Disallow: /personal/ 
Disallow: /upload/ 
Disallow: /search/ 
Disallow: /*/search/ 
Disallow: /*/slide_show/ 
Disallow: /*/gallery/*order=* 
Disallow: /*?* 
Disallow: /*&print= 
Disallow: /*register= 
Disallow: /*forgot_password= 
Disallow: /*change_password= 
Disallow: /*login= 
Disallow: /*logout= 
Disallow: /*auth= 
Disallow: /*action=* 
Disallow: /*bitrix_*= 
Disallow: /*backurl=* 
Disallow: /*BACKURL=* 
Disallow: /*back_url=* 
Disallow: /*BACK_URL=* 
Disallow: /*back_url_admin=* 
Disallow: /*print_course=Y 
Disallow: /*COURSE_ID= 
Allow: /bitrix/*.css 
Allow: /bitrix/*.js 
Sitemap: http://yoursite.com/sitemap.xml

[fs-toc-omit]Some of the practical things you may not know about

Indexed, though blocked by robots.txt

Sometimes you can see this warning in the Google Search Console. This happens when Google perceives the directives outlined in robots.txt as recommendations and not rules, thus effectively ignoring them. And although Google’s representatives do not see this as a critical problem, this, in fact, could result in a lot of junk pages being indexed.

"Indexed, though blocked by robots.txt" screen in Google Search Console
"Indexed, though blocked by robots.txt" screen in Google Search Console

To solve this problem, follow these recommendations:

❓ Determine whether these pages should be indexed. See what information they contain and whether they need to attract users from the search.

✅ If you do not want these pages blocked, find the directive responsible for this in your robots.txt file. If the answer is not apparent without third-party tools, you can do it with the robots.txt test tool.

The results after checking which directive blocks a URL
The results after checking which directive blocks a URL

Update your robots.txt without including this directive. Alternatively, you can specify the URL you want to be indexed through Allow if you need it to hide other less useful URLs.

❌Robots.txt is not the most reliable mechanism if you want to block this page for Google search. To avoid indexing, remove the previous line used for this in the robots.txt file and add the "noindex" meta to the page.

Important! For the noindex directive to work, the robots.txt file must not block access to the page for search robots. Otherwise, the bots will not be able to process the page’s code and will not detect the noindex meta tag. As a result, this page’s content will still be visible in search results if, for instance, other sites provide links to it.

If you need to close the site for a while with 503, don’t do it for robots.txt

When a site is undergoing extensive maintenance, or there are other important reasons, you can temporarily pause or disable it, thus preventing access to both bots and users alike. For this purpose, they use the 503 server response code.

However, John Mueller, Search Advocate at Google, has shown in a Twitter thread what you need to do and check to temporarily put your site on halt.

According to John, the robots.txt file should never return a 503 because the Googlebot will assume the site is completely blocked through robots.txt. For this, the robots.txt file should return 200 OK, having all the necessary directives written in the file, or 404.

If robots.txt is served with a 503, robots will assume the site is fully blocked by robots.txt
If robots.txt is served with a 503, robots will assume the site is fully blocked by robots.txt

Conclusion

Robots.txt is a useful tool for shaping the interactions between search engine crawlers and your site. When used correctly, it can positively impact the site’s ranking, allowing you to manage the indexing of your documents effectively.

We hope this guide can help you understand how robots.txt files work, how they’re organized, and how to use them correctly.

Writing team:
Dmуtro
Editor
Have a project
in your mind?
Let’s communicate.
Get expert estimation
Get expert estimation
expert postexpert photo

Frequently Asked Questions

copy iconcopy icon
Ready to discuss
your project with us?
Book a call
Book a call
4.9 AVG. SCORE
Based on 80+ reviews
TOP RATED COMPANY
with 100% Job Success
FEATURED Web Design
AgencY IN UAE
TOP DESIGN AGENCY
WORLDWIDE

Join Halo Lab’s newsletter!

Get weekly updates on the newest stories, posts and case studies right in your mailbox.

Thank you for subscribing!
Please, enter a valid email
Thank you for subscribing!
Hmm...something went wrong.
Ready to discuss
your project with us?
Please, enter a valid email
By sending this form I confirm that I have read and accept the Privacy Policy

Thank you!
We will contact you ASAP!

error imageclose icon
Hmm...something went wrong. Please try again 🙏
SEND AGAIN
SEND AGAIN
error icon