Update: Arne has posted an early test version on the WordPress support forums here. At this stage it’s not yet ready for release. If you would like to test that version, you can support Arne’s effort by downloading and reporting any issues to him on that thread.
I’m lazy and have not yet tried the early release version.
——————————————————–
WordPress 3.0′s Multisite feature is cool and useful. The Google (XML) Sitemaps Generator plugin is also cool and useful. Unfortunately Arne Brachhold’s excellent plugin does not work with multisite blogs.
If you activate the plugin on a multisite enabled WordPress install, you get this error message.

Which is a shame, but it did not take me a long time to find a work around. My setup is using multisite with sub-domains and with the Domain Mapping plugin. These instructions are for the 3.2.4 version of the plugin.
1. Modify the plugin
Edit the file wp-content/plugins/google-sitemap-generator/sitemap.php and comment out lines 53 to 58 to look like this
//Check for 3.0 multisite, NOT supported yet!
// if((defined('WP_ALLOW_MULTISITE') && WP_ALLOW_MULTISITE) || (function_exists('is_multisite') && is_multisite())) {
// if(function_exists('is_super_admin') && is_super_admin()) {
// add_action('admin_notices', array('GoogleSitemapGeneratorLoader', 'AddMultisiteWarning'));
// }
//
// return;
// }
You can delete these lines, but I prefer to comment them out. All this does is prevent the plugin from detecting the multisite setup and not becoming active.
2. Get your rewrite rules ready
In your blog’s .htaccess file add these lines above your WordPress rules
RewriteRule ^sitemap.xml sitemap-%{SERVER_NAME}.xml [L]
RewriteRule ^sitemap.xml.gz sitemap-%{SERVER_NAME}.xml.gz [L]
This will come in handy later.
3. Activate the plugin and set these options
Now on each of your sites in your WordPress network, activate the Google (XML) Sitemap plugin. Do not Network Activate it.
Now got to your XML-Sitemap options page and for “Location of your sitemap file” select Custom location.

In the custom location change your change the file name sitemap.xml to sitemap-yourblogservername.xml. My server name is blog.dembowski.net so I’m using sitemap-blog.dembowski.net.xml. Save the options.
Look in your WordPress installation’s root and check if you have sitemap.xml or sitemap.xml.gz. If you do then delete them both.
Now at the top of that options page, click on “rebuild the sitemap manually” and confirm that your new sitemap-yourblogservername.xml has been created.
4. Test and confirm that this worked
Now test two things. Start by pointing your browser to http://yourblogservername/sitemap.xml and then http://yourblogservername/sitemap-yourblogservername.xml. If you setup your .htaccess rewrite rules correctly, then both URLs should work.
Load up your WordPress generated robots.txt file via http://yourblogservername/robots.txt and look at the Sitemap line. Mine reads like this
User-agent: * Disallow: Sitemap: http://blog.dembowski.net/sitemap-blog.dembowski.net.xml.gz
I have that rewrite rule in case the default location for the sitemap is used. When you load the sitemap via the normal location, the rewite rule sends it to the correct location. The second gziped sitemap URL is fine.
There should be no real sitemap.xml or sitemap.xml.gz files in your blog’s root directory. Instead, each sitemap file should have your virtual WordPress network names instead.
5. Rinse and repeat
Repeat this process for each site in your WordPress Network and you can continue to use this sitemap plugin. You will need to activate the plugin in each of your sites and change sitemap.xml to include the site name just as I outline in step 3.
6. The caveat
If this works for you, great! But if it doesn’t, please don’t bug Arne. If and when he makes his plugin multisite compatible, then it will be probably a better solution than this one. I’m not seeing any PHP errors or warning in my log files, but there may be reasons why this is not a good idea.
Also, when you modify your copy of a plugin in the WordPress plugin repository and that plugin is updated you will lose your edits from step 1 when you update the plugin.
In the meanwhile, I can continue to use this excellent plugin.
Hello and thanks for this wonderful tutorial. Can you please tell me how to use this plugin with multisite @ directory. I’m not using it @ sub-domain. hence, the above re-write rules are not working.
Abhinav,
You are entirely welcome.
I have not tried a directory install, and that sounds like a tough one.
Each blog in it’s own directory would use the same sitemap. What you would need is a combined sitemap for each of your sites i.e. http://yoursite.com/blog1/ http://yoursite.com/blog2/ etc.
I don’t think there is a graceful work around for a directory based site with this plugin. It would need Arne to recode it and make it multisite aware.
Before I fixed this problem with my installation, I was successfully using this plugin:
http://wordpress.org/extend/plugins/xml-sitemap-feed/
I preferred Arne’s plugin but that one worked as well. Give it a try, from the documentation it looks like it may work.
Good luck.
HERE is the rewrite_rule for directory installation.
http://cnzhx.net/blog/articles/google-xml-sitemaps-and-wordpress-multisite/
You could skip the Chinese chars and look for the rules, or like this:
where $1 is the directories of sites on your network.
like:
That would work, but whenever I got to that link I get a 404 page.
Edit: Okay, I get it. That site is in China and restricts visitors. Try this link instead for people not in China.
It’s odd! But I can click the link and go to the right page. AND, this site is mainly in Chinese but it’s hosted in U.S. with a free host plan. Maybe FREE is the reason.
Anyway, that’s not important because the rules is here and anyone can see it.
This worked perfectly. Thank you, you have saved me so much time and I was getting a headache trying to find a plugin that could do this.
I hope Arne can get his plugin updated soon, but for now this is just what I needed.
Thanks Again
You’re welcome.
Thinking about Abhinav’s problem re directory multisite, blanket multisite support maybe problematic.
Subdomain multisite should be a quick check and adjustment, but there may be more to it than I am aware of.
Jan,
Thank you for posting this!
Had to play around with the subdomain url because I’m on cloud servers but aside from that your instructions are excellent and the plugin works flawlessly.
Cheers!
JAG
Jag,
You’re welcome.
[...] 我就碰到了这样的事情,好在从国外某个网站上看到了临时的解决办法,经过测试,该方法也适用于以子目录(Sub-Directory)形式安装的多站点,当然,根据原文作者的叙述我们知道,它是适用于以子域名(Sub-Domain)方式启用的多站点的。 [...]
[...] a la incompatibilidad de plugins, por ejemplo el famoso Google (XML) Sitemaps Generator (para generar archivos con el sitemap) no trabaja con WP multisite. Pero Jan Dembowski nos explica [...]
[...] posibles dolores de cabeza. Respecto a la incompatibilidad de plugins, por ejemplo el famoso Google (XML) Sitemaps Generator (para generar archivos con el sitemap) no trabaja con WP multisite. Pero Jan Dembowski nos explica [...]
[...] che sarà aggiornato il plug-in, purtroppo bisognerà ripetere la procedura già spiegata. Via: Mostly Harmless Articoli Correlati:WordPress 3.0 disponibileImpostare data in italiano in WordPressCondividi var [...]
Jan, thanks a lot! It’s realy works!
I made it on my web(multi)site, and it works correctly. Any php errors or other bugs.
Thanks again!
Max,
You’re welcome and I’m glad it works. Multisite is so much easier than maintaining 4 or 5 separate WordPress installations. Having this plugin work is a bonus.
Jan,
I have once more question. I can’t find, where is robots.txt formed?
As I understand, there is no any live file whith such name. But it’s going generating by Google XML Sitemap plugin due GET query?
So, question is “how can I put my own exclusions to robots.txt output?”
Thank you, again!
That’s a fun one. You want to add specific data to the artificial robots.txt file for your site. I haven’t tried but give this plugin a look. It might let you do what you want.
http://wordpress.org/extend/plugins/robots-meta/
Yeah, I got this one http://wordpress.org/extend/plugins/pc-robotstxt/ for my site.
Seems like it works correctly.
[...] fouillant le web j’ai trouvé la solution suivante sur le blog de Jan Dembowski, solution compatible avec la version 3.2.4 de Google XML [...]
[...] Google XML Sitemaps and WordPress Multisite [...]
There is a more elegant way for networks. You can activate the plugin for network and edit the function GetXmlPath in sitemap-core.php
function GetXmlPath($forceAuto=false) { if(!$forceAuto && $this->GetOption("b_location_mode")=="manual") { $xml_path = $this->GetOption("b_filename_manual"); } else { $xml_path = $this->GetHomePath() . $this->GetOption("b_filename"); } if((defined('WP_ALLOW_MULTISITE') && WP_ALLOW_MULTISITE) || (function_exists('is_multisite') && is_multisite())) { return str_replace('sitemap.xml', 'sitemaps/sitemap.'.$_SERVER['HTTP_HOST'].'.xml', $xml_path); } return $xml_path; }Create a directory in your root path called “sitemaps” and chmod it to 777. Add this to your .htaccess:
RewriteRule ^sitemap.xml sitemaps/sitemap.%{SERVER_NAME}.xml [L] RewriteRule ^sitemap.xml.gz sitemaps/sitemap.%{SERVER_NAME}.xml.gz [L]Thats it! The sitemaps will be generated in the sitemap directory.
Oliver,
That is a better way to do it and I considered making those changes.
However, my PHP is less than reliable so I kept it as simple for me as I could. Hopefully Arne’s solution will be more elegant than my hack.
Error loading stylesheet: An unknown error has occurred (805303f4)http://www.mysite.net/wp-content/plugins/google-sitemap-generator/sitemap.xsl
i did all like you described and still getting errors while creating sitemap for my subdomains?!?!
Ivan,
It should work. Try loading the sitemap.xsl file directly and see if there is some problem with retrieving that file. You may see an error in your web server’s error_log file.
i can load sitemap.xsl just fine, i can even access to rootdomain sitemap the only problem is when i try to access to subdomain’s sitemap
Hi Oliver,
Have you tried those changes yourself.When I activate plugin for network the error message pops up as said in this article.
“Google XML Sitemaps is not multisite compatible.
Unfortunately the Google XML Sitemaps plugin was not tested with the multisite feature of WordPress 3.0 yet. The plugin will not be active until you disable the multisite mode. Otherwise go to active plugins and deactivate the Google XML Sitemaps plugin to make this message disappear.”
So it seems plugin can’t me made active using network activate mode.
Anjan,
The changes Oliver discussed were for after the multi-site check was disabled.
You still need to comment out the checks from lines 53 to 58 at the top of this blog post.
[...] diesem Blog habe ich eine Anleitung gefunden wie man das Google XML Sitemaps Plugin anpassen muss das dieses [...]
[...] まず、参考にさせていただいた「WP3.0ネットワークでGoogle Sitemapを作成する」は「Google XML Sitemaps and WordPress Multisite」を参考にしたものということなので、そちらも合わせて読まれることをお勧めします。 以下、参考にさせていただいた「WP3.0ネットワークでGoogle Sitemapを作成する」を基準に、今回少し自分なりに工夫した点について掲げます。 [...]
I think that the .htaccess rewrite rule should be more strict
With your example the url for sitemap.xml.gz is redirected to to sitemap.xml
I suggest using:
RewriteRule ^sitemap.xml$ sitemaps/sitemap.%{SERVER_NAME}.xml [L] RewriteRule ^sitemap.xml.gz$ sitemaps/sitemap.%{SERVER_NAME}.xml.gz [L]NTB,
The inclusion of the EOL $ character is not a bad idea, and does make it a more specific match in the rewrite rules. I left it as is because it works for me.
Also I prefer to have the sitemaps in the blog root directory. Just my preference, I’m sure you’ll set it as you see fit.
hello,
my wpmu main domain is nol.im, is it correct setting for subdomain ?
Absolute or relative path to the sitemap file, including name.
/home/nol/public_html/jewelry.nol.im/sitemap-jewelry.nol.im.xml
Complete URL to the sitemap file, including name.
http://jewelry.nol.im/sitemap-jewelry.nol.im.xml
[...] 参考: Google XML Sitemaps and WordPress Multisite [...]
Thanks for the advice!
I did all but still have this message: Google XML Sitemaps is not multisite compatible.
You must have missed a step. Commenting out those line will let Google XML Sitemaps work in multi-site mode.
Try downloading a fresh copy of the plugin and make the modifications again.
Hello, thks for the great hack.
After the process, I had both sitemaps, the old and the new one.
After delete the oldest, I check my robots.txt, as you sugested, but I only have “User-agent: *” and “Disallow:” terms. Should it have too a “new sitemap path”, havent it?
I made a .htacess hack putting the RewriteRule above de # BEGIN WordPress line. Sorry for may poor php skill
Thks again.
Alexandre
Alexandre,
Do you have a real robots.txt file or are you using the WordPress generated one? If you have a real robots.txt file, rename it to robots-old.txt and the try to load http://your-url/robots.txt
See if that does it.
Jan -
What do you do if you’ve got the multisite blog installed in the root directory? There is no directory for the main blog so what would you use for the $1 variable?
Here’s a follow up question – what if you’re using another sitemap generator for the rest of your site which also leaves a sitemap.xml file in the root directory? It needs to be placed in another subdirectory and that would probably be a prudent measure unless you only run wordpress on your domain.
Michael,
I think you’ve lost me there.
This is a simple solution for using Arne’s plugin for with a multisite install using sub-domains. A sub-domain install is supposed to be in the root directory.
Even if you don’t have an active blog at your-root.com you will have blog1.your-root.com, blog2.your-root.com, etc.
The rewrite rule will make sure that is the default blog1.your-root.com/sitemap.xml, blog2.your-root.com/sitemap.xml, etc. will serve the correct sitemap for the correct blog.
You could put the sitemap.xml somewhere else and delete the sitemap rewite rules.
[...] Unul dintre pluginurile importante care nu funcționa corect cu WordPress Multisite este Google Sitemap XML. Pentru utilizatorii mai avansați – necesită modificarea unui fișier PHP, adăugarea unor reguli noi în .htaccess și configurare avansată a pluginului, găsești un articol explicativ aici. [...]
Hi,
What do you do with the old sitemap you have submitted under Google’s webmaster’s tool? Do you delete it or what?
Now I have two, the old one and the newly created after making your modifications. Is this going to affect my index or perhaps, my ranking?
Thanks
I just checked my Google Webmaster tools for this site and the other in my WordPress network. I’m still getting crawled and my indexing doesn’t seem to have changed. Nice to see that the rewrite rules are working.
I don’t think you’ll suffer any penalty with Google. Since I’ve done this I still get the same amount of traffic.
[...] aunque el autor está trabajando en una versión que lo soporte. Mientras que esto sea así, Ian Dembowski ha creado un workaround fácil y rápido que funciona a las mil maravillas. Estos son los pasos a [...]
[...] embargo, en uno de los comentarios del post Google XML Sitemaps and WordPress Multisite, se aporta una alternativa mucho más elegante. A continuación, los pasos a [...]
[...] embargo, en uno de los comentarios del post Google XML Sitemaps and WordPress Multisite, se aporta una alternativa mucho más elegante. A continuación, los pasos a [...]
Thanks for this great tutorial.
It’s even more elegant, to create a subdirectory for each set of sitemaps.
So the RewriteRules would look like:
RewriteRule ^sitemap.xml.gz sitemaps/%{SERVER_NAME}/sitemap.xml.gz [L] RewriteRule ^sitemap.xml sitemaps/%{SERVER_NAME}/sitemap.xml [L]As mentioned before in exact this order, gz first, then the one without. Otherwise the first rule catches them all.
The third step is spare to edit for each blog, if you replace the following into sitemap-core.php in function GetXmlPath, line 1386:
return $this->GetHomePath() . $this->GetOption("b_filename");with this:
$dir = $this->GetHomePath() . 'sitemaps/'.trailingslashit($_SERVER['HTTP_HOST']); if(!file_exists($dir)) { mkdir($dir); clearstatcache(); sleep(1); } return $dir . $this->GetOption("b_filename");This will automatically create a subdir for each blog containing the sitemaps therefor.
Step 4 is also spare, if you don’t use a physical robots.txt, but the WordPress virtual one instead. You only need to check “Add the sitemap to the virtual robots.txt” in the XML Sitemap options and are done with your hand work.
Markus,
I’m glad you liked the post. I’ve added some formatting to your comment so that readers can see more clearly what you are refering to.
Your edits would have been a more elegant solution: fortunately Arne is working on a version of his plugin that visualizes the sitemap.xml files.
No more real files, it’s a more dynamic solution. Of course, this may mean more CPU time but I’m confident that the next release will be worth the wait.