#3426 closed feature request (fixed)
Should include default favicon
Reported by: | robertaccettura | Owned by: | cpoteet |
---|---|---|---|
Milestone: | 3.0 | Priority: | normal |
Severity: | normal | Version: | 2.8 |
Component: | Performance | Keywords: | has-patch tested health-check commit |
Focuses: | Cc: |
Description
By default there should be a favicon. Some browsers (won't mention names) try and retrieve whatever is at /favicon.ico (for those of us who install wp at the root of the hostname. If wordpress handles 404's as well, you'll be wasting cpu/memory to serve up a 404 for not good reason. I guess it could be a wordpress logo, or just something generic like a white square (blank in the url bar) 100% transparent (does that work in all browsers?) or something else rather neutral.
It's rather wasteful on behalf of the UA, but I guess that's the way the cookie crumbles.
Attachments (9)
Change History (68)
#1
@
18 years ago
- Component changed from Optimization to Template
- Keywords favicon added
- Milestone set to 2.0.7
- Owner changed from anonymous to cpoteet
- Priority changed from low to lowest
- Severity changed from minor to trivial
- Status changed from new to assigned
Here is a suggested favicon from the WP logo.
#3
@
18 years ago
The favicon looks crummy in its scaled state. If I have time, I think I'll to a retouch pixel-by-pixel.
#5
@
18 years ago
- Milestone changed from 2.0.7 to 2.2
If located within the theme, it can only be used for people with mod_rewrite or 404 processing for their permalinks.
#6
@
18 years ago
- Resolution set to wontfix
- Status changed from assigned to closed
I don't think we should include a default favicon. WP isn't always in the root. Even if it was, including one might overwrite someone's default.
#8
in reply to:
↑ description
@
16 years ago
- Priority changed from lowest to normal
- Resolution wontfix deleted
- Status changed from closed to reopened
Replying to robertaccettura:
By default there should be a favicon. Some browsers (won't mention names) try and retrieve whatever is at /favicon.ico (for those of us who install wp at the root of the hostname. If wordpress handles 404's as well, you'll be wasting cpu/memory to serve up a 404 for not good reason. I guess it could be a wordpress logo, or just something generic like a white square (blank in the url bar) 100% transparent (does that work in all browsers?) or something else rather neutral.
It's rather wasteful on behalf of the UA, but I guess that's the way the cookie crumbles.
I'm re-opening this as I work for a web host that provides one-click installations of word press. While including a default favicon.ico may not be ideal, I can say the lack of a favicon.ico causes the CPU usage of a site to jump by 400%. This is really pretty insane.
So here are 2 alternatives to including a favicon.ico:
- During the setup process, simply do a 'touch' of the favicon.ico file in the base of the install. If you are concerned about changing the mtime of the file, then check for it's existence first. You could even implement putting a WordPress branded favicon.ico in place if you wanted the additional free "advertising".
- Modify the default .htaccess file to not redirect to index.php on a 404 error if the requested files was favicon.ico.
Either of these solutions would resolve this issue. This bug was reported 2 years ago. Think of how many barrels of oil have been burned needlessly. Just think of the positive spin you could put on this simple fix in comparison to the negative spin that could easily be applied. Seems like a no-brainer to me.
#10
@
16 years ago
Perhaps something like what was implemented on wp.com (http://en.blog.wordpress.com/2008/12/02/go-get-a-blavatar/) could be implemented for wp.org.
#11
follow-up:
↓ 13
@
16 years ago
Not a lot of negative spin really though is there, as this was closed 2 years ago and not a peep since.
Generally -1 on this, I think.
It's added complexity in the installation, because rather than just dropping a zip, you're having to have an installer that shifts .ico files around.
Absolutely -1 to just dropping the .ico file in regardless, potentially undoing people's work.
To be honest, if you're a web hosting provider worried about the cost of not serving up .ico files, you could implement your own host-wide policy on it.
Likewise if you are a site owner interested in having a favicon, then you'd already have one.
Lastly I think part of the point of a favicon is to distinguish one site from another by its icon. That is somewhat diluted if all the default WP installs have the same icon.
I think this is generally more plugin land.
#12
@
16 years ago
- Resolution set to wontfix
- Status changed from reopened to closed
We aren't going to include a default favicon.
#13
in reply to:
↑ 11
;
follow-up:
↓ 15
@
16 years ago
- Component changed from General to Performance
- Milestone set to 2.9
- Resolution wontfix deleted
- Severity changed from trivial to normal
- Status changed from closed to reopened
- Type changed from enhancement to defect (bug)
- Version set to 2.8
Replying to mrmist:
Absolutely -1 to just dropping the .ico file in regardless, potentially undoing people's work.
I'm calling this a defect and think this should be revisited. Although, it is not common for a heavily trafficked site not to have a favicon it seems to be a significant problem for web hosts:
http://blog.nearlyfreespeech.net/2009/06/16/quick-wordpress-performance-tip-create-a-favicon/
http://www.dreamhoststatus.com/2009/06/10/faviconico-favicongif-and-robotstxt-update/
Possible Solution:
If the request gets to WordPress then a favicon does not exist, so WordPress can serve up WordPress's logo favicon from wp-includes/images/
Generally I want to stay away from adding / modifying the favicon information in the <header>
To Investigate:
Any solution would want to confirm that it works with popular caching solutions such as supercache and batcache.
#15
in reply to:
↑ 13
;
follow-up:
↓ 16
@
16 years ago
- Keywords needs-patch added
Replying to lloydbudd:
Replying to mrmist:
Absolutely -1 to just dropping the .ico file in regardless, potentially undoing people's work.
I'm calling this a defect and think this should be revisited. Although, it is not common for a heavily trafficked site not to have a favicon it seems to be a significant problem for web hosts:
http://blog.nearlyfreespeech.net/2009/06/16/quick-wordpress-performance-tip-create-a-favicon/
http://www.dreamhoststatus.com/2009/06/10/faviconico-favicongif-and-robotstxt-update/
Possible Solution:
If the request gets to WordPress then a favicon does not exist, so WordPress can serve up WordPress's logo favicon from wp-includes/images/
Generally I want to stay away from adding / modifying the favicon information in the <header>
To Investigate:
Any solution would want to confirm that it works with popular caching solutions such as supercache and batcache.
I think if the request gets to WordPress then the shared hosts have already lost anyway.
While we can improve on the performance of serving a 404 page by sending out the icon if it gets to WordPress. I am not sure that is going to make it as good for the shared hosts as the files being there.
Maybe we could add rewrite rules to the htaccess for these specific files instead?
#16
in reply to:
↑ 15
;
follow-up:
↓ 17
@
16 years ago
I think if the request gets to WordPress then the shared hosts have already lost anyway.
While we can improve on the performance of serving a 404 page by sending out the icon if it gets to WordPress. I am not sure that is going to make it as good for the shared hosts as the files being there.
I was thinking that it might help a large chunk of scenarios, where they would be smart enough to have a caching solution in place, but I'm know thinking that solving it there also is not the correct place.
Maybe we could add rewrite rules to the htaccess for these specific files instead?
Interesting idea, though haven't htaccess dependent solutions to other problems always been frowned upon.
Looks like the best solution is theme hook based? Insert default favicon info if user/theme does not override.
#17
in reply to:
↑ 16
@
16 years ago
Replying to lloydbudd:
Looks like the best solution is theme hook based? Insert default favicon info if user/theme does not override.
Could also do a file_exists() to check for a favicon in the root, and put a default if none is there already. Should be done in the theme so that it can be replaced/disabled easily.
#18
@
16 years ago
Actually... here's another option:
If a 404 is served for '/favicon.ico'... then set a wp_option which would flag in the wp-admin alerting any user with the ability to edit options to enable a default favicon checkbox (which can use standard wp header hook) or to create a favicon.
This a little more graceful.
#19
@
16 years ago
Remember if there is some solution that involves checking for the existance of the favicon, then it also needs to check that WordPress itself is in the root folder - if not, then it might simply be inappropriate to add a WordPress type favicon to the site.
In general I think this sounds like a whole bunch of extra code and / or options that would add clutter to admin and make the average user go "eh?". But what do I know, I'm not average. :)
#20
@
16 years ago
This isn't so much a user feature, but an ISP and performance feature.
Serving up a 404 is a waste of cpu, memory and database connections. It turns 1 pageview into 2. Hence if there is a reasonable way to fix this and prevent the bogus pageview... for people who don't know about using a favicon, they will improve performance, and their hosts will be able to shed some unnecessary load.
#21
follow-up:
↓ 22
@
16 years ago
An occurrence of this issue was Matt's 1st story in his Velocity 09 talk
http://velocityconference.blip.tv/file/2293079/
- shipping with a default favicon in wp-includes/images/ seems like a no brainer, and updating the bundled themes to use it.
- Triggering a warning in the admin if 404 is served for '/favicon.ico' sounds elegant to me. Though maybe should take a step back and look for generalized solutions.
#22
in reply to:
↑ 21
@
15 years ago
Replying to lloydbudd:
- shipping with a default favicon in wp-includes/images/ seems like a no brainer, and updating the bundled themes to use it.
wp-includes/images/ won't help for /favicon.ico requests.
- Triggering a warning in the admin if 404 is served for '/favicon.ico' sounds elegant to me. Though maybe should take a step back and look for generalized solutions.
So what for? Then just put a favicon.ico into the wordpress zip and go for it. I suggest to use a very reduced version (for example 1bit colors) as favicon.ico so that a site owner is aware of the possibilities.
#24
follow-up:
↓ 28
@
15 years ago
- Keywords needs-patch added; has-patch tested removed
The patch is going to need to be more extensive than that. The automatic upgrade process will also need to check and make sure there is not a custom favicon.ico before copying the default favicon over the users custom favicon.
#25
@
15 years ago
Why not just make a rewrite rule for it, like the robots.txt one? Then if a real favicon file exists the rewrite rules are such that it will be served; otherwise, the default in /wp-includes/images/ can be used.
#26
@
15 years ago
I believe one of the reasons behind adding a default was to reduce server load for requests to favicon.ico. So that a request wouldn't have to go through PHP to deliver the favicon.
If we wanted to add a new Apache mod_rewrite rule that will go into .htaccess to redirect requests to the one in wp-includes/images when a favicon.ico doesn't exist I would be happy with that.
#27
@
15 years ago
rewrite rule to the resuce. those server who do not have rewrite rules won't have the problem with the 404s, right?
It would be possible to block the request then us sparing a file.
Additionally I add another "missing favicon"-favicon.
#28
in reply to:
↑ 24
@
15 years ago
Replying to sivel:
The patch is going to need to be more extensive than that. The automatic upgrade process will also need to check and make sure there is not a custom favicon.ico before copying the default favicon over the users custom favicon.
asccording to what filosofo suggest, this ain't any issues. no checks need to be made because the core file is linked only if not a users favicon actually exists.
#30
@
15 years ago
We already intercept robots.txt requests if the file doesn't exist. I think we can do the same for favicon.ico.
And if we want to allow uploading favicons we can consider porting the blavatar stuff from wp.com.
#31
follow-up:
↓ 32
@
15 years ago
Granted, if we do it like robots.txt we'll still load a lot of WP unless we add a short circuit.
#32
in reply to:
↑ 31
@
15 years ago
Replying to ryan:
Granted, if we do it like robots.txt we'll still load a lot of WP unless we add a short circuit.
Yes, so it would still run WP twice on each page load. Seems revmj and westi have the right solution: add another rule to htaccess to redirect requests for /favicon.ico
to wp-includes/images/favicon.ico
when the file doesn't exist.
Of course this will have to go at the bottom of htaccess so if there's already a redirect for favicon
, we don't override it.
#33
follow-up:
↓ 34
@
15 years ago
Another possible solution would be to intercept requests for favicon.ico very early, perhaps near the top of wp-settings.php and output something like:
if ( preg_match('/favicon.ico$/i', $_SERVER['REQUEST_URI']) ) { header( 'Content-Type: image/x-icon' ); header( 'Content-Length: 0' ); exit; }
#34
in reply to:
↑ 33
@
15 years ago
Replying to azaozz:
Another possible solution would be to intercept requests for favicon.ico very early, perhaps near the top of wp-settings.php and output something like:
I like this idea, especially if you add a no-cache header, because it will keep browsers from caching the default favicon even after a real one has been put in place.
#35
@
15 years ago
Is the best solution here really to provide a duff/correct image or to highlight to the user that there site would perform better if they had one.
I think I the following is as far as we should go in the core:
- Add a rule to the default .htaccess section which points at a favicon.ico in wp-includes/images if one does not exist in /
Other things which should/could be addressed by one or many canonical plugin:
- Add a warning for admins - maybe we need a performance page or even better a performance canonical plugin - it's not something you need forever!
- blavatar idea
#36
@
15 years ago
It just pops in my mind to think about having the favicon placed per theme as well. I think this makes sense for example if you make a nice theme and want that to ship with a favicon. But that's just an idea.
#37
@
15 years ago
As we are now feature frozen it is too late to include this into 2.9.
Moving to Future Release as there is currently no patch.
I think this is best solved by a canonical plugin which checks for existence of the file and suggests adding one to improve performance.
#42
@
15 years ago
the idea discussed in #11412 was to add one or two things:
- a few lines in the htaccess file to catch favicon requests and bail accordingly.
- a handler in WP that bails before the WP_Query
#43
@
15 years ago
I'm playing around with adding this rewrite rule atm:
RewriteRule \.(gif|png|jpe?g|css|js|ico)$ - [L]
#45
@
15 years ago
- Keywords tested added
Marking this as tested. it has been running on my server for a week without a hiccup.
#46
@
15 years ago
Just made a little review, I like the simplicity of this patch.
It might make sense to limit it to favicon.ico only in case someone actually wants to return dynamically generated images or so. Just as a note. Or: Offer a filter then for it, so a plugin can interact into that.
#47
@
15 years ago
Rather than changing mod_rewrite rules, which people running on non-Apache platforms like nginx or IIS probably won't appreciate, we should special-case favicon.ico with an early exit someplace like wp-settings.php since this is a fairly common problem that causes performance issues, as azaozz suggested with his simple patch.
#48
@
15 years ago
That's what I originally had in mind. Other variations would be fpassthru() rather than base64_decode() or moving it higher up (index.php would be the most optimal) to prevent PHP from having to needlessly compile multiple files before aborting to a favicon.
#50
@
15 years ago
I was under the impression fpassthru was faster than readfile() but either would work.
#51
@
15 years ago
This one uses a default favicon in the wp-content directory. It also sets cache headers for 3hrs which should be adequate for an average session and avoid multiple requests. While this gets rid of DB connections and most overhead it's still php processing, anything that can be cut can be helpful.
#52
@
15 years ago
Thinking more about this: best "fix" is when the site has an actual icon. Don't think WordPress should be substituting it if it doesn't exist (millions and millions of web pages with the same favicon).
Also the browsers seem to have "special" caching for these icons, don't think we need to try to refresh them every few hours (would probably affect only network caches).
3426-4.patch is based on 3426_favicon_v2.diff.
#53
@
15 years ago
- Not really sure a null image is really per-spec though it should work in all browsers without issue.
- Will proxies and reverse proxies cache a request with a response of 0 bytes? Or will it hit origin every time? If it's hitting the origin, that defeats the point. Pretty sure many don't cache that.
- The reason for setting cache is to ensure any proxy will keep it cached and offset load issues.
The point here isn't design but to reduce load due to this operator error.
If not the wordpress logo (which is good enough on wordpress.com's millions of blogs) then a transparent image would serve the purpose just as well.
#55
@
15 years ago
I'm +1 on 3426.4.patch (though it is stale due to #11881). Let's get this in.
Suggested Favicon