<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss2full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.askapache.com/~d/styles/itemcontent.css"?><rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" version="2.0">

<channel>
	<title>AskApache Web Fire</title>
	
	<link>http://www.askapache.com</link>
	<description>.htaccess, Net Security, Server Tech, Web Development, Tutorials and Articles. Come through in something amazing.. blazing.</description>
	<lastBuildDate>Fri, 25 Jun 2010 00:15:39 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<feedburner:info uri="apache/htaccess" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://feeds.askapache.com/apache/htaccess" /><feedburner:emailServiceId>apache/htaccess</feedburner:emailServiceId><feedburner:feedburnerHostname>http://feedburner.google.com</feedburner:feedburnerHostname><feedburner:feedFlare href="http://add.my.yahoo.com/rss?url=http%3A%2F%2Ffeeds.askapache.com%2Fapache%2Fhtaccess" src="http://us.i1.yimg.com/us.yimg.com/i/us/my/addtomyyahoo4.gif">Subscribe with My Yahoo!</feedburner:feedFlare><feedburner:feedFlare href="http://www.bloglines.com/sub/http://feeds.askapache.com/apache/htaccess" src="http://www.bloglines.com/images/sub_modern11.gif">Subscribe with Bloglines</feedburner:feedFlare><feedburner:feedFlare href="http://www.netvibes.com/subscribe.php?url=http%3A%2F%2Ffeeds.askapache.com%2Fapache%2Fhtaccess" src="http://www.netvibes.com/img/add2netvibes.gif">Subscribe with Netvibes</feedburner:feedFlare><feedburner:feedFlare href="http://fusion.google.com/add?feedurl=http%3A%2F%2Ffeeds.askapache.com%2Fapache%2Fhtaccess" src="http://buttons.googlesyndication.com/fusion/add.gif">Subscribe with Google</feedburner:feedFlare><feedburner:feedFlare href="http://www.pageflakes.com/subscribe.aspx?url=http%3A%2F%2Ffeeds.askapache.com%2Fapache%2Fhtaccess" src="http://www.pageflakes.com/ImageFile.ashx?instanceId=Static_4&amp;fileName=ATP_blu_91x17.gif">Subscribe with Pageflakes</feedburner:feedFlare><feedburner:feedFlare href="http://www.live.com/?add=http%3A%2F%2Ffeeds.askapache.com%2Fapache%2Fhtaccess" src="http://tkfiles.storage.msn.com/x1piYkpqHC_35nIp1gLE68-wvzLZO8iXl_JMledmJQXP-XTBOLfmQv4zhj4MhcWEJh_GtoBIiAl1Mjh-ndp9k47If7hTaFno0mxW9_i3p_5qQw">Subscribe with Live.com</feedburner:feedFlare><feedburner:browserFriendly>Thanks for your Interest, you are very nice!</feedburner:browserFriendly><item>
		<title>Crazy POWERFUL Bash Prompt</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/xmdP_W9e0LY/bash-power-prompt.html</link>
		<comments>http://www.askapache.com/linux-unix/bash-power-prompt.html#comments</comments>
		<pubDate>Tue, 25 May 2010 19:02:34 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Making Money]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Shell Scripting]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WiredTree]]></category>
		<category><![CDATA[.bashrc]]></category>
		<category><![CDATA[404 Not Found]]></category>
		<category><![CDATA[admin]]></category>
		<category><![CDATA[Advanced]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[bash_profile]]></category>
		<category><![CDATA[CommandLine]]></category>
		<category><![CDATA[Dig]]></category>
		<category><![CDATA[Examples]]></category>
		<category><![CDATA[Forms]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[grep]]></category>
		<category><![CDATA[HowTo]]></category>
		<category><![CDATA[Kung-Fu]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Login]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[Port]]></category>
		<category><![CDATA[Prompt]]></category>
		<category><![CDATA[PROMPT_COMMAND]]></category>
		<category><![CDATA[PS1]]></category>
		<category><![CDATA[Putty]]></category>
		<category><![CDATA[ram]]></category>
		<category><![CDATA[Redirect]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[Shell]]></category>
		<category><![CDATA[Shell History]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSH]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[trick]]></category>
		<category><![CDATA[Username]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=4069</guid>
		<description><![CDATA[<p><a class="IFL" href='http://www.askapache.com/linux-unix/bash-power-prompt.html' title='bash power prompt PS1'><img width="350" height="65" src="http://uploads.askapache.com/2010/03/bash-power-prompt-ps1-350x65.png" class="attachment-thumbnail" alt="bash power prompt PS1" title="bash power prompt PS1" /></a>This <a href='http://www.askapache.com/linux-unix/bash-power-prompt.html' title='amazing bash linux prompt'>amazing bash linux prompt</a> does more than meets the eye.  If you want to know how to become really good with technology, linux is the secret sauce behind the AskApache articles.  Open Source is elixir of the web.  Thanks to everyone who helped me for the past 20 years.  <strong>I use linux/bsd</strong> because <strong>homey don't play</strong>, so this is geared to be as productive a prompt as I can make it.<br /><br /><strong>Don't have much time.. or just don't care?</strong> Not a problem, here are the 3 lines to copy and paste - you can just paste them right in your shell to test it, or add to a startup script.<br class="C" /></p>
<pre style='font-size:8px'>export AA_P=&#34;export PVE=\&#34;\\033[m\\033[38;5;2m\&#34;\$(( \`sed -n \&#34;s/MemFree:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&#34; /proc/meminfo\` / 1024 ))\&#34;\\033[38;5;22m/\&#34;\$((\`sed -n \&#34;s/MemTotal:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&#34; /proc/meminfo\`/ 1024 ))MB\&#34;\\t\\033[m\\033[38;5;55m\$(&#60; /proc/loadavg)\\033[m\&#34;;echo -en \&#34;\&#34;&#34;
export PROMPT_COMMAND=&#34;history -a;((\$SECONDS % 10==0 ))&#38;&#38;eval \&#34;\$AA_P\&#34;;echo -en \&#34;\$PVE\&#34;;&#34;
export PS1=&#34;\\[\\e[m\\n\\e[1;30m\\][\$\$:\$PPID \\j:\\!\\[\\e[1;30m\\]]\\[\\e[0;36m\\] \\T \\d \\[\\e[1;30m\\][\\[\\e[1;34m\\]\\u@\\H\\[\\e[1;30m\\]:\\[\\e[0;37m\\]\${SSH_TTY} \\[\\e[0;32m\\]+\${SHLVL}\\[\\e[1;30m\\]] \\[\\e[1;37m\\]\\w\\[\\e[0;37m\\] \\n(\$SHLVL:\\!)\\\$ &#34; &#38;&#38; eval $AA_P</pre>]]></description>
			<content:encoded><![CDATA[<p><a style="display:block;width:140px;float:left;padding:1em;" href='http://www.askapache.com/linux-unix/bash-power-prompt.html' title='bash power prompt screenshot'><img width="116" height="62" src="http://uploads.askapache.com/2010/03/bash-power-prompt-ss-116x62.png" class="attachment-thumbnail" alt="bash power prompt screenshot" title="bash power prompt screenshot" /></a>From <strong>setting the window title</strong> to show the last run command (filtered), saving your <strong>history</strong> and keeping multi-session history intact, resetting the <strong>color/cursor/highlighting</strong> of errant color-emitting commands, these 2 prompt examples do more than meet the eye and are extremely fast.</p>
<p>Don&#8217;t have much time or just don&#8217;t care? No problem, this is a simple copy and paste&#8230; here&#8217;s one to start (all 1 line, just cut and paste right into the shell, once you&#8217;ve made sure its safe).<br class="C" /></p>
<pre>PS1=&quot;\n\[\033[1;30m\][$$:$PPID - \j:\!\[\033[1;30m\]]\[\033[0;36m\] \T \
\[\033[1;30m\][\[\033[1;34m\]\u@\H\[\033[1;30m\]:\[\033[0;37m\]${SSH_TTY:-o} \
\[\033[0;32m\]+${SHLVL}\[\033[1;30m\]] \[\033[1;37m\]\w\[\033[0;37m\] \n\$ &quot;</pre>
<p><a href='http://www.askapache.com/linux-unix/bash-power-prompt.html/toprc/' rel='attachment wp-att-4414'>toprc</a></p>
<p>Or for POWER PROMPT</p>
<pre>PROMPT_COMMAND=&#039;history -a;echo -en &quot;\033[m\033[38;5;2m&quot;$(( `sed -n &quot;s/MemFree:[\t ]\+\([0-9]\+\) kB/\1/p&quot; /proc/meminfo`/1024))&quot;\033[38;5;22m/&quot;$((`sed -n &quot;s/MemTotal:[\t ]\+\([0-9]\+\) kB/\1/Ip&quot; /proc/meminfo`/1024 ))MB&quot;\t\033[m\033[38;5;55m$(&lt; /proc/loadavg)\033[m&quot;&#039;
PS1=&#039;\[\e[m\n\e[1;30m\][$$:$PPID \j:\!\[\e[1;30m\]]\[\e[0;36m\] \T \d \[\e[1;30m\][\[\e[1;34m\]\u@\H\[\e[1;30m\]:\[\e[0;37m\]${SSH_TTY} \[\e[0;32m\]+${SHLVL}\[\e[1;30m\]] \[\e[1;37m\]\w\[\e[0;37m\] \n($SHLVL:\!)\$ &#039;
 </pre>
<h2>Or for Extreme Power Prompt</h2>
<p>Updated!  5/25/2010,  This is what I use at the moment.. It&#8217;s the coolest code I&#8217;ve ever seen to do this.  I rewrote the above (and below) bash prompts to this format because it is much more robust, and believe it or not its way faster for your machine.  Yes the code below is correct, it looks a little weird to export vars from within an exported var statement..  but this is correct. If you just learn this one bit of code, you will gain a lot of shell kung fu, at least I have!  Enjoy!</p>
<pre style='font-size:9px'>export AA_P=&quot;export PVE=\&quot;\\033[m\\033[38;5;2m\&quot;\$(( \`sed -n \&quot;s/MemFree:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&quot; /proc/meminfo\` / 1024 ))\&quot;\\033[38;5;22m/\&quot;\$((\`sed -n \&quot;s/MemTotal:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&quot; /proc/meminfo\`/ 1024 ))MB\&quot;\\t\\033[m\\033[38;5;55m\$(&lt; /proc/loadavg)\\033[m\&quot;;echo -en \&quot;\&quot;&quot;
export PROMPT_COMMAND=&quot;history -a;((\$SECONDS % 10==0 ))&amp;&amp;eval \&quot;\$AA_P\&quot;;echo -en \&quot;\$PVE\&quot;;&quot;
export PS1=&quot;\\[\\e[m\\n\\e[1;30m\\][\$\$:\$PPID \\j:\\!\\[\\e[1;30m\\]]\\[\\e[0;36m\\] \\T \\d \\[\\e[1;30m\\][\\[\\e[1;34m\\]\\u@\\H\\[\\e[1;30m\\]:\\[\\e[0;37m\\]\${SSH_TTY} \\[\\e[0;32m\\]+\${SHLVL}\\[\\e[1;30m\\]] \\[\\e[1;37m\\]\\w\\[\\e[0;37m\\] \\n(\$SHLVL:\\!)\\\$ &quot;
export PVE=&quot;\\033[m\\033[38;5;2m813\\033[38;5;22m/1024MB\\t\\033[m\\033[38;5;55m0.25 0.22 0.18 1/66 26820\\033[m&quot; &amp;&amp; eval $AA_P</pre>
<pre>[24574:16122 0:344] 05:49:07 Wed May 26 [faux@backtrack-askapache:/dev/pts/0 +1] ~
(1:344)$ export AA_P=&quot;export PVE=\&quot;\\033[m\\033[38;5;2m\&quot;\$(( \`sed -n \&quot;s/MemFree:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&quot; /proc/meminfo\` / 1024 ))\&quot;\\033[38;5;22m/\&quot;\$((\`sed -n \&quot;s/MemTotal:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&quot; /proc/meminfo\`/ 1024 ))MB\&quot;\\t\\033[m\\033[38;5;55m\$(&lt; /proc/loadavg)\\033[m\&quot;;echo -en \&quot;\&quot;&quot;
&gt;&gt;&gt; export &#039;AA_P=export PVE=&quot;\033[m\033[38;5;2m&quot;$(( `sed -n &quot;s/MemFree:[\t ]\+\([0-9]\+\) kB/\1/p&quot; /proc/meminfo` / 1024 ))&quot;\033[38;5;22m/&quot;$((`sed -n &quot;s/MemTotal:[\t ]\+\([0-9]\+\) kB/\1/p&quot; /proc/meminfo`/ 1024 ))MB&quot;\t\033[m\033[38;5;55m$(&lt; /proc/loadavg)\033[m&quot;;echo -en &quot;&quot;&#039;
&gt;&gt;&gt; AA_P=&#039;export PVE=&quot;\033[m\033[38;5;2m&quot;$(( `sed -n &quot;s/MemFree:[\t ]\+\([0-9]\+\) kB/\1/p&quot; /proc/meminfo` / 1024 ))&quot;\033[38;5;22m/&quot;$((`sed -n &quot;s/MemTotal:[\t ]\+\([0-9]\+\) kB/\1/p&quot; /proc/meminfo`/ 1024 ))MB&quot;\t\033[m\033[38;5;55m$(&lt; /proc/loadavg)\033[m&quot;;echo -en &quot;&quot;&#039;</pre>
<pre>[24574:16122 0:345] 05:49:09 Wed May 26 [faux@backtrack-askapache:/dev/pts/0 +1] ~
(1:345)$ export PROMPT_COMMAND=&quot;history -a;((\$SECONDS % 10==0 ))&amp;&amp;eval \&quot;\$AA_P\&quot;;echo -en \&quot;\$PVE\&quot;;&quot;
&gt;&gt;&gt; export &#039;PROMPT_COMMAND=history -a;(($SECONDS % 10==0 ))&amp;&amp;eval &quot;$AA_P&quot;;echo -en &quot;$PVE&quot;;&#039;
&gt;&gt;&gt; PROMPT_COMMAND=&#039;history -a;(($SECONDS % 10==0 ))&amp;&amp;eval &quot;$AA_P&quot;;echo -en &quot;$PVE&quot;;&#039;
&gt;&gt;&gt; history -a
&gt;&gt;&gt; (( 66 % 10==0  ))
&gt;&gt;&gt; echo -en &#039;\033[m\033[38;5;2m813\033[38;5;22m/1024MB\t\033[m\033[38;5;55m0.35 0.24 0.19 1/68 27241\033[m&#039;</pre>
<pre>813/1024MB      0.35 0.24 0.19 1/68 27241
[24574:16122 0:346] 05:49:09 Wed May 26 [faux@backtrack-askapache:/dev/pts/0 +1] ~
(1:346)$ export PS1=&quot;\\[\\e[m\\n\\e[1;30m\\][\$\$:\$PPID \\j:\\!\\[\\e[1;30m\\]]\\[\\e[0;36m\\] \\T \\d \\[\\e[1;30m\\][\\[\\e[1;34m\\]\\u@\\H\\[\\e[1;30m\\]:\\[\\e[0;37m\\]\${SSH_TTY} \\[\\e[0;32m\\]+\${SHLVL}\\[\\e[1;30m\\]] \\[\\e[1;37m\\]\\w\\[\\e[0;37m\\] \\n(\$SHLVL:\\!)\\\$ &quot;
&gt;&gt;&gt; export &#039;PS1=\[\e[m\n\e[1;30m\][$$:$PPID \j:\!\[\e[1;30m\]]\[\e[0;36m\] \T \d \[\e[1;30m\][\[\e[1;34m\]\u@\H\[\e[1;30m\]:\[\e[0;37m\]${SSH_TTY} \[\e[0;32m\]+${SHLVL}\[\e[1;30m\]] \[\e[1;37m\]\w\[\e[0;37m\] \n($SHLVL:\!)\$ &#039;
&gt;&gt;&gt; PS1=&#039;\[\e[m\n\e[1;30m\][$$:$PPID \j:\!\[\e[1;30m\]]\[\e[0;36m\] \T \d \[\e[1;30m\][\[\e[1;34m\]\u@\H\[\e[1;30m\]:\[\e[0;37m\]${SSH_TTY} \[\e[0;32m\]+${SHLVL}\[\e[1;30m\]] \[\e[1;37m\]\w\[\e[0;37m\] \n($SHLVL:\!)\$ &#039;
&gt;&gt;&gt; history -a
&gt;&gt;&gt; (( 67 % 10==0  ))
&gt;&gt;&gt; echo -en &#039;\033[m\033[38;5;2m813\033[38;5;22m/1024MB\t\033[m\033[38;5;55m0.35 0.24 0.19 1/68 27241\033[m&#039;</pre>
<pre>813/1024MB      0.35 0.24 0.19 1/68 27241
[24574:16122 0:347] 05:49:10 Wed May 26 [faux@backtrack-askapache:/dev/pts/0 +1] ~
(1:347)$ export PVE=&quot;\\033[m\\033[38;5;2m813\\033[38;5;22m/1024MB\\t\\033[m\\033[38;5;55m0.25 0.22 0.18 1/66 26820\\033[m&quot;
&gt;&gt;&gt; export &#039;PVE=\033[m\033[38;5;2m813\033[38;5;22m/1024MB\t\033[m\033[38;5;55m0.25 0.22 0.18 1/66 26820\033[m&#039;
&gt;&gt;&gt; PVE=&#039;\033[m\033[38;5;2m813\033[38;5;22m/1024MB\t\033[m\033[38;5;55m0.25 0.22 0.18 1/66 26820\033[m&#039;
&gt;&gt;&gt; history -a
&gt;&gt;&gt; (( 67 % 10==0  ))
&gt;&gt;&gt; echo -en &#039;\033[m\033[38;5;2m813\033[38;5;22m/1024MB\t\033[m\033[38;5;55m0.25 0.22 0.18 1/66 26820\033[m&#039;</pre>
<h2>256 Color Prompt Command</h2>
<p class="bnote"><strong>NOTE:</strong> I have been preparing a 256color terminal article for some time now, as I have tweaked, hacked, read, and experimented with more than I would ever like to admit.  So stay tuned, there isn't any tutorial, book, or online howto remotely close to as good as what I'm close to posting...</p>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html/super-optimized-256color-prompt/" rel="attachment wp-att-4297"><img src="http://uploads.askapache.com/2010/03/super-optimized-256color-prompt.png" alt="Super-optimized 256color BASH Prompt" title="Super-optimized 256color BASH Prompt" width="726" height="177" class="size-full wp-image-4297" /></a></p>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html/256-color-prompt/" rel="attachment wp-att-4280"><img src="http://uploads.askapache.com/2010/03/256-color-prompt.png" alt="256 color prompt_command and PS1" title="256 color prompt" width="642" height="147" class="size-full wp-image-4280" /></a></p>
<p>If you have a 256-color enabled terminal try this..<br class="C" /></p>
<pre>    export PROMPT_COMMAND=&#039;echo -en &quot;\033[m\033[38;5;2m&quot;$(( `sed -n &quot;s/MemFree:[\t ]\+\([0-9]\+\) kB/\1/p&quot; /proc/meminfo`/1024))&quot;\033[38;5;22m/&quot;$((`sed -n &quot;s/MemTotal:[\t ]\+\([0-9]\+\) kB/\1/Ip&quot; /proc/meminfo`/1024 ))MB&quot;\t\033[m\033[38;5;55m$(&lt; /proc/loadavg)\033[m&quot;&#039;
    export PS1=&#039;\[\e[m\n\e[1;30m\][$$:$PPID \j:\!\[\e[1;30m\]]\[\e[0;36m\] \T \d \[\e[1;30m\][\[\e[1;34m\]\u@\H\[\e[1;30m\]:\[\e[0;37m\]${SSH_TTY} \[\e[0;32m\]+${SHLVL}\[\e[1;30m\]] \[\e[1;37m\]\w\[\e[0;37m\] \n($SHLVL:\!)\$ &#039;</pre>
<p>Which double-quoted is:</p>
<pre>declare -x PROMPT_COMMAND=&quot;echo -en \&quot;\\033[m\\033[38;5;2m\&quot;\$(( \`sed -n \&quot;s/MemFree:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/p\&quot; /proc/meminfo\`/1024))\&quot;\\033[38;5;22m/\&quot;\$((\`sed -n \&quot;s/MemTotal:[\\t ]\\+\\([0-9]\\+\\) kB/\\1/Ip\&quot; /proc/meminfo\`/1024 ))MB\&quot;\\t\\033[m\\033[38;5;55m\$(&lt; /proc/loadavg)\\033[m\&quot;&quot;
declare -x PS1=&quot;\\[\\e[m\\n\\e[1;30m\\][\$\$:\$PPID \\j:\\!\\[\\e[1;30m\\]]\\[\\e[0;36m\\] \\T \\d \\[\\e[1;30m\\][\\[\\e[1;34m\\]\\u@\\H\\[\\e[1;30m\\]:\\[\\e[0;37m\\]\${SSH_TTY} \\[\\e[0;32m\\]+\${SHLVL}\\[\\e[1;30m\\]] \\[\\e[1;37m\\]\\w\\[\\e[0;37m\\] \\n(\$SHLVL:\\!)\\\$ &quot;</pre>
<p class="cnote"><strong>For Commandlinefu.com users</strong>:  Here ya go!  <a href='http://www.askapache.com/linux-unix/bash-power-prompt.html/toprc/' rel='attachment wp-att-4414'>toprc</a></p>
<p>That looks great, and is practicallly totally free in terms of how much cpu/work it makes the shell do for each command.  So for slow terminals, or text-terminals like I use, this is great.  Other than PS1, there is 1 other variable..  It&#8217;s called PROMPT_COMMAND and is execed right in front of the PS1.  I show 2 ways to utilize this, the goal being to show there is no right way.. fast is fast and money is money.  I use a function called aa_pc I threw together that shows me in color how much memory is on my system.. very cool.</p>
<h2>PROMPT = ?</h2>
<p>Here&#8217;s a screenshot of the code in my vim + screen multiplexed bash 4 environment..   It&#8217;s placed all the way at the bottom of the file and is the last thing executed by the client processing the script.  Also, while it&#8217;s great to look so good, this is all 100% for efficiency since I use one shell or another every day.</p>
<div id="attachment_4177" class="wp-caption alignnone" style="width: 805px"><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html/bash-prompt-screenshot/" rel="attachment wp-att-4177"><img src="http://uploads.askapache.com/2010/03/bash-prompt-screenshot.png" alt="Custom Power Prompt - currently mine" title="Custom Power Prompt -<br />
currently mine" width="795" height="596" class="size-full wp-image-4177" /></a><p class="wp-caption-text">Custom Power Prompt - currently mine</p></div>
<p>Here&#8217;s the code I&#8217;m using today, that produced this screen-shot &#8212; I am always changing stuff so it&#8217;s a little more tough to figure out.</p>
<pre>  function aa_pc()
  {
        local M=$( free -olm|sed &quot;/Mem/!d; s/Mem:[^0-9]*\([0-9]*\)[^0-9]*\([0-9]*\)[^0-9]*\([0-9]*\).*/ \
        ${GREP_COLOR}\2MB${R}\/\3MB/&quot;; ); echo -e &quot;$M `pwd`&quot;
  }
&nbsp;
  aa_grep_color(){ export GREP_COLOR=`tput setaf $(aa_random_under 6)`; }
  aa_random_under(){ echo -en $(( $RANDOM % ${1:-$RANDOM} + 1 )); }
  uptime1(){ sed &#039;/.*,  \([0-9]*\) users,  load average: \(.*\)/!d; s//[ \2, \1 users ]/;q&#039;;
&nbsp;
  $SED -n &#039;/i/!Q2&#039; &lt;&lt;&lt; $- &amp;&amp; \
  {
        case ${TERM:-dummy} in xterm*|screen*|*color*)echo; ;; *) return; esac;
  }
&nbsp;
  # hack for being able to source all the functions in this file from a script
  MASTER_RESET=$`echo -e &quot;rs1\nrs2\ninitc\nis2\ncnorm\nrmso\nsgr0&quot; | tput -S`
&nbsp;
  # only for color-aware (some guessing) terminals, kick everyone else OUT
  case ${TERM:-dummy} in xterm*|screen*|*color*)echo; ;; *) return; esac;
&nbsp;
  [[ -r /etc/DIR_COLORS ]] &amp;&amp; eval `dircolors -b /etc/DIR_COLORS`
&nbsp;
  # changes the window title in terminals like putty or konsole
  echo -ne &quot;\033]0; ${USER}@${HOSTNAME}  +${SHLVL} @${SSH_TTY/\/dev\/} - `uptime1` \007&quot;
&nbsp;
  # show title, setup the colors, vars, funcs, settings
  asetup_colors &amp;&amp; ascript_title
  export PROMPT_COMMAND=&#039;history -a;aa_pc&#039;
  export PS1=&#039;\[\033[1;30m\][$$:$PPID - \j:\!\[\033[1;30m\]]\[\033[0;36m\] \T\
  \d \[\033[1;30m\][\[\033[1;34m\]\u@\H\[\033[1;30m\]:\[\033[0;37m\]${SSH_TTY} \
  \[\033[0;32m\]+${SHLVL}\[\033[1;30m\]] \[\033[1;37m\]\w\[\033[0;37m\] \n\$ &#039;</pre>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html"><img src="http://uploads.askapache.com/2010/03/bash-power-prompt-ss.png" alt="bash power prompt screenshot" title="bash power prompt screenshot" width="898" height="480" /></a></p>
<p>I&#8217;ve used many shells over the years and have learned many tweaks and tricks for a powerful prompt.  It may look deceptively simple.  One cool thing this prompt does is display the command line (filtered) in the putty/konsole/xterm window, so if you have several windows minimized you can easily find the one you are looking for.<br class="C" /></p>
<p>There is a lot of good info about the BASH prompt around the net, but it can be complicated for a new user, and as an advanced user you will notice most of the info is very outdated and not very optimized for speed.  To get this articles recommended prompt working is devastatingly simple, just export the <code>PROMPT_COMMAND</code> and <code>PS1</code> variables that are shown below.  Most &#8220;power prompts&#8221; that utilize things like PROMPT_COMMAND do so very haphazardly or very extravagantly.</p>
<p>I&#8217;ve been called a lot of things but not extravagant, and because I use this prompt on many different servers, platforms, and systems I made sure to not make things complicated.  To test them just copy and paste the code below into your shell which will <strong>export PROMPT_COMMAND</strong> and <strong>PS1</strong> variables and work right away.  So test it out, and if you like it add it to your .bashrc or other startup file (please do a <code>$ man bash</code>).</p>
<ul>
<li><a href="#power-prompt-commands">Custom Power Prompt Commands</a>
<ol>
<li><a href="#prompt_command">PROMPT_COMMAND Detailed</a></li>
<li><a href="#detailed-ps1">PS1 Detailed</a></li>
</ol>
</li>
<li><a href="#hacker-prompts">Additional Info for Hackers</a>
<ol>
<li><a href="#set-xterm-title">Setting Window Title</a></li>
<li><a href="#strip-colors">Stripping Colors from PS1</a></li>
<li><a href="#uptime-alt">Alternative to Uptime/Loadavg (proc)</a></li>
<li><a href="#multi-prompt-switcher">Multi-Prompt Switcher Function</a></li>
</ol>
</li>
<li><a href="#bash-prompt-reading">Bash Prompts &#8211; More Reading</a>
<ol>
<li><a href="#ps1-examples">Other Simple Power Prompt Examples</a></li>
<li><a href="#bash-prompt-vars">All Prompt Variables</a></li>
<li><a href="#prompt-escapes">Escape Codes for PS1</a></li>
<li><a href="#more-reading">Additional Reading</a></li>
</ol>
</li>
</ul>
<p><a id="power-prompt-commands" name="power-prompt-commands"></a></p>
<h2>Bash Power Prompt</h2>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html"><img src="http://uploads.askapache.com/2010/03/bash-power-prompt-ps1.png" alt="bash power prompt PS1" title="bash power prompt PS1" width="513" height="96" /></a><br />From setting the window title to show the last run command (filtered), saving your history and keeping multi-session history intact, resetting the color/cursor/highlighting of errant color-emitting commands, this prompt does more than meets the eye extremely fast.</p>
<p class="enote">Don&#8217;t have much time? Don&#8217;t care?  You may copy and paste these 2 lines into your shell and that&#8217;s all there is to it!</p>
<pre>export PROMPT_COMMAND=&#039;export H1=&quot;`history 1|sed -e &quot;s/^[\ 0-9]*//; s/[\d0\d31\d34\d39\d96\d127]*//g; s/\(.\{1,50\}\).*$/\1/g&quot;`&quot;;history -a;echo -e &quot;sgr0\ncnorm\nrmso&quot;|tput -S&#039;
export PS1=&#039;\n\e[1;30m[\j:\!\e[1;30m]\e[0;36m \T \d \e[1;30m[\e[1;34m\u@\H\e[1;30m:\e[0;37m`tty 2&gt;/dev/null` \e[0;32m+${SHLVL}\e[1;30m] \e[1;37m\w\e[0;37m\[\033]0;[ ${H1}&#46;.. ] \w - \u@\H +$SHLVL @`tty 2&gt;/dev/null` - [ `uptime` ]\007\]\n\[\]\$ &#039;</pre>
<p><a id="prompt_command" name="prompt_command"></a></p>
<h2>PROMPT_COMMAND</h2>
<p>This holds commands to be run prior to displaying the prompt.  Let&#8217;s break it down.</p>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html"><img src="http://uploads.askapache.com/2010/03/askapache-prompt.jpg" alt="PS1 Prompt Example" title="PS1 Prompt Example" width="663" height="120" class="size-full wp-image-4150" /></a></p>
<p>First this takes the last command executed and filters it using sed to remove the initial history command number, and also to remove any quotes (single or double) and/or backticks.  Also, it only saves the first 50 chars, which are then exported as the value of H1, which because it is exported is now globally accessible to the rest of the shell.  This is important because we use this variable in PS1 to print the last run command as the title of our putty window (or konsole).</p>
<pre>export H1=`history 1 | sed -e &#039;s/^[\ 0-9]*//; s/[\d0\d31\d34\d39\d96\d127]*//g; s/\(.\{1,50\}\).*$/\1/g&#039;`</pre>
<p>The next command simply appends your last command to the history file.  Usually this is <code>~/.bash_profile</code>, or whatever <code>$HISTFILE</code> is.  This makes sure you never lose history in case of a shell crash or ssh connection terminated. </p>
<pre>history -a</pre>
<p>Finally there is this golden nugget of shell kung-fu.  This outputs 3 terminal escape sequences according to the terminal in use and its capabilities.. so very robust, should work on any shell newer than 1984.  By echoing the following 3 term names separated by a newline <code>\n</code> and using tput -S it will output the terminal sequences for all 3.  sgr0 resets the colors, cnorm resets the cursor, and rmso resets the background color.</p>
<p class="cnote">You can view the escape sequences generated by tput with strace, cat -t, etc..  For instance on my shell (xterm-256color via portaputty) the below command generates: <code>\33(B\33[m\33[?12l\33[?25h\33[27m</code>.  This is helpful because if you aren't coding for several terminals you can hard code that in your echo's instead of using tput, saving some overhead.</p>
<pre>echo -e &#039;sgr0\ncnorm\nrmso&#039; | tput -S
# For my term this is the same as if I just did
# echo -e &quot;\33(B\33[m\33[?12l\33[?25h\33[27m&quot;</pre>
<p><a id="detailed-ps1" name="detailed-ps1"></a></p>
<h2>PS1 Detailed</h2>
<p><code>PS1</code> is the variable that is expanded as your prompt.  So if you did a <code>$ unset PS1</code> then you can still run commands and everything, but your screen will be blank which is confusing to say the least.</p>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html"><img src="http://uploads.askapache.com/2010/03/askapache-htop.jpg" alt="The HTOP command in full color to manage mysql" title="The HTOP command in full color to manage mysql" width="404" height="176" class="size-full wp-image-4149" /></a></p>
<p>This PS1 shows which SHLVL level the shell is in, which is how many levels deep of shells you are currently at.  If you run <code>$ bash -l</code> from a bash shell it will create a new instance of bash as a child of the calling bash, so the SHLVL (shell level) gets incremented by 1.  I usually avoid creating subshells by instead executing a new bash with <code>exec</code> which instead of creating a new bash as a child of the current bash, it replaces the current bash process with the new one: <code>$ exec bash -l</code>.</p>
<pre>export PS1=&#039;\n\e[1;30m[\j:\!\e[1;30m]\e[0;36m \T \d \e[1;30m[\e[1;34m\u@\H\e[1;30m:\e[0;37m`tty 2&gt;/dev/null` \e[0;32m+${SHLVL}\e[1;30m] \e[1;37m\w\e[0;37m\[\033]0;[ ${H1}&#46;.. ] \w - \u@\H +$SHLVL @`tty 2&gt;/dev/null` - [ `uptime` ]\007\]\n\[\]\$ &#039;
&nbsp;
# with nocolors
# export PS1=&#039;\n[\j:\!] \T \d [\u@\H:`tty 2&gt;/dev/null` +${SHLVL}] \w\[\033]0;[ ${H1}&#46;.. ] \w - \u@\H +$SHLVL @`tty 2&gt;/dev/null` - [ `uptime` ]\007\]\n\[\]\$ &#039;</pre>
<h3>TTY</h3>
<p>This command is very useful for me because I use multiplexed terminals, about 6 at a time, so it is crucial sometimes to know which tty I am using.  Since SSH is the ONLY protocol I ever use for anything, I used to depend on the SSH_TTY variable being set instead of using tty, which as a command has more overhead then just echoing a variable.  But I found that when running multiplexing terminals with tmux, screen, etc.. the SSH_TTY variable stays with the initial tty created upon login.   <strong>Note:</strong> <code>2>/dev/null</code> redirects any errors that running the tty command might issue to the /dev/null device, which is the same thing as a black hole, it goes nowhere so is an efficient way to send data for deletion.  Depending on your server and ssh settings you may not even have a tty or it may just appear that you do not.  Some web hosting companies do odd things to prevent their users from using tty devices and programs.  But if you get a little creative you can always find the current tty.. like <code>$ readlink /proc/self/fd/0</code> will return the same thing as <code>$ tty</code>.</p>
<pre>`tty 2&gt;/dev/null`</pre>
<p><a id="set-xterm-title" name="set-xterm-title"></a></p>
<h3>Changing Window Title with PS1</h3>
<p>This simple bash function changes the title of the window to the passed parameter.  The key thing to note is that this works because of the special escapes on either end of the echo'd data.</p>
<pre>function set_window_title()
{
  echo -e &quot;\033]0; ${1:-$USER@$HOST - $SHLVL} \007&quot;;
}</pre>
<p><a id="hacker-prompts" name="hacker-prompts"></a></p>
<h2>Additional Info for Hackers</h2>
<p>More reading and digging.</p>
<p><a id="strip-colors" name="strip-colors"></a></p>
<h3>Strip Colors for Readability</h3>
<p>You can use this command to strip a PS1 of all colors, which shortens the variable dramatically in some cases.</p>
<pre>sed &#039;s/\\[eE][[0-9]*;[0-9]*m//g&#039; &lt;&lt;&lt; $PS1
# ie export PS1=$(sed &#039;s/\\[eE][[0-9]*;[0-9]*m//g&#039; &lt;&lt;&lt; $PS1);</pre>
<p><a id="multi-prompt-switcher" name="multi-prompt-switcher"></a></p>
<h3>Multi-Prompt Switcher Function</h3>
<p>This function demonstrates 1 way that you can change your prompts at will.  It creates an array named AAPS that you can add as many PS1 values to as you want.  Each time the function is run it simply changes the prompt string variable PS1 to the value of the next item in the AAPS array.  Once it reaches the last item in AAPS, it resets back to the first <code>AAPS[0]</code> prompt.  Just an example to play with, not tested very much.</p>
<pre>aa_multi_prompt ()
{
    declare -a AAPS;
    AAPS[0]=&#039;\n[\j:\!] \T \d [\u@\H:`tty 2&gt;/dev/null` +${SHLVL}] \w\[\033]0;[ ${H1}&#46;.. ] \w - \u@\H +$SHLVL @`tty 2&gt;/dev/null` - [ `uptime` ]\007\]\n\[\]\$&#039;;
    AAPS[1]=&#039;\n[\j:\!] \T \d \n[\u@\H:`tty 2&gt;/dev/null` +${SHLVL}] \w\[\033]0;[ ${H1}&#46;.. ] \w - \u@\H +$SHLVL @`tty 2&gt;/dev/null` - [ `uptime` ]\007\]\n\[\]\$&#039;;
&nbsp;
    : ${PLVL:=0};
    [[ &quot;${#AAPS[@]}&quot; -lt &quot;$PLVL&quot; || &quot;${#AAPS[@]}&quot; -eq &quot;$PLVL&quot; ]] &amp;&amp; PLVL=0;
    export PS1=${AAPS[$PLVL]} &amp;&amp; (( PLVL++ )) &amp;&amp; export PLVL
}</pre>
<h3>BASH 4 Multi-Prompt</h3>
<p>Here's an example from bash-4, but it works for all bash versions.</p>
<pre>prompt ()
{
    case &quot;$1&quot; in
        d)
            PS1=&#039;$(dirs) \$ &#039;
        ;;
        n)
            PS1=&#039;\$ &#039;
        ;;
        hsw)
            PS1=&#039;\h[$SHLVL]: \w \$ &#039;
        ;;
        hw)
            PS1=&#039;\h: \w \$ &#039;
        ;;
        sh)
            PS1=&#039;[$SHLVL] \h\$ &#039;
        ;;
        sw)
            PS1=&#039;[$SHLVL] \w \$ &#039;
        ;;
        uh)
            PS1=&#039;\u@\h\$ &#039;
        ;;
        uhsHw)
            PS1=&#039;\u@\h[$SHLVL]:\#: \w \$ &#039;
        ;;
        uhsw)
            PS1=&#039;\u@\h[$SHLVL]: \w \$ &#039;
        ;;
        uhw)
            PS1=&#039;\u@\h: \w \$ &#039;
        ;;
        uw)
            PS1=&#039;(\u) \w \$ &#039;
        ;;
        w)
            PS1=&#039;\w \$ &#039;
        ;;
    esac
}</pre>
<p><a id="uptime-alt" name="uptime-alt"></a></p>
<h3>Alternative to uptime:</h3>
<pre>echo &quot;Up for $(( $(sed &#039;s/^\([0-9]*\).*/\1/&#039; /proc/uptime) / (60*60*24) )) days - [`cat /proc/loadavg`]&quot;
# or
echo &quot;Uptime: $(( `sed &#039;s/^\([0-9]*\).*/\1/g&#039; /proc/uptime` / 86400 )) days. Load: $(&lt;/proc/loadavg)&quot;</pre>
<p><a id="bash-prompt-reading" name="bash-prompt-reading"></a></p>
<h2>Bash Prompts - More Reading</h2>
<p><a id="bash-prompt-vars" name="bash-prompt-vars"></a></p>
<h3>All Bash Prompt Variables</h3>
<p>These are the environment variables provided by BASH (and most shells) and control your prompt string.   While all are interesting and good to know about, <code>PROMPT_COMMAND</code> and <code>PS1</code> are the only ones that directly modify the prompt that is displayed.</p>
<dl>
<dt>PROMPT_COMMAND</dt>
<dl>If set, the value is executed as a command <strong>prior</strong> to issuing each primary prompt.</dl>
<dt>PS1</dt>
<dl>The value of this parameter is expanded and used as the primary prompt string.  The default value is "<code>\s-\v\$ </code>".</dl>
<dt>PS2</dt>
<dl>The value of this parameter is expanded as with PS1 and used as the secondary prompt string.  The default is "<code>> </code>".</dl>
<dt>PS3</dt>
<dl>The value of this parameter is used as the prompt for the select command.</dl>
<dt>PS4</dt>
<dl>The  value of this parameter is expanded as with PS1 and the value is printed before each command bash displays during an execution trace.  The first character of PS4 is replicated multiple times, as necessary, to indicate multiple levels of indirection.  The default is "<code>+</code>".</dl>
</dl>
<p><a id="prompt-escapes" name="prompt-escapes"></a></p>
<h3>Prompt Escape Codes</h3>
<p>When executing interactively, bash displays the primary prompt PS1 when it is ready to read a command and the secondary prompt PS2 when it needs more input to complete a command.  Bash allows these prompt strings to be customized by inserting a number of backslash-escaped special characters that are decoded as follows:</p>
<ul>
<li><code>\a</code> - an ASCII bell character (07)</li>
<li><code>\d</code> - the date in "Weekday Month Date" format (e.g., "Tue May 26")</li>
<li><code>\D{format}</code> - the format is passed to <a href="http://www.freebsd.org/cgi/man.cgi?query=strftime">strftime(3)</a> and the result is inserted into the prompt string; an empty format results in a locale-specific time representation.  The braces are required
<li><code>\e</code> - an ASCII escape character (033)</li>
<li><code>\h</code> - the hostname up to the first '.'</li>
<li><code>\H</code> - the hostname</li>
<li><code>\j</code> - the number of jobs currently managed by the shell</li>
<li><code>\l</code> - the basename of the shellâs terminal device name</li>
<li><code>\n</code> - newline</li>
<li><code>\r</code> - carriage return</li>
<li><code>\s</code> - the name of the shell, the basename of <var>$0</var> (the portion following the final slash)</li>
<li><code>\t</code> - the current time in 24-hour HH:MM:SS format</li>
<li><code>\T</code> - the current time in 12-hour HH:MM:SS format</li>
<li><code>\@</code> - the current time in 12-hour am/pm format</li>
<li><code>\A</code> - the current time in 24-hour HH:MM format</li>
<li><code>\u</code> - the username of the current user</li>
<li><code>\v</code> - the version of bash (e.g., 2.00)</li>
<li><code>\V</code> - the release of bash, version + patch level (e.g., 2.00.0)</li>
<li><code>\w</code> - the current working directory, with <var>$HOME</var> abbreviated with a tilde</li>
<li><code>\W</code> - the basename of the current working directory, with <var>$HOME</var> abbreviated with a tilde</li>
<li><code>\!</code> - the history number of this command</li>
<li><code>\#</code> - the command number of this command</li>
<li><code>\$</code> - if the effective UID is 0, a <strong>#</strong>, otherwise a <strong>$</strong></li>
<li><code>\nnn</code> - the character corresponding to the octal number nnn
<li><code>\\</code> - a backslash</li>
<li><code>\[</code> - begin a sequence of non-printing characters, which could be used to embed a terminal control sequence into the prompt</li>
<li><code>\]</code> - end a sequence of non-printing characters</li>
</ul>
<p>The  command  number  and the history number are usually different: the history number of a command is its position in the history list, which may include commands restored from the history file, while the command number is the position in the sequence of commands executed during the current shell session.  After the string is decoded, it is expanded via parameter expansion, command substitution, arithmetic expansion, and quote removal, subject to the value of the promptvars shell option, which if set, prompt strings undergo parameter expansion, command substitution, arithmetic expansion, and quote removal after being expanded as described in PROMPTING above.   <var>promptvars</var> is enabled by default.</p>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html"><img src="http://uploads.askapache.com/2010/03/bash-power-prompt-ps1.png" alt="bash power prompt PS1" title="bash power prompt PS1" width="513" height="96" /></a></p>
<p><a id="ps1-examples" name="ps1-examples"></a></p>
<h3>More Example Prompts</h3>
<pre>export PS1=&quot;\n\e[1;37m[\e[0;32m\u\e[0;35m@\e[0;32m\h\e[1;37m]\e[1;37m[\e[0;31m\w\e[1;37m]\n$ \e[0m&quot;
[user@host][~/bin/tools]
$</pre>
<pre>export PS1=&quot;\n[$?]\e[1;37m[\e[0;32m\u\e[0;35m@\e[0;32m\h\e[1;37m]\e[1;37m[\e[0;31m\w\e[1;37m]($SHLVL:\!)\n\[\033[0m\]\$ &quot;
[0][user@host][~/bin/tools](1:2130)</pre>
<pre>export PS1=&#039;\[\033[1;33m\]\u\[\033[1;37m\]@\[\033[1;32m\]\h\[\033[1;37m\]:\[\033[1;31m\]\w \[\033[1;36m\]\$ \[\033[0m\]&#039;
user@host:~/bin/tools $</pre>
<pre>export PS1=&quot;\e[1;31m[\h]$NC \W &gt; \[\033]0;\${TERM} [\u@\h] \w\]&quot;
[lifesaver] tools &gt;</pre>
<h2>Benchmarking PROMPT_COMMAND</h2>
<p>When figuring out how resource intensive your prompt_command is (if you choose to do that sort of thing), it's nice to do it like this.  I ended up using  this information from the following test to create the prompt_command used in the first 256-color prompt above.</p>
<pre>#!/bin/bash
&nbsp;
function clean_results()
{
      grep ^real | cut -dm -f2 | sort | uniq -c | sort -n
}
&nbsp;
for i in {0..500};
do
      time sh -c &quot;expr `sed -nu &#039;s/^MemFree:[\t ]\+\([0-9]\+\) kB/\1/Ip&#039; /proc/meminfo`/1024&quot; &amp;&gt;/dev/nulll;
done 2&gt;&amp;1 | clean_results
&nbsp;
# print separating line
printf &quot;%$((${COLUMNS:-`tput cols`} - 10))s\n&quot; &#039; &#039; | sed -u &#039;s/ /-/g&#039;
&nbsp;
for i in {0..500};
do
      time sh -c &quot;echo $(( `sed -nu &#039;s/^MemFree:[\t ]\+\([0-9]\+\) kB/\1/Ip&#039; /proc/meminfo`/1024 ))&quot; &amp;&gt;/dev/null;
done 2&gt;&amp;1 | clean_results
&nbsp;
exit $?</pre>
<p>Generates this output, meaning that using expr takes longer.</p>
<pre>      1 0.011s
      1 0.014s
      2 0.009s
      2 0.012s
      5 0.008s
     12 0.004s
     47 0.007s
    215 0.005s
    216 0.006s
&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-
      1 0.003s
      2 0.007s
     59 0.006s
    196 0.004s
    243 0.005s</pre>
<p><a id="more-reading" name="more-reading"></a></p>
<h3>Additional Links</h3>
<ul>
<li><a href="http://tldp.org/HOWTO/From-PowerUp-To-Bash-Prompt-HOWTO.html">From Power Up To Bash Prompt - TLDP</a></li>
<li><a href="http://www.ibiblio.org/pub/Linux/docs/HOWTO/other-formats/html_single/Bash-Prompt-HOWTO.html">Bash Prompt HOWTO -TLDP</a></li>
<li><a href="http://tldp.org/LDP/abs/html/sample-bashrc.html">A Sample .bashrc File - TLDP</a></li>
<li><a href="http://gentoo.linuxhowtos.org/bash/bash_prompt_howto.htm">Gentoo Linux Howtos: bash -> Bash Prompt Howto - Gentoo</a></li>
<li><a href="http://www.debian-administration.org/article/Fancy_Bash_Prompts">Fancy Bash Prompts - Debian Administration</a></li>
</ul>
<p><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html"></a><a href="http://www.askapache.com/linux-unix/bash-power-prompt.html">Crazy POWERFUL Bash Prompt</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/r-M7hPhZS_C6Saa5M6fju6ZmiiQ/0/da"><img src="http://feedads.g.doubleclick.net/~a/r-M7hPhZS_C6Saa5M6fju6ZmiiQ/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/r-M7hPhZS_C6Saa5M6fju6ZmiiQ/1/da"><img src="http://feedads.g.doubleclick.net/~a/r-M7hPhZS_C6Saa5M6fju6ZmiiQ/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=xmdP_W9e0LY:v43WBCsFt7M:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=xmdP_W9e0LY:v43WBCsFt7M:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=xmdP_W9e0LY:v43WBCsFt7M:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=xmdP_W9e0LY:v43WBCsFt7M:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=xmdP_W9e0LY:v43WBCsFt7M:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=xmdP_W9e0LY:v43WBCsFt7M:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=xmdP_W9e0LY:v43WBCsFt7M:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/linux-unix/bash-power-prompt.html/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		<feedburner:origLink>http://www.askapache.com/linux-unix/bash-power-prompt.html</feedburner:origLink></item>
		<item>
		<title>Questions I Ask Web Hosting Companies, Before Buying</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/6H5PFcHQ8Jc/before-buying-web-hosting.html</link>
		<comments>http://www.askapache.com/web-hosting/before-buying-web-hosting.html#comments</comments>
		<pubDate>Sun, 25 Apr 2010 10:15:16 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Making Money]]></category>
		<category><![CDATA[Review]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Web Design]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WiredTree]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[Examples]]></category>
		<category><![CDATA[Hosting]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Powweb]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[tutorial]]></category>
		<category><![CDATA[VPS]]></category>
		<category><![CDATA[Web Hosts]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=4419</guid>
		<description><![CDATA[<p>The following is a transcript of a chat I had with a company called tektonic, and at that time I was looking for a cheap linux host to use for some redundancy/failover operations.  I generally contact a new hosting company like this every few months.. I like to have options available in case of some kind of failure or network attack, so it's always a good idea to have a few ace linux servers in your back pocket.</p>
<p>If you've read any other articles on AskApache, you can see a certain obsession towards optimization, speed, and security -- so that is the purpose of the following questions.</p>
]]></description>
			<content:encoded><![CDATA[<p>I&#8217;m always on the lookout for cheap hosting and great hosting companies, and being that I have done this for many years, on many platforms, and with many hosts, my only requirement is that the host uses a UNIX/BSD/LINUX operating system.  I&#8217;m just not one of those people who likes to do things the hard way, constantly, if its even possible on a non-nix, or one of those people who enjoys getting hacked or my sites defaced by a cracker.  So *nix is definitely a requirement.  This is just a current look at the basic idea I use when looking for a web host.  If you were smart you would do a whole lot more than this.</p>
<h2>Research the People</h2>
<p>Ok, in a web hosting company there are 5 distinct groups of people, at least generally, that you will want to get in contact with or at least do some background research on (like the owners/founders).  Depending on which of these groups you talk to will determine the amount and quality of information you get, the difference is night and day. Because of my past experience with really bad hosts (DreamHost), and really great hosts (<a rel="nofollow" href="http://www.wiredtree.com/298.html">WiredTree</a>), I am very cautious and purposeful in making this decision, so I go to great lengths to contact at least one person from each of these groups.  Most good advice says to also get in touch with customers.. I don&#8217;t usually need/want to do that though because most customers don&#8217;t know jack.  But of course I know a few of the customers because I research the hosts network block and test the speed and servers that run on their IP block.</p>
<h3>Who / Why</h3>
<p>Being a curious and inquisitive person by nature, I always do background research on who started the company, how they started it, and what skills they have.  Knowing who the owners are and if they are real unix/network experts or just snake oil salesmen really makes a difference in this world of smoke and mirrors.</p>
<p> Here&#8217;s my recommendation of which group to contact, in order of best to worst:</p>
<ol>
<li><strong>Owners/Founders</strong> &#8211; The Founders have been involved since the start of the company.  Always contact.</li>
<li><strong>System Admins</strong> &#8211; Programmers and System Operators who keep things running, fix problems tech support cant.  Always contact.</li>
<li><strong>Sales/Marketing</strong> &#8211; Both types have different motivations for what they say, and how they say it.  Always contact both.</li>
<li><strong>Tech Support</strong> &#8211; They make the web go round, will always know a lot about problems and issues their customers frequently experience.  Always contact.</li>
<li><strong>Management</strong> &#8211; These people are in charge of the day-to-day operations, overseers.  Contact optional.</li>
</ol>
<h2>Questions to Ask</h2>
<p>The following is a transcript of a chat I had with a company called <a href="http://tektonic.net/">tektonic</a>, and at that time I was looking for a cheap linux host to use for some redundancy/failover operations.  I generally contact a new hosting company like this every few months.. I like to have options available in case of some kind of failure or network attack, so it&#8217;s always a good idea to have a few ace linux servers in your back pocket.</p>
<p>If you&#8217;ve read any other articles on AskApache, you can see a certain obsession towards optimization, speed, and security &#8212; so that is the purpose of the following questions.</p>
<table cellspacing="0" cellpadding="5" border="1" width="100%" dir="ltr">
<tbody>
<tr>
<td colspan="2">
<div>General Info</div>
</td>
</tr>
<tr>
<td><strong>Chat start time</strong></td>
<td> Apr 7, 2010 7:18:07 AM EST</td>
</tr>
<tr>
<td><strong>Chat end time</strong></td>
<td> Apr 7, 2010 8:38:52 AM EST</td>
</tr>
<tr>
<td><strong>Duration (actual chatting time)</strong></td>
<td> 01:20:44</td>
</tr>
<tr>
<td><strong>Operator</strong></td>
<td> Vish</td>
</tr>
</tbody>
</table>
<h2>Chat Transcript</h2>
<div class="zebra3" style="font-size:1.1em;line-height:.9em;">
<blockquote>
<p style="color:#ccc"><strong>info:</strong> Please wait for a site operator to respond. You are 1 out of 1 in the queue. The average wait time is 0 minutes and 30 seconds.</p>
<p style="color:#ccc"><strong>info:</strong> You are now chatting with &#39;Vish&#39;</p>
<p><strong>Vish:</strong> Hello</p>
<p class="aa21"><strong>AskApache:</strong> Hi vish, i was looking to purchase a planwith you guys but had some questions.. is this the right place to ask?</p>
<p><strong>Vish:</strong> yeah sure</p>
<p><strong>Vish:</strong> Let me know how may I assist you with ?</p>
<p class="aa21"><strong>AskApache:</strong> what is your cheapest plan that includes ssh?</p>
<p><strong>Vish:</strong> <a href="http://tektonic.net/vps.php">http://tektonic.net/vps.php</a></p>
<p><strong>Vish:</strong> Linux-360</p>
<p class="aa21"><strong>AskApache:</strong> im there.. </p>
<p><strong>Vish:</strong> It is cheapest plan you can have</p>
<p class="aa21"><strong>AskApache:</strong> what does full root access mean for you guys? </p>
<p class="aa21"><strong>AskApache:</strong> do you have swap? jailshell?</p>
<p><strong>Vish:</strong> you have full access of you server .</p>
<p class="aa21"><strong>AskApache:</strong> including network interface device access? ie.. is it possible to setup virtual nics?</p>
<p><strong>Vish:</strong> Sorry we do not provide it.</p>
<p><strong>Vish:</strong> hold on </p>
<p><strong>Vish:</strong> Let me check</p>
<p class="aa21"><strong>AskApache:</strong> how can i find out more about the limits of the machine for the Linux-360?</p>
<p class="aa21"><strong>AskApache:</strong> like how many processes, fd descriptors.. </p>
<p><strong>Vish:</strong> You can mail us at sales department.</p>
<p><strong>Vish:</strong> They will get back to you with in few hrs with your answers </p>
<p><strong>Vish:</strong> You can just drop mail at <a href="mailto:sales@tektonic.net">sales@tektonic.net</a></p>
<p class="aa21"><strong>AskApache:</strong> no thanks.</p>
<p class="aa21"><strong>AskApache:</strong> jw if you had that info offhand.</p>
<p class="aa21"><strong>AskApache:</strong> do you know if cpanel is optinoal?</p>
<p class="aa21"><strong>AskApache:</strong> could it be uninstalled?</p>
<p><strong>Vish:</strong> yeah</p>
<p><strong>Vish:</strong> you can install or uninstall as you wish </p>
<p class="aa21"><strong>AskApache:</strong> Thanks vish you are being very helpful&#8230; a few more.. </p>
<p><strong>Vish:</strong> sure</p>
<p class="aa21"><strong>AskApache:</strong> what operating system?</p>
<p><strong>Vish:</strong> Hold on ..</p>
<p><strong>Vish:</strong> allow me a moment. </p>
<p class="aa21"><strong>AskApache:</strong> please take your time</p>
<p><strong>Vish:</strong> We do provide Ubantu , Centos and Debian</p>
<p><strong>Vish:</strong> You can reinstall your server any time with one click </p>
<p class="aa21"><strong>AskApache:</strong> what devices are supported in /dev ?</p>
<p class="aa21"><strong>AskApache:</strong> do you support loop devices, ramdisk/tmpfs/swap?</p>
<p><strong>Vish:</strong> One moment please..</p>
<p class="aa21"><strong>AskApache:</strong> no rush at all, thanks</p>
<p><strong>Vish:</strong> We do provide tmpfs but ramdisk and swap is not available .</p>
<p><strong>Vish:</strong> All basic device are available with us optional devices like TUN is also enabled for you automatically. </p>
<p class="aa21"><strong>AskApache:</strong> sweet</p>
<p class="aa21"><strong>AskApache:</strong> is ipv6 supported?</p>
<p><strong>Vish:</strong> It is there but we do support currently .</p>
<p><strong>Vish:</strong> We are thinking to provide it in near future for our clients ;)</p>
<p class="aa21"><strong>AskApache:</strong> good idea, people will start using it in 5years or so.. maybe</p>
<p class="aa21"><strong>AskApache:</strong> how is the internal network segmented? vlans? </p>
<p class="aa21"><strong>AskApache:</strong> for security..</p>
<p><strong>Vish:</strong> Yeah, We do have Vlans</p>
<p class="aa21"><strong>AskApache:</strong> security is very crucial.</p>
<p><strong>Vish:</strong> You can check  more info in network here <a href="http://tektonic.net/network.php">network</a></p>
<p class="aa21"><strong>AskApache:</strong> ok thanks brb</p>
<p class="aa21"><strong>AskApache:</strong> do you allow kernel modules? or reloading the kernel like kexec?</p>
<p><strong>Vish:</strong> a moment please.</p>
<p><strong>Vish:</strong> What type kernel module you are looking for exactly ?</p>
<p><strong>Vish:</strong> kexex is  for fast reboot .</p>
<p><strong>Vish:</strong> Is there any specific requirement ?</p>
<p><strong>Vish:</strong> As we do not allow kernel modules on VPS they are not supported by virtuzzo. </p>
<p class="aa21"><strong>AskApache:</strong> ok.. so far so good. let me think a minute.</p>
<p class="aa21"><strong>AskApache:</strong> what kind of failovers do you have? </p>
<p class="aa21"><strong>AskApache:</strong> like if a machine fails to reboot or goes offline</p>
<p><strong>Vish:</strong> we do not provide failover services for vpses at this time. You  will have power panel in hand using it you can reboot or reinstall your machine in one click. You can reach us 24*7 for live support.</p>
<p class="aa21"><strong>AskApache:</strong> one problem that I&#39;ve seen on other vps&#39;s is sometimes a vps upon reboot fails to recognize the network interface/fails to connect to the web.. When that happens we are unable to ssh into the box to fix the problem and rely on support.. is this something that would be easy/normal for your support (to have to manually login to the vps locally)</p>
<p><strong>Vish:</strong> There are the possiblities for the issue so we need to check in server but you can reach us anytime for live chat and ticket system.</p>
<p><strong>Vish:</strong> as you are on live chat right now ;)</p>
<p class="aa21"><strong>AskApache:</strong> so your support does have access to the vps locally? </p>
<p class="aa21"><strong>AskApache:</strong> in case the network is down due to vps errors</p>
<p><strong>Vish:</strong> Yes, We have the access</p>
<p class="aa21"><strong>AskApache:</strong> do you run any packet filtering on the network or is this controlled solely with the vps?</p>
<p class="aa21"><strong>AskApache:</strong> like iptables stuff.. switch/router filtering beyond defaults..</p>
<p><strong>Vish:</strong> No , we dont have packet filtering the port we block is IRC only.</p>
<p class="aa21"><strong>AskApache:</strong> great</p>
<p><strong>Vish:</strong> I&#39;m sorry for the delay. I&#39;ll be right with you.</p>
<p><strong>Vish:</strong> Is there anything else I may assist you with ?</p>
<p class="aa21"><strong>AskApache:</strong> no problem, you&#39;ve answered all my questions so far.. trying to think of anything else I&#39;d like to know before buying.. </p>
<p><strong>Vish:</strong> Sure</p>
<p><strong>Vish:</strong> Is there anything else I can help you with ?</p>
<p class="aa21"><strong>AskApache:</strong> Does the Linux-360 support filesystems? what storage devices are included (usually just 1 ext2/3/4 fs for vps).. Is it possible to repartition the drive? </p>
<p class="aa21"><strong>AskApache:</strong> Oh and the other kernel module I would love to have on a vps is fuse so that I can mount remote filesystems (such as sshfs or nbd)</p>
<p><strong>Vish:</strong> We do not provide kernel modules on VPS.</p>
<p class="aa21"><strong>AskApache:</strong> do you allow kernel compilation? (that way i can build the module statically into the kernel) </p>
<p><strong>Vish:</strong> A moment please.</p>
<p><strong>Vish:</strong> We do not allow kernel compilation on VPS.</p>
<p class="aa21"><strong>AskApache:</strong> ok, thats smart security</p>
<p class="aa21"><strong>AskApache:</strong> what about the linux-360 partitioning question?</p>
<p><strong>Vish:</strong> Thanks. :)</p>
<p><strong>Vish:</strong> it is tmpfs on VPS</p>
<p><strong>Vish:</strong> and we dot allow repartition.</p>
<p class="aa21"><strong>AskApache:</strong> which is ultimately mounted on.. filesystems? like could I modify an ext3 / to ext4 or reiserfs?</p>
<p class="aa21"><strong>AskApache:</strong> expected.. ok</p>
<p><strong>Vish:</strong> No, it is vzfs</p>
<p class="aa21"><strong>AskApache:</strong> even better.</p>
<p class="aa21"><strong>AskApache:</strong> thats what i mostly use.</p>
<p><strong>Vish:</strong> great</p>
<p class="aa21"><strong>AskApache:</strong> What vps os install images do you use? like where do you get the CentOS/Ubuntu/Debian vps images? And are they modified/customized by you guys in any way?</p>
<p class="aa21"><strong>AskApache:</strong> Or just all defaults?</p>
<p><strong>Vish:</strong> they include basic services such as httpd, sendmail</p>
<p class="aa21"><strong>AskApache:</strong> sorry for all the q&#39;s &#8230; I wasn&#39;t thinking that I&#39;d actually find a good host to purchase, but so far tek is looking really good.. might go ahead within the hour.</p>
<p><strong>Vish:</strong> otherwise default </p>
<p><strong>Vish:</strong> We get it from parallels</p>
<p><strong>Vish:</strong> Okay great.</p>
<p><strong>Vish:</strong> Is there anything else I can help you with ?</p>
<p class="aa21"><strong>AskApache:</strong> like: <a href="http://download.openvz.org/template/precreated/">http://download.openvz.org/template/precreated/</a></p>
<p class="aa21"><strong>AskApache:</strong> do you use templates like that.. </p>
<p><strong>Vish:</strong> We get it  from parallels</p>
<p class="aa21"><strong>AskApache:</strong> how many employees do you have? how many customers? </p>
<p><strong>Vish:</strong> Sorry, We do not disclose this information</p>
<p class="aa21"><strong>AskApache:</strong> thats fine.. </p>
<p><strong>Vish:</strong> For more you can contact sales department.</p>
<p><strong>Vish:</strong> You are on technical department live chat.</p>
<p class="aa21"><strong>AskApache:</strong> can you give me more info on what type of parallels products you utilize? </p>
<p class="aa21"><strong>AskApache:</strong> I wouldn&#39;t last long on any other chat.. ;)</p>
<p class="aa21"><strong>AskApache:</strong> I&#39;m curious so if it&#39;s a template/container I haven&#39;t used before I can test it out on my own machine.</p>
<p><strong>Vish:</strong> We provide power panel from parallels</p>
<p class="aa21"><strong>AskApache:</strong> i mean like the templates/container versions you use.. I want to check that you use updated/new versions and are valid licensed.</p>
<p><strong>Vish:</strong> you mean OS version ?</p>
<p class="aa21"><strong>AskApache:</strong> basically, do you know if you use the latest available os images from parallels.. </p>
<p class="aa21"><strong>AskApache:</strong> and I will let you go with that.. </p>
<p style="color:#ccc"><strong>info:</strong> Your chat transcript will be sent to your email at the end of your chat.</p>
<p><strong>Vish:</strong> Yes , We do provide latest OS version as per requirement. </p>
<p class="aa21"><strong>AskApache:</strong> thank you vish, you&#39;ve been most helpful. I am going to do a little more digging online about you guys and will probably be back with a couple questions.. cya around, have an awesome day</p>
</blockquote>
</div>
<h2>Hosts used by AskApache.com</h2>
<p><a rel="nofollow" href="http://www.wiredtree.com/298.html">WiredTree</a> is the main hosting company that I mainly use for this site and my business.  It took me 10+ years of trial and error before I found them, you can believe I will be posting alot more about them on this site, stay tuned.  I also use <a rel="nofollow" href="http://secure.hostgator.com/~affiliat/cgi-bin/affiliates/clickthru.cgi?id=askapache">HostGator</a>, and several other dependable nix hosts that are dirt cheap.</p>
<h2>Finding A Host</h2>
<p>I used to spend days and weeks googling for a host that wouldn&#8217;t end up burning me later, oh that really sucked.  Now I use a site developed by a colleague of mine, <a href="http://www.webhostingsearch.com/">Web Hosting Search</a> as it lets me fairly quickly find a linux host with my bare requirements.  From THERE is when I start my own research.  This includes email and followups on the phone, visiting wiki&#8217;s, googling owners, sneaking around in customer areas, etc..</p>
<h2>Who do you Use?</h2>
<p>I&#8217;d love to hear about anyone&#8217;s experiences with specific hosts, recommendations especially!</p>
<p><a href="http://www.askapache.com/web-hosting/before-buying-web-hosting.html"></a><a href="http://www.askapache.com/web-hosting/before-buying-web-hosting.html">Questions I Ask Web Hosting Companies, Before Buying</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/0D8F3yCwcnATWNC76Go4HLG8FZA/0/da"><img src="http://feedads.g.doubleclick.net/~a/0D8F3yCwcnATWNC76Go4HLG8FZA/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/0D8F3yCwcnATWNC76Go4HLG8FZA/1/da"><img src="http://feedads.g.doubleclick.net/~a/0D8F3yCwcnATWNC76Go4HLG8FZA/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=6H5PFcHQ8Jc:qNuI3cvvV4U:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=6H5PFcHQ8Jc:qNuI3cvvV4U:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=6H5PFcHQ8Jc:qNuI3cvvV4U:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=6H5PFcHQ8Jc:qNuI3cvvV4U:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=6H5PFcHQ8Jc:qNuI3cvvV4U:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=6H5PFcHQ8Jc:qNuI3cvvV4U:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=6H5PFcHQ8Jc:qNuI3cvvV4U:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/web-hosting/before-buying-web-hosting.html/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		<feedburner:origLink>http://www.askapache.com/web-hosting/before-buying-web-hosting.html</feedburner:origLink></item>
		<item>
		<title>HOWTO: Uninstall CPANEL over SSH</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/wyDk1szkibM/uninstall-cpanel.html</link>
		<comments>http://www.askapache.com/server-administration/uninstall-cpanel.html#comments</comments>
		<pubDate>Sat, 24 Apr 2010 18:55:40 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Shell Scripting]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WiredTree]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[centos]]></category>
		<category><![CDATA[Cpanel]]></category>
		<category><![CDATA[cpanel uninstall]]></category>
		<category><![CDATA[kill cpanel]]></category>
		<category><![CDATA[linux find]]></category>
		<category><![CDATA[uninstall cpanel]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=4404</guid>
		<description><![CDATA[<p>The following is just a quick reference of some of the commands I used to uninstall cpanel.  This is for advanced users of the shell.  If you aren't that advanced and you run a single one of these commands without fully understanding it, you will probably kill your server, probably lose everything on it permanently, probably not have a website or email for weeks..  So backup all your data FIRST.  Also, if you aren't 100% sure you won't run into problems, you should contact your hosts technical support - but be prepared for some MAJOR negativity..  cpanel makes things very easy for hosts, and the last thing tech support wants is to fix a server broken by someone who doesn't know what they are doing.</p>]]></description>
			<content:encoded><![CDATA[<p><strong>WARNING!</strong> This is for advanced users of the shell, this is NOT a howto or tutorial.  The thing is, I googled <strong>how to uninstall cpanel</strong> and for once in my life I came up empty.. And certainly the cpanel official sites themselves don&#8217;t provide any instructions other than to say &#8220;Dont uninstall it, reinstall your entire operating system without it.&#8221;..   they sure don&#8217;t seem confident that they know exactly what their code is doing.  At this point this is more of a series of notes than a guide.  Ok now go have some fun!</p>
<h2>Why Uninstall?</h2>
<p>Why?  Because I have always built my servers, php installations, perl installs, ruby, iptables, everything from source.  I read the INSTALL/README docs, I read the man pages, and I read the info pages as well.  I google for configuration advice, I google for tips, and I don&#8217;t need a web-based perl script messing my stuff up!</p>
<p>The main problems I had with cpanel, which really is a great bit of software for millions of website developers, is that it was incredibly sneaky!  I used it for about 6 months and spent that entire time trying to figure out what the heck it was doing.  A couple issues that I really disliked, it takes over your bind install, it takes over your apache install, it takes over your php install.  And although it does let you configure some things (very few) for custom configurations and the like, I just don&#8217;t need any of that.  By removing the darn thing I am saving GIGS of space on my server, tons of bandwidth, and most importantly to me I am saving CPU and processing time along with RAM and IO speed.</p>
<h3>Anything Else</h3>
<p>Please.. I could go on for DAYS!  Another reason I have wanted to be rid of cpanel is that I like my servers to be as lean and mean as possible.  This means I like as few files and processes as possible.  There are many benefits to this, like it&#8217;s much easier for my integrity checking software and rootkit/antivirus software to run and drastically reduces the false positives.  And there is that glaring security issue of constantly having cpanel run it&#8217;s own software to create the WHM/Cpanel web interface, which is accessible online.  I haven&#8217;t researched cpanel security at all, it&#8217;s possible that it never has security problems that are published, but for me, why take the chance?</p>
<h2>Warning &#8211; Caution!</h2>
<p>The following is just a quick reference of some of the commands I used to uninstall cpanel.  This is for advanced users of the shell.  If you aren&#8217;t that advanced and you run a single one of these commands without fully understanding it, you will probably kill your server, probably lose everything on it permanently, probably not have a website or email for weeks..  So backup all your data FIRST.  Also, if you aren&#8217;t 100% sure you won&#8217;t run into problems, you should contact your hosts technical support &#8211; but be prepared for some MAJOR negativity..  cpanel makes things very easy for hosts, and the last thing tech support wants is to fix a server broken by someone who doesn&#8217;t know what they are doing.</p>
<h2>Last Warning!</h2>
<p>Unless you understand what theses commands do and the purpose they serve, do not try any of this.  These are not the exact commands I used verbatim, they are also not in order.  I only put them up here because I was so amazed that google didn&#8217;t have any uninstall cpanel intructions.  Hopefully it&#8217;s not a conspiracy that will get my site taken down.. ;)</p>
<p>That said and out of the way, it really only took me about 10 minutes to uninstall cpanel completely.  But keep in mind I have been closely monitoring and debugging cpanel for 6 months, so I knew what I was doing.  And finally, I do apologize for not having better instructions.. but hey, if you don&#8217;t get this then you have no business trying to figure out how to uninstall cpanel!  It&#8217;s great software and shouldn&#8217;t be removed unless you are fully capable of managing email/dns/www/ftp and any/all other servers and services on your machine by hand.</p>
<h2>Do This First</h2>
<p>I have a few drafts I&#8217;m working on at the moment with specifics, but for now you will have to figure it out with google.  Basically you want to make sure you don&#8217;t totally knock your machine offline without being able to reconnect.  What I do is compile a static version of openssh and a few other security-type shell tools, and configure this binary sshd to run by using inittab, which is the file run by init (pid 1) and makes sure if it dies it is restarted.  Here is my /etc/inittab to run the static sshd binary:</p>
<pre>hh:12345:respawn:/failover/os/sbin/aassh -D -q -u0 -f /failover/os/etc/aassh</pre>
<p>Another trick is to keep a detached screen logged in to root.  That way if you mess up your sudoers or securetty or pam or whatever, you can just reattach and fix it.</p>
<p>Finally, you may want to setup your syslog to start earlier than usual, and set up more than normal verbosity.  ( I take it to the max ).  Then you should setup a 2nd server or machine somewhere to act as a syslog server.  Lastly, configure your web server syslog to copy all messages to the remote syslog you set up.  I use a reverse ssh tunnel to encrypt the syslog packets, but when I do something serious like reboot after uninstalling cpanel, I prepare for it by adding additional networking routes on my machine to make sure I will get some logs even if sshd cant start or even if my network addresses aren&#8217;t brought up correctly.</p>
<p>If that sounds easy to you, please continue.   If you are saying: Wha??? Continue in read-only mode.</p>
<p class="cnote">Also, you can&#8217;t just uninstall cpanel, I have replaced a lot of cpanel already, like building my own bind, apache, php, syslog and making sure they work and aren&#8217;t being tampered with by cpanel.  Basically cpanel runs everything on your server in most cases, so you should prepare by creating your own static software to replace cpanel, and make sure it works.</p>
<h2>Find files Accessing /var/cpanel</h2>
<p>More than likely these will need to be killed.</p>
<pre>lsof +w -Rg -nP +c15 -x f +D /var/cpanel
lsof +w -Rg -nP +c15 -x f +D /usr/local/cpanel</pre>
<h2>Killing cpanel</h2>
<p>Just an example, your machine may have a lot more than these, I have been slowly taking control of my machine back from cpanel for 6 months, so it was easier for me.</p>
<pre>for P in tailwatchd queueprocd cpanellogd exim; do pkill -9 $P; done</pre>
<h2>Commands and Shortcuts</h2>
<pre>alias NF=&#039;nice find $PWD -mount -depth ! -type d&#039;
alias NFF=&#039;nice find $PWD -mount -depth ! -type d | xargs -IF87 file F87&#039;
alias NA=&#039;nice find $PWD -mount -depth&#039;
alias NAF=&#039;nice find $PWD -mount -depth | xargs -IF87 file F87&#039;</pre>
<h2>Watch out for crontab</h2>
<p>An example of the sneakiness (from my POV, from most it&#8217;s called builtin robustness) that cpanel does is automagically adding crontab entries that make it behave similarly to a self-propagating virus.  If you don&#8217;t disable the cronjobs and kill the right processes within a short period of time, be prepared for a magic resurrection.</p>
<p>Here&#8217;s my awesome crontab information function, you will need to check every file, it lists the default crons on my box, and every users crontab, but it can&#8217;t account for other cron software like at and other crons.</p>
<pre>function askapache_crontab()
{
  local GG i;
  for i in `getent passwd|cut -d &quot;:&quot; -f1`;
  do
    GG=$(sudo crontab -u $i -l 2&gt;$N6 | tr -s &#039;\n\000&#039; | sed &#039;/^#/d&#039;);
    [[ ${#GG} -gt 3 ]] &amp;&amp; sleep 1 &amp;&amp; echo -e &quot;$i \n\n${GG}&quot;
  done;
   sleep 4;
   ls -aLls1ch &#45;-color=always /etc/cron.{hourly,daily,weekly,monthly,d} | sed &#039;/^total/d; /\ drwxr-xr-x/d&#039;;
}</pre>
<pre>grep -ir /var/spool cpan</pre>
<pre>#6 3 * * * /scripts/upcp
#0 1 * * * /scripts/cpbackup
#0 2 * * * /scripts/mailman_chown_archives
#35 * * * * /usr/bin/test -x /usr/local/cpanel/bin/tail-check &amp;&amp; /usr/local/cpanel/bin/tail-check
#11,26,41,56 * * * * /usr/local/cpanel/whostmgr/bin/dnsqueue &gt; /dev/null 2&gt;&amp;1
#30 */4 * * * /usr/bin/test -x /scripts/update_db_cache &amp;&amp; /scripts/update_db_cache
#45 */8 * * * /usr/bin/test -x /usr/local/cpanel/bin/optimizefs &amp;&amp; /usr/local/cpanel/bin/optimizefs
#*/5 * * * * /usr/local/cpanel/bin/dcpumon &gt;/dev/null 2&gt;&amp;1
#25 1 * * * /usr/local/cpanel/whostmgr/docroot/cgi/cpaddons_report.pl &#45;-notify</pre>
<h2>Delete Crontabs</h2>
<pre>sudo crontab -u mailman -r</pre>
<h2>Find INIT scripts with cpanel</h2>
<p>This is the main startup script: <code>/usr/local/cpanel/etc/init/startup</code></p>
<p>I had no idea ruby-on-rails was being controlled by cpanel.. sneaky bugger.  You can tell by all of these advanced unix commands just how difficult it would be to uninstall cpanel, its totally like the Alien!</p>
<pre>(1:3744)# find . ! -type d -print0|xargs -0 -I&#039;F87&#039; grep -Hi &quot;cpan\|tailwat\|chkser&quot; F87
./fastmail:# Author:       cPanel, Inc. &lt;nick@cpanel.net&gt;
./httpd:        HTTPD=/usr/local/cpanel/bin/chroothttpd
./cpanel:# cpanel8       Start Cpanel Services
./cpanel:# Author:       cPanel, Inc. &lt;nick@cpanel.net&gt;
./cpanel:# description: This is the cpanel webserver and chat.
./cpanel:# processname: cpaneld
./cpanel:# pidfile: /var/run/cpanel.pid
./cpanel:[ -f /usr/local/cpanel/etc/init/startup ] || exit 0
./cpanel:       if [ -f &quot;/var/cpanel/smtpgidonlytweak&quot; ]; then
./cpanel:       echo -n &quot;Starting cPanel services: &quot;
./cpanel:       daemon /usr/local/cpanel/etc/init/startcpsrvd
./cpanel:       echo -n &quot;Starting cPanel brute force detector services: &quot;
./cpanel:       daemon /usr/local/cpanel/etc/init/startcphulkd
./cpanel:    echo -n &quot;Starting cPanel dav services: &quot;
./cpanel:       daemon /usr/local/cpanel/etc/init/startcpdavd
./cpanel:               daemon /usr/local/cpanel/etc/init/startcppop
./cpanel:       echo -n &quot;Starting cPanel Chat services: &quot;
./cpanel:               daemon /usr/local/cpanel/entropychat/entropychat
./cpanel:               daemon /usr/local/cpanel/bin/startmelange
./cpanel:                       /usr/local/cpanel/bin/startinterchange
./cpanel:       echo -n &quot;Starting cPanel ssl services: &quot;
./cpanel:       daemon /usr/local/cpanel/startstunnel
./cpanel:    echo -n &quot;Starting cPanel Queue services: &quot;
./cpanel:       daemon /usr/local/cpanel/etc/init/startqueueprocd
./cpanel:    echo -n &quot;Starting tailwatchd: &quot;
./cpanel:    daemon /usr/local/cpanel/libexec/tailwatchd &#45;-start
./cpanel:       echo -n &quot;Starting cPanel Log services: &quot;
./cpanel:       daemon /usr/local/cpanel/cpanellogd
./cpanel:    action &quot;Starting mailman services: &quot; /usr/local/cpanel/etc/init/startmailman
./cpanel:    action &quot;Stopping tailwatchd: &quot; /usr/local/cpanel/libexec/tailwatchd &#45;-stop
./cpanel:    action &quot;Stopping cPanel services: &quot; /usr/local/cpanel/etc/init/stopcpsrvd
./cpanel:       action &quot;Stopping cPanel dav services: &quot; /usr/local/cpanel/etc/init/stopcpdavd
./cpanel:       action &quot;Stopping cPanel queue services: &quot; /usr/local/cpanel/etc/init/stopqueueprocd
./cpanel:       action &quot;Stopping cPanel brute force detector services: &quot; /usr/local/cpanel/etc/init/stopcphulkd
./cpanel:               action &quot;Stopping pop3 services: &quot; /usr/local/cpanel/etc/init/stopcppop
./cpanel:       echo -n &quot;Stopping cPanel log services: &quot;
./cpanel:       killproc cpanellogd
./cpanel:       echo -n &quot;Stopping cPanel Chat services: &quot;
./cpanel:       action &quot;Stopping cPanel ssl services: &quot; /usr/local/cpanel/etc/init/stopstunnel
./cpanel:       action &quot;Stopping mailman services: &quot; /usr/local/cpanel/etc/init/stopmailman
./cpanel:       if [ -e &quot;/usr/local/cpanel/3rdparty/mailman/bin/mailmanctl&quot; ]; then
./exim:if [ -e &quot;/etc/chkserv.d&quot; ]; then
./exim:        for file in `ls /etc/chkserv.d`
./exim:            if [ ! -e &quot;/usr/local/cpanel/libexec/tailwatchd&quot; ]; then
./exim:    if [ -x &quot;/usr/local/cpanel/etc/init/startspamd&quot; ]; then
./exim:        /usr/local/cpanel/etc/init/startspamd
./exim:        if [ ! -e &quot;/usr/local/cpanel/libexec/tailwatchd&quot; ]; then
./ror:  /usr/local/cpanel/bin/rormgr &#45;-startboot
./ror:  /usr/local/cpanel/bin/rormgr &#45;-stopall
./ror:  /usr/local/cpanel/bin/rormgr &#45;-stopall
./ror:  /usr/local/cpanel/bin/rormgr &#45;-startboot
./ror:  /usr/local/cpanel/bin/rormgr &#45;-statusall
./securetmp:# Author:       cPanel, Inc. &lt;copyright@cpanel.net&gt;</pre>
<h3>Turn off cpanel services</h3>
<p>You should remove the below delete command and start by just disabling the inits by turning them off.  Then reboot. Then delete.  If your machine won&#8217;t reboot, I told you so, Cpanel told you so, and likely your host told you so.</p>
<pre>for S in cpanel ror securetmp fastmail exim; do R=$(command chkconfig &#45;-level 123456 $S off ||echo); R=$(command chkconfig &#45;-del $S ||echo); done</pre>
<h4>HTTPD</h4>
<p>If you are running chrooted httpd then you&#8217;ll need to make sure you don&#8217;t delete your entire webserver on accident.  Here&#8217;s a relevant part from the /etc/init.d/httpd script.</p>
<pre># the path to your httpd binary, including options if necessary
if [ -e &quot;/etc/chroothttpd&quot; ]; then
        HTTPD=/usr/local/cpanel/bin/chroothttpd
else
        HTTPD=/usr/local/apache/bin/httpd
fi</pre>
<h2>Finding files owned by cpanel</h2>
<p>Some super cool bash commands in this post.. let&#8217;s start with one to find all the files and folders on your machine owned by cpanel.  Check your /etc/passwd file for your machines specific usernames and groups.  This command saves all the filenames to ~/cpanel-files-backup.txt, which is used by tar next to create a backup of all of them.</p>
<pre>{ find / -mount -depth -maxdepth 150 \( -group cpanel -o   -group cpanel-phpmyadmin -o -group cpanel-phppgadmin   -o -group cpanelphpmyadmin   -o -group cpanelphppgadmin   -o -group cpanelhorde   -o -group cpanelroundcube \) -print; find / -mount -depth -maxdepth 150 \( -user cpanel -o   -user cpanel-phpmyadmin -o -user cpanel-phppgadmin   -o -user cpanelphpmyadmin   -o -user cpanelphppgadmin   -o -user cpanelhorde   -o -user cpanelroundcube \) -print; } &gt; ~/cpanel-files-backup.txt</pre>
<p>Here&#8217;s another way to search directories.</p>
<pre> grep &#45;-color=always -Hir cpanel /var</pre>
<h2>Create the Backup</h2>
<p>Note that you must have the latest version of tar for this exact command, also you should backup /var/cpanel and /usr/local/cpanel and /etc and heck the whole machine why dontcha!</p>
<pre>tar -T ~/cpanel-files-backup.txt -cvz &#45;-checkpoint=1000 &#45;-checkpoint-action=&quot;ttyout=\rHit %s checkpoint #%u&quot; -f /cpanel-files-backup.tgz &#45;-totals</pre>
<h2>Remove Files</h2>
<p>Once you do this your upstream without a paddle, you better make sure you know what you&#8217;re doing with this.  This removes all those files.</p>
<pre>cat ~/cpanel-files-backup.txt | xargs -I&#039;F87&#039; rm -vfr F87</pre>
<p>Additionally you will want to remove /usr/local/cpanel and /var/cpanel &#8211; What I always do when running as root is alias my rm command to instead simply move the files to a .trash folder.  That way if something goes bork you have a better chance at fixing it.</p>
<h2>Find Group-Owned Files</h2>
<pre>find / -mount -depth -maxdepth 150 \
\(  -group cpanel -o \
  -group cpanel-phpmyadmin \
  -o -group cpanel-phppgadmin \
  -o -group cpanelphpmyadmin \
  -o -group cpanelphppgadmin \
  -o -group mailman \
  -o -group cpanelhorde \
  -o -group cpanelroundcube \
\) -fprintf /root/cpanel-group-files.log &#039;%#8k %#5m %11M %#10u:%-10g %-5U:%-5G %p %f %Y %F\n&#039;</pre>
<h2>Find User-Owned Files</h2>
<pre>find / -mount -depth -maxdepth 150 \(
  -user cpanel \
  -o -user cpanel-phpmyadmin \
  -o -user cpanel-phppgadmin \
  -o -user cpanelphpmyadmin \
  -o -user cpanelphppgadmin \
  -o -user mailman \
  -o -user cpanelhorde \
  -o -user cpanelroundcube
\) -fprintf /root/cpanel-users-files.log &#039;%#8k %#5m %11M %#10u:%-10g %-5U:%-5G %p %f %Y %F\n&#039;</pre>
<pre>       4  0755  drwxr-xr-x     cpanel:cpanel     32002:32004 /var/cpanel/userhomes/cpanel cpanel d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin/tmp tmp d reiserfs
       4  0644  -rw-r&#45;-r&#45;- cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin/.cpanel/caches/featurelists/default.cache default.cache f reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin/.cpanel/caches/featurelists featurelists d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin/.cpanel/caches caches d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin/.cpanel .cpanel d reiserfs
       4  0750  drwxr-x&#45;&#45;- cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin/mail mail d reiserfs
       4  0711  drwx&#45;-x&#45;-x cpanel-phpmyadmin:cpanel-phpmyadmin 32005:32007 /var/cpanel/userhomes/cpanel-phpmyadmin cpanel-phpmyadmin d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin/sessions sessions d reiserfs
       4  0644  -rw-r&#45;-r&#45;- cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin/.cpanel/caches/featurelists/default.cache default.cache f reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin/.cpanel/caches/featurelists featurelists d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin/.cpanel/caches caches d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin/.cpanel .cpanel d reiserfs
       4  0750  drwxr-x&#45;&#45;- cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin/mail mail d reiserfs
       4  0711  drwx&#45;-x&#45;-x cpanelphppgadmin:cpanelphppgadmin 32009:32011 /var/cpanel/userhomes/cpanelphppgadmin cpanelphppgadmin d reiserfs
       4  0750  drwxr-x&#45;&#45;- cpanelroundcube:cpanelroundcube 514  :514   /var/cpanel/userhomes/cpanelroundcube/mail mail d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelroundcube:cpanelroundcube 514  :514   /var/cpanel/userhomes/cpanelroundcube/sessions sessions d reiserfs
       4  0711  drwx&#45;-x&#45;-x cpanelroundcube:cpanelroundcube 514  :514   /var/cpanel/userhomes/cpanelroundcube cpanelroundcube d reiserfs
       4  0644  -rw-r&#45;-r&#45;-     cpanel:cpanel     32002:32004 /var/cpanel/.cpanel/caches/featurelists/default.cache default.cache f reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;-     cpanel:cpanel     32002:32004 /var/cpanel/.cpanel/caches/featurelists featurelists d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;-     cpanel:cpanel     32002:32004 /var/cpanel/.cpanel/caches caches d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;-     cpanel:cpanel     32002:32004 /var/cpanel/.cpanel .cpanel d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelroundcube:cpanelroundcube 514  :514   /var/cpanel/roundcube/tmp tmp d reiserfs
       4  0700  drwx&#45;&#45;-&#45;&#45;- cpanelroundcube:cpanelroundcube 514  :514   /var/cpanel/roundcube/log log d reiserfs</pre>
<h3>Find Permissions</h3>
<pre>cat ~/cpanel-group-files.log ~/cpanel-users-files.log |tr -s &#039;\000 \t&#039;|cut -d&#039; &#039; -f3|sort -u</pre>
<h3>Find files tailwatchd</h3>
<pre>(1:3732)# $NICE find ${1:-`pwd`} -mount -name &#039;*tailwatch*&#039;
/usr/local/cpanel/libexec/tailwatchd
/usr/local/cpanel/libexec/tailwatch
/usr/local/cpanel/libexec/tailwatch/tailwatchd
/usr/local/cpanel/etc/init/scripts/freebsd/tailwatchd.sh
/usr/local/cpanel/etc/init/scripts/trustix/tailwatchd
/usr/local/cpanel/etc/init/scripts/centos/tailwatchd
/usr/local/cpanel/etc/init/scripts/suse/tailwatchd
/usr/local/cpanel/etc/init/scripts/caos/tailwatchd
/usr/local/cpanel/etc/init/scripts/whitebox/tailwatchd
/usr/local/cpanel/etc/init/scripts/mandrake/tailwatchd
/usr/local/cpanel/etc/init/scripts/debian/tailwatchd
/usr/local/cpanel/etc/init/scripts/redhat/tailwatchd
/usr/local/cpanel/etc/init/scripts/fedora/tailwatchd
/usr/local/cpanel/etc/init/stoptailwatchd
/usr/local/cpanel/etc/init/starttailwatchd
/usr/local/cpanel/bin/tailwatchd
/usr/local/cpanel/logs/tailwatchd_log
/var/log/cpanel/tailwatchd_log
/var/cpanel/log_rotation/cp_tailwatchd_log.cpanellogd
/var/cpanel/tailwatch.positions
/var/run/tailwatchd.pid
/etc/chkserv.d/tailwatchd
/scripts/restartsrv_tailwatchd</pre>
<h2>Delete cpanel Users/Groups</h2>
<pre>for U in cpanel-phpmyadmin cpanel-phppgadmin cpanelphpmyadmin cpanelphppgadmin cpanelhorde cpanelroundcube machbuild; do userdel -fr $U; groupdel $U; done</pre>
<h2>Check for broken symlinks</h2>
<pre>find / -mount -depth -type l -print0 |xargs -0 -P0 -I&#039;F87&#039; file -s &#039;F87&#039; | sed -n &#039;/: broken symbolic link to/p&#039;</pre>
<p>Especially check /etc</p>
<pre>$ find /etc -mount -depth -type l -print0 |xargs -0 -P0 -I&#039;F87&#039; file -s &#039;F87&#039; | sed -n &#039;/: broken symbolic link to/p&#039;
/etc/ftpd-rsa.pem                   broken symbolic link to `/var/cpanel/ssl/ftp/ftpd-rsa.pem&#039;
/etc/rc.d/rc1.d/K10chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc1.d/K30antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc1.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/rc.d/rc3.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/rc.d/rc3.d/S80chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc3.d/S80antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc6.d/K10chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc6.d/K30antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc6.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/rc.d/rc5.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/rc.d/rc5.d/S80chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc5.d/S80antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc2.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/rc.d/rc2.d/S80chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc2.d/S80antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc4.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/rc.d/rc4.d/S80chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc4.d/S80antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc0.d/K10chkservd         broken symbolic link to `../init.d/chkservd&#039;
/etc/rc.d/rc0.d/K30antirelayd       broken symbolic link to `../init.d/antirelayd&#039;
/etc/rc.d/rc0.d/K80dcc              broken symbolic link to `../init.d/dcc&#039;
/etc/authlib/authProg               broken symbolic link to `/usr/local/cpanel/bin/courier-auth&#039;</pre>
<p>And delete if you are sure</p>
<pre>find /etc -mount -depth -type l -print0 |xargs -0 -P0 -I&#039;F87&#039; file -s &#039;F87&#039; | sed -n &#039;/: broken symbolic link to/p&#039; |cut -d&#039; &#039; -f1|xargs -I&#039;F87&#039; rm -rvf &#039;F87&#039;</pre>
<h2>Reinstall CSF</h2>
<p>The only thing I actually used that came with cpanel is the CSF/LFD Firewall package, which is a fantastic piece of software.  I had to reinstall this, and to get it working without cpanel add the following line to the csf.conf</p>
<pre>GENERIC = &quot;1&quot;</pre>
<h2>Thats It</h2>
<p>Now once you&#8217;ve cleaned up everything, you should try everything conceivable to get an error before rebooting.  Like you should start and stop every service in /etc/init.d/, you should use telinit to check various runlevels (which keeps your sshd connection still live).  Go all out, should take at least a full hour.</p>
<p>Another thing I like to do is rebuild alot of my source-built software again in case anything got messed up.  I upgrade perl from cpanels 5.8.8 to 5.10, which is pretty thorough, and you know, reinstall anything else I think I might need.  One of the benefits of compiling your own software is all I have to do is cd to the source directory and type <code>make -B &#038;&#038; ( { make test || make check || make checks || make tests; } || echo  ) &#038;&#038; sudo make install</code> and that&#8217;s it.  The tests/checks are optional of course.</p>
<p>If anyone actually ever reads this and does it, please share your advice here.. everybody knows we need it!  Good Luck</p>
<p><a href="http://www.askapache.com/server-administration/uninstall-cpanel.html"></a><a href="http://www.askapache.com/server-administration/uninstall-cpanel.html">HOWTO: Uninstall CPANEL over SSH</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/xKcrETTZAtXSx1Pu34a0Vi7cbTY/0/da"><img src="http://feedads.g.doubleclick.net/~a/xKcrETTZAtXSx1Pu34a0Vi7cbTY/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/xKcrETTZAtXSx1Pu34a0Vi7cbTY/1/da"><img src="http://feedads.g.doubleclick.net/~a/xKcrETTZAtXSx1Pu34a0Vi7cbTY/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=wyDk1szkibM:OizPYymVSyM:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=wyDk1szkibM:OizPYymVSyM:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=wyDk1szkibM:OizPYymVSyM:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=wyDk1szkibM:OizPYymVSyM:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=wyDk1szkibM:OizPYymVSyM:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=wyDk1szkibM:OizPYymVSyM:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=wyDk1szkibM:OizPYymVSyM:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/server-administration/uninstall-cpanel.html/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		<feedburner:origLink>http://www.askapache.com/server-administration/uninstall-cpanel.html</feedburner:origLink></item>
		<item>
		<title>Real-Life Htaccess Files from My Server</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/SVPrPi8_8YI/real-world-htaccess-files.html</link>
		<comments>http://www.askapache.com/htaccess/real-world-htaccess-files.html#comments</comments>
		<pubDate>Sat, 17 Apr 2010 15:06:22 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[Apache Modules]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Mod_Rewrite]]></category>
		<category><![CDATA[SEO]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[AddHandler]]></category>
		<category><![CDATA[Backups]]></category>
		<category><![CDATA[Block IP]]></category>
		<category><![CDATA[Cache-Control]]></category>
		<category><![CDATA[cheatsheets]]></category>
		<category><![CDATA[developers]]></category>
		<category><![CDATA[errordocument]]></category>
		<category><![CDATA[etag]]></category>
		<category><![CDATA[htaccess tricks]]></category>
		<category><![CDATA[http cookie]]></category>
		<category><![CDATA[indexes]]></category>
		<category><![CDATA[Mod_Security]]></category>
		<category><![CDATA[open source]]></category>
		<category><![CDATA[password protection]]></category>
		<category><![CDATA[real world]]></category>
		<category><![CDATA[rewritecond]]></category>
		<category><![CDATA[rewriterule]]></category>
		<category><![CDATA[Source Code]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=4357</guid>
		<description><![CDATA[<pre>#### No https except to wp-admin - 
# If the request is empty ( implies fopen or normal file access by a php script )
RewriteCond %{THE_REQUEST} ^$ [OR]
&#160;
# OR if the request if for wp-admin or wp-login.php
RewriteCond %{REQUEST_URI} ^/(wp-admin&#124;wp-login\.php).*$ [NC,OR]
&#160;
# OR if the Referer is https
RewriteCond %{HTTP_REFERER} ^https://www.askapache.com/.*$ [NC]
&#160;
# THEN skip the following rule, basically all this does is force https or badhost to be redirected
# BUT because of the above 3 rewritecond&#039;s, this won&#039;t break poorly written admin scripts
RewriteRule .* - [S=1]
&#160;
RewriteCond %{HTTPS} =on [OR]
RewriteCond %{HTTP_HOST} !^www\.askapache\.com$ [NC]
RewriteRule .* http://www.askapache.com%{REQUEST_URI} [R=301,L]
&#160;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(wp-admin/.*&#124;wp-login\.php.*)\ HTTP/ [NC]
RewriteCond %{HTTPS} !=on
RewriteRule .* https://%{SERVER_NAME}%{REQUEST_URI} [R=301,L]</pre>]]></description>
			<content:encoded><![CDATA[<p>I was going through some backups from years ago, and ran:</p>
<pre>locate .htaccess | xargs -I&#039;{}&#039; cat &#039;{}&#039; &gt;&gt; master-htaccesser.txt</pre>
<p>My site is named after reading source code because that is what helps me the most when I&#8217;m trying to learn something unusually difficult.   Just like functions and aliases, it is very helpful to have cheatsheets for common commands.. not much is better than real-world examples.  Unfortunately because this was compiled from hundreds of htaccess files on multiple hosts and platforms, and due to the concatenation, it&#8217;s not organized.</p>
<p>Normally I would not publish something like this, who knows how much unreleased tricks I forgot about..  but in order to say thanks to all those working for open-source, the FSF, and to all those who don&#8217;t steal content, and to all the incredible authors who shared with me (I twitter most of what I find, and follow my favs), here ya go..</p>
<p class="cnote"><strong>ATTN:</strong> Please let me know if this is total junk or not, this is around 1/500th of my master-htaccesser.txt file.. and I&#8217;d be happy to post more if it helps..</p>
<h2>Checking for Cookie</h2>
<p>Used this to stop mp3-scrapers.. checks for a cookie ending in MP3P=02357</p>
<pre>Options -Indexes
RewriteEngine On
RewriteCond %{HTTP_COOKIE} !^.*MP3P=([0-9]+).* [NC]
RewriteRule .* - [F,L]</pre>
<h2>Setting Environment Var if Proxied</h2>
<pre>RewriteEngine On
RewriteRule &quot;\.(gif|png|jpg)$&quot; &quot;-&quot; [ENV=proxied_image:1]
RewriteCond &quot;%{ENV:proxied_image}&quot; &quot;!1&quot;
RewriteRule &quot;^&quot; &quot;-&quot; [ENV=proxied_other:1]</pre>
<h2>nokeepalive for ErrorDocs and Abusers</h2>
<pre>Options SymLinksIfOwnerMatch IncludesNOEXEC
AddOutputFilter Includes html
SetEnv nokeepalive
Order Allow,Deny
Allow from all
# 1 YEAR
&lt;FilesMatch &quot;\.(js|css)$&quot;&gt;
Header unset Pragma
FileETag None
Header set Cache-Control &quot;public&quot;
Header set Expires &quot;Thu, 15 Apr 2010 20:00:00 GMT&quot;
Header unset Last-Modified
Header unset Last-Modified
Header unset ETag
&nbsp;
SetOutputFilter DEFLATE
Header set Cache-Control &quot;public&quot;
Header set Expires &quot;Thu, 15 Apr 2010 20:00:00 GMT&quot;
&lt;/FilesMatch&gt;
SecFilterEngine Off
&nbsp;
# 1 YEAR
&lt;FilesMatch &quot;\.(js|css)$&quot;&gt;
Header unset Pragma
FileETag None
Header set Cache-Control &quot;public&quot;
Header set Expires &quot;Thu, 15 Apr 2010 20:00:00 GMT&quot;
Header unset Last-Modified
Header unset Last-Modified
Header unset ETag
&nbsp;
SetOutputFilter DEFLATE
Header set Cache-Control &quot;public&quot;
Header set Expires &quot;Thu, 15 Apr 2010 20:00:00 GMT&quot;
&lt;/FilesMatch&gt;</pre>
<h2>Unreleased Tests for AskApache Password Protection</h2>
<pre># +ASKAPACHE PASSPRO 4.6.6
#######################################################
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
# +APRO SIDS
# +SID 21030002
Order Deny,Allow
Deny from All
Satisfy Any
AuthType Digest
AuthName &quot;Protected By AskApache&quot;
AuthDigestDomain / http://www.askapache.com/
AuthDigestFile /home/.greer/askapache/sites/askapache.com/.htpasswda3
Require valid-user
&lt;FilesMatch &quot;\.(ico|pdf|flv|jpg|jpeg|mp3|mpg|mp4|mov|wav|wmv|png|gif|swf|css|js)$&quot;&gt;
Allow from All
&lt;/FilesMatch&gt;
&lt;FilesMatch &quot;(async-upload|admin-ajax)\.php$&quot;&gt;
&lt;IfModule mod_security.c&gt;
SecFilterEngine Off
&lt;/IfModule&gt;
Allow from All
&lt;/FilesMatch&gt;
# -SID 21030002
# -APRO SIDS
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
#######################################################
# -ASKAPACHE PASSPRO 4.6.6
&nbsp;
# +ASKAPACHE PASSPRO 4.6.6
#######################################################
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
# +APRO SIDS
# +SID Test
ErrorDocument 401 /wp-content/askapache/test.gif
ErrorDocument 403 /wp-content/askapache/test.gif
ErrorDocument 404 /wp-content/askapache/test.gif
ErrorDocument 500 /wp-content/askapache/test.gif
ServerSignature On
&lt;IfModule mod_alias.c&gt;
RedirectMatch 305 ^.*modaliastest$ http://www.askapache.com
&lt;/IfModule&gt;
&lt;IfModule mod_rewrite.c&gt;
RewriteEngine On
RewriteBase /
RewriteCond %{QUERY_STRING} modrewritetest [NC]
RewriteRule .* http://www.askapache.com [R=307,L]
&lt;/IfModule&gt;
&lt;Files modsec_check.gif&gt;
&lt;IfModule mod_security.c&gt;
SetEnv MODSEC_ENABLE On
SecFilterEngine On
SecFilterDefaultAction &quot;nolog,noauditlog,pass&quot;
SecAuditEngine Off
SecFilterInheritance Off
SecFilter modsecuritytest &quot;deny,nolog,noauditlog,status:503&quot;
Deny from All
&lt;/IfModule&gt;
&lt;/Files&gt;
&lt;Files basic_auth_test.gif&gt;
AuthType Basic
AuthName &quot;askapache test&quot;
AuthUserFile /home/.greer/askapache/sites/askapache.com/htdocs/wp-content/askapache/.htpasswd-basic
Require valid-user
&lt;/Files&gt;
&lt;Files digest_check.gif&gt;
AuthType Digest
AuthName &quot;askapache test&quot;
AuthDigestDomain /wp-content/askapache/ http://www.askapache.com/wp-content/askapache/
AuthUserFile /home/.greer/askapache/sites/askapache.com/htdocs/wp-content/askapache/.htpasswd-digest
Require none
&lt;/Files&gt;
&lt;Files authuserfile_test.gif&gt;
AuthType Digest
AuthName &quot;askapache test&quot;
AuthDigestDomain /wp-content/askapache/ http://www.askapache.com/wp-content/askapache/
AuthUserFile /home/.greer/askapache/sites/askapache.com/htdocs/wp-content/askapache/.htpasswd-digest
Require valid-user
&lt;/Files&gt;
&lt;Files authdigestfile_test.gif&gt;
AuthType Digest
AuthName &quot;askapache test&quot;
AuthDigestDomain /wp-content/askapache/ http://www.askapache.com/wp-content/askapache/
AuthDigestFile /home/.greer/askapache/sites/askapache.com/htdocs/wp-content/askapache/.htpasswd-digest
Require valid-user
&lt;/Files&gt;
# -SID Test
# -APRO SIDS
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
#######################################################
# -ASKAPACHE PASSPRO 4.6.6</pre>
<h2>Warming up to the really advanced tests</h2>
<pre>Options +ExecCGI
Order Deny,Allow
Deny from All
Allow from 208.113.134.190 64.111.114.111 208.113.134.203 208.113.152.201 env=REDIRECT_STATUS
Satisfy Any
Options +FollowSymLinks
AddHandler application/x-httpd-php .php
&nbsp;
RewriteEngine On
RewriteBase /
RewriteCond %{QUERY_STRING} !^tyy+$ [NC]
RewriteCond %{REMOTE_USER} ^(.+)$
RewriteRule ^(.*)$ $1/-%1 [R=302,L]
Options +ExecCGI +FollowSymLinks
DirectoryIndex index.php
ErrorDocument 404 /cgi-bin/pro/index.php
&nbsp;
AuthType Digest
AuthName &quot;AskApache Pro&quot;
AuthDigestFile /home/askapache/sites/askapache.com/.htpasswd-pro
AuthDigestDomain /cgi-bin/pro/ http://www.askapache.com/cgi-bin/pro/ https://www.askapache.com/cgi-bin/pro/
Require user askapacheDirectoryIndex p.php
ErrorDocument 403 /cgi-bin/p/p.php
ErrorDocument 401 /cgi-bin/p/p.php
ErrorDocument 500 /cgi-bin/p/p.php
ErrorDocument 503 /cgi-bin/p/p.php
&nbsp;
RewriteEngine On
RewriteBase /
RewriteRule .* - [E=INFO_API_VERSION:%{API_VERSION}]
RewriteRule .* - [E=INFO_AUTH_TYPE:%{AUTH_TYPE}]
RewriteRule .* - [E=INFO_CONTENT_LENGTH:%{CONTENT_LENGTH}]
RewriteRule .* - [E=INFO_CONTENT_TYPE:%{CONTENT_TYPE}]
RewriteRule .* - [E=INFO_DOCUMENT_ROOT:%{DOCUMENT_ROOT}]
RewriteRule .* - [E=INFO_GATEWAY_INTERFACE:%{GATEWAY_INTERFACE}]
RewriteRule .* - [E=INFO_HTTPS:%{HTTPS}]
RewriteRule .* - [E=INFO_HTTP_ACCEPT:%{HTTP:Accept}]
RewriteRule .* - [E=INFO_HTTP_ACCEPT_LANGUAGE:%{HTTP:Accept-Language}]
RewriteRule .* - [E=INFO_HTTP_ACCEPT_ENCODING:%{HTTP:Accept-Encoding}]
RewriteRule .* - [E=INFO_HTTP_ACCEPT_CHARSET:%{HTTP:Accept-Charset}]
RewriteRule .* - [E=INFO_HTTP_CACHE_CONTROL:%{HTTP:Cache-Control}]
RewriteRule .* - [E=INFO_HTTP_CONNECTION:%{HTTP:Connection}]
RewriteRule .* - [E=INFO_HTTP_COOKIE:%{HTTP_COOKIE}]
RewriteRule .* - [E=INFO_HTTP_FORWARDED:%{HTTP_FORWARDED}]
RewriteRule .* - [E=INFO_HTTP_HOST:%{HTTP_HOST}]
RewriteRule .* - [E=INFO_HTTP_KEEP_ALIVE:%{HTTP_KEEP_ALIVE}]
RewriteRule .* - [E=INFO_HTTP_PROXY_CONNECTION:%{HTTP_PROXY_CONNECTION}]
RewriteRule .* - [E=INFO_HTTP_REFERER:%{HTTP:Referer}]
RewriteRule .* - [E=INFO_HTTP_USER_AGENT:%{HTTP_USER_AGENT}]
RewriteRule .* - [E=INFO_IS_SUBREQ:%{IS_SUBREQ}]
RewriteRule .* - [E=INFO_ORIG_PATH_INFO:%{ORIG_PATH_INFO}]
RewriteRule .* - [E=INFO_ORIG_PATH_TRANSLATED:%{ORIG_PATH_TRANSLATED}]
RewriteRule .* - [E=INFO_ORIG_SCRIPT_FILENAME:%{ORIG_SCRIPT_FILENAME}]
RewriteRule .* - [E=INFO_ORIG_SCRIPT_NAME:%{ORIG_SCRIPT_NAME}]
RewriteRule .* - [E=INFO_PATH:%{PATH}]
RewriteRule .* - [E=INFO_PATH_INFO:%{PATH_INFO}]
RewriteRule .* - [E=INFO_QUERY_STRING:%{QUERY_STRING}]
RewriteRule .* - [E=INFO_REDIRECT_QUERY_STRING:%{REDIRECT_QUERY_STRING}]
RewriteRule .* - [E=INFO_REDIRECT_REMOTE_USER:%{REDIRECT_REMOTE_USER}]
RewriteRule .* - [E=INFO_REDIRECT_STATUS:%{REDIRECT_STATUS}]
RewriteRule .* - [E=INFO_REDIRECT_URL:%{REDIRECT_URL}]
RewriteRule .* - [E=INFO_REMOTE_ADDR:%{REMOTE_ADDR}]
RewriteRule .* - [E=INFO_REMOTE_HOST:%{REMOTE_HOST}]
RewriteRule .* - [E=INFO_REMOTE_IDENT:%{REMOTE_IDENT}]
RewriteRule .* - [E=INFO_REMOTE_PORT:%{REMOTE_PORT}]
RewriteRule .* - [E=INFO_REMOTE_USER:%{REMOTE_USER}]
RewriteRule .* - [E=INFO_REQUEST_FILENAME:%{REQUEST_FILENAME}]
RewriteRule .* - [E=INFO_REQUEST_METHOD:%{REQUEST_METHOD}]
RewriteRule .* - [E=INFO_REQUEST_URI:%{REQUEST_URI}]
RewriteRule .* - [E=INFO_REDIRECT_REQUEST_URI:%{REDIRECT_REQUEST_URI}]
RewriteRule .* - [E=INFO_SCRIPT_FILENAME:%{SCRIPT_FILENAME}]
RewriteRule .* - [E=INFO_SCRIPT_GROUP:%{SCRIPT_GROUP}]
RewriteRule .* - [E=INFO_SCRIPT_NAME:%{SCRIPT_NAME}]
RewriteRule .* - [E=INFO_SCRIPT_URI:%{SCRIPT_URI}]
RewriteRule .* - [E=INFO_SCRIPT_URL:%{SCRIPT_URL}]
RewriteRule .* - [E=INFO_SCRIPT_USER:%{SCRIPT_USER}]
RewriteRule .* - [E=INFO_SERVER_ADDR:%{SERVER_ADDR}]
RewriteRule .* - [E=INFO_SERVER_ADMIN:%{SERVER_ADMIN}]
RewriteRule .* - [E=INFO_SERVER_NAME:%{SERVER_NAME}]
RewriteRule .* - [E=INFO_SERVER_PORT:%{SERVER_PORT}]
RewriteRule .* - [E=INFO_SERVER_PROTOCOL:%{SERVER_PROTOCOL}]
RewriteRule .* - [E=INFO_SERVER_SIGNATURE:%{SERVER_SIGNATURE}]
RewriteRule .* - [E=INFO_SERVER_SOFTWARE:%{SERVER_SOFTWARE}]
RewriteRule .* - [E=INFO_THE_REQUEST:%{THE_REQUEST}]
RewriteRule .* - [E=INFO_TIME:%{TIME}]
RewriteRule .* - [E=INFO_TIME_DAY:%{TIME_DAY}]
RewriteRule .* - [E=INFO_TIME_HOUR:%{TIME_HOUR}]
RewriteRule .* - [E=INFO_TIME_MIN:%{TIME_MIN}]
RewriteRule .* - [E=INFO_TIME_MON:%{TIME_MON}]
RewriteRule .* - [E=INFO_TIME_SEC:%{TIME_SEC}]
RewriteRule .* - [E=INFO_TIME_WDAY:%{TIME_WDAY}]
RewriteRule .* - [E=INFO_TIME_YEAR:%{TIME_YEAR}]
RewriteRule .* - [E=INFO_TZ:%{TZ}]
RewriteRule .* - [E=INFO_UNIQUE_ID:%{UNIQUE_ID}]
&nbsp;
RequestHeader set INFO_API_VERSION &quot;%{INFO_API_VERSION}e&quot;
RequestHeader set INFO_AUTH_TYPE &quot;%{INFO_AUTH_TYPE}e&quot;
RequestHeader set INFO_CONTENT_LENGTH &quot;%{INFO_CONTENT_LENGTH}e&quot;
RequestHeader set INFO_CONTENT_TYPE &quot;%{INFO_CONTENT_TYPE}e&quot;
RequestHeader set INFO_DOCUMENT_ROOT &quot;%{INFO_DOCUMENT_ROOT}e&quot;
RequestHeader set INFO_GATEWAY_INTERFACE &quot;%{INFO_GATEWAY_INTERFACE}e&quot;
RequestHeader set INFO_HTTPS &quot;%{INFO_HTTPS}e&quot;
RequestHeader set INFO_HTTP_ACCEPT &quot;%{INFO_HTTP_ACCEPT}e&quot;
RequestHeader set INFO_HTTP_ACCEPT_LANGUAGE &quot;%{INFO_HTTP_ACCEPT_LANGUAGE}e&quot;
RequestHeader set INFO_HTTP_ACCEPT_ENCODING &quot;%{INFO_HTTP_ACCEPT_ENCODING}e&quot;
RequestHeader set INFO_HTTP_ACCEPT_CHARSET &quot;%{INFO_HTTP_ACCEPT_CHARSET}e&quot;
RequestHeader set INFO_HTTP_CACHE_CONTROL &quot;%{INFO_HTTP_CACHE_CONTROL}e&quot;
RequestHeader set INFO_HTTP_CONNECTION &quot;%{INFO_HTTP_CONNECTION}e&quot;
RequestHeader set INFO_HTTP_COOKIE &quot;%{INFO_HTTP_COOKIE}e&quot;
RequestHeader set INFO_HTTP_FORWARDED &quot;%{INFO_HTTP_FORWARDED}e&quot;
RequestHeader set INFO_HTTP_HOST &quot;%{INFO_HTTP_HOST}e&quot;
RequestHeader set INFO_HTTP_KEEP_ALIVE &quot;%{INFO_HTTP_KEEP_ALIVE}e&quot;
RequestHeader set INFO_HTTP_PROXY_CONNECTION &quot;%{INFO_HTTP_PROXY_CONNECTION}e&quot;
RequestHeader set INFO_HTTP_REFERER &quot;%{INFO_HTTP_REFERER}e&quot;
RequestHeader set INFO_HTTP_USER_AGENT &quot;%{INFO_HTTP_USER_AGENT}e&quot;
RequestHeader set INFO_IS_SUBREQ &quot;%{INFO_IS_SUBREQ}e&quot;
RequestHeader set INFO_ORIG_PATH_INFO &quot;%{INFO_ORIG_PATH_INFO}e&quot;
RequestHeader set INFO_ORIG_PATH_TRANSLATED &quot;%{INFO_ORIG_PATH_TRANSLATED}e&quot;
RequestHeader set INFO_ORIG_SCRIPT_FILENAME &quot;%{INFO_ORIG_SCRIPT_FILENAME}e&quot;
RequestHeader set INFO_ORIG_SCRIPT_NAME &quot;%{INFO_ORIG_SCRIPT_NAME}e&quot;
RequestHeader set INFO_PATH &quot;%{INFO_PATH}e&quot;
RequestHeader set INFO_PATH_INFO &quot;%{INFO_PATH_INFO}e&quot;
RequestHeader set INFO_QUERY_STRING &quot;%{INFO_QUERY_STRING}e&quot;
RequestHeader set INFO_REDIRECT_QUERY_STRING &quot;%{INFO_REDIRECT_QUERY_STRING}e&quot;
RequestHeader set INFO_REDIRECT_REMOTE_USER &quot;%{INFO_REDIRECT_REMOTE_USER}e&quot;
RequestHeader set INFO_REDIRECT_STATUS &quot;%{INFO_REDIRECT_STATUS}e&quot;
RequestHeader set INFO_REDIRECT_URL &quot;%{INFO_REDIRECT_URL}e&quot;
RequestHeader set INFO_REMOTE_ADDR &quot;%{INFO_REMOTE_ADDR}e&quot;
RequestHeader set INFO_REMOTE_HOST &quot;%{INFO_REMOTE_HOST}e&quot;
RequestHeader set INFO_REMOTE_IDENT &quot;%{INFO_REMOTE_IDENT}e&quot;
RequestHeader set INFO_REMOTE_PORT &quot;%{INFO_REMOTE_PORT}e&quot;
RequestHeader set INFO_REMOTE_USER &quot;%{INFO_REMOTE_USER}e&quot;
RequestHeader set INFO_REQUEST_FILENAME &quot;%{INFO_REQUEST_FILENAME}e&quot;
RequestHeader set INFO_REQUEST_METHOD &quot;%{INFO_REQUEST_METHOD}e&quot;
RequestHeader set INFO_REQUEST_URI &quot;%{INFO_REQUEST_URI}e&quot;
RequestHeader set INFO_REQUEST_URI &quot;%{INFO_REQUEST_URI}e&quot;
RequestHeader set INFO_SCRIPT_FILENAME &quot;%{INFO_SCRIPT_FILENAME}e&quot;
RequestHeader set INFO_SCRIPT_GROUP &quot;%{INFO_SCRIPT_GROUP}e&quot;
RequestHeader set INFO_SCRIPT_NAME &quot;%{INFO_SCRIPT_NAME}e&quot;
RequestHeader set INFO_SCRIPT_URI &quot;%{INFO_SCRIPT_URI}e&quot;
RequestHeader set INFO_SCRIPT_URL &quot;%{INFO_SCRIPT_URL}e&quot;
RequestHeader set INFO_SCRIPT_USER &quot;%{INFO_SCRIPT_USER}e&quot;
RequestHeader set INFO_SERVER_ADDR &quot;%{INFO_SERVER_ADDR}e&quot;
RequestHeader set INFO_SERVER_ADMIN &quot;%{INFO_SERVER_ADMIN}e&quot;
RequestHeader set INFO_SERVER_NAME &quot;%{INFO_SERVER_NAME}e&quot;
RequestHeader set INFO_SERVER_PORT &quot;%{INFO_SERVER_PORT}e&quot;
RequestHeader set INFO_SERVER_PROTOCOL &quot;%{INFO_SERVER_PROTOCOL}e&quot;
RequestHeader set INFO_SERVER_SIGNATURE &quot;%{INFO_SERVER_SIGNATURE}e&quot;
RequestHeader set INFO_SERVER_SOFTWARE &quot;%{INFO_SERVER_SOFTWARE}e&quot;
RequestHeader set INFO_THE_REQUEST &quot;%{INFO_THE_REQUEST}e&quot;
RequestHeader set INFO_TIME &quot;%{INFO_TIME}e&quot;
RequestHeader set INFO_TIME_DAY &quot;%{INFO_TIME_DAY}e&quot;
RequestHeader set INFO_TIME_HOUR &quot;%{INFO_TIME_HOUR}e&quot;
RequestHeader set INFO_TIME_MIN &quot;%{INFO_TIME_MIN}e&quot;
RequestHeader set INFO_TIME_MON &quot;%{INFO_TIME_MON}e&quot;
RequestHeader set INFO_TIME_SEC &quot;%{INFO_TIME_SEC}e&quot;
RequestHeader set INFO_TIME_WDAY &quot;%{INFO_TIME_WDAY}e&quot;
RequestHeader set INFO_TIME_YEAR &quot;%{INFO_TIME_YEAR}e&quot;
RequestHeader set INFO_TZ &quot;%{INFO_TZ}e&quot;
RequestHeader set INFO_UNIQUE_ID &quot;%{INFO_UNIQUE_ID}e&quot;
&nbsp;
Options +FollowSymLinks +ExecCGI
DirectoryIndex /cgi-bin/rewrite-test/index.php
&nbsp;
Header echo ^.*
&nbsp;
AuthType Digest
AuthName &quot;AskApache Pro&quot;
AuthDigestFile /home/askapache/sites/askapache.com/.htpasswd-pro
AuthDigestDomain / http://www.askapache.com/cgi-bin/rewrite-test/ https://www.askapache.com/cgi-bin/rewrite-test/
Require user askapache
&nbsp;
SetEnv MODSEC_ENABLE=On
&nbsp;
SetEnvIfNoCase ^WWW-Auth &quot;(.+)&quot; HTTP_WWW_AUTHORIZATION=$1
SetEnvIfNoCase ^If &quot;(.+)&quot; HTTP_IF_MODIFIED_SINCE=$1
SetEnvIfNoCase ^If-None-Match$ &quot;(.+)&quot; HTTP_IF_NONE_MATCH=$1
SetEnvIfNoCase ^Cache-Control$ &quot;(.+)&quot; HTTP_CACHE_CONTROL=$1
SetEnvIfNoCase ^Connection$ &quot;(.+)&quot; HTTP_CONNECTION=$1
SetEnvIfNoCase ^Keep-Alive$ &quot;(.+)&quot; HTTP_KEEP_ALIVE=$1
SetEnvIfNoCase ^Authorization$ &quot;(.+)&quot; HTTP_AUTHORIZATION=$1
SetEnvIfNoCase ^Authorization$ &quot;.+username=\&quot;(.+)\&quot;.+&quot; HTTP_REMOTE_USER=$1
SetEnvIfNoCase ^Content-Type$ &quot;(.+)&quot; HTTP_CONTENT_TYPE=$1
SetEnvIfNoCase ^Content-Length$ &quot;(.+)&quot; HTTP_CONTENT_LENGTH=$1
SetEnvIfNoCase Server_Addr &quot;(.+)&quot; SERVER_ADDR=$1
SetEnvIfNoCase Request_Method &quot;(.+)&quot; REQUEST_METHOD=$1
SetEnvIfNoCase Request_Protocol &quot;(.+)&quot; REQUEST_PROTOCOL=$1
SetEnvIfNoCase Request_URI &quot;(.+)&quot; REQUEST_URI=$1
&nbsp;
ErrorDocument 100 /cgi-bin/rewrite-test/index.php?g=100
ErrorDocument 101 /cgi-bin/rewrite-test/index.php?g=101
ErrorDocument 102 /cgi-bin/rewrite-test/index.php?g=102
ErrorDocument 200 /cgi-bin/rewrite-test/index.php?g=200
ErrorDocument 201 /cgi-bin/rewrite-test/index.php?g=201
ErrorDocument 202 /cgi-bin/rewrite-test/index.php?g=202
ErrorDocument 203 /cgi-bin/rewrite-test/index.php?g=203
ErrorDocument 204 /cgi-bin/rewrite-test/index.php?g=204
ErrorDocument 205 /cgi-bin/rewrite-test/index.php?g=205
ErrorDocument 206 /cgi-bin/rewrite-test/index.php?g=206
ErrorDocument 207 /cgi-bin/rewrite-test/index.php?g=207
ErrorDocument 300 /cgi-bin/rewrite-test/index.php?g=300
ErrorDocument 301 /cgi-bin/rewrite-test/index.php?g=301
ErrorDocument 302 /cgi-bin/rewrite-test/index.php?g=302
ErrorDocument 303 /cgi-bin/rewrite-test/index.php?g=303
ErrorDocument 304 /cgi-bin/rewrite-test/index.php?g=304
ErrorDocument 305 /cgi-bin/rewrite-test/index.php?g=305
ErrorDocument 306 /cgi-bin/rewrite-test/index.php?g=306
ErrorDocument 307 /cgi-bin/rewrite-test/index.php?g=307
ErrorDocument 400 /cgi-bin/rewrite-test/index.php?g=400
ErrorDocument 401 /cgi-bin/rewrite-test/index.php?g=401
ErrorDocument 402 /cgi-bin/rewrite-test/index.php?g=402
ErrorDocument 403 /cgi-bin/rewrite-test/index.php?g=403
ErrorDocument 404 /cgi-bin/rewrite-test/index.php?g=404
ErrorDocument 405 /cgi-bin/rewrite-test/index.php?g=405
ErrorDocument 406 /cgi-bin/rewrite-test/index.php?g=406
ErrorDocument 407 /cgi-bin/rewrite-test/index.php?g=407
ErrorDocument 408 /cgi-bin/rewrite-test/index.php?g=408
ErrorDocument 409 /cgi-bin/rewrite-test/index.php?g=409
ErrorDocument 410 /cgi-bin/rewrite-test/index.php?g=410
ErrorDocument 411 /cgi-bin/rewrite-test/index.php?g=411
ErrorDocument 412 /cgi-bin/rewrite-test/index.php?g=412
ErrorDocument 413 /cgi-bin/rewrite-test/index.php?g=413
ErrorDocument 414 /cgi-bin/rewrite-test/index.php?g=414
ErrorDocument 415 /cgi-bin/rewrite-test/index.php?g=415
ErrorDocument 416 /cgi-bin/rewrite-test/index.php?g=416
ErrorDocument 417 /cgi-bin/rewrite-test/index.php?g=417
ErrorDocument 418 /cgi-bin/rewrite-test/index.php?g=418
ErrorDocument 419 /cgi-bin/rewrite-test/index.php?g=419
ErrorDocument 420 /cgi-bin/rewrite-test/index.php?g=420
ErrorDocument 421 /cgi-bin/rewrite-test/index.php?g=421
ErrorDocument 422 /cgi-bin/rewrite-test/index.php?g=422
ErrorDocument 423 /cgi-bin/rewrite-test/index.php?g=423
ErrorDocument 424 /cgi-bin/rewrite-test/index.php?g=424
ErrorDocument 425 /cgi-bin/rewrite-test/index.php?g=425
ErrorDocument 426 /cgi-bin/rewrite-test/index.php?g=426
ErrorDocument 500 /cgi-bin/rewrite-test/index.php?g=500
ErrorDocument 501 /cgi-bin/rewrite-test/index.php?g=501
ErrorDocument 502 /cgi-bin/rewrite-test/index.php?g=502
ErrorDocument 503 /cgi-bin/rewrite-test/index.php?g=503
ErrorDocument 504 /cgi-bin/rewrite-test/index.php?g=504
ErrorDocument 505 /cgi-bin/rewrite-test/index.php?g=505
ErrorDocument 506 /cgi-bin/rewrite-test/index.php?g=506
ErrorDocument 507 /cgi-bin/rewrite-test/index.php?g=507
ErrorDocument 508 /cgi-bin/rewrite-test/index.php?g=508
ErrorDocument 509 /cgi-bin/rewrite-test/index.php?g=509
ErrorDocument 510 /cgi-bin/rewrite-test/index.php?g=510
&nbsp;
RewriteEngine On
RewriteBase /
&nbsp;
RewriteRule .* - [E=IN_AUTH_TYPE:%{AUTH_TYPE}]
RewriteRule .* - [E=IN_CONTENT_LENGTH:%{CONTENT_LENGTH}]
RewriteRule .* - [E=IN_CONTENT_TYPE:%{CONTENT_TYPE}]
RewriteRule .* - [E=IN_DATE_GMT:%{DATE_GMT}]
RewriteRule .* - [E=IN_DATE_LOCAL:%{DATE_LOCAL}]
RewriteRule .* - [E=IN_DOCUMENT_NAME:%{DOCUMENT_NAME}]
RewriteRule .* - [E=IN_DOCUMENT_PATH_INFO:%{DOCUMENT_PATH_INFO}]
RewriteRule .* - [E=IN_DOCUMENT_ROOT:%{DOCUMENT_ROOT}]
RewriteRule .* - [E=IN_DOCUMENT_URI:%{DOCUMENT_URI}]
RewriteRule .* - [E=IN_GATEWAY_INTERFACE:%{GATEWAY_INTERFACE}]
RewriteRule .* - [E=IN_LAST_MODIFIED:%{LAST_MODIFIED}]
RewriteRule .* - [E=IN_PATH_INFO:%{PATH_INFO}]
RewriteRule .* - [E=IN_PATH_TRANSLATED:%{PATH_TRANSLATED}]
RewriteRule .* - [E=IN_QUERY_STRING:%{QUERY_STRING}]
RewriteRule .* - [E=IN_QUERY_STRING_UNESCAPED:%{QUERY_STRING_UNESCAPED}]
RewriteRule .* - [E=IN_REMOTE_ADDR:%{REMOTE_ADDR}]
RewriteRule .* - [E=IN_REMOTE_HOST:%{REMOTE_HOST}]
RewriteRule .* - [E=IN_REMOTE_IDENT:%{REMOTE_IDENT}]
RewriteRule .* - [E=IN_REMOTE_PORT:%{REMOTE_PORT}]
RewriteRule .* - [E=IN_REMOTE_USER:%{REMOTE_USER}]
RewriteRule .* - [E=IN_REDIRECT_HANDLER:%{REDIRECT_HANDLER}]
RewriteRule .* - [E=IN_REDIRECT_QUERY_STRING:%{REDIRECT_QUERY_STRING}]
RewriteRule .* - [E=IN_REDIRECT_REMOTE_USER:%{REDIRECT_REMOTE_USER}]
RewriteRule .* - [E=IN_REDIRECT_STATUS:%{REDIRECT_STATUS}]
RewriteRule .* - [E=IN_REDIRECT_URL:%{REDIRECT_URL}]
RewriteRule .* - [E=IN_REQUEST_METHOD:%{REQUEST_METHOD}]
RewriteRule .* - [E=IN_REQUEST_URI:%{REQUEST_URI}]
RewriteRule .* - [E=IN_SCRIPT_FILENAME:%{SCRIPT_FILENAME}]
RewriteRule .* - [E=IN_SCRIPT_NAME:%{SCRIPT_NAME}]
RewriteRule .* - [E=IN_SERVER_ADMIN:%{SERVER_ADMIN}]
RewriteRule .* - [E=IN_SERVER_NAME:%{SERVER_NAME}]
RewriteRule .* - [E=IN_SERVER_ADDR:%{SERVER_ADDR}]
RewriteRule .* - [E=IN_SERVER_PORT:%{SERVER_PORT}]
RewriteRule .* - [E=IN_SERVER_PROTOCOL:%{SERVER_PROTOCOL}]
RewriteRule .* - [E=IN_SERVER_SIGNATURE:%{SERVER_SIGNATURE}]
RewriteRule .* - [E=IN_SERVER_SOFTWARE:%{SERVER_SOFTWARE}]
RewriteRule .* - [E=IN_USER_NAME:%{USER_NAME}]
RewriteRule .* - [E=IN_TZ:%{TZ}]
RewriteRule .* - [E=IN_API_VERSION:%{API_VERSION}]
RewriteRule .* - [E=IN_HTTPS:%{HTTPS}]
RewriteRule .* - [E=IN_HTTP_ACCEPT:%{HTTP_ACCEPT}]
RewriteRule .* - [E=IN_HTTP_ACCEPT_CHARSET:%{HTTP_ACCEPT_CHARSET}]
RewriteRule .* - [E=IN_HTTP_ACCEPT_ENCODING:%{HTTP_ACCEPT_ENCODING}]
RewriteRule .* - [E=IN_HTTP_ACCEPT_LANGUAGE:%{HTTP_ACCEPT_LANGUAGE}]
RewriteRule .* - [E=IN_HTTP_CACHE_CONTROL:%{HTTP_CACHE_CONTROL}]
RewriteRule .* - [E=IN_HTTP_CONNECTION:%{HTTP_CONNECTION}]
RewriteRule .* - [E=IN_HTTP_COOKIE:%{HTTP_COOKIE}]
RewriteRule .* - [E=IN_HTTP_FORWARDED:%{HTTP_FORWARDED}]
RewriteRule .* - [E=IN_HTTP_HOST:%{HTTP_HOST}]
RewriteRule .* - [E=IN_HTTP_KEEP_ALIVE:%{HTTP_KEEP_ALIVE}]
RewriteRule .* - [E=IN_HTTP_PROXY_CONNECTION:%{HTTP_PROXY_CONNECTION}]
RewriteRule .* - [E=IN_HTTP_REFERER:%{HTTP_REFERER}]
RewriteRule .* - [E=IN_HTTP_USER_AGENT:%{HTTP_USER_AGENT}]
RewriteRule .* - [E=IN_IS_SUBREQ:%{IS_SUBREQ}]
RewriteRule .* - [E=IN_ORIG_PATH_INFO:%{ORIG_PATH_INFO}]
RewriteRule .* - [E=IN_ORIG_PATH_TRANSLATED:%{ORIG_PATH_TRANSLATED}]
RewriteRule .* - [E=IN_ORIG_SCRIPT_FILENAME:%{ORIG_SCRIPT_FILENAME}]
RewriteRule .* - [E=IN_ORIG_SCRIPT_NAME:%{ORIG_SCRIPT_NAME}]
RewriteRule .* - [E=IN_PATH:%{PATH}]
RewriteRule .* - [E=IN_PHP_SELF:%{PHP_SELF}]
RewriteRule .* - [E=IN_REQUEST_FILENAME:%{REQUEST_FILENAME}]
RewriteRule .* - [E=IN_REQUEST_TIME:%{REQUEST_TIME}]
RewriteRule .* - [E=IN_SCRIPT_GROUP:%{SCRIPT_GROUP}]
RewriteRule .* - [E=IN_SCRIPT_USER:%{SCRIPT_USER}]
RewriteRule .* - [E=IN_THE_REQUEST:%{THE_REQUEST}]
RewriteRule .* - [E=IN_TIME:%{TIME}]
RewriteRule .* - [E=IN_TIME_DAY:%{TIME_DAY}]
RewriteRule .* - [E=IN_TIME_HOUR:%{TIME_HOUR}]
RewriteRule .* - [E=IN_TIME_MIN:%{TIME_MIN}]
RewriteRule .* - [E=IN_TIME_MON:%{TIME_MON}]
RewriteRule .* - [E=IN_TIME_SEC:%{TIME_SEC}]
RewriteRule .* - [E=IN_TIME_WDAY:%{TIME_WDAY}]
RewriteRule .* - [E=IN_TIME_YEAR:%{TIME_YEAR}]
RewriteRule .* - [E=IN_PATH:%{PATH}]
RewriteRule .* - [E=IN_SCRIPT_URI:%{SCRIPT_URI}]
RewriteRule .* - [E=IN_SCRIPT_URL:%{SCRIPT_URL}]
RewriteRule .* - [E=IN_UNIQUE_ID:%{UNIQUE_ID}]
&nbsp;
RewriteRule .* - [E=ENV_PATH:%{ENV:PATH}]
RewriteRule .* - [E=ENV_SCRIPT_URI:%{ENV:SCRIPT_URI}]
RewriteRule .* - [E=ENV_SCRIPT_URL:%{ENV:SCRIPT_URL}]
RewriteRule .* - [E=ENV_UNIQUE_ID:%{ENV:UNIQUE_ID}]
&nbsp;
RequestHeader set AUTH_TYPE &quot;%{IN_AUTH_TYPE}e&quot;
RequestHeader set CONTENT_LENGTH &quot;%{IN_CONTENT_LENGTH}e&quot;
RequestHeader set CONTENT_TYPE &quot;%{IN_CONTENT_TYPE}e&quot;
RequestHeader set DATE_GMT &quot;%{IN_DATE_GMT}e&quot;
RequestHeader set DATE_LOCAL &quot;%{IN_DATE_LOCAL}e&quot;
RequestHeader set DOCUMENT_NAME &quot;%{IN_DOCUMENT_NAME}e&quot;
RequestHeader set DOCUMENT_PATH_INFO &quot;%{IN_DOCUMENT_PATH_INFO}e&quot;
RequestHeader set DOCUMENT_ROOT &quot;%{IN_DOCUMENT_ROOT}e&quot;
RequestHeader set DOCUMENT_URI &quot;%{IN_DOCUMENT_URI}e&quot;
RequestHeader set GATEWAY_INTERFACE &quot;%{IN_GATEWAY_INTERFACE}e&quot;
RequestHeader set LAST_MODIFIED &quot;%{IN_LAST_MODIFIED}e&quot;
RequestHeader set PATH_INFO &quot;%{IN_PATH_INFO}e&quot;
RequestHeader set PATH_TRANSLATED &quot;%{IN_PATH_TRANSLATED}e&quot;
RequestHeader set QUERY_STRING &quot;%{IN_QUERY_STRING}e&quot;
RequestHeader set QUERY_STRING_UNESCAPED &quot;%{IN_QUERY_STRING_UNESCAPED}e&quot;
RequestHeader set REMOTE_ADDR &quot;%{IN_REMOTE_ADDR}e&quot;
RequestHeader set REMOTE_HOST &quot;%{IN_REMOTE_HOST}e&quot;
RequestHeader set REMOTE_IDENT &quot;%{IN_REMOTE_IDENT}e&quot;
RequestHeader set REMOTE_PORT &quot;%{IN_REMOTE_PORT}e&quot;
RequestHeader set REMOTE_USER &quot;%{IN_REMOTE_USER}e&quot;
RequestHeader set REDIRECT_HANDLER &quot;%{IN_REDIRECT_HANDLER}e&quot;
RequestHeader set REDIRECT_QUERY_STRING &quot;%{IN_REDIRECT_QUERY_STRING}e&quot;
RequestHeader set REDIRECT_REMOTE_USER &quot;%{IN_REDIRECT_REMOTE_USER}e&quot;
RequestHeader set REDIRECT_STATUS &quot;%{IN_REDIRECT_STATUS}e&quot;
RequestHeader set REDIRECT_URL &quot;%{IN_REDIRECT_URL}e&quot;
RequestHeader set REQUEST_METHOD &quot;%{IN_REQUEST_METHOD}e&quot;
RequestHeader set REQUEST_URI &quot;%{IN_REQUEST_URI}e&quot;
RequestHeader set SCRIPT_FILENAME &quot;%{IN_SCRIPT_FILENAME}e&quot;
RequestHeader set SCRIPT_NAME &quot;%{IN_SCRIPT_NAME}e&quot;
RequestHeader set SCRIPT_URI &quot;%{IN_SCRIPT_URI}e&quot;
RequestHeader set SCRIPT_URL &quot;%{IN_SCRIPT_URL}e&quot;
RequestHeader set SERVER_ADMIN &quot;%{IN_SERVER_ADMIN}e&quot;
RequestHeader set SERVER_NAME &quot;%{IN_SERVER_NAME}e&quot;
RequestHeader set SERVER_ADDR &quot;%{IN_SERVER_ADDR}e&quot;
RequestHeader set SERVER_PORT &quot;%{IN_SERVER_PORT}e&quot;
RequestHeader set SERVER_PROTOCOL &quot;%{IN_SERVER_PROTOCOL}e&quot;
RequestHeader set SERVER_SIGNATURE &quot;%{IN_SERVER_SIGNATURE}e&quot;
RequestHeader set SERVER_SOFTWARE &quot;%{IN_SERVER_SOFTWARE}e&quot;
RequestHeader set UNIQUE_ID &quot;%{IN_UNIQUE_ID}e&quot;
RequestHeader set USER_NAME &quot;%{IN_USER_NAME}e&quot;
RequestHeader set TZ &quot;%{IN_TZ}e&quot;
RequestHeader set API_VERSION &quot;%{IN_API_VERSION}e&quot;
RequestHeader set HTTPS &quot;%{IN_HTTPS}e&quot;
RequestHeader set HTTP_ACCEPT &quot;%{IN_HTTP_ACCEPT}e&quot;
RequestHeader set HTTP_ACCEPT_CHARSET &quot;%{IN_HTTP_ACCEPT_CHARSET}e&quot;
RequestHeader set HTTP_ACCEPT_ENCODING &quot;%{IN_HTTP_ACCEPT_ENCODING}e&quot;
RequestHeader set HTTP_ACCEPT_LANGUAGE &quot;%{IN_HTTP_ACCEPT_LANGUAGE}e&quot;
RequestHeader set HTTP_CACHE_CONTROL &quot;%{IN_HTTP_CACHE_CONTROL}e&quot;
RequestHeader set HTTP_CONNECTION &quot;%{IN_HTTP_CONNECTION}e&quot;
RequestHeader set HTTP_COOKIE &quot;%{IN_HTTP_COOKIE}e&quot;
RequestHeader set HTTP_FORWARDED &quot;%{IN_HTTP_FORWARDED}e&quot;
RequestHeader set HTTP_HOST &quot;%{IN_HTTP_HOST}e&quot;
RequestHeader set HTTP_KEEP_ALIVE &quot;%{IN_HTTP_KEEP_ALIVE}e&quot;
RequestHeader set HTTP_PROXY_CONNECTION &quot;%{IN_HTTP_PROXY_CONNECTION}e&quot;
RequestHeader set HTTP_REFERER &quot;%{IN_HTTP_REFERER}e&quot;
RequestHeader set HTTP_USER_AGENT &quot;%{IN_HTTP_USER_AGENT}e&quot;
RequestHeader set IS_SUBREQ &quot;%{IN_IS_SUBREQ}e&quot;
RequestHeader set ORIG_PATH_INFO &quot;%{IN_ORIG_PATH_INFO}e&quot;
RequestHeader set ORIG_PATH_TRANSLATED &quot;%{IN_ORIG_PATH_TRANSLATED}e&quot;
RequestHeader set ORIG_SCRIPT_FILENAME &quot;%{IN_ORIG_SCRIPT_FILENAME}e&quot;
RequestHeader set ORIG_SCRIPT_NAME &quot;%{IN_ORIG_SCRIPT_NAME}e&quot;
RequestHeader set PATH &quot;%{IN_PATH}e&quot;
RequestHeader set PHP_SELF &quot;%{IN_PHP_SELF}e&quot;
RequestHeader set REQUEST_FILENAME &quot;%{IN_REQUEST_FILENAME}e&quot;
RequestHeader set REQUEST_TIME &quot;%{IN_REQUEST_TIME}e&quot;
RequestHeader set SCRIPT_GROUP &quot;%{IN_SCRIPT_GROUP}e&quot;
RequestHeader set SCRIPT_USER &quot;%{IN_SCRIPT_USER}e&quot;
RequestHeader set THE_REQUEST &quot;%{IN_THE_REQUEST}e&quot;
RequestHeader set TIME &quot;%{IN_TIME}e&quot;
RequestHeader set TIME_DAY &quot;%{IN_TIME_DAY}e&quot;
RequestHeader set TIME_HOUR &quot;%{IN_TIME_HOUR}e&quot;
RequestHeader set TIME_MIN &quot;%{IN_TIME_MIN}e&quot;
RequestHeader set TIME_MON &quot;%{IN_TIME_MON}e&quot;
RequestHeader set TIME_SEC &quot;%{IN_TIME_SEC}e&quot;
RequestHeader set TIME_WDAY &quot;%{IN_TIME_WDAY}e&quot;
RequestHeader set TIME_YEAR &quot;%{IN_TIME_YEAR}e&quot;
&nbsp;
SetEnvIfNoCase ^WWW-Auth &quot;(.+)&quot; HTTP_WWW_AUTHORIZATION=$1
SetEnvIfNoCase ^If &quot;(.+)&quot; HTTP_IF_MODIFIED_SINCE=$1
SetEnvIfNoCase ^If-None-Match$ &quot;(.+)&quot; HTTP_IF_NONE_MATCH=$1
SetEnvIfNoCase ^Cache-Control$ &quot;(.+)&quot; HTTP_CACHE_CONTROL=$1
SetEnvIfNoCase ^Connection$ &quot;(.+)&quot; HTTP_CONNECTION=$1
SetEnvIfNoCase ^Keep-Alive$ &quot;(.+)&quot; HTTP_KEEP_ALIVE=$1
SetEnvIfNoCase ^Authorization$ &quot;(.+)&quot; HTTP_AUTHORIZATION=$1
SetEnvIfNoCase ^Content-Type$ &quot;(.+)&quot; HTTP_CONTENT_TYPE=$1
SetEnvIfNoCase ^Content-Length$ &quot;(.+)&quot; HTTP_CONTENT_LENGTH=$1
SetEnvIfNoCase ^Authorization$ &quot;.+username=\&quot;([a-zA-Z0-9]+)\&quot;.+&quot; REMOTE_USER=$1
SetEnvIfNoCase Server_Addr &quot;(.+)&quot; SERVER_ADDR=$1
SetEnvIfNoCase Request_Method &quot;(.+)&quot; REQUEST_METHOD=$1
SetEnvIfNoCase Request_Protocol &quot;(.+)&quot; REQUEST_PROTOCOL=$1
SetEnvIfNoCase Request_URI &quot;(.+)&quot; REQUEST_URI=$1
&nbsp;
RequestHeader set IF_MODIFIED_SINCE &quot;%{HTTP_IF_MODIFIED_SINCE}e&quot;
RequestHeader set IF_NONE_MATCH &quot;%{HTTP_IF_NONE_MATCH}e&quot;
RequestHeader set CACHE_CONTROL &quot;%{HTTP_CACHE_CONTROL}e&quot;
RequestHeader set CONNECTION &quot;%{HTTP_CONNECTION}e&quot;
RequestHeader set KEEP_ALIVE &quot;%{HTTP_KEEP_ALIVE}e&quot;
RequestHeader set AUTHORIZATION &quot;%{HTTP_AUTHORIZATION}e&quot;
RequestHeader set REMOTE_USER &quot;%{REMOTE_USER}e&quot;
RequestHeader set CONTENT_TYPE &quot;%{HTTP_CONTENT_TYPE}e&quot;
RequestHeader set CONTENT_LENGTH &quot;%{HTTP_CONTENT_LENGTH}e&quot;
RequestHeader set SERVER_ADDR &quot;%{SERVER_ADDR}e&quot;
RequestHeader set REQUEST_METHOD &quot;%{REQUEST_METHOD}e&quot;
RequestHeader set REQUEST_PROTOCOL &quot;%{REQUEST_PROTOCOL}e&quot;
RequestHeader set REQUEST_URI &quot;%{REQUEST_URI}e&quot;
&nbsp;
RequestHeader set UNIQUE_ID &quot;%{ENV_UNIQUE_ID}e&quot;
RequestHeader set SCRIPT_URL &quot;%{ENV_SCRIPT_URL}e&quot;
RequestHeader set SCRIPT_URI &quot;%{ENV_SCRIPT_URI}e&quot;
RequestHeader set PATH &quot;%{ENV_PATH}e&quot;
&nbsp;
Options +ExecCGI +FollowSymLinks
&nbsp;
Order Deny,Allow
Deny from All
Allow from 208.113.134.190  64.111.114.111 208.113.134.203 208.113.152.201 env=REDIRECT_STATUS
Satisfy Any
&nbsp;
SecFilterEngine Off</pre>
<h2>More Mod_Security (1)</h2>
<pre>#
# Order Deny,Allow
# First, all Allow directives are evaluated; at least one must match, or the request is rejected.
# Next, all Deny directives are evaluated. If any matches, the request is rejected.
# Last, any requests which do not match an Allow or a Deny directive are denied by default.
#
Order Allow,Deny
Allow from all
Deny from 217.219.
&nbsp;
#Order Deny,Allow
# First, all Deny directives are evaluated; if any match, the request is denied unless it also matches an Allow directive.
# Any requests which do not match any Allow or Deny directives are permitted.
&nbsp;
#SetEnvIf content-type (multipart/form-data)(.*) NEW_CONTENT_TYPE=application/x-www-form-urlencoded$2 OLD_CONTENT_TYPE=$1$2
#RequestHeader set content-type %{NEW_CONTENT_TYPE}e env=NEW_CONTENT_TYPE
SetEnvIfNoCase Content-Type &quot;^multipart/form-data&quot; !MODSEC_NOPOSTBUFFERING
SetEnvIfNoCase Content-Type &quot;^application/x-www-form-urlencoded&quot; !MODSEC_NOPOSTBUFFERING
SetEnv suppress-error-charset
SetEnvIfNoCase Content-Type &quot;^multipart/form-data&quot; !MODSEC_NOPOSTBUFFERING
&nbsp;
SetEnvIf Request_URI &quot;^/(cgi-bin/search\.php|cgi-bin/java\.cgi|wp-admin/.*)&quot; MODSEC_ENABLE=Off
SetEnvIf Request_URI &quot;^/(online-tools/js-compress.*)&quot; &quot;MODSEC_NOPOSTBUFFERING=Do not buffer file uploads&quot;
SetEnvIfNoCase Remote_Addr ^208\.113\.134\.190$ MODSEC_ENABLE=Off
SetEnvIfNoCase Remote_Addr ^64\.111\.114\.111$ MODSEC_ENABLE=Off
&nbsp;
### Section 1: Global Environment
#
# The directives in this section affect the overall operation of Apache,
# such as the number of concurrent requests it can handle or where it
# can find its configuration files.
#
#
# TZ: Your address, where problems with the server should be
# e-mailed.  This address appears on some server-generated pages, such
# as error documents.  e.g. admin@your-domain.com
#
SetEnv TZ America/Indianapolis
&nbsp;
#
# ServerAdmin: Your address, where problems with the server should be
# e-mailed.  This address appears on some server-generated pages, such
# as error documents.  e.g. admin@your-domain.com
#
SetEnv SERVER_ADMIN webmaster@askapache.com
&nbsp;
#
# Optionally add a line containing the server version and virtual host
# name to server-generated pages (internal error documents, FTP directory
# listings, mod_status and mod_info output etc., but not CGI generated
# documents or custom error documents).
# Set to &quot;EMail&quot; to also include a mailto: link to the ServerAdmin.
# Set to one of:  On | Off | EMail
#
ServerSignature Off
&nbsp;
#
# Possible values for the Options directive are &quot;None&quot;, &quot;All&quot;,
# or any combination of:
#   Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
#
# The Options directive is both complicated and important.  Please see
# http://httpd.apache.org/docs/2.0/mod/core.html#options
# for more information.
#
Options -Indexes -Includes -ExecCGI -MultiViews
&nbsp;
#
# DirectoryIndex: sets the file that Apache will serve if a directory
# is requested.
#
DirectoryIndex index.php
&nbsp;
#
# Action lets you define media types that will execute a script whenever
# a matching file is called. This eliminates the need for repeated URL
# pathnames for oft-used CGI file processors.
# Format: Action media/type /cgi-script/location
# Format: Action handler-name /cgi-script/location
#
Action php5-cgi /bin/php.cgi
&nbsp;
#
# AddHandler allows you to map certain file extensions to &quot;handlers&quot;:
# actions unrelated to filetype. These can be either built into the server
# or added with the Action directive (see below)
#
# To use CGI scripts outside of ScriptAliased directories:
# (You will also need to add &quot;ExecCGI&quot; to the &quot;Options&quot; directive.)
#
AddHandler php5-cgi .php .inc
&nbsp;
#
# Commonly used filename extensions to character sets. You probably
# want to avoid clashes with the language extensions, unless you
# are good at carefully testing your setup after each change.
# See http://www.iana.org/assignments/character-sets for the
# official list of charset names and their respective RFCs.
#
AddDefaultCharset UTF-8
&nbsp;
#
# AddType allows you to add to or override the MIME configuration
# file mime.types for specific file types.
#
#
AddType &#039;application/rdf+xml; charset=UTF-8&#039; .rdf
AddType &#039;application/xhtml+xml; charset=UTF-8&#039; .xhtml
AddType &#039;application/xhtml+xml; charset=UTF-8&#039; .xhtml.gz
AddType &#039;text/html; charset=UTF-8&#039; .html
AddType &#039;text/html; charset=UTF-8&#039; .html.gz
AddType application/octet-stream .rar .chm .bz2 .tgz .msi .pdf .exe
AddType application/vnd.ms-excel .csv
AddType application/x-httpd-php-source .phps
AddType application/x-pilot .prc .pdb
AddType application/x-shockwave-flash .swf
AddType application/xrds+xml .xrdf
AddType text/plain .ini .sh .bsh .bash .awk .nawk .gawk .csh .var .c .in .h .asc .md5 .sha .sha1
AddType video/x-flv .flv
&nbsp;
#
# AddEncoding allows you to have certain browsers uncompress
# information on the fly. Note: Not all browsers support this.
# Despite the name similarity, the following Add* directives have nothing
# to do with the FancyIndexing customization directives above.
#
AddEncoding x-compress .Z
AddEncoding x-gzip .gz .tgz
&nbsp;
#
# DefaultType: the default MIME type the server will use for a document
# if it cannot otherwise determine one, such as from filename extensions.
# If your server contains mostly text or HTML documents, &quot;text/plain&quot; is
# a good value.  If most of your content is binary, such as applications
# or images, you may want to use &quot;application/octet-stream&quot; instead to
# keep browsers from trying to display binary files as though they are
# text.
#
DefaultType text/html</pre>
<h2>Error Documents</h2>
<pre>#
# Customizable error responses come in three flavors:
# 1) plain text 2) local redirects 3) external redirects
#
#100 Continue
#101 Switching Protocols
#102 Processing
#200 OK
#201 Created
#202 Accepted
#203 Non-Authoritative Information
#204 No Content
#205 Reset Content
#206 Partial Content
#207 Multi-Status
#300 Multiple Choices
#301 Moved Permanently
#302 Found
#303 See Other
#304 Not Modified
#305 Use Proxy
#306 unused
#307 Temporary Redirect
#400 Bad Request
#401 Authorization Required
#402 Payment Required
#403 Forbidden
#404 Not Found
#405 Method Not Allowed
#406 Not Acceptable
#407 Proxy Authentication Required
#408 Request Time-out
#409 Conflict
#410 Gone
#411 Length Required
#412 Precondition Failed
#413 Request Entity Too Large
#414 Request-URI Too Large
#415 Unsupported Media Type
#416 Requested Range Not Satisfiable
#417 Expectation Failed
#418 unused
#419 unused
#420 unused
#421 unused
#422 Unprocessable Entity
#423 Locked
#424 Failed Dependency
#425 No code
#426 Upgrade Required
#500 Internal Server Error
#501 Method Not Implemented
#502 Bad Gateway
#503 Service Temporarily Unavailable
#504 Gateway Time-out
#505 HTTP Version Not Supported
#506 Variant Also Negotiates
#507 Insufficient Storage
#508 unused
#509 unused
#510 Not Extended
&nbsp;
#ErrorDocument 100 /e/100_CONTINUE.html
#ErrorDocument 101 /e/101_SWITCHING_PROTOCOLS.html
#ErrorDocument 102 /e/102_PROCESSING.html
&nbsp;
#ErrorDocument 200 /e/200_OK.html
#ErrorDocument 201 /e/201_CREATED.html
#ErrorDocument 202 /e/202_ACCEPTED.html
#ErrorDocument 203 /e/203_NON_AUTHORITATIVE.html
#ErrorDocument 204 /e/204_NO_CONTENT.html
#ErrorDocument 205 /e/205_RESET_CONTENT.html
#ErrorDocument 206 /e/206_PARTIAL_CONTENT.html
#ErrorDocument 207 /e/207_MULTI_STATUS.html
&nbsp;
#ErrorDocument 300 /e/300_MULTIPLE_CHOICES.html
#ErrorDocument 301 /e/301_MOVED_PERMANENTLY.html
#ErrorDocument 302 /e/302_MOVED_TEMPORARILY.html
#ErrorDocument 303 /e/303_SEE_OTHER.html
#ErrorDocument 304 /e/304_NOT_MODIFIED.html
#ErrorDocument 305 /e/305_USE_PROXY.html
#ErrorDocument 307 /e/307_TEMPORARY_REDIRECT.html
&nbsp;
ErrorDocument 400 /e/400_BAD_REQUEST.html
ErrorDocument 401 /e/401_UNAUTHORIZED.html
ErrorDocument 402 /e/402_PAYMENT_REQUIRED.html
ErrorDocument 403 /e/403_FORBIDDEN.html
#ErrorDocument 404 /e/404_NOT_FOUND.html
ErrorDocument 404 /index.php?error=404
ErrorDocument 405 /e/405_METHOD_NOT_ALLOWED.html
ErrorDocument 406 /e/406_NOT_ACCEPTABLE.html
ErrorDocument 407 /e/407_PROXY_AUTHENTICATION_REQUIRED.html
ErrorDocument 408 /e/408_REQUEST_TIME_OUT.html
ErrorDocument 409 /e/409_CONFLICT.html
ErrorDocument 410 /e/410_GONE.html
ErrorDocument 411 /e/411_LENGTH_REQUIRED.html
ErrorDocument 412 /e/412_PRECONDITION_FAILED.html
ErrorDocument 413 /e/413_REQUEST_ENTITY_TOO_LARGE.html
ErrorDocument 414 /e/414_REQUEST_URI_TOO_LARGE.html
ErrorDocument 415 /e/415_UNSUPPORTED_MEDIA_TYPE.html
ErrorDocument 416 /e/416_RANGE_NOT_SATISFIABLE.html
ErrorDocument 417 /e/417_EXPECTATION_FAILED.html
ErrorDocument 422 /e/422_UNPROCESSABLE_ENTITY.html
ErrorDocument 423 /e/423_LOCKED.html
ErrorDocument 424 /e/424_FAILED_DEPENDENCY.html
ErrorDocument 426 /e/426_UPGRADE_REQUIRED.html
ErrorDocument 500 /e/500_INTERNAL_SERVER_ERROR.html
ErrorDocument 501 /e/501_NOT_IMPLEMENTED.html
ErrorDocument 502 /e/502_BAD_GATEWAY.html
ErrorDocument 503 /e/503_SERVICE_UNAVAILABLE.html
ErrorDocument 504 /e/504_GATEWAY_TIME_OUT.html
ErrorDocument 505 /e/505_VERSION_NOT_SUPPORTED.html
ErrorDocument 506 /e/506_VARIANT_ALSO_VARIES.html
ErrorDocument 507 /e/507_INSUFFICIENT_STORAGE.html
ErrorDocument 510 /e/510_NOT_EXTENDED.html</pre>
<h2>Caching</h2>
<p>h2></p>
<pre>#
#  HEADERS and CACHING
#
Header unset Pragma
FileETag None
Header unset ETag
&nbsp;
# 1 YEAR
&lt;FilesMatch &quot;\.(ico|pdf|flv|jpg|jpeg|png|gif|swf)$&quot;&gt;
Header unset P3P
Header unset Pragma
FileETag None
Header unset ETag
Header set Cache-Control &quot;public,max-age=29030400&quot;
Header set Expires &quot;Thu, 15 Apr 2010 20:00:00 GMT&quot;
Header unset Last-Modified
&lt;/FilesMatch&gt;
&nbsp;
# 2 HOURS
&lt;FilesMatch &quot;\.(html|htm|xml|txt|xsl|rdf|rss)$&quot;&gt;
&lt;IfModule mod_expires.c&gt;
ExpiresActive On
ExpiresDefault A3600
&lt;/IfModule&gt;
&lt;/FilesMatch&gt;</pre>
<h2>Redirect Hack</h2>
<pre>#Redirect 400 /e/400
#Redirect 401 /e/401
#Redirect 402 /e/402
#Redirect 403 /e/403
Redirect 404 /index.php?error=404
#Redirect 405 /e/405
#Redirect 406 /e/406
#Redirect 407 /e/407
#Redirect 408 /e/408
#Redirect 409 /e/409
#Redirect 410 /e/410
#Redirect 411 /e/411
#Redirect 412 /e/412
#Redirect 413 /e/413
#Redirect 414 /e/414
#Redirect 415 /e/415
#Redirect 416 /e/416
#Redirect 417 /e/417
#Redirect 418 /e/418
#Redirect 419 /e/419
#Redirect 420 /e/420
#Redirect 421 /e/421
#Redirect 422 /e/422
#Redirect 423 /e/423
#Redirect 424 /e/424
#Redirect 425 /e/425
#Redirect 426 /e/426
#Redirect 500 /e/500
#Redirect 501 /e/501
#Redirect 502 /e/502
#Redirect 503 /e/503
#Redirect 504 /e/504
#Redirect 505 /e/505
#Redirect 506 /e/506
#Redirect 507 /e/507
#Redirect 508 /e/508
#Redirect 509 /e/509
#Redirect 510 /e/510</pre>
<h2>301 PERMANENT REDIRECTS</h2>
<pre>
#
# Redirect allows you to tell clients about documents which used to exist in
# your server&#039;s namespace, but do not anymore. This allows you to tell the
# clients where to look for the relocated document.
#
Redirect 301 /12-lessons-for-those-afraid-of-css.html http://www.askapache.com/css/12-lessons-for-those-afraid-of-css.html
Redirect 301 /2006/htaccess/htaccesselite-ultimate-htaccess-article.html http://www.askapache.com/htaccess/apache-htaccess.html
Redirect 301 /2007/phpbb/sending-post-form-data-with-php-curl.html http://www.askapache.com/htaccess/sending-post-form-data-with-php-curl.html
Redirect 301 /2007/webmaster/custom-phpini-with-fastcgi-on-dreamhost.html http://www.askapache.com/dreamhost/custom-phpini-with-fastcgi-on-dreamhost.html
Redirect 301 /2007/webmaster/custom-phpini-with-fastcgi-on-dreamhost.html http://www.askapache.com/dreamhost/custom-phpini-with-fastcgi-on-dreamhost.html
Redirect 301 /2007/webmaster/php-and-ajax-shell-console.html http://www.askapache.com/tools/php-and-ajax-shell-console.html
Redirect 301 /27-request-methods-for-use-with-apache-and-rewritecond-and-htaccess.html http://www.askapache.com/htaccess/27-request-methods-for-use-with-apache-and-rewritecond-and-htaccess.html
Redirect 301 /404-google-wordpress-plugin.html http://www.askapache.com/seo/404-google-wordpress-plugin.html
Redirect 301 /503-service-temporarily-unavailable.html http://www.askapache.com/htaccess/503-service-temporarily-unavailable.html
Redirect 301 /Overview-about.rdf http://www.askapache.com/askapache-home.rdf
Redirect 301 /abbr-acronym.html http://www.askapache.com/xhtml/abbr-acronym.html
Redirect 301 /adsense-robots.html http://www.askapache.com/google/adsense-robots.html
Redirect 301 /alexa-toolbar-firefox.html http://www.askapache.com/tools/alexa-toolbar-firefox.html
Redirect 301 /allowing-access-from-1-static-ip-and-deny-the-rest.html http://www.askapache.com/htaccess/apache-htaccess.html
Redirect 301 /anti-virus-spyware-rootkit.html http://www.askapache.com/security/anti-virus-spyware-rootkit.html
Redirect 301 /apache-ssl-in-htaccess-examples.html http://www.askapache.com/htaccess/apache-ssl-in-htaccess-examples.html
Redirect 301 /awk-tutorial.html http://www.askapache.com/awk/awk-tutorial.html
Redirect 301 /best-adsense-optimization.html http://www.askapache.com/wordpress/best-adsense-optimization.html
Redirect 301 /commonly-used-htaccess-code-examples.html http://www.askapache.com/htaccess/commonly-used-htaccess-code-examples.html
Redirect 301 /css-background-image-sprite.html http://www.askapache.com/css/css-background-image-sprite.html
Redirect 301 /css-browser-screenshots.html http://www.askapache.com/tools/css-browser-screenshots.html
Redirect 301 /css-class-example.html http://www.askapache.com/css/css-class-example.html
Redirect 301 /curl-multi-downloads.html http://www.askapache.com/php/curl-multi-downloads.html
Redirect 301 /custom-boot-menu-in-windows-xp.html http://www.askapache.com/windows/custom-boot-menu-in-windows-xp.html
Redirect 301 /donate http://www.dreamhost.com/donate.cgi?id=8261
Redirect 301 /donate/ http://www.dreamhost.com/donate.cgi?id=8261
Redirect 301 /htaccess.txt http://z.askapache.com/p/htaccess.txt
Redirect 301 /htaccess/404-errorpages.html http://www.askapache.com/seo/google-ajax-search-seo-tips.html
Redirect 301 /htaccess/feedsmith http://www.askapache.com/htaccess/feedsmith-htaccess.html
Redirect 301 /htaccess/http-status-codes.html http://www.askapache.com/htaccess/apache-status-code-headers-errordocument.html
Redirect 301 /htaccess/instruct-search-engines-to-come-back-to-site-after-you-finish-working-on-it.html http://www.askapache.com/htaccess/503-service-temporarily-unavailable.html
Redirect 301 /htaccess/speed-up-the-apache-web-server-with-configuration-hacks.html http://www.askapache.com/htaccess/apache-web-server-speed-configuration-hacks.html
Redirect 301 /instruct-search-engines-to-come-back-to-site-after-you-finish-working-on-it.html http://www.askapache.com/htaccess/503-service-temporarily-unavailable.html
Redirect 301 /security/bypassing-vlan.html http://www.askapache.com/security/hacking-vlan-switched-networks.html
Redirect 301 /security/bypassing-vlanbypassing-vlan.html http://www.askapache.com/security/hacking-vlan-switched-networks.html
Redirect 301 /security/rigging-the-dreamhost-site-of-the-month-contest.html http://www.askapache.com/dreamhost/rigging-the-dreamhost-site-of-the-month-contest.html
Redirect 301 /seo/tailrankcom-robot.html http://www.askapache.com/seo/tailrank-robot.html
Redirect 301 /webmaster/caching-tutorial-for-webmasters.html http://www.askapache.com/htaccess/caching-tutorial-for-webmasters.html
Redirect 301 /webmaster/lft-traceroute-tool.html http://www.askapache.com/tools/lft-traceroute-tool.html</pre>
<h2>301 PERMANENT REDIRECTMATCH</h2>
<pre>#
#  PERMANENT REDIRECTMATCH
#
#RedirectMatch 301 ^/&amp;(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/(.+)\.html/$ http://www.askapache.com/$1.html
RedirectMatch 301 ^/&amp;amp(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/.*feed\.gif$ http://z.askapache.com/feed.gif
RedirectMatch 301 ^/([^/]+)//$ http://www.askapache.com/$1/
RedirectMatch 301 ^/(.+)/htaccesselite-ultimate-htaccess-article.html(.*) http://www.askapache.com/htaccess/apache-htaccess.html
RedirectMatch 301 ^/(.+)\.html/([a-z][a-z])/$ http://www.askapache.com/$1.html
RedirectMatch 301 ^/([\(]+)(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/([^9]*)9O1X.3y(.*)/(.*)$ http://www.askapache.com/$2
RedirectMatch 301 ^/.3y(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/200([0-9])/([0-9])(.*)$ http://www.askapache.com/top-100/
RedirectMatch 301 ^/200([0-9])/([^01])(.*)$ http://www.askapache.com/$2$3
RedirectMatch 301 ^/about/glossary(.*)$ http://www.askapache.com/glossary$1
RedirectMatch 301 ^/apache-speed(.*)$ http://www.askapache.com/htaccess/apache-speed$1
RedirectMatch 301 ^/category/(.+)$ http://www.askapache.com/$1
RedirectMatch 301 ^/docs/(.*)$ http://askapache.info/$1
RedirectMatch 301 ^/htaccess/feedsmith-htaccess(.*) http://www.askapache.com/htaccess/redirecting-wordpress-feeds-to-feedburner.html
RedirectMatch 301 ^/robots-txt(.*)$ http://www.askapache.com/robots.txt
RedirectMatch 301 ^/hosting/?$ http://www.askapache.com/web-hosting/
RedirectMatch 301 ^/.+favicon.ico$ http://www.askapache.com/favicon.ico
#RedirectMatch 301 ^/wp-content/uploads/(.*)$ http://z.askapache.com/uploads/$1
#RedirectMatch 301 ^/z/(.+)$ http://z.askapache.com/$1
#RedirectMatch 301 ^/(z|t|i|j|c|p)/(.*)$ http://z.askapache.com/$1/$2
&nbsp;
#
#  TEMPORARY REDIRECTMATCH
#
RedirectMatch 307 ^/getflash/?$ http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash
RedirectMatch 307 ^/dream/?$ http://www.askapache.com/dreamhost/
RedirectMatch 307 ^/(cse|apachecse|apachecsetest|apachesearch)/?$ http://www.google.com/coop/cse?cx=002660089121042511758%3Akk7rwc2gx0i
RedirectMatch 307 ^/search/lr-lang(.*)$ http://feeds.askapache.com/apache/htaccess
&nbsp;
#
#  PERMANENT GONE
#
RedirectMatch 410 ^/funny(.*)</pre>
<h2>My Favorite modsec_v1 stuff</h2>
<pre># Pass: Allows request to continue, further filters could still halt request.
# Allow: Allows matching requests through, will not be tested against other filters.
# Deny: Stops the request outright, returns a HTTP 500 error code by default.
# Status: Used to specify an alternate HTTP error code.
# Redirect: Matching requests are redirected to the provided URL.
# Exec: Allows execution of a local system binary or script.
# Log: Logs request only.
# Nolog: Does not log request.
# Chain: Allows you to create list of filters for more granulated security. All filters must be cleared before action is taken with the final filter.
&nbsp;
SecFilterEngine On
SecFilterCheckURLEncoding On
SecFilterCheckUnicodeEncoding Off
SecFilterScanPOST On
&nbsp;
#SecUploadKeepFiles On
#SecUploadDir /home/askapache/sites/askapache.com/logs/sec-upload
#SecUploadApproveScript /home/askapache/sites/askapache.com/htdocs/cgi-bin/check.sh
&nbsp;
#SecRuleEngine On
#SecAuditEngine On
#SecAuditEngine Off
SecAuditEngine RelevantOnly
SecAuditLog /home/askapache/sites/askapache.com/logs/modsec_audit.log
SecFilterDebugLog /home/askapache/sites/askapache.com/logs/modsec_debug.log
SecFilterDebugLevel 1
#SecAuditLogRelevantStatus &quot;^(?:1|2(?!00)|5|4(?!04))&quot;
SecAuditLogRelevantStatus &quot;^(1|2(?!00)|4([0-9](0|1|2|5|6|7|8|9))|5)&quot;
SecFilterForceByteRange 1 255
&nbsp;
#SecFilterInheritance Off
# 0 EMERGENCY - system is unusable
# 1 ALERT - action must be taken immediately
# 2 CRITICAL - critical conditions
# 3 ERROR - error conditions
# 4 WARNING - warning conditions
# 5 NOTICE - normal but significant conditions
# 6 INFO - informational
# 7 DEBUG - debug-level messages
&nbsp;
SecFilterDefaultAction &quot;deny,severity:6,status:403&quot;
&nbsp;
#SecFilterSelective REQUEST_METHOD &quot;POST&quot; &quot;pass,auditlog,severity:6&quot;
SecFilterSelective REQUEST_URI &quot;^/(xmlrpc|wp-comments-post)\.php&quot; &quot;pass,log,auditlog,severity:6&quot;
#SecFilterSelective REMOTE_ADDR ^$ &quot;pass,log,auditlog,severity:6&quot;
#SecFilterSelective REMOTE_ADDR ^203\.221\.91\.20$ &quot;pass,log,auditlog,severity:6&quot;
&nbsp;
#SecFilterSelective REQUEST_URI &quot;^/htaccess.*&quot; &quot;pass,log,auditlog&quot;
#SecFilterSelective REQUEST_URI &quot;^/feed.*&quot; &quot;pass,log,auditlog&quot;
#SecFilterSelective REQUEST_URI &quot;^/.*trackback.*&quot; &quot;pass,log,auditlog&quot;
#SecFilterSelective REQUEST_URI &quot;^/valid.*&quot; &quot;pass,log,auditlog&quot;
&nbsp;
#Enforce proper HTTP requests
SecFilterSelective SERVER_PROTOCOL &quot;!^HTTP/(0\.9|1\.0|1\.1)$&quot; &quot;id:340000,rev:1,severity:6,msg:&#039;Bad HTTP Protocol&#039;&quot;
&nbsp;
# Only accept request encodings we know how to handle
SecFilterSelective REQUEST_METHOD &quot;!^(GET|HEAD|POST)$&quot; &quot;chain,id:340001,rev:1,severity:6,msg:&#039;Restricted HTTP function,status:405&#039;&quot;
SecFilterSelective HTTP_Content-Type &quot;!(^$|^application/x-www-form-urlencoded$|^multipart/form-data)&quot;
&nbsp;
# Require Content-Length to be provided with every POST request
SecFilterSelective REQUEST_METHOD &quot;^POST$&quot; &quot;chain,id:340003,rev:1,severity:6,msg:&#039;Content Length not provided with POST&#039;,status:411&quot;
SecFilterSelective HTTP_Content-Length &quot;^$&quot;
&nbsp;
# Don&#039;t accept transfer encodings we know we don&#039;t handle
# (and you don&#039;t need it anyway)
SecFilterSelective HTTP_Transfer-Encoding &quot;!^$&quot; &quot;id:340004,rev:1,severity:6,msg:&#039;Dis-allowed Transfer Encoding&#039;&quot;
&nbsp;
#Generic rule for allowed characters, adjust for your site before activating
##SecFilterSelective REQUEST_URI &quot;!^[a-zA-Z0-9\.\+\_\/\-\?\=\&amp;\%\#]+$&quot; &quot;chain,id:390002,rev:1,severity:4,msg:&#039;Restricted HTTP character set&#039;&quot;
##SecFilterSelective REQUEST_URI &quot;!^/(openid|wp-admin|wp-includes|wp-content|wp-login.php)&quot;
&nbsp;
#HTTP response splitting generic sigs
#SecFilter &quot;Content-Length\:.*Content-Type\:.*Content-Type\:&quot; &quot;id:340005,rev:1,severity:4,msg:&#039;HTTP response splitting&#039;&quot;
&nbsp;
#HTTP response splitting generic sigs
#SecFilter &quot;Content-Length\:&quot; &quot;chain,id:340006,rev:1,severity:4,msg:&#039;HTTP response splitting&#039;&quot;
#SecFilter &quot;Content-Type\:&quot;
&nbsp;
#catch smuggling attacks
#SecFilter &quot;^(GET|POST).*Host:.*^(GET|POST)&quot;  &quot;id:300012,rev:1,severity:4,msg:&#039;catch smuggling attacks&#039;&quot;
&nbsp;
#XSS insertion into Content-Type
#SecFilterSelective THE_REQUEST &quot;Content-Type\:.*(&lt;[[:space:]]*(script|about|applet|activex|chrome)*&gt;.*(script|about|applet|activex|chrome)[[:space:]]*&gt;|onmouseover=|javascript\:)&quot; &quot;id:300002,rev:1,severity:4,msg:&#039;XSS attack in Content-type header&#039;&quot;
&nbsp;
#Code injection via content length
#SecFilterSelective HTTP_Content-Length|HTTP_USER_AGENT &quot;\;(system|passthru|exec)\(&quot; &quot;id:330003,rev:1,severity:4,msg:&#039;Code Injection in Content-Length header&#039;&quot;
&nbsp;
#Don&#039;t accept chunked encodings modsecurity can not look at these, so this is a hole that can bypass your rules, the rule before this one should cover this, but hey paranoia is cheap
#SecFilterSelective HTTP_Transfer-Encoding &quot;chunked&quot; &quot;id:300003,rev:1,severity:4,msg:&#039;Chunked Transfer Encoding denied&#039;&quot;
&nbsp;
##generic recursion signatures
#SecFilterSelective REQUEST_URI &quot;\.\./\.\./&quot; &quot;id:300004,rev:2,severity:4,msg:&#039;Generic Path Recursion1 denied&#039;&quot;
#SecFilterSelective THE_REQUEST &quot;\.\|\./\.\|\./\.\|&quot; &quot;id:300005,rev:1,severity:4,msg:&#039;Generic Path Recursion2 denied&#039;&quot;
#SecFilterSelective THE_REQUEST &quot;\.\.\./&quot; &quot;id:300006,rev:1,severity:4,msg:&#039;Bogus Path denied&#039;&quot;
&nbsp;
#Generic PHP exploit signatures
#SecFilterSelective REQUEST_URI &quot;&lt;\?php (chr|fwrite|fopen|system|echr|passthru|popen|proc_open|shell_exec|exec|proc_nice|proc_terminate|proc_get_status|proc_close|pfsockopen|leak|apache_child_terminate|posix_kill|posix_mkfifo|posix_setpgid|posix_setsid|posix_setuid|phpinfo)\(.*\)\;&quot; &quot;id:330002,rev:1,severity:4,msg:&#039;Generic PHP exploit pattern denied&#039;&quot;
&nbsp;
#Prevent SQL injection in cookies
##SecFilterSelective COOKIE_VALUES &quot;((select|grant|delete|insert|drop|alter|replace|truncate|update|create|rename|describe)[[:space:]]+[A-Z|a-z|0-9|\*| |\,]+[[:space:]]+(from|into|table|database|index|view)[[:space:]]+[A-Z|a-z|0-9|\*| |\,]|UNION SELECT.*\&#039;.*\&#039;.*,[0-9].*INTO.*FROM)&quot; &quot;id:300011,rev:1,severity:4,msg:&#039;Generic SQL injection in cookie&#039;&quot;
&nbsp;
#Prevent SQL injection in UA
##SecFilterSelective HTTP_USER_AGENT &quot;((select|grant|delete|insert|drop|alter|replace|truncate|update|create|rename|describe)[[:space:]]+[A-Z|a-z|0-9|\*| |\,]+[[:space:]]+(from|into|table|database|index|view)[[:space:]]+[A-Z|a-z|0-9|\*| |\,]|UNION SELECT.*\&#039;.*\&#039;.*,[0-9].*INTO.*FROM)&quot; &quot;id:300012,rev:1,severity:4,msg:&#039;Generic SQL injection in User Agent header&#039;&quot;
&nbsp;
# Generic filter to prevent SQL injection attacks
# Understand that all SQL filters are very limited and are very difficult to prevent false postives and negatives.
# Please report false positives/negatives to mike@gotroot.com
#SecFilter &quot;((select|grant|delete|insert|drop|alter|replace|truncate|update|create|rename|describe)[[:space:]]+[A-Z|a-z|0-9|\*| |\,]+[[:space:]]+(from|into|table|database|index|view)[[:space:]]+[A-Z|a-z|0-9|\*| |\,]|UNION SELECT.*\&#039;.*\&#039;.*,[0-9].*INTO.*FROM)&quot; &quot;id:300013,rev:1,severity:4,msg:&#039;Generic SQL injection protection&#039;&quot;
&nbsp;
#generic XSS PHP attack types
##SecFilterSelective REQUEST_URI &quot;\.php\?&quot; &quot;chain,id:300010,rev:1,severity:4,msg:&#039;Generic PHP XSS exploit pattern denied&#039;&quot;
#SecFilter &quot;(javascript\:/(.*new\x20ActiveXObject.*Sh\.regwrite|.*window\.opener\.document\.body.\innerHTML=window\.opener\.document\.body\.innerHTML\.replace)|onmouseover=\&#039;javascript)&quot;
&nbsp;
#Generic XSS filter
#please report false positives
##SecFilterSelective REQUEST_URI &quot;!/mt\.cgi&quot; &quot;chain,msg:&#039;XSS2&#039;&quot;
#SecFilter &quot;&lt;[[:space:]]*(script|about|applet|activex|chrome)*&gt;.*(script|about|applet|activex|chrome)[[:space:]]*&gt;&quot;
&nbsp;
#XSS in referrer and UA headers
##SecFilterSelective HTTP_REFERER|HTTP_USER_AGENT &quot;&lt;[[:space:]]*(script|about|applet|activex|chrome)*&gt;.*(script|about|applet|activex|chrome)[[:space:]]*&gt;&quot; &quot;msg:&#039;XSS3&#039;&quot;
&nbsp;
#HTTP header PHP code injection attacks
##SecFilterSelective HTTP_CLIENT_IP|HTTP_USER_AGENT|HTTP_Referer &quot;(&lt;\?php|&lt;[[:space:]]?\?[[:space:]]?php|&lt;\? php)&quot; &quot;msg:&#039;PHP1&#039;&quot;
&nbsp;
#Generic PHP remote file injection
##SecFilterSelective REQUEST_URI &quot;!(/do_command)&quot; &quot;chain,msg:&#039;PHP2&#039;&quot;
##SecFilterSelective REQUEST_URI &quot;\.php\?.*=(https?|ftp)\:/.*(cmd|command)=&quot;
&nbsp;
#script, perl, etc. code in HTTP_Referer string
##SecFilterSelective HTTP_Referer &quot;\#\!.*/&quot; &quot;msg:&#039;perl script1&#039;&quot;
&nbsp;
#remote file inclusion generic attack signature
#SecFilterSelective THE_REQUEST  &quot;\.(dat|gif|jpg|png|bmp|txt|vir|dot)\?&quot; &quot;chain,msg:&#039;remote 1&#039;&quot;
#SecFilter &quot;((name|pm_path|pagina|path|include_location|root|page|open)=(http|https|ftp)|(cmd|command|inc)=)&quot;
&nbsp;
#remote file inclusion generic attack signature
#SecFilterSelective THE_REQUEST  &quot;\.(dat|gif|jpg|png|bmp|txt|vir|dot)\?\&amp;(cmd|command|inc|name)=&quot; &quot;msg:&#039;remote2&#039;&quot;
&nbsp;
#remote file inclusion generic attack signature
#SecFilterSelective ARGS  &quot;\.(dat|gif|jpg|png|bmp|txt|vir|dot)&quot; &quot;chain,msg:&#039;file inclusion1&#039;&quot;
#SecFilter &quot;\?\&amp;(cmd|inc|name)=&quot;
&nbsp;
#remote file inclusion generic attack signature
#SecFilterSelective ARGS  &quot;\.(dat|gif|jpg|png|bmp|txt|vir|dot)\?\&amp;(cmd|inc|name)=&quot; &quot;msg:&#039;file inclusion2&#039;&quot;
&nbsp;
#remote file inclusion generic attack signature
#SecFilterSelective REQUEST_URI  &quot;\.php\?.*=(http|https|ftp)\:/.*\?&amp;cmd=&quot; &quot;msg:&#039;file inclusion3&#039;&quot;
&nbsp;
#Bogus file extensions generic signature
#SecFilterSelective THE_REQUEST  &quot;[A-Za-z0-9]\.(gif|jpg|png|bmp)\.txt&quot; &quot;msg:&#039;file extension&#039;&quot;
&nbsp;
#PHP remote path attach generic signature
#SecFilterSelective REQUEST_URI  &quot;\.ph(p(3|4)?).*path=(http|https|ftp)\:/&quot; &quot;msg:&#039;remote path1&#039;&quot;
#SecFilterSelective REQUEST_URI  &quot;\.php.*path=(http|https|ftp)\:/&quot; &quot;msg:&#039;remote path2&#039;&quot;
&nbsp;
#generic php attack sigs
#SecFilterSelective REQUEST_URI &quot;(&amp;(cmd|command)=(id|uname)\x20|cmd\?(cmd|command)=|(spy|cmd|cmd_out|sh)\.(gif|jpg|png|bmp|txt)\?&amp;(cmd|command)=|\.php\?&amp;(cmd|command)=)&quot; &quot;msg:&#039;php attack1&#039;&quot;
&nbsp;
# WEB-MISC apache directory disclosure attempt
#SecFilterSelective THE_REQUEST &quot;////&quot; &quot;msg:&#039;apache directory disclosure&#039;&quot;
&nbsp;
#PHP defenses
##SecFilterSelective ARG_PHPSESSID &quot;!^$&quot; &quot;msg:&#039;something in phpsessid&#039;&quot;
##SecFilterSelective COOKIE_PHPSESSID &quot;!^$&quot; &quot;msg:&#039;something in cookie phpsessid&#039;&quot;
&nbsp;
#PHP defenses
##SecFilterSelective COOKIE_ASKAPACHEID &quot;!^[0-9a-z]*$&quot; &quot;msg:&#039;bad value for cookie&#039;&quot;
&nbsp;
#cross site scripting attempt TYPE + JAVASCRIPT
##SecFilterSelective THE_REQUEST &quot;TYPE\s*=\s*[\&#039;\&quot;]text\/javascript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt STYLE + JAVASCRIPT
##SecFilterSelective THE_REQUEST &quot;TYPE\s*=\s*[\&#039;\&quot;]application\/x-javascript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt STYLE + JSCRIPT
##SecFilterSelective THE_REQUEST &quot;TYPE\s*=\s*[\&#039;\&quot;]text\/jscript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
# cross site scripting attempt STYLE + VBSCRIPT
##SecFilterSelective THE_REQUEST &quot;TYPE\s*=\s*[\&#039;\&quot;]text\/vbscript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt STYLE + VBSCRIPT
##SecFilterSelective THE_REQUEST &quot;TYPE\s*=\s*[\&#039;\&quot;]application\/x-vbscript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt STYLE + ECMACRIPT
##SecFilterSelective THE_REQUEST &quot;TYPE\s*=\s*[\&#039;\&quot;]text\/ecmascript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
# cross site scripting attempt STYLE + EXPRESSION
##SecFilterSelective THE_REQUEST &quot;STYLE[\s]*=[\s]*[^&gt;]expression[\s]*\(&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt STYLE + EXPRESSION
##SecFilterSelective THE_REQUEST &quot;[\s]*expression[\s]*\([^}]}[\s]*&lt;\/STYLE&gt;&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
# cross site scripting attempt using XML
##SecFilterSelective THE_REQUEST &quot;&lt;!\[CDATA\[&lt;\]\]&gt;SCRIPT&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt executing hidden Javascript
##SecFilterSelective THE_REQUEST &quot;eval[\s]*\([\s]*[^\.]\.innerHTML[\s]*\)&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt executing hidden Javascript
##SecFilterSelective THE_REQUEST &quot;window\.execScript[\s]*\(&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting attempt to execute Javascript code
###SecFilterSelective THE_REQUEST &quot;/(((URL|SRC|HREF|LOWSRC)[\s]*=)|(url[\s]*[\(]))[\s]*[\&#039;\&quot;]*javascript[\:]&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#cross site scripting HTML Image tag set to javascript attempt
#SecFilterSelective THE_REQUEST &quot;img src=javascript&quot; &quot;msg:&#039;cross-site1&#039;&quot;
&nbsp;
#Fake image file shell attacvk
#SecFilterSelective HTTP_Content-Type &quot;image/.*&quot; &quot;msg:&#039;image shell 1&#039;&quot;
#SecFilterSelective POST_PAYLOAD &quot;chr\(&quot; &quot;msg:&#039;image shell2&#039;&quot;
&nbsp;
#bogus graphics file
#SecFilterSelective HTTP_Content-Disposition &quot;\.php&quot;  &quot;chain,msg:&#039;bogus graphics&#039;&quot;
#SecFilterSelective HTTP_Content-Type &quot;(image/gif|image/jpg|image/png|image/bmp)&quot;
&nbsp;
# Allow only letters, digits, underscore, and square brackets (for arrays)
# in variable names#
#SecFilterSelective ARGS_NAMES &quot;!^[][a-zA-Z0-9_]+$&quot;
&nbsp;
#&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-
# reject keywords that appear in POST or GET
#=============================================
SecFilterSignatureAction &quot;nolog,auditlog,deny,severity:6,status:403&quot;
&nbsp;
SecFilterSelective REQUEST_URI  &quot;^/.*/wp-comments-post\.php&quot; &quot;id:50200,msg:&#039;WORDPRESS SPAM bad wp-comments-post location&#039;&quot;
&nbsp;
&lt;Files wp-comments-post.php&gt;
# fail for empty comment fields
SecFilterSelective &quot;ARG_comment_post_ID|ARG_submit&quot; &quot;^$&quot; &quot;id:50300,msg:&#039;WORDPRESS SPAM MISSING comment_post_ID&#039;&quot;
SecFilterSelective &quot;ARG_comment_post_ID&quot; &quot;!^[0-9]{1,6}$&quot; &quot;id:50301,msg:&#039;WORDPRESS SPAM BAD comment_post_ID&#039;&quot;
SecFilterSelective &quot;HTTP_Cookie&quot; &quot;^$&quot; &quot;id:50302,msg:&#039;WORDPRESS SPAM No cookie&#039;&quot;
&nbsp;
##SecFilterSelective &quot;comment_post_DI&quot; &quot;^$&quot; &quot;id:50310,msg:&#039;WORDPRESS SPAM MISSING comment_post_DI&#039;&quot;
##SecFilterSelective &quot;comment_post_DI&quot; &quot;!^[0-9]{1,2}$&quot; &quot;id:50311,msg:&#039;WORDPRESS SPAM MISSING comment_post_DI&#039;&quot;
&lt;/Files&gt;
&lt;pre&gt;
&nbsp;
&lt;h2&gt;MODSEC Continued.. Custom Anti-Spam (WordPress) I made&lt;/h2&gt;
&lt;pre&gt;
SecFilterSignatureAction &quot;nolog,noauditlog,deny,severity:6,redirect:http://www.askapache.com/feed/&quot;
SecFilterSelective ARGS|THE_REQUEST &quot;00bp\.com|360\.yahoo|987mb\.com|Ambien|American airline&quot; &quot;id:50010,msg:&#039;SPAM 10&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;Ativan|Caresoprodol|Darvocet|Ephedra|Ephedrine&quot; &quot;id:50011,msg:&#039;SPAM 11&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;Gambling|Lexapro|Tramadol|Venlafaxine&quot; &quot;id:50012,msg:&#039;SPAM 12&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;\[URL=|abgood|acura|acyclovir|adderall&quot; &quot;id:50013,msg:&#039;SPAM 13&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;adipex|alcohol|alprazolam|amateur|amrit&quot; &quot;id:50014,msg:&#039;SPAM 14&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;anal sex|analfinder|angelina jolie|asshole|axspace\.com&quot; &quot;id:50015,msg:&#039;SPAM 15&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;baccarat|bankrupt|bikini|biotic|black jack|blowjob&quot; &quot;id:50016,msg:&#039;SPAM 16&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;blackjack|blog\.360|brutality|buddhism|butalbital&quot; &quot;id:50017,msg:&#039;SPAM 17&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;cadillac|canalis|card credit|card stud|carisoprodol&quot; &quot;id:50018,msg:&#039;SPAM 18&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;carmen|cash advance|cash credit|casino|catch\.com&quot; &quot;id:50019,msg:&#039;SPAM 19&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;celebrex|celexa|cellulite|cheap|cheerleader&quot; &quot;id:50020,msg:&#039;SPAM 20&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;chevrolet|child abuse|cialis|cigarette|cipro&quot; &quot;id:50021,msg:&#039;SPAM 21&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;citroen|claritin|cleavage|clomid|codeine&quot; &quot;id:50022,msg:&#039;SPAM 22&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;consulting23|craps online|credit card|credit debt|crestor&quot; &quot;id:50023,msg:&#039;SPAM 23&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;dealership|debt free|desnudas|diazepam|dick&quot; &quot;id:50024,msg:&#039;SPAM 24&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;dildo|drugstore|earrings|endometrioma|endowment&quot; &quot;id:50025,msg:&#039;SPAM 25&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;erotic|estrogen|fioricet|francaise|freehost\.com&quot; &quot;id:50026,msg:&#039;SPAM 26&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;freehostia|freemb\.com|fuck|geocities\.com|hacking myspace&quot; &quot;id:50027,msg:&#039;SPAM 27&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;holdem|honda|hotels|hydrocodone|hypnotic&quot; &quot;id:50028,msg:&#039;SPAM 28&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;hyundai|implants|incest|instant approval|insurance&quot; &quot;id:50029,msg:&#039;SPAM 29&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;interracial|jaguar|jenny movie|johanson|kasino&quot; &quot;id:50030,msg:&#039;SPAM 30&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;lesbian|levitra|lipitor|loan|lolita&quot; &quot;id:50031,msg:&#039;SPAM 31&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;lorazepam|lorcet|lyrics|madamic|majorette&quot; &quot;id:50032,msg:&#039;SPAM 32&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;malaria|mastercar|masturbate|masturbation|maturewomen&quot; &quot;id:50033,msg:&#039;SPAM 33&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;mazda|medication|medicine|megsfree5\.com|mercedes&quot; &quot;id:50034,msg:&#039;SPAM 34&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;meridia|metformin|mitsubishi|mortgage|myspace profile&quot; &quot;id:50035,msg:&#039;SPAM 35&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;naked|neocool|nexium|nimire\.com|nissan&quot; &quot;id:50036,msg:&#039;SPAM 36&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;nokia|nude|nudism|nymph|open toe&quot; &quot;id:50037,msg:&#039;SPAM 37&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;oprodol|orgasm|oxycodone|oxycontin|packages&quot; &quot;id:50038,msg:&#039;SPAM 38&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;painrelief|pantyhose|paxil|payday|penis&quot; &quot;id:50039,msg:&#039;SPAM 39&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;percocet|pharmacy|phentermine|phetermine|phpbb_root&quot; &quot;id:50040,msg:&#039;SPAM 40&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;pictaboo|pictorial|pills|pissing|play craps&quot; &quot;id:50041,msg:&#039;SPAM 41&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;playgirl|pocker web|poker|pontiac|poquer&quot; &quot;id:50042,msg:&#039;SPAM 42&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;porn|pounder|prescription|preteen|prevacid&quot; &quot;id:50043,msg:&#039;SPAM 43&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;price1|prilosec|propecia|proza|prozac&quot; &quot;id:50044,msg:&#039;SPAM 44&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;puddled|pussy|refinance|rentals|replica&quot; &quot;id:50045,msg:&#039;SPAM 45&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;ringtones|roulette|screensaver|seduced|sexual&quot; &quot;id:50046,msg:&#039;SPAM 46&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;sexy|shemale|shiloh|singulair|site-host&quot; &quot;id:50047,msg:&#039;SPAM 47&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;slot machine|slot maschine|slots machine|solpip\.com|soma&quot; &quot;id:50048,msg:&#039;SPAM 48&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;sperm|starlets|supplier|suzuki|tadalafil&quot; &quot;id:50049,msg:&#039;SPAM 49&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;toyota|tylenol|ultram|valium|viagra&quot; &quot;id:50050,msg:&#039;SPAM 50&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;vigora|vioxx|wallpaper|warez|webcam&quot; &quot;id:50051,msg:&#039;SPAM 51&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;webpages\.com|wellbutrin|whitesluts|wholesale|whore&quot; &quot;id:50052,msg:&#039;SPAM 52&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;windshield|xanax|xenical|y lohan|yourgirls&quot; &quot;id:50053,msg:&#039;SPAM 53&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;youtube\.com|zantac|sex offenders|hotgay|Zoloft|celtic women&quot; &quot;id:50054,msg:&#039;SPAM 54&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;dollhouse|freehot|kardashian|oralsex&quot; &quot;id:50055,msg:&#039;SPAM 55&#039;
SecFilterSelective ARGS|THE_REQUEST &quot;freeimghost&quot; &quot;id:50056,msg:&#039;SPAM 56&#039;</pre>
<h2>Unreleased AskApache Lightning code - caching plugin for WordPress</h2>
<pre>RewriteEngine On
RewriteBase /
&nbsp;
RewriteCond %{REQUEST_URI} ^/(stats/|missing\.html|failed_auth\.html|test/).* [NC,OR]
RewriteCond %{ENV:REDIRECT_STATUS} =200
RewriteRule .* - [L]
&nbsp;
RewriteCond %{HTTP_HOST} !=www.askapache.com
RewriteCond %{HTTP_HOST} !=z.askapache.com
RewriteRule .? http://www.askapache.com%{REQUEST_URI}%{QUERY_STRING} [R=301,L]
&nbsp;
#RewriteCond %{HTTPS} =on
#RewriteCond %{THE_REQUEST} !^[A-Z]{3,9}\ /(wp-login.php|wp-admin)(.*)\ HTTP/ [NC]
#RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(.*)\ HTTP/ [NC]
#RewriteRule .* http://www.askapache.com/$1 [R=301,L]
&nbsp;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(.+)%20(.+)\ HTTP/ [NC]
RewriteRule .* http://www.askapache.com/%1-%2 [R=301,L]
&nbsp;
RewriteCond %{THE_REQUEST} ^GET\ /valid-html/.*\ HTTP/ [NC]
RewriteCond %{HTTP_REFERER} ^https?://www.askapache.com(.+).*$ [NC]
RewriteRule .* http://validator.w3.org/check?uri=http://www.askapache.com%1;ss=1;outline=1;debug [R=307,L,NE]
&nbsp;
RewriteCond %{THE_REQUEST} ^GET\ /valid-css/.*\ HTTP/ [NC]
RewriteRule .* http://jigsaw.w3.org/css-validator/validator?uri=z.askapache.com/z/c/apache-10.css [R=301,L]
&nbsp;
RewriteCond %{THE_REQUEST} ^GET\ /search/.*\ HTTP/ [NC]
RewriteCond %{QUERY_STRING} ^s=(.+)$ [NC]
RewriteRule .* http://www.askapache.com/search/%1? [R=302,L]
&nbsp;
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{DOCUMENT_ROOT}/X%{REQUEST_URI}index.html -f
RewriteRule ^(.*)$ /X%{REQUEST_URI}index.html [L]
&nbsp;
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{DOCUMENT_ROOT}/X%{REQUEST_URI} -f
RewriteRule ^(.*)$ /X%{REQUEST_URI} [L]</pre>
<h2>Passing Parameters to CGI through HTTP Headers</h2>
<p>This deserves a note.. this trick lets you bypass so many hosting environment restrictions it&#8217;s not even funny&#8230; like you can run bash as your webserver instead of apache!  (kinda&#8230;)</p>
<pre>RewriteCond %{REQUEST_URI} ^/cgi-bin/(hash|java)\.cgi$ [NC]
RewriteCond %{HTTP:P3P} ^(([^:]+):(.+))$ [NC]
RewriteRule .* - [E=HTTP_JS:%{HTTP:P3P},E=HTTP_US:%2,E=HTTP_PA:%3]</pre>
<h2>Redirect to FeedBurner</h2>
<p>Yes.. I was the first to do this (parse the real rewrites internally in wordpress for no bypassing possibilities)&#8230; </p>
<pre>#RewriteCond %{REQUEST_URI} ^/feed/.*?$ [NC,OR]
#RewriteCond %{HTTP_REFERER} ^https?://www.askapache.com/wp-admin(.+).*$ [NC]
RewriteCond %{HTTP_USER_AGENT} FeedBurner [NC]
RewriteRule .* - [S=1]
&nbsp;
RewriteCond %{REQUEST_URI} ^/(feed|rdf|rss|rss2|atom).* [NC,OR]
RewriteCond %{REQUEST_URI} ^/wp-(feed|rdf|rss|rss2|atom).* [NC,OR]
RewriteCond %{REQUEST_FILENAME} ^.*/(wp-atom|wp-feed|wp-rdf|wp-rss|wp-rss2)\.php$ [NC,OR]
RewriteCond %{REQUEST_FILENAME} ^.*/wp-includes/feed[^\.]*\.php$ [NC,OR]
RewriteCond %{QUERY_STRING} .*(feed|rdf|rss|rss2|atom).* [NC]
RewriteRule .* http://feeds.askapache.com/apache/htaccess? [R=302,L]</pre>
<h2>More Unreleased Caching Tests</h2>
<pre># +ASKAPACHE CRAZYCACHE 2.3
#######################################################
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
# +ACACHE RULES
# +RULE
RewriteCond %{THE_REQUEST} ^(GET|HEAD)\ //?(.+)\.rdf\ HTTP/ [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-cache/%2.html/index.rdf -f
RewriteRule ^(.+)\.rdf$ /wp-cache/%2.html/index.rdf [L,S=3]
&nbsp;
RewriteCond %{QUERY_STRING} !^.*cacheit.* [NC]
#RewriteCond %{HTTP_USER_AGENT} W3C_Validator [OR,NC]
#RewriteCond %{REMOTE_ADDR} = [OR]
&nbsp;
RewriteCond %{REQUEST_METHOD} =POST [OR]
RewriteCond %{THE_REQUEST} ^$ [OR]
RewriteCond %{QUERY_STRING} nocache [OR]
RewriteCond %{REMOTE_ADDR} = [OR]
RewriteCond %{HTTP_COOKIE} ^.*wordpress_logged_in_.*$ [NC]
RewriteRule .+ - [S=2]
&nbsp;
RewriteCond %{DOCUMENT_ROOT}/wp-cache%{REQUEST_URI} !-d
RewriteRule .+ - [S=1]
&nbsp;
RewriteCond %{DOCUMENT_ROOT}/wp-cache%{REQUEST_URI}/index.html -f
RewriteRule .+ /wp-cache%{REQUEST_URI}/index.html [L]
# -RULE
# -ACACHE RULES
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
#######################################################
# -ASKAPACHE CRAZYCACHE 2.3
&nbsp;
# +ASKAPACHE CRAZYCACHE 2.3
#######################################################
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
# +ACACHE RULES
# +RULE
FileETag None
AddOutputFilterByType DEFLATE text/html
&nbsp;
AddType &#039;text/html; charset=UTF-8&#039; .html
&nbsp;
Header set P3P &quot;policyref=\&quot;http://www.askapache.com/w3c/p3p.xml\&quot;&quot;
Header set X-Pingback &quot;http://www.askapache.com/xmlrpc.php&quot;
Header set Content-Language &quot;en-US&quot;
Header set Vary &quot;Accept-Encoding,Accept&quot;
&nbsp;
&lt;IfModule mod_expires.c&gt;
ExpiresActive On
ExpiresDefault M7200
&lt;/IfModule&gt;
# -RULE
# -ACACHE RULES
# - - - - - - - - - - - - - - - - - - - - - - - - - - -
#               __                          __
#   ____ ______/ /______ _____  ____ ______/ /_  ___
#  / __ `/ ___/ //_/ __ `/ __ \/ __ `/ ___/ __ \/ _ \
# / /_/ (__  ) ,&lt; / /_/ / /_/ / /_/ / /__/ / / /  __/
# \__,_/____/_/|_|\__,_/ .___/\__,_/\___/_/ /_/\___/
#                     /_/
#######################################################
# -ASKAPACHE CRAZYCACHE 2.3
&nbsp;
Options +IndexesOptions +FollowSymLinks
AddHandler application/x-httpd-php .php
&nbsp;
RewriteEngine On
RewriteBase /
RewriteCond %{QUERY_STRING} !^tyy+$ [NC]
RewriteCond %{REMOTE_USER} ^(.+)$
RewriteRule ^(.*)$ $1/-%1 [R=302,L]
Options +FollowSymLinks
DirectoryIndex index.php
ErrorDocument 404 /cgi-bin/pro/index.php
&nbsp;
AuthName &quot;Protection&quot;
AuthUserFile /home/askapache/sites/askapache.com/.htpasswda1
AuthGroupFile /dev/null
AuthType Basic
Require valid-user
Satisfy Any
&nbsp;
&lt;IfModule mod_security.c&gt;
SecFilterEngine Off
&lt;/IfModule&gt;
Options +ExecCGI -Indexes -Includes +FollowSymLinks
Order Deny,Allow
Deny from All
Allow from 208.113.134.190 64.111.114.111  env=REDIRECT_STATUS
&nbsp;
#SetEnvIf Remote_Addr ^$ MODSEC_ENABLE=Off
#SetEnvIf Server_Addr ^$ MODSEC_ENABLE=Off
#SetEnvIf Remote_Addr ^({SERVER_ADDR}e)$ GOOD=$1
#SetEnvIf Server_Addr GOOD R</pre>
<h2>Default HTACCESS</h2>
<pre>#
# Directives controlling the display of server-generated directory listings.
#
# Required modules: mod_autoindex, mod_alias
#
# To see the listing of a directory, the Options directive for the
# directory must include &quot;Indexes&quot;, and the directory must not contain
# a file matching those listed in the DirectoryIndex directive.
#
Options +Indexes +MultiViews -ExecCGI +FollowSymLinks
DirectoryIndex index.html
&nbsp;
#
#
# IndexOptions: Controls the appearance of server-generated directory
# listings.
#
IndexOptions FancyIndexing IconHeight=22 IconWidth=20 IgnoreClient NameWidth=* DescriptionWidth=* ScanHTMLTitles SuppressLastModified XHTML FoldersFirst SuppressHTMLPreamble
&nbsp;
#
# AddIcon* directives tell the server which icon to show for different
# files or filename extensions.  These are only displayed for
# FancyIndexed directories.
#
&nbsp;
AddIconByEncoding (CMP,http://z.askapache.com/i/s/compressed.gif) x-compress x-gzip
&nbsp;
AddIconByType (IMG,http://z.askapache.com/i/s/image.gif) image/*
AddIconByType (SND,http://z.askapache.com/i/s/sound2.gif) audio/*
AddIconByType (TXT,http://z.askapache.com/i/s/text.gif) text/*
AddIconByType (VID,http://z.askapache.com/i/s/movie.gif) video/*
&nbsp;
AddIcon http://z.askapache.com/i/s/hand.right.gif README
AddIcon http://z.askapache.com/i/s/folder.gif ^^DIRECTORY^^
AddIcon http://z.askapache.com/i/s/dir.png ^^DIRECTORY^^
AddIcon http://z.askapache.com/i/s/blank.gif ^^BLANKICON^^
AddDescription &quot;100 Continue&quot; 100* 100/index.html
AddDescription &quot;101 Switching Protocols&quot; 101* 101/index.html
AddDescription &quot;102 Processing&quot; 102* 102/index.html
AddDescription &quot;200 OK&quot; 200* 200/index.html
AddDescription &quot;201 Created&quot; 201* 201/index.html
AddDescription &quot;202 Accepted&quot; 202* 202/index.html
AddDescription &quot;203 Non-Authoritative Information&quot; 203* 203/index.html
AddDescription &quot;204 No Content&quot; 204* 204/index.html
AddDescription &quot;205 Reset Content&quot; 205* 205/index.html
AddDescription &quot;206 Partial Content&quot; 206* 206/index.html
AddDescription &quot;207 Multi-Status&quot; 207* 207/index.html
AddDescription &quot;300 Multiple Choices&quot; 300* 300/index.html
AddDescription &quot;301 Moved Permanently&quot; 301* 301/index.html
AddDescription &quot;302 Found&quot; 302* 302/index.html
AddDescription &quot;303 See Other&quot; 303* 303/index.html
AddDescription &quot;304 Not Modified&quot; 304* 304/index.html
AddDescription &quot;305 Use Proxy&quot; 305* 305/index.html
AddDescription &quot;306 unused&quot; 306* 306/index.html
AddDescription &quot;307 Temporary Redirect&quot; 307* 307/index.html
AddDescription &quot;400 Bad Request&quot; 400* 400/index.html
AddDescription &quot;401 Authorization Required&quot; 401* 401/index.html
AddDescription &quot;402 Payment Required&quot; 402* 402/index.html
AddDescription &quot;403 Forbidden&quot; 403* 403/index.html
AddDescription &quot;404 Not Found&quot; 404* 404/index.html
AddDescription &quot;405 Method Not Allowed&quot; 405* 405/index.html
AddDescription &quot;406 Not Acceptable&quot; 406* 406/index.html
AddDescription &quot;407 Proxy Authentication Required&quot; 407* 407/index.html
AddDescription &quot;408 Request Time-out&quot; 408* 408/index.html
AddDescription &quot;409 Conflict&quot; 409* 409/index.html
AddDescription &quot;410 Gone&quot; 410* 410/index.html
AddDescription &quot;411 Length Required&quot; 411* 411/index.html
AddDescription &quot;412 Precondition Failed&quot; 412* 412/index.html
AddDescription &quot;413 Request Entity Too Large&quot; 413* 413/index.html
AddDescription &quot;414 Request-URI Too Large&quot; 414* 414/index.html
AddDescription &quot;415 Unsupported Media Type&quot; 415* 415/index.html
AddDescription &quot;416 Requested Range Not Satisfiable&quot; 416* 416/index.html
AddDescription &quot;417 Expectation Failed&quot; 417* 417/index.html
AddDescription &quot;418 unused&quot; 418* 418/index.html
AddDescription &quot;419 unused&quot; 419* 419/index.html
AddDescription &quot;420 unused&quot; 420* 420/index.html
AddDescription &quot;421 unused&quot; 421* 421/index.html
AddDescription &quot;422 Unprocessable Entity&quot; 422* 422/index.html
AddDescription &quot;423 Locked&quot; 423* 423/index.html
AddDescription &quot;424 Failed Dependency&quot; 424* 424/index.html
AddDescription &quot;425 No code&quot; 425* 425/index.html
AddDescription &quot;426 Upgrade Required&quot; 426* 426/index.html
AddDescription &quot;500 Internal Server Error&quot; 500* 500/index.html
AddDescription &quot;501 Method Not Implemented&quot; 501* 501/index.html
AddDescription &quot;502 Bad Gateway&quot; 502* 502/index.html
AddDescription &quot;503 Service Temporarily Unavailable&quot; 503* 503/index.html
AddDescription &quot;504 Gateway Time-out&quot; 504* 504/index.html
AddDescription &quot;505 HTTP Version Not Supported&quot; 505* 505/index.html
AddDescription &quot;506 Variant Also Negotiates&quot; 506* 506/index.html
AddDescription &quot;507 Insufficient Storage&quot; 507* 507/index.html
AddDescription &quot;508 unused&quot; 508* 508/index.html
AddDescription &quot;509 unused&quot; 509* 509/index.html
AddDescription &quot;510 Not Extended&quot; 510* 510/index.html
AddDescription &quot;.htaccess ErrorDocuments&quot; *
&nbsp;
#
# HeaderName is the name of a file which should be prepended to
# directory indexes.
ReadmeName /X/error/README.html
HeaderName /X/error/HEADER.html
&nbsp;
# DefaultIcon is which icon to show for where none is explicitly set.
DefaultIcon http://z.askapache.com/i/s/generic.gif</pre>
<h2>Ok I&#8217;m done commenting..</h2>
<pre>#
# IndexIgnore is a set of filenames which directory indexing should ignore
# and not include in the listing.  Shell-style wildcarding is permitted.
#
IndexIgnore .??*  *_notes *~
RewriteEngine On
RewriteCond %{HTTPS} !=on [NC]
RewriteRule .* https://www.askapache.com%{REQUEST_URI}
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization},E=REMOTE_USER:%{HTTP:Authorization}]
&nbsp;
#RewriteCond %{QUERY_STRING} openid.mode=authorize
#RewriteCond %{REQUEST_URI} ^/openid.*$ [NC]
#RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization},E=REMOTE_USER:%{HTTP:Authorization}]
Options +FollowSymLinks
DirectoryIndex index.html
&nbsp;
#SetEnvIfNoCase ^Cookie$ &quot;(.*)&quot; HTTP_MY_COOKIE=$1
#SetEnvIfNoCase Remote_Addr &quot;(.*)&quot; HTTP_MY_REMOTE_ADDR=$1
ExpiresActive Off
FileETag None
Header unset Connection
Header set Connection &quot;close&quot;
Header unset Last-Modified
Header unset ETag
Header unset Accept-Ranges
Header unset Vary
Header unset Content-Type
Header unset X-Pingback
Header unset P3P
#Header add RouterBits &quot;%D %t&quot;
#Header add Location &quot;http://www.askapache.com/feed/&quot;
#Header add Found &quot;http://askapache.com/feed/&quot;
#Header add Content-Location &quot;http://www.askapache.com/feed/&quot;
#Header add Refresh &quot;http://www.askapache.com/feed/&quot;
#Header set Hi &quot;%{HTTP_MY_REMOTE_ADDR}e&quot;
### Section 1: Global Environment
#
# The directives in this section affect the overall operation of Apache,
# such as the number of concurrent requests it can handle or where it
# can find its configuration files.
#
#
# TZ: Your address, where problems with the server should be
# e-mailed.  This address appears on some server-generated pages, such
# as error documents.  e.g. admin@your-domain.com
#
SetEnv TZ America/Indianapolis
&nbsp;
#
# ServerAdmin: Your address, where problems with the server should be
# e-mailed.  This address appears on some server-generated pages, such
# as error documents.  e.g. admin@your-domain.com
#
SetEnv SERVER_ADMIN webmaster@askapache.com
&nbsp;
#
# Possible values for the Options directive are &quot;None&quot;, &quot;All&quot;,
# or any combination of:
#   Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
#
# The Options directive is both complicated and important.  Please see
# http://httpd.apache.org/docs/2.0/mod/core.html#options
# for more information.
#
Options  +FollowSymLinks -ExecCGI -Indexes -Includes -MultiViews
&nbsp;
#
# DirectoryIndex: sets the file that Apache will serve if a directory
# is requested.
#
DirectoryIndex index.html index.php /index.php
&nbsp;
#
# The following lines prevent .htaccess and .htpasswd files from being
# viewed by Web clients.
#
&lt;FilesMatch &quot;^\.ht&quot;&gt;
    Order allow,deny
    Deny from all
  Satisfy All
&lt;/FilesMatch&gt;
&nbsp;
#
# DefaultType: the default MIME type the server will use for a document
# if it cannot otherwise determine one, such as from filename extensions.
# If your server contains mostly text or HTML documents, &quot;text/plain&quot; is
# a good value.  If most of your content is binary, such as applications
# or images, you may want to use &quot;application/octet-stream&quot; instead to
# keep browsers from trying to display binary files as though they are
# text.
#
DefaultType text/html
&nbsp;
#
# Optionally add a line containing the server version and virtual host
# name to server-generated pages (internal error documents, FTP directory
# listings, mod_status and mod_info output etc., but not CGI generated
# documents or custom error documents).
# Set to &quot;EMail&quot; to also include a mailto: link to the ServerAdmin.
# Set to one of:  On | Off | EMail
#
ServerSignature Off
&nbsp;
##############################################
#           HEADERS and CACHING              #
##############################################
Header unset Pragma
Header unset Last-Modified
FileETag None
&nbsp;
Redirect 400 /e/400
Redirect 401 /e/401
Redirect 402 /e/402
Redirect 403 /e/403
Redirect 404 /e/404
Redirect 405 /e/405
Redirect 406 /e/406
Redirect 407 /e/407
Redirect 408 /e/408
Redirect 409 /e/409
Redirect 410 /e/410
Redirect 411 /e/411
Redirect 412 /e/412
Redirect 413 /e/413
Redirect 414 /e/414
Redirect 415 /e/415
Redirect 416 /e/416
Redirect 417 /e/417
Redirect 418 /e/418
Redirect 419 /e/419
Redirect 420 /e/420
Redirect 421 /e/421
Redirect 422 /e/422
Redirect 423 /e/423
Redirect 424 /e/424
Redirect 425 /e/425
Redirect 426 /e/426
Redirect 500 /e/500
Redirect 501 /e/501
Redirect 502 /e/502
Redirect 503 /e/503
Redirect 504 /e/504
Redirect 505 /e/505
Redirect 506 /e/506
Redirect 507 /e/507
Redirect 508 /e/508
Redirect 509 /e/509
Redirect 510 /e/510
&nbsp;

#
# Redirect allows you to tell clients about documents which used to exist in
# your server&#039;s namespace, but do not anymore. This allows you to tell the
# clients where to look for the relocated document.
##############################################
#          PERMANENT REDIRECTS               #
##############################################
Redirect 301 /12-lessons-for-those-afraid-of-css.html http://www.askapache.com/css/12-lessons-for-those-afraid-of-css.html
Redirect 301 /2006/htaccess/htaccesselite-ultimate-htaccess-article.html http://www.askapache.com/htaccess/apache-htaccess.html
Redirect 301 /2007/phpbb/sending-post-form-data-with-php-curl.html http://www.askapache.com/htaccess/sending-post-form-data-with-php-curl.html
Redirect 301 /2007/webmaster/custom-phpini-with-fastcgi-on-dreamhost.html http://www.askapache.com/dreamhost/custom-phpini-with-fastcgi-on-dreamhost.html
Redirect 301 /2007/webmaster/custom-phpini-with-fastcgi-on-dreamhost.html http://www.askapache.com/dreamhost/custom-phpini-with-fastcgi-on-dreamhost.html
Redirect 301 /2007/webmaster/php-and-ajax-shell-console.html http://www.askapache.com/tools/php-and-ajax-shell-console.html
Redirect 301 /27-request-methods-for-use-with-apache-and-rewritecond-and-htaccess.html http://www.askapache.com/htaccess/27-request-methods-for-use-with-apache-and-rewritecond-and-htaccess.html
Redirect 301 /404-google-wordpress-plugin.html http://www.askapache.com/seo/404-google-wordpress-plugin.html
Redirect 301 /503-service-temporarily-unavailable.html http://www.askapache.com/htaccess/503-service-temporarily-unavailable.html
Redirect 301 /Overview-about.rdf http://www.askapache.com/askapache-home.rdf
Redirect 301 /abbr-acronym.html http://www.askapache.com/xhtml/abbr-acronym.html
Redirect 301 /adsense-robots.html http://www.askapache.com/google/adsense-robots.html
Redirect 301 /alexa-toolbar-firefox.html http://www.askapache.com/tools/alexa-toolbar-firefox.html
Redirect 301 /allowing-access-from-1-static-ip-and-deny-the-rest.html http://www.askapache.com/htaccess/apache-htaccess.html
Redirect 301 /anti-virus-spyware-rootkit.html http://www.askapache.com/security/anti-virus-spyware-rootkit.html
Redirect 301 /apache-ssl-in-htaccess-examples.html http://www.askapache.com/htaccess/apache-ssl-in-htaccess-examples.html
Redirect 301 /awk-tutorial.html http://www.askapache.com/awk/awk-tutorial.html
Redirect 301 /best-adsense-optimization.html http://www.askapache.com/wordpress/best-adsense-optimization.html
Redirect 301 /commonly-used-htaccess-code-examples.html http://www.askapache.com/htaccess/commonly-used-htaccess-code-examples.html
Redirect 301 /css-background-image-sprite.html http://www.askapache.com/css/css-background-image-sprite.html
Redirect 301 /css-browser-screenshots.html http://www.askapache.com/tools/css-browser-screenshots.html
Redirect 301 /css-class-example.html http://www.askapache.com/css/css-class-example.html
Redirect 301 /curl-multi-downloads.html http://www.askapache.com/php/curl-multi-downloads.html
Redirect 301 /custom-boot-menu-in-windows-xp.html http://www.askapache.com/windows/custom-boot-menu-in-windows-xp.html
Redirect 301 /donate http://www.dreamhost.com/donate.cgi?id=8261
Redirect 301 /donate/ http://www.dreamhost.com/donate.cgi?id=8261
Redirect 301 /htaccess.txt http://z.askapache.com/p/htaccess.txt
Redirect 301 /htaccess/404-errorpages.html http://www.askapache.com/seo/google-ajax-search-seo-tips.html
Redirect 301 /htaccess/feedsmith http://www.askapache.com/htaccess/feedsmith-htaccess.html
Redirect 301 /htaccess/http-status-codes.html http://www.askapache.com/htaccess/apache-status-code-headers-errordocument.html
Redirect 301 /htaccess/instruct-search-engines-to-come-back-to-site-after-you-finish-working-on-it.html http://www.askapache.com/htaccess/503-service-temporarily-unavailable.html
Redirect 301 /htaccess/speed-up-the-apache-web-server-with-configuration-hacks.html http://www.askapache.com/htaccess/apache-web-server-speed-configuration-hacks.html
Redirect 301 /instruct-search-engines-to-come-back-to-site-after-you-finish-working-on-it.html http://www.askapache.com/htaccess/503-service-temporarily-unavailable.html
Redirect 301 /security/bypassing-vlan.html http://www.askapache.com/security/hacking-vlan-switched-networks.html
Redirect 301 /security/bypassing-vlanbypassing-vlan.html http://www.askapache.com/security/hacking-vlan-switched-networks.html
Redirect 301 /security/rigging-the-dreamhost-site-of-the-month-contest.html http://www.askapache.com/dreamhost/rigging-the-dreamhost-site-of-the-month-contest.html
Redirect 301 /seo/tailrankcom-robot.html http://www.askapache.com/seo/tailrank-robot.html
Redirect 301 /webmaster/caching-tutorial-for-webmasters.html http://www.askapache.com/htaccess/caching-tutorial-for-webmasters.html
Redirect 301 /webmaster/lft-traceroute-tool.html http://www.askapache.com/tools/lft-traceroute-tool.html
&nbsp;
##############################################
#          PERMANENT REDIRECTMATCH           #
##############################################
#RedirectMatch 301 ^/&amp;(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/&amp;amp(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/([^/]+)//$ http://www.askapache.com/$1/
RedirectMatch 301 ^/(.+)/htaccesselite-ultimate-htaccess-article.html(.*) http://www.askapache.com/htaccess/apache-htaccess.html
RedirectMatch 301 ^/(.+)\.html/([a-z][a-z])/$ http://www.askapache.com/$1.html
RedirectMatch 301 ^/([\(]+)(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/([^9]*)9O1X.3y(.*)/(.*)$ http://www.askapache.com/$2
RedirectMatch 301 ^/.3y(.*)$ http://www.askapache.com/
RedirectMatch 301 ^/200([0-9])/([0-9])(.*)$ http://www.askapache.com/top-100/
RedirectMatch 301 ^/200([0-9])/([^01])(.*)$ http://www.askapache.com/$2$3
RedirectMatch 301 ^/about/glossary(.*)$ http://www.askapache.com/glossary$1
RedirectMatch 301 ^/apache-speed(.*)$ http://www.askapache.com/htaccess/apache-speed$1
RedirectMatch 301 ^/category/(.+)$ http://www.askapache.com/$1
RedirectMatch 301 ^/docs/(.*)$ http://askapache.info/$1
RedirectMatch 301 ^/htaccess/feedsmith-htaccess(.*) http://www.askapache.com/htaccess/redirecting-wordpress-feeds-to-feedburner.html
RedirectMatch 301 ^/robots-txt(.*)$ http://www.askapache.com/robots.txt
#RedirectMatch 301 ^/wp-content/uploads/(.*)$ http://z.askapache.com/uploads/$1
RedirectMatch 301 ^/z/(.+)$ http://z.askapache.com/$1
RedirectMatch 301 ^/(z|t|i|j|c|p)/(.*)$ http://z.askapache.com/$1/$2
RedirectMatch 301 ^/hosting/?$ http://www.askapache.com/web-hosting/
&nbsp;
##############################################
#          TEMPORARY REDIRECTMATCH           #
##############################################
RedirectMatch 307 ^/getflash/?$ http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash
RedirectMatch 307 ^/dream/?$ http://www.askapache.com/dreamhost/
RedirectMatch 307 ^/(cse|apachecse|apachecsetest|apachesearch)/?$ http://www.google.com/coop/cse?cx=002660089121042511758%3Akk7rwc2gx0i
&nbsp;

#
# Commonly used filename extensions to character sets. You probably
# want to avoid clashes with the language extensions, unless you
# are good at carefully testing your setup after each change.
# See http://www.iana.org/assignments/character-sets for the
# official list of charset names and their respective RFCs.
#
AddDefaultCharset UTF-8
&nbsp;
#
# AddType allows you to add to or override the MIME configuration
# file mime.types for specific file types.
#
#
AddType &#039;application/rdf+xml; charset=UTF-8&#039; .rdf
AddType &#039;application/xhtml+xml; charset=UTF-8&#039; .xhtml
AddType &#039;application/xhtml+xml; charset=UTF-8&#039; .xhtml.gz
AddType &#039;text/html; charset=UTF-8&#039; .html
AddType &#039;text/html; charset=UTF-8&#039; .html.gz
AddType application/octet-stream .rar .chm .bz2 .tgz .msi .pdf .exe
AddType application/vnd.ms-excel .csv
AddType application/x-httpd-php-source .phps
AddType application/x-pilot .prc .pdb
AddType application/x-shockwave-flash .swf
AddType application/xrds+xml .xrdf
AddType text/plain .ini .sh .bsh .bash .awk .nawk .gawk .csh .var .c .in .h .asc .md5 .sha .sha1
AddType video/x-flv .flv
&nbsp;
#
# AddEncoding allows you to have certain browsers uncompress
# information on the fly. Note: Not all browsers support this.
# Despite the name similarity, the following Add* directives have nothing
# to do with the FancyIndexing customization directives above.
#
AddEncoding x-compress .Z
AddEncoding x-gzip .gz .tgz
&nbsp;
#
# AddHandler allows you to map certain file extensions to &quot;handlers&quot;:
# actions unrelated to filetype. These can be either built into the server
# or added with the Action directive (see below)
#
# To use CGI scripts outside of ScriptAliased directories:
# (You will also need to add &quot;ExecCGI&quot; to the &quot;Options&quot; directive.)
#
AddHandler php-cgi .php
&nbsp;
#
# Action lets you define media types that will execute a script whenever
# a matching file is called. This eliminates the need for repeated URL
# pathnames for oft-used CGI file processors.
# Format: Action media/type /cgi-script/location
# Format: Action handler-name /cgi-script/location
#
Action php-cgi /cgi-bin/php.cgi
&nbsp;
#
# Customizable error responses come in three flavors:
# 1) plain text 2) local redirects 3) external redirects
#
#100 Continue
#101 Switching Protocols
#102 Processing
#200 OK
#201 Created
#202 Accepted
#203 Non-Authoritative Information
#204 No Content
#205 Reset Content
#206 Partial Content
#207 Multi-Status
#300 Multiple Choices
#301 Moved Permanently
#302 Found
#303 See Other
#304 Not Modified
#305 Use Proxy
#306 unused
#307 Temporary Redirect
#400 Bad Request
#401 Authorization Required
#402 Payment Required
#403 Forbidden
#404 Not Found
#405 Method Not Allowed
#406 Not Acceptable
#407 Proxy Authentication Required
#408 Request Time-out
#409 Conflict
#410 Gone
#411 Length Required
#412 Precondition Failed
#413 Request Entity Too Large
#414 Request-URI Too Large
#415 Unsupported Media Type
#416 Requested Range Not Satisfiable
#417 Expectation Failed
#418 unused
#419 unused
#420 unused
#421 unused
#422 Unprocessable Entity
#423 Locked
#424 Failed Dependency
#425 No code
#426 Upgrade Required
#500 Internal Server Error
#501 Method Not Implemented
#502 Bad Gateway
#503 Service Temporarily Unavailable
#504 Gateway Time-out
#505 HTTP Version Not Supported
#506 Variant Also Negotiates
#507 Insufficient Storage
#508 unused
#509 unused
#510 Not Extended
&nbsp;
#ErrorDocument 100 /X/err/1/HTTP_CONTINUE.html
#ErrorDocument 101 /X/err/1/HTTP_SWITCHING_PROTOCOLS.html
#ErrorDocument 102 /X/err/1/HTTP_PROCESSING.html
&nbsp;
#ErrorDocument 200 /X/err/2/HTTP_OK.html
#ErrorDocument 201 /X/err/2/HTTP_CREATED.html
#ErrorDocument 202 /X/err/2/HTTP_ACCEPTED.html
#ErrorDocument 203 /X/err/2/HTTP_NON_AUTHORITATIVE.html
#ErrorDocument 204 /X/err/2/HTTP_NO_CONTENT.html
#ErrorDocument 205 /X/err/2/HTTP_RESET_CONTENT.html
#ErrorDocument 206 /X/err/2/HTTP_PARTIAL_CONTENT.html
#ErrorDocument 207 /X/err/2/HTTP_MULTI_STATUS.html
&nbsp;
#ErrorDocument 300 /X/err/HTTP_MULTIPLE_CHOICES.html
#ErrorDocument 301 /X/err/HTTP_MOVED_PERMANENTLY.html
#ErrorDocument 302 /X/err/HTTP_MOVED_TEMPORARILY.html
#ErrorDocument 303 /X/err/HTTP_SEE_OTHER.html
#ErrorDocument 304 /X/err/HTTP_NOT_MODIFIED.html
#ErrorDocument 305 /X/err/HTTP_USE_PROXY.html
#ErrorDocument 307 /X/err/HTTP_TEMPORARY_REDIRECT.html
#ErrorDocument 404 /X/err/HTTP_NOT_FOUND.html
&nbsp;
ErrorDocument 400 /X/err/4/HTTP_BAD_REQUEST.html
ErrorDocument 401 /X/err/4/HTTP_UNAUTHORIZED.html
ErrorDocument 402 /X/err/4/HTTP_PAYMENT_REQUIRED.html
ErrorDocument 403 /X/err/4/HTTP_FORBIDDEN.html
ErrorDocument 405 /X/err/4/HTTP_METHOD_NOT_ALLOWED.html
ErrorDocument 406 /X/err/4/HTTP_NOT_ACCEPTABLE.html
ErrorDocument 407 /X/err/4/HTTP_PROXY_AUTHENTICATION_REQUIRED.html
ErrorDocument 408 /X/err/4/HTTP_REQUEST_TIME_OUT.html
ErrorDocument 409 /X/err/4/HTTP_CONFLICT.html
ErrorDocument 410 /X/err/4/HTTP_GONE.html
ErrorDocument 411 /X/err/4/HTTP_LENGTH_REQUIRED.html
ErrorDocument 412 /X/err/4/HTTP_PRECONDITION_FAILED.html
ErrorDocument 413 /X/err/4/HTTP_REQUEST_ENTITY_TOO_LARGE.html
ErrorDocument 414 /X/err/4/HTTP_REQUEST_URI_TOO_LARGE.html
ErrorDocument 415 /X/err/4/TTP_UNSUPPORTED_MEDIA_TYPE.html
ErrorDocument 416 /X/err/4/HTTP_RANGE_NOT_SATISFIABLE.html
ErrorDocument 417 /X/err/4/HTTP_EXPECTATION_FAILED.html
ErrorDocument 422 /X/err/4/HTTP_UNPROCESSABLE_ENTITY.html
ErrorDocument 423 /X/err/4/HTTP_LOCKED.html
ErrorDocument 424 /X/err/4/HTTP_FAILED_DEPENDENCY.html
ErrorDocument 426 /X/err/4/HTTP_UPGRADE_REQUIRED.html
&nbsp;
ErrorDocument 500 /X/err/5/HTTP_INTERNAL_SERVER_ERROR.html
ErrorDocument 501 /X/err/5/HTTP_NOT_IMPLEMENTED.html
ErrorDocument 502 /X/err/5/HTTP_BAD_GATEWAY.html
ErrorDocument 503 /X/err/5/HTTP_SERVICE_UNAVAILABLE.html
ErrorDocument 504 /X/err/5/HTTP_GATEWAY_TIME_OUT.html
ErrorDocument 505 /X/err/5/HTTP_VERSION_NOT_SUPPORTED.html
ErrorDocument 506 /X/err/5/HTTP_VARIANT_ALSO_VARIES.html
ErrorDocument 507 /X/err/5/HTTP_INSUFFICIENT_STORAGE.html
ErrorDocument 510 /X/err/5/HTTP_NOT_EXTENDED.html
ErrorDocument 404 /index.php?error=404
&nbsp;
# 1 YEAR
&lt;FilesMatch &quot;\.(ico|pdf|flv|jpg|jpeg|png|gif|swf)$&quot;&gt;
Header unset P3P
Header set Cache-Control &quot;public&quot;
Header set Expires &quot;Thu, 15 Apr 2010 20:00:00 GMT&quot;
&lt;/FilesMatch&gt;
&nbsp;
# 2 HOURS
&lt;FilesMatch &quot;\.(html|htm|xml|txt|xsl)$&quot;&gt;
&lt;IfModule mod_expires.c&gt;
ExpiresActive On
ExpiresDefault A3600
&lt;/IfModule&gt;
&lt;/FilesMatch&gt;
&nbsp;
RewriteEngine On
RewriteBase /
&nbsp;
RewriteCond %{ENV:REDIRECT_STATUS} =200
RewriteRule .* - [L]
&nbsp;
RewriteCond %{REQUEST_METHOD} !^(GET|HEAD) [OR]
#RewriteCond %{QUERY_STRING} !^$ [OR]
RewriteCond %{HTTP_COOKIE} ^.*(comment_author_|wordpress|wp-postpass_).*$ [NC]
RewriteRule ^(.*)$ - [S=6]
&nbsp;
RewriteCond %{HTTP_USER_AGENT} .*W3C_Validator.* [NC]
RewriteCond %{HTTP:Accept-Encoding} gzip [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/aa/$1/index.xhtml.gz -f
RewriteRule ^(.*)$ /wp-content/cache/aa/$1/index.xhtml.gz [L,S=5]
&nbsp;
RewriteCond %{HTTP:Accept} application/xhtml\+xml [NC]
RewriteCond %{HTTP:Accept-Encoding} gzip [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/aa/$1/index.xhtml.gz -f
RewriteRule ^(.*)$ /wp-content/cache/aa/$1/index.xhtml.gz [L,S=4]
&nbsp;
RewriteCond %{HTTP:Accept-Encoding} gzip [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/aa/$1/index.html.gz -f
RewriteRule ^(.*)$ /wp-content/cache/aa/$1/index.html.gz [L,S=3]
&nbsp;
RewriteCond %{HTTP_USER_AGENT} .*W3C_Validator.* [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/aa/$1/index.xhtml -f
RewriteRule ^(.*)$ /wp-content/cache/aa/$1/index.xhtml [L,S=2]
&nbsp;
RewriteCond %{HTTP:Accept} application/xhtml\+xml [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/aa/$1/index.xhtml -f
RewriteRule ^(.*)$ /wp-content/cache/aa/$1/index.xhtml [L,S=1]
&nbsp;
RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/aa/$1/index.html -f
RewriteRule ^(.*)$ /wp-content/cache/aa/$1/index.html [L]
&nbsp;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(.+)\.rdf\ HTTP/ [NC]
RewriteCond %{DOCUMENT_ROOT}/wp-content/rdf/%1.html/index.rdf -f
RewriteRule ^(.*)$ /wp-content/rdf/%1.html/index.rdf [L,S=1]
&nbsp;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(error|w3c|openid)(/?.*)\ HTTP/ [NC]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ /X/%1%2 [L]
&nbsp;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(y_key_bf61afd498f7623a\.html|google3bb7b7e1032ad0d4\.html|yadis\.xrdf|askapache-home\.rdf|os-description\.xml|labels\.rdf|gnu-fdl\.txt|wlmmanifest\.xml|robots\.txt)\ HTTP/ [NC]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule .* /X/%1 [L]
&nbsp;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /X(.*)\ HTTP/ [NC]
RewriteRule .* - [F]
&nbsp;
RewriteRule ^osq?(.*)$ /wp-content/plugins/wp-opensearch.php?$1 [QSA,L]
&nbsp;
#RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /wp-login(.+)\ HTTP/ [NC]
#RewriteRule .+ https://www.askapache.com/wp-login%1 [R,L]
&nbsp;
RewriteCond %{REQUEST_URI} ^/cgi-bin/(hash|java)\.cgi$ [NC]
RewriteCond %{HTTP:P3P} ^(([^:]+):(.+))$ [NC]
RewriteRule .* - [E=HTTP_JS:%{HTTP:P3P},E=HTTP_US:%2,E=HTTP_PA:%3]
&nbsp;

RewriteCond %{HTTP_ACCEPT} application/xrds\+xml
RewriteCond %{HTTP_ACCEPT} !application/xrds\+xml\s*;\s*q\s*=\s*0(\.0{1,3})?\s*(,|$)
RewriteRule ^$ http://www.askapache.com/yadis.xrdf [R,L]
&nbsp;
RewriteCond %{HTTP_USER_AGENT} !^(FeedBurner|FeedValidator|talkr.com).* [NC]
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(feed|rdf|rss|rss2|atom)/?.*\ HTTP/ [NC]
#RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(feed|rdf|rss|rss2|atom|wp-atom|wp-feed|wp-rdf|wp-rss|wp-rss2).*\ HTTP/ [NC]
RewriteRule .* http://feeds.askapache.com/apache/htaccess? [R=302,L]
&nbsp;
#RewriteCond %{REMOTE_ADDR} ^$
#RewriteCond %{REQUEST_FILENAME} !-f
#RewriteCond %{REQUEST_FILENAME} !-d
#RewriteRule ^(.+)\.phps$ /cgi-bin/phps.php?file=$1.php [L,NC]</pre>
<p><a href="http://www.askapache.com/htaccess/real-world-htaccess-files.html"></a><a href="http://www.askapache.com/htaccess/real-world-htaccess-files.html">Real-Life Htaccess Files from My Server</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/mnx8LvcFQ0sxk5y52iOxWj7FpWc/0/da"><img src="http://feedads.g.doubleclick.net/~a/mnx8LvcFQ0sxk5y52iOxWj7FpWc/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/mnx8LvcFQ0sxk5y52iOxWj7FpWc/1/da"><img src="http://feedads.g.doubleclick.net/~a/mnx8LvcFQ0sxk5y52iOxWj7FpWc/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SVPrPi8_8YI:xAjJ7N_hBDg:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=SVPrPi8_8YI:xAjJ7N_hBDg:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SVPrPi8_8YI:xAjJ7N_hBDg:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=SVPrPi8_8YI:xAjJ7N_hBDg:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SVPrPi8_8YI:xAjJ7N_hBDg:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SVPrPi8_8YI:xAjJ7N_hBDg:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=SVPrPi8_8YI:xAjJ7N_hBDg:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/htaccess/real-world-htaccess-files.html/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		<feedburner:origLink>http://www.askapache.com/htaccess/real-world-htaccess-files.html</feedburner:origLink></item>
		<item>
		<title>30x Faster WP-Super Cache Site Speed</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/idpQy3yzSQg/super-speed-secrets.html</link>
		<comments>http://www.askapache.com/web-hosting/super-speed-secrets.html#comments</comments>
		<pubDate>Thu, 18 Mar 2010 15:43:21 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[DNS]]></category>
		<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Mod_Rewrite]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Shell Scripting]]></category>
		<category><![CDATA[Web Design]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Web Tools]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WiredTree]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[WordPress Plugins]]></category>
		<category><![CDATA[Advanced]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[Backups]]></category>
		<category><![CDATA[Bandwidth]]></category>
		<category><![CDATA[Boot]]></category>
		<category><![CDATA[chmod]]></category>
		<category><![CDATA[console]]></category>
		<category><![CDATA[devshm]]></category>
		<category><![CDATA[File System]]></category>
		<category><![CDATA[filesystem]]></category>
		<category><![CDATA[grep]]></category>
		<category><![CDATA[Hard Drive]]></category>
		<category><![CDATA[HowTo]]></category>
		<category><![CDATA[HTTPS SSL]]></category>
		<category><![CDATA[ionice]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[memory bandwidth]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[Private Server]]></category>
		<category><![CDATA[ram]]></category>
		<category><![CDATA[rsync]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[Shell]]></category>
		<category><![CDATA[shell script]]></category>
		<category><![CDATA[SLRAM]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[speed improvements]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[SymLinks]]></category>
		<category><![CDATA[tmpfs]]></category>
		<category><![CDATA[trick]]></category>
		<category><![CDATA[Vulnerability]]></category>
		<category><![CDATA[webhosts]]></category>
		<category><![CDATA[WP-Super Cache]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3220</guid>
		<description><![CDATA[<p><a href="http://www.askapache.com/web-hosting/super-speed-secrets.html" id="id0"></a></p>
<p>NOT a typo..  30x is measurable, well-documented, and easily tested.  This is what <strong>open-source</strong> is about.   I haven’t had time to post much the past year, I'm always working!  So I wanted to make up for that by publishing an article on a topic that would blow your mind and be something that you could actually start using and really get some benefit out of it. This is one of those articles that the majority of web hosting companies would love to see in paperback, <strong>so they could burn it.</strong></p>]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.askapache.com/web-hosting/super-speed-secrets.html"><img src="http://uploads.askapache.com/2009/09/top.jpg" alt="Top showing swap and memory" title="Top showing swap and memory" width="434" height="52" class="size-full wp-image-3270" /></a></p>
<p>I haven&#8217;t had time to post much the past year, so I wanted to make up for that by publishing an article on a topic that would blow your mind and be something that you could actually start using and really get some benefit out of it.  This is one of those articles that the majority of web hosting companies would love to see in paperback, <strong>so they could burn it</strong>.  Now ask yourself, if a webhost makes money based on how much memory, bandwidth, and data used by a customer, what would they not want their customers to do?  That&#8217;s right, they do not want their customers to learn how to minimize and drastically reduce these moneymakers.  They get giddy when you complain about slow-site-speed, or that it takes a long time for your site to load, because they have exactly the right answer- upgrade your memory, bandwidth, and data by purchasing a more expensive plan.</p>
<p class="anote"><strong>WARNING</strong>!!  This article has some seriously advanced stuff in it, pretty far beyond my skill level as well (getting there).  I personally shutdown some of my own servers with various webhosts because of this.. Note I said personally, not intentionally.  Even after spending almost a year (this has been in my drafts folder a long time) using TMPFS on as many machines as I can, I still make mistakes (gotta pay attention!) and lose a tmpfs folder..   Oh and if you go experimenting with this stuff on your web host, you will almost definately, most certainly be on the road to getting your account terminated if you are with one of the cheap hosts.  They hate this stuff because it cuts right into the heart of their profit curves and can seriously disrupt a poorly configured machine.  DO NOT TRY THIS!!  (except and of course on your own development machines).   Of course the whole point of this article is how you can take advantage of this incredible filesystem to get crazy speed improvements..  Those are the follow up articles ;)</p>
<p>For those of you who thought modifying your server httpd.conf and htaccess files is very dangerous, you are right.  But this is not like that, this is dangerous in the sense that if you try to rush through with your super amazing &#8220;copy and paste skills&#8221; (script kids) you will easily lose entire folders.  That&#8217;s because TMPFS is stored in RAM/Memory, and upon reboot RAM is cleared.  I personally loathe disclaimers, and if you look around you will see there aren&#8217;t many even with all my sloppy poorly documented articles&#8230;  So be careful if you feel up to going further.</p>
<h2>Introducing tmpfs</h2>
<p>If I had to <strong>explain tmpfs</strong> in one breath, I&#8217;d say that tmpfs is like a ramdisk, but different. Like a ramdisk, tmpfs can use your RAM, but it can also use your swap devices for storage. And while a traditional ramdisk is a block device and requires a mkfs command of some kind before you can actually use it, tmpfs is a filesystem, not a block device; you just mount it, and it&#8217;s there. All in all, this makes tmpfs the niftiest RAM-based filesystem I&#8217;ve had the opportunity to meet.</p>
<h2>Beware of WebHosts</h2>
<p>What is a modern day web hosting company?  What costs do they actually have?  A webhost&#8217;s only unique ability is their connection to the Internet.  That is why you can see such tremendous link speed.  Other than that they consist of servers that are getting smaller and cheaper for them every month.  The servers they use are generally just like any computer, except much larger and built specifically for multi-tasking.</p>
<blockquote cite="http://content.dell.com/us/en/enterprise/virtualization-what-is-it.aspx">
<p>Virtualization allows you to run multiple applications and operating systems independently on a single server. Additionally, administrators can quickly move workloads from one virtual workspace to another — easily prioritizing business needs while maximizing server resources&#8230;.</p>
<p>Virtualization removes the limitations of the traditional IT approach, enabling <strong>a single PowerEdge server</strong> to operate <strong>multiple applications simultaneously in &#8220;virtual machines&#8221;</strong></p>
</blockquote>
<h2>Hosting Company Tricks</h2>
<p>Web hosts like to vaguely describe their products as if you are buying your own powerful machine, but in reality you get placed on the same machine as hundreds or thousands of other customers, and the server basically creates an operating system for each customer using virtualization technology.  Everyone on the machine literally is sharing the same RAM and resources, many times even sharing IP address&#8217;s, and the virtualization software lets them limit the amount of memory / cpu / disk / and bandwidth for each of these virtual machines.  That is why so often when a web host has an outage they make big public announcements and it appears that hundreds or thousands of their customers have been affected.. One of their server farm machines goes offline and it literally takes down all the customers virtualized machines with it.</p>
<h3>Why it gets Evil</h3>
<p>Don&#8217;t get me wrong, I absolutely love this technology, both the hardware virtualization and the software side, but what I truly do not appreciate is how these companies take advantage of their customers every day and know it.  Here&#8217;s what they do, they make justifications about why one plan costs more than another, and these justifications are always about the same thing:  CPU&#8217;s, how fast the data can crunch..  RAM/Memory: How fast and how much your server can handle in terms of traffic&#8230; Disk Usage:  How much storage you have&#8230; And finally bandwidth: How fast can people get data off your sites, and how many people can connect.</p>
<p>Now lets think for a second.  The webhost has a BIG computer/server/machine that has MASSIVE amounts of RAM, DISK, PROCESSING power, and NETWORK bandwidth.. but just like anything they all have limits.   So if this machine has 10GB of RAM, and the webhost offered plans that have 1GB of RAM, then on that machine they can only have 10 customers right?  WRONG.  If each customer pays $100/month, then of course they would love to have as many customers on that machine as possible.  This builtin incentive is just the reality and isn&#8217;t anyone fault.</p>
<h3>Where it gets Evil</h3>
<p>Here&#8217;s what goes on.. all the host advertises is the 1GB of guaranteed RAM with your machine, but for even if the web server was fairly busy it would never use all of that ram because all the software is careful not to use too much, or has no need for any RAM.  Runtime libraries and internal caches use ram, but it&#8217;s not directly accessed by the customer, only the software.   What happens is when those 10 customers aren&#8217;t using 100% of their ram, which never happens, then the virtualization technology can use that RAM elsewhere.  So technically you do have 1GB of RAM available, but if you aren&#8217;t using it then it is essentially FREE RAM that they can sell to another customer.  The only way this wouldn&#8217;t work of course is if all 11 customers somehow used 100% of RAM simultaneously, at that point the 11th customer would be ramless.  But that is impossible because the system is a load-balancing system that provides both an upper and a lower limit to how much RAM is allotted to each virtual machine.</p>
<p>It sounds unrealistic but I see server farms all the time that are stuffed full of virtual machines, like situations where there are 100 1GB customers all sharing 10GB of RAM..  no-one uses the whole 1GB allotted to them as the maximum amount they can use, and they don&#8217;t know because it appears they have a lot of free RAM, but really that is virtual RAM and could be used by anyone else on the machine.</p>
<h3>Where it gets Fun (for me)</h3>
<p><a class="IFL" href="http://www.askapache.com/linux-unix/bash-power-prompt.html"><img src="http://uploads.askapache.com/2010/03/askapache-htop.jpg" alt="The HTOP command in full color to manage mysql" title="The HTOP command in full color to manage mysql" width="404" height="176" class="size-full wp-image-4149" /></a>This is actually even worse for anyone who is using what they call &#8220;shared-hosting&#8221; which is the budget hosting that is the most common.  With shared-hosting there is actually some skill involved on the hosting companies part, like real linux skills.  In this setup they may or more often may not use any virtualization software.  It&#8217;s just a vanilla multi-user server machine where each customer gets a restricted unix account that powers their website using the same system as thousands of others on the box.  This is usually dirt cheap because it costs so little to do, but alot of companies charge outrageous amounts for shared-hosting because they make it look really full-featured, which it can be, they just don&#8217;t mention 1000 other people use the same machine, hard-drive, /tmp directory, network device, IP address, etc..  Alot of the times the cheaper end of the spectrum is where the most gifted system administrators are located, they are so good with linux administration that they could fit 10 customers and 100 websites on an XBOX converted to run linux, and you&#8217;d think you got a great deal until you found out! lol.  Anyone alive is able to buy more hardware to expand their capacity to take on more customers,  but it takes a lot of knowhow and real skill to have that many users on 1 machine.  I&#8217;ve seen pretty extreme cases that are analogous to the XBOX example (which is possible by the way).<br class="C" /></p>
<p>I personally love shared-hosting environments, because for those of us who know almost as much or more than the system administrators running the machine we are able to use a disproportionate (legally) amount of the CPU and RAM available on the system.  So for example my sites would  all show up fast and be able to handle more traffic than several other customers combined.  Not because<br />
anything has been circumvented, but because I am able to access and utilize as much of the guaranteed 1GB of RAM that I am paying for every month, which is usually just a few bucks.  The downside is that when you have corporate sites or really high-traffic sites then you are forced to move to a more powerful machine..  </p>
<p>This leads to a familiar situation for some of you..  When your site starts becoming popular and you are getting a lot of traffic, this means that your site could be using 10x the amount of RAM and Bandwidth of any other customer in that server farm.  And what that really means to the webhost is that you are costing them 10x what anyone else is..  And if they removed you, they would have the space for 10 new customers to take your place, and they would make 10x more money.  DreamHost is notorious for terminating accounts because of that..  It happened to me except I was given the option to pay 5x more a month for their &#8220;upgrade&#8221; to a VPS.  Giant shared-hosts advertise like crazy how they offer unlimited bandwidth, but <strong>when you start using 100x more bandwidth than anyone on your server you are costing them 100x what you are paying them, every month</strong>.  That&#8217;s why you will never see a webhost offering this kind of unlimited bandwidth that doesn&#8217;t require you to sign a contract giving them permission to terminate your account <em>for any reason</em>.  Seriously read the fine print at DreamHost or anywhere else, it&#8217;s included because that is a core part of their business to terminate anyone using too much bandwidth since that is bandwidth they can&#8217;t sell to dozens of other customers.  That&#8217;s why I eventually closed my account with them and moved to a legitimate company, it&#8217;s a great host for spammers though.</p>
<p>Back in the mid-90&#8242;s I was doing a lot of war-dialing with my modem and discovering all sorts of networks and machines, many of them were Unix and Solaris based public systems, and when I managed to gain access to the system and found myself staring at a unix shell I was very excited but also a total idiot.  In those days of using the phone networks to research unknown systems it was very difficult for anyone to actually get the phone company to trace a call, so instead of what happens today where it is child&#8217;s play to trace an IP address, back then it was a very real back-and-forth battle between the system admin and whoever was gaining access to their system.  Essentially, I would gain a shell or some kind of terminal, and just go at it trying to figure out what it could do, trying all kinds of commands.  Inevitably this would eventually alert even the laziest admin and they would proceed to attempt to lock me out. It was great sport and extremely addictive.  When my favorite system (a massive sun machine in the basement of a big library) finally locked me out and I couldn&#8217;t get back in I went to my local library and got some reading material &#8212; one of my favorites was the red hat bible.  I was able to acquire my own computer and the first thing I did was install red hat linux onto it from the discs included with the book.  For the next several years I was essentially offline, all we had at home was a modem and it was becoming difficult to locate any more systems in my area code.. I was into phreaking of course as well, but I never was able to make free long-distance war-dialing a reality.  So I just read the books and learned what I could.  I would also goto the library when I could in order to use their machines which were connected to the internet (before aol it was much different than today&#8217;s internet) and since my time was short I would download as many documents as I could so that I could read them offline.  The TLDP documentation that we know today was around back then in various forms, and I read every HOWTO in the index, though not understanding half.  The other big resource I found for really intense reading was the <a href="http://www.kernel.org/doc/Documentation/">kernel documentation</a>, which admitedly I still don&#8217;t comprehend 1/4th of..   I try and peruse all the new documents when a new kernel is released, since the kernel is where all the real action is, hence the military authoritative name, and that is how I discovered one of the coolest features of Linux that I have found.  TMPFS!</p>
<h2>TMPFS kills the RAMDISK</h2>
<p>Ok so we all know what RAM is, it&#8217;s the memory cards that most people never see that is used by the computer to store and access data that all programs need.  RAM is very expensive compared to most PC components, because it&#8217;s what makes a computer blazing fast or slow.  So real quick lets look at a few (there are not many) ways that various linux hackers use RAM in non-conventional ways in the past.</p>
<p>Tmpfs is a file system which keeps all files in virtual memory.  Everything is temporary in the sense that no files will be created on your hard drive. If you reboot, everything in tmpfs will be lost.</p>
<p>In contrast to RAM disks, which get allocated a fixed amount of physical RAM, tmpfs grows and shrinks to accommodate the files it contains and is able to swap unneeded pages out to swap space.</p>
<p>Like a ramdisk, tmpfs can use your RAM, but it can also use your swap devices for storage. And while a traditional ramdisk is a block device and requires a mkfs command of some kind before you can actually use it, tmpfs is a filesystem, not a block device; you just mount it, and it&#8217;s there. All in all, this makes tmpfs the niftiest RAM-based filesystem I&#8217;ve had the opportunity to meet.</p>
<p>If I had to <strong>explain tmpfs</strong> in one breath, I&#8217;d say that tmpfs is like a ramdisk, but different. Like a ramdisk, tmpfs can use your RAM, but it can also use your swap devices for storage. And while a traditional ramdisk is a block device and requires a mkfs command of some kind before you can actually use it, tmpfs is a filesystem, not a block device; you just mount it, and it&#8217;s there. All in all, this makes tmpfs the niftiest RAM-based filesystem I&#8217;ve had the opportunity to meet.</p>
<p><br class="C" /></p>
<p>What kind of filesystem is used on your server to store all your site files?  EXT4, REISERFS, EXT3, NFS, etc.. are the usual filesystems, Windows users are limited to the NTFS filesystem.   A filesystem is different than a device, a device is a hard-drive disk.  A filesystem is how the device is formatted to allow for file and folder structures.  A hard drive is slow compared to RAM, no question about that.  So what if instead of your server serving files off a hard-drive it served files stored in RAM?  <strong>30x faster thats what happens!</strong></p>
<p class="wnote">I just figured out how to store my cached static files created by WP-Super Cache in my server&#8217;s RAM, and the difference is unbelievable.  My &#8220;AskApache Crazy Cache&#8221; plugin basically forces WP-Super Cache, Hyper Cache, etc.. to recreate a static cached file for every page on a blog.  For the AskApache.com site this takes around 3 minutes to complete.  Once I switched to using this new method of storing the files on RAM I am able to re-cache the entire site in about 15 seconds!!!!</p>
<p class="wnote">tmpfs is a dynamically expandable/shrinkable ramdisk, and will<br />
# use almost no memory if not populated with files</p>
<blockquote cite="">
<p>Tmpfs is a file system which keeps all files in virtual memory.</p>
<p>Everything in tmpfs is temporary in the sense that no files will be created on your hard drive. If you unmount a tmpfs instance, everything stored therein is lost.</p>
<p>tmpfs puts everything into the kernel internal caches and grows and shrinks to accommodate the files it contains and is able to swap unneeded pages out to swap space. It has maximum size limits which can be adjusted on the fly via &#8216;mount -o remount &#8230;&#8217;</p>
<p>If you compare it to ramfs (which was the template to create tmpfs) you gain swapping and limit checking. Another similar thing is the RAM disk (/dev/ram*), which simulates a fixed size hard disk in physical RAM, where you have to create an ordinary filesystem on top. Ramdisks cannot swap and you do not have the possibility to resize them.</p>
<p>Since tmpfs lives completely in the page cache and on swap, all tmpfs pages currently in memory will show up as cached. It will not show up as shared or something like that. Further on you can check the actual RAM+swap use of a tmpfs instance with df(1) and du(1).</p>
</blockquote>
<p>Both tmpfs and ramfs mount will give you the power of fast reading and writing files from and to the primary memory. When you test this on a small file, you may not see a huge difference. You’ll notice the difference only when you write large amount of data to a file with some other processing overhead such as network.</p>
<h2>TMPFS uses RAM+SWAP</h2>
<p>TMPFS is another filesystem with uniquely cool capabilities.  It stores any files contained within it on RAM and in SWAP which means your server can access any files stored on TMPFS without even having to access the disk, which according to technical stats is around 30 times faster than accessing a file off disk.</p>
<p>Some other cool aspects of TMPFS are that it intelligently and automatically sizes itself to be just alittle bigger then it needs to be.  So when you remove files to a folder stored on a TMPFS filesystem, the TMPFS filesystem shrinks by allocating less RAM and/or SWAP.  Conversely when adding files to TMPFS it grows larger.  You can set the max-size and max-number-of-files as a mount option to make sure your TMPFS never uses all of the available RAM and SWAP, which would halt your server.</p>
<h3>Swap</h3>
<p>Find the swap size.</p>
<pre># free -m -t
             total       used       free     shared    buffers     cached
Mem:           458         93        364          0          0          0
-/+ buffers/cache:         93        364
Swap:          900          0        900
Total:        1358         93       1264</pre>
<pre>Adding 3004144k swap on /dev/sdb2.  Priority:-1 extents:1 across:3004144k
Adding 2096472k swap on /dev/sda3.  Priority:-2 extents:1 across:2096472k</pre>
<h2>Using TMPFS for Cache</h2>
<p>The method here will show how to create and use a TMPFS filesystem to hold all the static files created by WP-Super Cache.  These static files are served to visitors instead of loading php for every request, so by moving those static files to TMPFS your server will be able to access and start sending your site to the browser 30x faster!</p>
<p>The WP-Super Cache plugin stores all the static files in the wp-content/cache folder of your WordPress installation, so to enable TMPFS we simply will create a new TMPFS filesystem and mount it to the wp-content/cache folder.  That makes anything in that folder (all the static files) be part of the TMPFS filesystem.</p>
<h2>Boosting Cache with TMPFS</h2>
<p>There are a lot of maybe new concepts surrounding TMPFS and it may seem too complicated, but the process of actually setting up a robust tmpfs to use for wp-super-cache&#8217;s cache folder is actually very simple.  As long as you have shell access to your server and the permissions required (any sudo or private server should be good to go) you can set this up in a couple minutes and not really have to give it a second thought or debug anything.  Here&#8217;s the process I&#8217;ve used on several client sites.</p>
<ol>
<li>Create a TMPFS Filesystem and Mount at /wp-content/cache/</li>
<li>Restore TMPFS Cached Files across Reboots</li>
<li>Keep a semi-current mirror of the TMPFS files on Disk</li>
</ol>
<p><br class="C" /></p>
<h3>Create TMPFS at wp-content/cache</h3>
<p>/etc/fstab</p>
<pre>tmpfs /home/askapache/wp-content/cache tmpfs defaults,size=2g,noexec,nosuid,uid=648,gid=648,mode=1755 0 0</pre>
<h3>Restoring TMPFS across Reboots</h3>
<p>In /etc/rc.local</p>
<pre>ionice -c3 -n7 nice -n 19 rsync -ahv &#45;-stats &#45;-delete /_b/tmpfs/cache/ /home/askapache/wp-content/cache/ 1&gt;/dev/null</pre>
<h3>Mirroring TMPFS to Disk</h3>
<p>Cronjob entry</p>
<pre>*/5 * * * * /usr/bin/ionice -c3 -n7 /bin/nice -n 19 /usr/bin/rsync -ah &#45;-stats &#45;-delete /home/askapache/wp-content/cache/ /_b/tmpfs/cache/ 1&gt;/dev/null</pre>
<p><span id="more-3220"></span></p>
<h2>/tmp, /var/run, and /var/lock</h2>
<p>The directories /tmp, /var/run, and /var/lock contain files that are not needed across reboots.  This means they are ideal candidates for tmpfs.  HEre&#8217;s how to do it.</p>
<pre>tmpfs /var/run tmpfs defaults,rw,nosuid,mode=0755 0 0</pre>
<pre>tmpfs /var/lock tmpfs defaults,rw,noexec,nosuid,nodev,mode=1777 0 0</pre>
<h2>Resize /dev/shm</h2>
<p>You can view your current /dev/shm size with the command <code>df -ha|grep /dev/shm</code> then if you want to resize that use the command:</p>
<pre>mount -t tmpfs -o remount,size-2G,rw,nosuid,nodev tmpfs /dev/shm</pre>
<pre>Secure /dev/shm:
&nbsp;
Step 1: Edit your /etc/fstab:
&nbsp;
nano -w /etc/fstab
&nbsp;
Locate:
&nbsp;
none /dev/shm tmpfs defaults,rw 0 0
&nbsp;
Change it to:
&nbsp;
none /dev/shm tmpfs defaults,nosuid,noexec,rw 0 0
&nbsp;
Step 2: Remount /dev/shm:
&nbsp;
mount -o remount /dev/shm
&nbsp;
guilt makes extensive use of the &#039;$$&#039; shell variable for temporary
files in /tmp. This is a serious security vulnerability; on multi-user
systems it allows an attacker to clobber files with something like the
following:
&nbsp;
for i in `seq 1 32768`; do
ln -sf /etc/passwd /tmp/guilt.log.$i;
done
&nbsp;
(In this example, if root does e.g. &#039;guilt push&#039;, /etc/passwd will get
clobbered.)</pre>
<p><br class="C" /></p>
<h3>Securing and Using /tmp</h3>
<ul>
<li><a href="http://www.sysadmin.md/secure-temporary-folders-on-existing-unix-or-linux-systems.html">Secure temporary folders on existing Unix or Linux systems</a></li>
<li><a href="https://wiki.torproject.org/noreply/TheOnionRouter/OperationalSecurity">Encrypt Storage and Swap Space</a></li>
</ul>
<p><a id="tmpfs-mount"></a></p>
<h2>tmpfs mount parameters</h2>
<p>A good way to find a good tmpfs upper-bound is to use top to monitor your system&#8217;s swap usage during peak usage periods. Then, make sure that you specify a tmpfs upper-bound that&#8217;s slightly less than the sum of all free swap and free RAM during these peak usage times. </p>
<p><strong>mode=1777</strong> sets sticky bit on directory. Only file owners can delete files in this directory.</p>
<p>The following parameters accept a suffix k, m or g for Ki, Mi, Gi (binary kilo, mega and giga) and can be changed on remount.</p>
<ul>
<li><strong>size</strong>:  Override default maximum size of the filesystem.  The size is given in bytes, and rounded down to entire pages.  The default is half of the memory.The limit of allocated bytes for this tmpfs instance. The default is half of your physical RAM without swap. If you oversize your tmpfs instances the machine will deadlock since the OOM handler will not be able to free that memory.</li>
<li><strong>nr_inodes</strong>:  Set number of inodes.</li>
<li><strong>nr_blocks</strong>:  Set number of blocks.</li>
<li><strong>mode</strong>: The permissions as an octal number</li>
<li><strong>uid</strong>: The user id</li>
<li><strong>gid</strong>: The group id</li>
</ul>
<pre>mount -t tmpfs -o size=10G,nr_inodes=10k,mode=700 tmpfs /mytmpfs</pre>
<p>Will give you tmpfs instance on /mytmpfs which can allocate 10GB RAM/SWAP in 10240 inodes and it is only accessible by root.</p>
<p><a id="tmp-tmpfs"></a></p>
<h2>Using tmpfs for /tmp storage</h2>
<p>Many users find it very convenient to use tmpfs for /tmp and /var/tmp which does a number of positive things.  Any temporary files are instead created in RAM not your hard-drive, which means that reading/writing/accessing those temporary files by various processes doesn&#8217;t slow down your hard-drive read/writes/accesses for your other processes.  This also has a side-effect of making your hard-drive have a longer life as it reduces activity by a huge amount.</p>
<p>Remember that tmpfs uses both RAM and swap, so make sure your machine has a large swapfile, like gigabytes.  If your tmpfs consumes all the swap and RAM then you are screwed, so make sure that you correctly set the mount options for the tmpfs so that it doesn&#8217;t do that.  If your /tmp or /var/tmp gets filled with tmp files that for some reason don&#8217;t get deleted except at reboot, and your machine has a very high uptime, then you will want to run some cron jobs to periodically clean the /tmp and /var/tmp directories of older files&#8230;</p>
<p>Here&#8217;s an example scenario: let&#8217;s say that we have an existing filesystem mounted at /tmp. However, we decide that we&#8217;d like to start using tmpfs for /tmp storage.</p>
<p>with recent 2.4 kernels, you can mount your new /tmp filesystem without getting the &#8220;device is busy&#8221; error: </p>
<pre>mount tmpfs /tmp -t tmpfs -o size=64m</pre>
<p>With a single command, your new tmpfs /tmp filesystem is mounted at /tmp, on top of the already-mounted partition, which can no longer be directly accessed. However, while you can&#8217;t get to the original /tmp, any processes that still have open files on this original filesystem can continue to access them. And, if you umount your tmpfs-based /tmp, your original mounted /tmp filesystem will reappear. In fact, you can mount any number of filesystems to the same mountpoint, and the mountpoint will act like a stack; unmount the current filesystem, and the last-most-recently mounted filesystem will reappear from underneath.</p>
<p><a id="bind-mounts"></a></p>
<h2>Bind Mounts</h2>
<p>Using bind mounts, we can mount all, or even part of an already-mounted filesystem to another location, and have the filesystem accessible from both mountpoints at the same time!</p>
<p>For example, you can use bind mounts to mount your existing /tmp filesystem to /sites/askapache.com/tmp, as follows:</p>
<pre>mount &#45;-bind /tmp /sites/askapache.com/tmp</pre>
<p>Now, if you look inside /sites/askapache.com/tmp, you&#8217;ll see your /tmp filesystem and all its files. And if you modify a file on your /tmp filesystem, you&#8217;ll see the modifications in /sites/askapache.com/tmp as well. This is because <strong>they are one and the same filesystem; the kernel is simply mapping the filesystem to two different mountpoints for us</strong>. </p>
<p>Note that when you mount a filesystem somewhere else, any filesystems that were mounted to mountpoints inside the bind-mounted filesystem will not be moved along. In other words, if you have /tmp/cache on a separate filesystem, the bind mount we performed above will leave /sites/askapache.com/tmp/cache empty. You&#8217;ll need an additional bind mount command to allow you to browse the contents of /tmp/cache at /sites/askapache.com/tmp/cache:</p>
<pre>mount &#45;-bind /tmp/cache /sites/askapache.com/tmp/cache</pre>
<h3>Bind mounting and /dev/shm</h3>
<p>glibc 2.2 and above expects tmpfs to be mounted at /dev/shm for POSIX shared memory (shm_open, shm_unlink). Adding the following line to /etc/fstab should take care of this:</p>
<pre>tmpfs  /dev/shm  tmpfs  defaults  0 0</pre>
<p>Many systems by default have a tmpfs filesystem mounted at /dev/shm that defaults to a size of half of your physical RAM without swap.  Say you decide that you&#8217;d like to start using tmpfs for /tmp, which currently lives on your root filesystem. Rather than mounting a new tmpfs filesystem to /tmp (which is possible), you may decide that you&#8217;d like the new /tmp to share the currently mounted /dev/shm filesystem. However, while you could bind mount /dev/shm to /tmp and be done with it, your /dev/shm contains some directories that you don&#8217;t want to appear in /tmp. So, what do you do? How about this:</p>
<pre>mkdir /dev/shm/tmp
chmod 1777 /dev/shm/tmp
mount &#45;-bind /dev/shm/tmp /tmp</pre>
<p>In this example, we first create a /dev/shm/tmp directory and then give it 1777 perms, the proper permissions for /tmp. Now that our directory is ready, we can mount /dev/shm/tmp, and only /dev/shm/tmp to /tmp. So, while /tmp/foo would map to /dev/shm/tmp/foo, there&#8217;s no way for you to access the /dev/shm/bar file from /tmp.</p>
<p><br class="C" /></p>
<p><a id="default-tmpfs-workaround"></a></p>
<h2>/etc/default/tmpfs WorkAround</h2>
<pre>$ cat /etc/default/tmpfs
# SHM_SIZE sets the maximum size (in bytes) that the /dev/shm tmpfs can use.
# If this is not set then the size defaults to the value of TMPFS_SIZE
# if that is set; otherwise to the kernel&#039;s default.
#
# The size will be rounded down to a multiple of the page size, 4096 bytes.
SHM_SIZE=524288000
# TMPFS_SIZE sets the max size that /dev/shm can use.  By default, the
# kernel sets this upper limit to half of available memory.
TMPFS_SIZE=524288000</pre>
<p><a id="rsync-vs-cp"></a></p>
<h2>RSYNC vs. CP</h2>
<pre>rsync [options]  SRC DEST
rsync -av &#45;-delete &#45;-stats /home/wincom/public_html/wp-content/cache/ /backups/tmp-mnt/cache/
-a, &#45;-archive               archive mode; same as -rlptgoD (no -H)
-r, &#45;-recursive             recurse into directories
-l, &#45;-links                 copy symlinks as symlinks
-p, &#45;-perms                 preserve permissions
-t, &#45;-times                 preserve times
-g, &#45;-group                 preserve group
-o, &#45;-owner                 preserve owner (super-user only)
-D                          same as &#45;-devices &#45;-specials
    &#45;-devices               preserve device files (super-user only)
    &#45;-specials              preserve special files
 -h, &#45;-human-readable        output numbers in a human-readable format
     &#45;-progress              show progress during transfer</pre>
<p><a id="mount-options"></a></p>
<h2>Mount Options</h2>
<p>The following options apply to any file system that is being mounted (but not every file  system  actually honors them)</p>
<ul>
<li><code>async</code> All I/O to the file system should be done asynchronously.</li>
<li><code>atime</code> Update inode access time for each access. This is the default.</li>
<li><code>auto</code> Can be mounted with the -a option.</li>
<li><code>defaults</code> Use default options: rw, suid, dev, exec, auto, nouser, and async.</li>
<li><code>dev</code> Interpret character or block special devices on the file system.</li>
<li><code>exec</code> Permit execution of binaries.</li>
<li><code>group</code> Allow an ordinary (i.e., non-root) user to mount the file system if one of his groups matches the group of the device.  This option implies the options nosuid and nodev (unless overridden by subsequent options, as in the option line group,dev,suid).</li>
<li><code>mand</code> Allow mandatory locks on this filesystem. See fcntl(2).</li>
<li><code>_netdev</code> The filesystem resides on a device that requires network access (used to prevent the system from attempting to mount these filesystems until the network has been enabled on the system).</li>
<li><code>noatime</code> Do not update inode access times on this file system (e.g, for faster access on the news spool to speed up news servers).</li>
<li><code>nodiratime</code> Do not update directory inode access times on this filesystem.</li>
<li><code>noauto</code> Can only be mounted explicitly (i.e., the -a option will not cause the file system to be mounted).</li>
<li><code>nodev</code> Do not interpret character or block special devices on the file system.</li>
<li><code>noexec</code> Do not allow direct execution of any binaries on the mounted file system.  (Until recently it was possible to run binaries anyway using a command like /lib/ld*.so /mnt/binary. This trick fails since Linux 2.4.25 / 2.6.0.)</li>
<li><code>nomand</code> Do not allow mandatory locks on this filesystem.</li>
<li><code>nosuid</code> Do not allow set-user-identifier or set-group-identifier bits to take effect. (This seems safe, but is in fact rather unsafe if you have suidperl(1) installed.)</li>
<li><code>nouser</code> Forbid an ordinary (i.e., non-root) user to mount the file system.  This is the default.</li>
<li><code>owner</code> Allow an ordinary (i.e., non-root) user to mount the file system if he is the owner of the device.  This option implies the options nosuid and nodev (unless overridden by subsequent options, as in the option line owner,dev,suid).</li>
<li><code>remount</code> Attempt to remount an already-mounted file system.  This is commonly used to change the mount flags for a file system, especially to make a readonly file system writeable. It does not change device or mount point.</li>
<li><code>ro</code> Mount the file system read-only.</li>
<li><code>_rnetdev</code> Like _netdev, except &#8220;fsck -a&#8221; checks this filesystem during rc.sysinit.</li>
<li><code>rw</code> Mount the file system read-write.</li>
<li><code>suid</code> Allow set-user-identifier or set-group-identifier bits to take effect.</li>
<li><code>sync</code> All I/O to the file system should be done synchronously. In case of media with limited number of write cycles (e.g. some flash drives) &#8220;sync&#8221; may cause life-cycle shortening.</li>
<li><code>dirsync</code> All directory updates within the file system should be done synchronously.  This affects the following system calls: creat, link, unlink, symlink, mkdir, rmdir, mknod and rename.</li>
<li><code>user</code> Allow  an ordinary user to mount the file system.  The name of the mounting user is written to mtab so that he can unmount the file system again.  This option implies the options noexec, nosuid, and nodev (unless overridden by subsequent options, as in the option line user,exec,dev,suid).</li>
<li><code>users</code> Allow every user to mount and unmount the file system.  This option implies the options noexec, nosuid, and nodev (unless overridden by subsequent options, as in the option line users,exec,dev,suid).</li>
</ul>
<p><a id="filesystems"></a></p>
<h2>Filesystems</h2>
<p>You can find out what is filesystems are in place by using one of the following linux commands:</p>
<pre>cat /etc/fstab
cat /etc/mtab
cat /proc/mounts
df -a</pre>
<h2>/etc/fstab</h2>
<pre>       /etc/fstab        file system table
       /etc/mtab         table of mounted file systems
       /etc/mtab~        lock file
       /etc/mtab.tmp     temporary file
       /etc/filesystems  a list of filesystem types to try</pre>
<p>From /etc/mtab</p>
<pre>none /tmp tmpfs size=128m,mode=1777 0 0</pre>
<p>From /proc/mounts</p>
<pre>none /tmp tmpfs rw,nodev,relatime,size=131072k 0 0</pre>
<p><br class="C" /></p>
<p><a id="fstab"></a></p>
<h2>/etc/fstab</h2>
<p>It is possible that files /etc/mtab and /proc/mounts don’t match. The first file is based only on the mount command options, but the content of the second file also depends on the kernel and others settings (e.g.  remote NFS server. In particular case  the  mount  command  may reports unreliable information about a NFS mount point and the /proc/mounts file usually contains more reliable information.)</p>
<p>This file is used in three ways:</p>
<ol>
<li>The following command (usually given in a bootscript) causes all file systems mentioned in fstab (of the proper type and/or having or not having the proper options) to be mounted as indicated, except for those whose line contains the noauto keyword. Adding the -F option will  make  mount  fork,  so that the filesystems are mounted simultaneously.
<pre>mount -a [-t type] [-O optlist]</pre>
</li>
<li>When mounting a file system mentioned in fstab, it suffices to give only the device, or only the mount point.</li>
<li>Normally, only the superuser can mount file systems.  However, when fstab contains the user option on a line, anybody can mount the corresponding system.</li>
</ol>
<p>The programs mount and umount maintain a list of currently mounted file systems in the file /etc/mtab.</p>
<p>Only the user that mounted a filesystem can unmount it again.  If any user should be able to unmount, then use users instead of user in the fstab line.  The owner option is similar to the user option, with the restriction that the user must be the owner of the special file.  The group option is similar, with the restriction that the user must be member of the group of the special file.</p>
<p>The order of records in fstab is important because fsck(8), mount(8), and umount(8) sequentially iterate through fstab doing their thing.</p>
<h3>The first field, (fs_spec)</h3>
<p>Describes the block special device or remote filesystem to be mounted.  For ordinary mounts it will hold (a link to) a block special device node (as created by mknod(8)) for the device to be mounted, like ‘/dev/cdrom’ or ‘/dev/sdb7’.  For NFS mounts one will have <code><host>:<dir></code>, e.g., ‘knuth.aeb.nl:/’.  For procfs, use ‘proc’.</p>
<p>Instead of giving the device explicitly, one may indicate the (ext2 or xfs) filesystem that is to be mounted by its UUID or volume label (cf.  e2label(8) or xfs_admin(8)), writing LABEL=<label> or UUID=<uuid>, e.g., ‘LABEL=Boot’ or  ‘UUID=3e6be9de-8139-11d1-9106-a43f08d823a6’.  This will make the system more robust: adding or removing a SCSI disk changes the disk device name but not the filesystem volume label.</p>
<h3>The second field, (fs_file)</h3>
<p>Describes the mount point for the filesystem.  For swap partitions, this field should be specified as ‘none’. If the name of the mount point contains spaces these can be escaped as ‘\040’.</p>
<p>The  third  field,  (fs_vfstype),  describes the type of the filesystem.  Linux supports lots of filesystem types, such as adfs, affs, autofs, coda, coherent, cramfs, devpts, efs, ext2, ext3, hfs, hpfs, iso9660, jfs, minix, msdos, ncpfs, nfs, ntfs, proc, qnx4, reiserfs, romfs, smbfs, sysv, tmpfs, udf, ufs, umsdos, vfat, xenix, xfs, and possibly others. For more details, see mount(8).  <strong>For the filesystems currently supported by the running kernel, see /proc/filesystems</strong>.  An entry swap denotes  a  file  or  partition  to  be  used  for  swapping,  cf.  swapon(8).  An entry ignore causes the line to be ignored.  This is useful to show disk partitions which are currently unused.</p>
<h3>The fourth field, (fs_mntops)</h3>
<p>Describes the mount options associated with the filesystem.  It  is formatted as a comma separated list of options.  It contains at least the type of mount plus any additional options appropriate to the filesystem type.  For documentation on the available options for non-nfs file systems, see mount(8).  For documentation on all nfs-specific options have a look at nfs(5).</p>
<p>Common for all types of file system are the options:</p>
<ul>
<li><strong>noauto</strong>: (do not mount when &#8220;mount -a&#8221; is given, e.g., at boot time)</li>
<li><strong>user</strong>: (allow a user to mount)</li>
<li><strong>owner</strong>: (allow device owner to mount)</li>
<li><strong>pamconsole</strong>: (allow a user at the console to mount)</li>
<li><strong>comment</strong>: (e.g., for use by fstab-maintaining programs).</li>
</ul>
<h3>The fifth field, (fs_freq)</h3>
<p>Used for these filesystems by the dump(8) command to determine which filesystems need to be dumped.  If the fifth field is not present, a value of zero is returned and dump will assume that the filesystem does not need to be dumped.</p>
<h3>The  sixth  field,  (fs_passno)</h3>
<p>Used by the fsck(8) program to determine the order in which filesystem checks are done at reboot time.  The root filesystem should be specified with a fs_passno of 1, and other filesystems should have a fs_passno of 2.  Filesystems within a drive will be checked sequentially, but filesystems on different drives will be checked at the same time to utilize parallelism available in the hardware.  If the sixth field is not present or zero, a value of zero is returned and <strong>fsck will assume that the filesystem does not need to be checked</strong>.</p>
<h3>More Reading</h3>
<ul>
<li><a href="http://www.thegeekstuff.com/2008/11/overview-of-ramfs-and-tmpfs-on-linux/">Overview of RAMFS and TMPFS on Linux</a></li>
<li><a href='http://uploads.askapache.com/2009/09/ramfs-rootfs-initramfs.txt'>ramfs, rootfs and initramfs</a></li>
<li><a href='http://uploads.askapache.com/2009/09/tmpfs.txt'>Tmpfs is a file system which keeps all files in virtual memory</a></li>
<li><a href="http://www.ibm.com/developerworks/library/l-fs3.html">IBM: Advanced filesystem implementor&#8217;s guide, Part 3</a></li>
<li><a href="http://en.wikipedia.org/wiki/TMPFS">TMPFS Wikipedia Entry</a></li>
<li><a href="http://en.wikipedia.org/wiki/Shared_memory">Shared Memory</a></li>
<li><a href="http://kevin.vanzonneveld.net/techblog/article/create_turbocharged_storage_using_tmpfs/">Create turbocharged storage using tmpfs</a></li>
<li><a href="http://dev.mysql.com/doc/refman/4.1/en/temporary-files.html">Where MySQL Stores Temporary Files</a></li>
<li><a href="http://www.linuxized.com/2009/05/speeding-up-firefox-with-tmpfs-and-automatic-rsync/">speeding up firefox with tmpfs and automatic rsync</a> <a href="http://www.linuxized.com/wp-content/uploads/2009/05/speedfox">(shell-script)</a> <a href="http://autoverse.net/blog/2009/apr/23/speed-firefox/">Original</a></li>
<li><a href="http://www.kernel.org/doc/Documentation/filesystems/tmpfs.txt">kernel documentation for tmpfs</a></li>
<li><a href="http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=386368">initscripts: please don&#8217;t mount /dev/shm noexec</a></li>
<li><a href="http://forums.debian.net/viewtopic.php?t=16450">HOWTO: Using tmpfs for /tmp, /var/{log,run,lock&#8230;}</a></li>
<li><a href="http://forums.gentoo.org/viewtopic-t-371889-highlight-tmpfs.html">Gentoo Forums: Using tmpfs for /var/{log,lock,&#8230;}</a></li>
<li><a href="http://forums.gentoo.org/viewtopic-t-717117-highlight-tmpfs.html">[TIP] Firefox and tmpfs: a surprising improvement</a></li>
</ul>
<blockquote cite="http://openquery.com/blog/experiment-mysql-tmpdir-on-tmpfs"><p>
<cite><a href="http://openquery.com/blog/experiment-mysql-tmpdir-on-tmpfs">Experiment: MySQL tmpdir on tmpfs</a></cite></p>
<p>In MySQL, the tmpdir path is mainly used for disk-based sorts (if the sort_buffer_size is not enough) and disk-based temp tables. The latter cannot always be avoided even if you made tmp_table_size and max_heap_table_size quite large, since MEMORY tables don’t support TEXT/BLOB type columns, and also since you just really don’t want to run the risk of exceeding available memory by setting these things too large.</p>
</blockquote>
<p><br class="C" /></p>
<h2>Use tmpfs for MySQL</h2>
<pre>&#45;-tmpdir=path, -t path</pre>
<blockquote cite="http://dev.mysql.com/doc/refman/4.1/en/server-options.html#option_mysqld_tmpdir"><p>The path of the directory to use for creating temporary files. It might be useful if your default /tmp directory resides on a partition that is too small to hold temporary tables. Starting from MySQL 4.1.0, this option accepts several paths that are used in round-robin fashion. Paths should be separated by colon characters (“:”) on Unix and semicolon characters (“;”) on Windows, NetWare, and OS/2. If the MySQL server is acting as a replication slave, you should not set &#8211;tmpdir to point to a directory on a memory-based file system or to a directory that is cleared when the server host restarts. For more information about the storage location of temporary files, see Section A.1.4.4, “Where MySQL Stores Temporary Files”. A replication slave needs some of its temporary files to survive a machine restart so that it can replicate temporary tables or LOAD DATA INFILE operations. If files in the temporary file directory are lost when the server restarts, replication fails. </p></blockquote>
<blockquote cite="http://dev.mysql.com/doc/refman/4.1/en/temporary-files.html"><p>On Unix, MySQL uses the value of the TMPDIR  environment variable as the path name of the directory in which to store temporary files. If TMPDIR  is not set, MySQL uses the system default, which is usually /tmp, /var/tmp, or /usr/tmp. </p>
<p> If the file system containing your temporary file directory is too small, you can use the &#8211;tmpdir option to mysqld to specify a directory in a file system where you have enough space.</p>
<p>Starting from MySQL 4.1, the &#8211;tmpdir option can be set to a list of several paths that are used in round-robin fashion. Paths should be separated by colon characters (“:”) on Unix and semicolon characters (“;”) on Windows, NetWare, and OS/2.<br />
Note</p>
<p>To spread the load effectively, these paths should be located on different physical disks, not different partitions of the same disk.</p>
<p>If the MySQL server is acting as a replication slave, you should not set &#8211;tmpdir to point to a directory on a memory-based file system or to a directory that is cleared when the server host restarts. A replication slave needs some of its temporary files to survive a machine restart so that it can replicate temporary tables or LOAD DATA INFILE operations. If files in the temporary file directory are lost when the server restarts, replication fails.</p>
<p>MySQL creates all temporary files as hidden files. This ensures that the temporary files are removed if mysqld is terminated. The disadvantage of using hidden files is that you do not see a big temporary file that fills up the file system in which the temporary file directory is located.
</p></blockquote>
<p><br class="C" /></p>
<h2>Shell Script for Firefox tmpfs</h2>
<pre>#!/bin/bash
### Bind temporary directories to /dev/shm ###
# I do this instead of mounting tmpfs on the #
# directories, so less memory gets wasted.   #
##############################################
mkdir /dev/shm/{tmp,lock}
mount &#45;-bind /dev/shm/tmp /tmp
mount &#45;-bind /dev/shm/tmp /var/tmp
mount &#45;-bind /dev/shm/lock /var/lock
chmod 1777 /dev/shm/{tmp,lock}</pre>
<hr />
<p><strong>Hey!</strong> You made it!@ at least to the bottom of the page..  I still have to finish this article, so check back in a few months.</p>
<p><a href="http://www.askapache.com/web-hosting/super-speed-secrets.html"></a><a href="http://www.askapache.com/web-hosting/super-speed-secrets.html">30x Faster WP-Super Cache Site Speed</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/GH_VvtzhgnOKFe-lF_M5Kchm3p4/0/da"><img src="http://feedads.g.doubleclick.net/~a/GH_VvtzhgnOKFe-lF_M5Kchm3p4/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/GH_VvtzhgnOKFe-lF_M5Kchm3p4/1/da"><img src="http://feedads.g.doubleclick.net/~a/GH_VvtzhgnOKFe-lF_M5Kchm3p4/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=idpQy3yzSQg:BJR6kYbYMSU:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=idpQy3yzSQg:BJR6kYbYMSU:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=idpQy3yzSQg:BJR6kYbYMSU:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=idpQy3yzSQg:BJR6kYbYMSU:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=idpQy3yzSQg:BJR6kYbYMSU:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=idpQy3yzSQg:BJR6kYbYMSU:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=idpQy3yzSQg:BJR6kYbYMSU:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/web-hosting/super-speed-secrets.html/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		<feedburner:origLink>http://www.askapache.com/web-hosting/super-speed-secrets.html</feedburner:origLink></item>
		<item>
		<title>Advanced WordPress wp-config.php Tweaks</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/I3-QaJt-u1Q/advanced-wp-config-php-tweaks.html</link>
		<comments>http://www.askapache.com/wordpress/advanced-wp-config-php-tweaks.html#comments</comments>
		<pubDate>Wed, 03 Mar 2010 08:23:37 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[CSS]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Mod_Rewrite]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[SEO]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Shell Scripting]]></category>
		<category><![CDATA[Web Design]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[WordPress Plugins]]></category>
		<category><![CDATA[301 Redirect]]></category>
		<category><![CDATA[admin]]></category>
		<category><![CDATA[Advanced]]></category>
		<category><![CDATA[Ajax]]></category>
		<category><![CDATA[Anti-Spam]]></category>
		<category><![CDATA[Apache]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[bash_profile]]></category>
		<category><![CDATA[caching]]></category>
		<category><![CDATA[cheatsheet]]></category>
		<category><![CDATA[chmod]]></category>
		<category><![CDATA[Cookies]]></category>
		<category><![CDATA[debugging]]></category>
		<category><![CDATA[Elite]]></category>
		<category><![CDATA[encryption]]></category>
		<category><![CDATA[error log]]></category>
		<category><![CDATA[Examples]]></category>
		<category><![CDATA[feed]]></category>
		<category><![CDATA[File Permissions]]></category>
		<category><![CDATA[File System]]></category>
		<category><![CDATA[filesystem]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[grep]]></category>
		<category><![CDATA[HowTo]]></category>
		<category><![CDATA[HTTP Headers]]></category>
		<category><![CDATA[HTTPS SSL]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Login]]></category>
		<category><![CDATA[Logs]]></category>
		<category><![CDATA[Mod_Rewrite cheatsheet]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[password]]></category>
		<category><![CDATA[php.ini]]></category>
		<category><![CDATA[phpinfo]]></category>
		<category><![CDATA[Port]]></category>
		<category><![CDATA[post]]></category>
		<category><![CDATA[Rewrite Tricks]]></category>
		<category><![CDATA[rewritecond]]></category>
		<category><![CDATA[rewriterule]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[Sessions]]></category>
		<category><![CDATA[Shell]]></category>
		<category><![CDATA[Socket]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSH]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[trick]]></category>
		<category><![CDATA[umask]]></category>
		<category><![CDATA[Username]]></category>
		<category><![CDATA[wp-config.php]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3341</guid>
		<description><![CDATA[<p>The bottom line for this article is that I want to make WordPress as fast, secure, and easy to install, run, and manage because I am using it more and more for client production sites, I will work for days in order to solve an issue so that I never have to spend time on that issue again. Time is money in this industry and that is ultimately (time) what there is to gain by tweaking WordPress.</p>

<p class="cnote"><strong>Note:</strong> I spent no time on readability, this is primarily a read the code and figure it out article.. This is for advanced users looking for a reference or discussion and for those of you looking to advance.  Feedback would be great <em>if you make it that far..</em></p>]]></description>
			<content:encoded><![CDATA[<p>The bottom line for this article is that I want to make WordPress as fast, secure, and easy to install, run, and manage because I am using it more and more for client production sites, I will work for days in order to solve an issue so that I never have to spend time on that issue again. Time is money in this industry and that is ultimately (time) what there is to gain by tweaking WordPress.</p>
<p class="cnote"><strong>Note:</strong> I spent no time on readability, this is primarily a read the code and figure it out article.. This is for advanced users looking for a reference or discussion and for those of you looking to advance.  Feedback would be great <em>if you make it that far..</em></p>
<p>For a better handle on the way I like to structure web site directories, see <a href="http://www.askapache.com/htaccess/optimize-website-files-cache-security.html">Optimize a Website for Speed, Security, and Easy Management</a> but note it is a bit outdated compared to what I&#8217;m doing now.  I don&#8217;t have the luxury of using only one type of server, or hosting provider anymore, so I have been working towards making things even more portable in order to move from host to host from server to server without issues i.e. my portable <a href="http://www.askapache.com/linux-unix/bash_profile-functions-advanced-shell.html">.bash_profile</a>.</p>
<p>So I&#8217;ve been basically experimenting various ways to accomplish that and thought I would share what I am currently doing for my benefit and hopefully get some input.  All of my WP installs run the development version, and one main idea with my setups is that upgrading is automated.  So I really keep the WordPress install clean and use plugins and wp-config.php to do all the customization.</p>
<ul>
<li>Portability &#8211; Hands-free upgrades and easy to move</li>
<li>Security &#8211; Additional security and protection</li>
<li>Speed &#8211; Less CPU and Disk I/O</li>
<li>Customization &#8211; All my favorite customizations</li>
</ul>
<h2>wp-config.php</h2>
<p>These are the main settings I use.. Seriously this is more like an interactive article, because to understand it you will need to do some code grepping.  You may want to grab a jolt.</p>
<h3>ASKAPACHE_ROOT</h3>
<p>The ASKAPACHE_ROOT variable is just a better way for me to be able to include and access all the different files in my site tree.  For instance, in my non-wp php files, I can do this:</p>
<pre>!defined(&#039;ASKAPACHE_ROOT&#039;) &amp;&amp; require $_SERVER[&#039;DOCUMENT_ROOT&#039;] . &#039;/wp-config.php&#039;;
include(ASKAPACHE_ROOT . &#039;/includes/custom-download.inc.php&#039;);</pre>
<h3>ASKAPACHE_LOCK</h3>
<p>This is one of my all-time favorite hacks, that I think is one of the most useful methods I employ as a web developer.  This allows me to use far-future-expire headers for optimum caching, while still forcing browsers to re-validate every day or so automatically, or forcing them to re-validate whenever I change the suffix.  This takes advantage of the <a href="http://www.askapache.com/htaccess/mod_rewrite-fix-for-caching-updated-files.html">mod_rewrite trick</a> that I use on EVERY site I run, definately worth learning. Because I practice best-practice web-standards, for every web site I create a single css file and javascript file, which I then add to the template like:</p>
<pre>&lt;link rel=&quot;stylesheet&quot; type=&quot;text/css&quot; media=&quot;all&quot; href=&quot;http://static.askapache.com/c/apache-0&lt;?php echo ASKAPACHE_LOCK?&gt;.css&quot; /&gt;
&lt;script src=&quot;http://static.askapache.com/j/apache-0&lt;?php echo ASKAPACHE_LOCK;?&gt;.js&quot; type=&quot;text/javascript&quot;&gt;&lt;/script&gt;</pre>
<pre>&lt;?php
/**
 * The base configurations of the WordPress.
 *
 * This file has the following configurations: MySQL settings, Table Prefix,
 * Secret Keys, WordPress Language, and ABSPATH. You can find more information by
 * visiting {@link http://codex.wordpress.org/Editing_wp-config.php Editing
 * wp-config.php} Codex page. You can get the MySQL settings from your web host.
 *
 * This file is used by the wp-config.php creation script during the
 * installation. You don&#039;t have to use the web site, you can just copy this file
 * to &quot;wp-config.php&quot; and fill in the values.
 *
 * @package WordPress
 */
/* http://codex.wordpress.org/Editing_wp-config.php */
&nbsp;
/** /home/liet/askapache.com */
!defined(&#039;ASKAPACHE_ROOT&#039;) &amp;&amp; define(&#039;ASKAPACHE_ROOT&#039;, str_replace(&#039;/public_html&#039;,&#039;&#039;, $_SERVER[&#039;DOCUMENT_ROOT&#039;]));
&nbsp;
/** The 008 at the end is for manual tweaking.  time() returns seconds since &#039;00:00:00 1970-01-01 UTC&#039;. */
// http://www.askapache.com/htaccess/mod_rewrite-fix-for-caching-updated-files.html
!defined(&#039;ASKAPACHE_LOCK&#039;) &amp;&amp; define(ASKAPACHE_LOCK&#039;, substr(time(),0,5).&#039;008&#039;); // 12533001
&nbsp;
/** absolute path to the WordPress directory */
!defined(&#039;ABSPATH&#039;) &amp;&amp; define(&#039;ABSPATH&#039;, ASKAPACHE_ROOT .&#039;/public_html/&#039;);
&nbsp;
/**
 * WP_SITEURL, defined since WordPress Version 2.2, allows the WordPress address (URL) to be defined. The valued defined is the address where your WordPress core files reside.
 * It should include the http:// part too. Do not put a slash &quot;/&quot; at the end.
 * Setting this value in wp-config.php overrides the wp_options table value for siteurl and disables the WordPress address (URL) field in the Administration &gt; Settings &gt; General panel.
 */
!defined(&#039;WP_SITEURL&#039;) &amp;&amp; define(&#039;WP_SITEURL&#039;, &#039;http://&#039;.$_SERVER[&#039;SERVER_NAME&#039;]);
&nbsp;
/**
 * WP_HOME is another wp-config.php option added in WordPress Version 2.2. Similar to WP_SITEURL,
 * WP_HOME overrides the wp_options table value for home but does not change it permanently.
 * home is the address you want people to type in their browser to reach your WordPress blog. It should include the http:// part. Also, do not put a slash &quot;/&quot; at the end.
 */
!defined(&#039;WP_HOME&#039;) &amp;&amp; define(&#039;WP_HOME&#039;, WP_SITEURL);
&nbsp;
/** no trailing slash, full paths only */
!defined(&#039;WP_CONTENT_DIR&#039;) &amp;&amp; define( &#039;WP_CONTENT_DIR&#039;, ABSPATH . &#039;wp-content&#039; );
&nbsp;
// full url - WP_CONTENT_DIR is defined further up
!defined(&#039;WP_CONTENT_URL&#039;) &amp;&amp; define( &#039;WP_CONTENT_URL&#039;, WP_SITEURL . &#039;/wp-content&#039;);
&nbsp;
/** Allows for the plugins directory to be moved from the default location. @since 2.6.0 */
// full path, no trailing slash
!defined(&#039;WP_PLUGIN_DIR&#039;) &amp;&amp; define( &#039;WP_PLUGIN_DIR&#039;, WP_CONTENT_DIR . &#039;/plugins&#039; );
&nbsp;
/** Allows for the plugins directory to be moved from the default location. @since 2.6.0 */
// full url, no trailing slash
!defined(&#039;WP_PLUGIN_URL&#039;) &amp;&amp; define( &#039;WP_PLUGIN_URL&#039;, WP_CONTENT_URL . &#039;/plugins&#039; );
&nbsp;
/** Allows for the plugins directory to be moved from the default location. @since 2.1.0 */
// Relative to ABSPATH.  For back compat.
//!defined(&#039;PLUGINDIR&#039;) &amp;&amp; define( &#039;PLUGINDIR&#039;, &#039;wp-content/plugins&#039; );
&nbsp;
/** Number of autosaves to save. TRUE is default and enables post revisions, FALSE disables revisions completely. */
!defined(&#039;WP_POST_REVISIONS&#039;) &amp;&amp; define(&#039;WP_POST_REVISIONS&#039;, 150);
&nbsp;
/* ini_set(&#039;memory_limit&#039;, WP_MEMORY_LIMIT); */
!defined(&#039;WP_MEMORY_LIMIT&#039;) &amp;&amp; define(&#039;WP_MEMORY_LIMIT&#039;, &#039;64M&#039;);
&nbsp;
/** Only check at this interval for new messages. Default is 5min */
/** @since 2.9  */
!defined(&#039;WP_MAIL_INTERVAL&#039;) &amp;&amp; define(&#039;WP_MAIL_INTERVAL&#039;, 3600); // 1 hour
&nbsp;
/** Saves updated post values to post from edit window every x seconds. (default 60)
 * When editing a post, WordPress uses Ajax to auto-save revisions to the post as you edit. You may want to increase this setting for longer delays in between auto-saves, or decrease the setting to make sure you never lose changes.
 * @since 2.5.0 */
!defined( &#039;AUTOSAVE_INTERVAL&#039; ) &amp;&amp; define( &#039;AUTOSAVE_INTERVAL&#039;, 60 );
&nbsp;
/** @since 2.9.0  */
/** Permanently deletes posts, pages, attachments, and comments which have been in the trash for EMPTY_TRASH_DAYS. */
!defined( &#039;EMPTY_TRASH_DAYS&#039; ) &amp;&amp; define( &#039;EMPTY_TRASH_DAYS&#039;, 300 );</pre>
<hr class="C" />
<h2>Debugging WordPress</h2>
<p>One of my secrets for getting really good at this stuff is to master debugging.  There is really not ever a time when I am working on a site that I don&#8217;t have <a href="http://www.askapache.com/security/elite-log-file-scrolling-with-color-syntax.html">color-highlighted logs scrolling automatically in an ssh window</a>.  It&#8217;s really almost impossible to fix problems with wordpress or do any kind of advanced anything without being able to view debugging info.  At first I relied heavily on a <a href="http://www.askapache.com/php/custom-phpini-tips-and-tricks.html">custom php.ini</a> being available on the server, but after having to deal with many hosts who don&#8217;t allow <code>php.ini</code> files I now rely completely on setting values using <a href="http://php.net/manual/en/function.ini-set.php">ini_set</a> for ultimate portability. Detailed towards the end of this article and is also included in this <code>wp-config.php</code></p>
<pre>/**#@+
 * DEBUGGING STUFF
 */
/** display of notices during development. if false, error_reporting is E_ERROR | E_WARNING | E_PARSE | E_USER_ERROR | E_USER_WARNING | E_RECOVERABLE_ERROR otherwise E_ALL */
!defined(&#039;WP_DEBUG&#039;) &amp;&amp; define(&#039;WP_DEBUG&#039;, false);
&nbsp;
/** The SAVEQUERIES definition saves the database queries to a array and that array can be displayed to help analyze those queries.
 *  The information saves each query, what function called it, and how long that query took to execute.  */
!defined(&#039;SAVE_QUERIES&#039;) &amp;&amp; define(&#039;SAVE_QUERIES&#039;, WP_DEBUG);
&nbsp;
!defined(&#039;ACTION_DEBUG&#039;) &amp;&amp; define(&#039;ACTION_DEBUG&#039;, WP_DEBUG);
&nbsp;
/** This will allow you to edit the scriptname.dev.js files in the wp-includes/js and wp-admin/js directories.  */
!defined(&#039;SCRIPT_DEBUG&#039;) &amp;&amp; define(&#039;SCRIPT_DEBUG&#039;, WP_DEBUG);

&nbsp;
/** Add define(&#039;WP_DEBUG_LOG&#039;, true); to enable php debug logging to WP_CONTENT_DIR/debug.log */
//!defined(&#039;WP_DEBUG_LOG&#039;) &amp;&amp; define(&#039;WP_DEBUG_LOG&#039;, true);
&nbsp;
/** This determines whether errors should be printed to the screen as part of the output or if they should be hidden from the user.
 *  Add define(&#039;WP_DEBUG_DISPLAY&#039;, false); to wp-config.php to use the globally configured setting for display_errors and not force it to On */
!defined(&#039;WP_DEBUG_DISPLAY&#039;) &amp;&amp; define(&#039;WP_DEBUG_DISPLAY&#039;, false);</pre>
<hr class="C" />
<h2>Ultimate Security Tweaks</h2>
<p>Well, ultimate for WP&#8217;s built-in keys and password functions, this is all for wp-config.php keep in mind.  This is a very neccessary and recommended step, and is one of the only things I modify for each new installation.</p>
<h3>Security KEYS</h3>
<p>If like me you are familiar with password-cracking software like John the ripper, rainbow hash tables, l0pht-crack, etc.. then you will like to know that you can specify your own keys and salts for the encryption used by WP.  They are <code>AUTH_KEY</code>, <code>AUTH_SALT</code>, <code>SECURE_AUTH_KEY</code>, <code>SECURE_AUTH_SALT</code>, <code>LOGGED_IN_KEY</code>, <code>LOGGED_IN_SALT</code>, <code>NONCE_KEY</code>, <code>NONCE_SALT</code>, <code>SECRET_KEY</code> and <code>SECRET_SALT</code>.</p>
<p>A random and long key gives you better encryption, and exponentially increasing that is using a random and long salt for the encryption.  Encryptions with known salts are incredibly easy to decrypt compared to encryptions with secure salts, because the salt + key individually need to be guessed in order to find a matching hash, vs. just the key if the salt is known.  See: <a href="http://www.askapache.com/security/locating-weak-passwords.html">Locating weak passwords</a>.</p>
<blockquote>
<p>A secret key is a hashing salt which makes your site harder to hack and access harder to crack by adding random elements to the password.</p>
<p>In simple terms, a secret key is a password with elements that make it harder to generate enough options to break through your security barriers. A password like &#8220;password&#8221; or &#8220;test&#8221; is simple and easily broken. A random, unpredictable password such as &#8220;88a7da62429ba6ad3cb3c76a09641fc&#8221; takes years to come up with the right combination.</p>
</blockquote>
<p>For more information on the technical background and breakdown of secret keys and secure passwords, see: </p>
<ul>
<li><a href="http://wordpress.org/support/topic/170987">WordPress Support Forum &#8211; HOWTO: Set up secret keys in WordPress 2.6+</a></li>
<li><a href="http://en.wikipedia.org/wiki/Password_cracking">Wikipedia&#8217;s explanation of Password Cracking</a></li>
</ul>
<p>I like to use the <a href="https://api.wordpress.org/secret-key/1.1/">WordPress.org secret-key service</a> 4 times.  That&#8217;s because for each key and salt I like to do: (1 key from api +random keyboard input+1 key from api).</p>
<pre>/**#@+
 * Authentication Unique Keys.
 *
 * Change these to different unique phrases!
 * You can generate these using the {@link https://api.wordpress.org/secret-key/1.1/ WordPress.org secret-key service}
 * You can change these at any point in time to invalidate all existing cookies.
 * This will force all users to have to log in again.
 *
 * @since 2.6.0
 *
 * Get salt to add to hashes to help prevent attacks.
 *
 * The secret key is located in two places: the database in case the secret key
 * isn&#039;t defined in the second place, which is in the wp-config.php file. If you
 * are going to set the secret key, then you must do so in the wp-config.php
 * file.
 *
 * The secret key in the database is randomly generated and will be appended to
 * the secret key that is in wp-config.php file in some instances. It is
 * important to have the secret key defined or changed in wp-config.php.
 *
 * If you have installed WordPress 2.5 or later, then you will have the
 * SECRET_KEY defined in the wp-config.php already. You will want to change the
 * value in it because hackers will know what it is. If you have upgraded to
 * WordPress 2.5 or later version from a version before WordPress 2.5, then you
 * should add the constant to your wp-config.php file.
 *
 * Below is an example of how the SECRET_KEY constant is defined with a value.
 * You must not copy the below example and paste into your wp-config.php. If you
 * need an example, then you can have a
 * {@link https://api.wordpress.org/secret-key/1.1/ secret key created} for you.
 *
 * Salting passwords helps against tools which has stored hashed values of
 * common dictionary strings. The added values makes it harder to crack if given
 * salt string is not weak.
 *
 * @since 2.5
 * @link https://api.wordpress.org/secret-key/1.1/ Create a Secret Key for wp-config.php
 *
 * @return string Salt value from either &#039;SECRET_KEY&#039; or &#039;secret&#039; option
 */
define(&#039;AUTH_KEY&#039;,        &#039;jflkhaskljdfhkljasdhflkjashd;flkjhas;djfh;kajshdflkjashdlfkjhasdlkfhal?p[B+GR{@&gt;{Yq`c|LnG;dvq#| %OA_cbBSU6,rICC1o/c)-|&#039;);
define(&#039;SECURE_AUTH_KEY&#039;, &#039;jflkhaskljdfhkljasdhflkjashd;flkjhas;djfh;kajshdflkjashdlfkjhasdlkfhal?Vp[Bb15baar8&amp;R-r&lt;[T|?(xhJJABGq+Ux+U$)-Hltp/&#039;);
define(&#039;LOGGED_IN_KEY&#039;,   &#039;jflkhaskljdfhkljasdhflkjashd;flkjhas;djfh;kajshdflkjashdlfkjhasdlkfhal?Vp[B&lt;5n6DG|YWnJ9tY2!M1L)`{-$LW~~Ia%.uCbn!P. 41o2$Z$4&#039;);
define(&#039;NONCE_KEY&#039;,       &#039;jflkhaskljdfhkljasdhflkjashd;flkjhas;djfh;kajshdflkjashdlfkjhasdlkfhal?Vp[Bgu&lt;wM*zewR0.{+m:bmrB?wj!B,4]Wo+4 Avk ApR-D?E&#039;);
define(&#039;SECRET_KEY&#039;,     &#039;jflkhaskljdfhkljasdhflkjashd;flkjhas;djfh;kajshdflkjashdlfkjhasdlkfhal?Vp[B52ugH6muE9r4._iZwoYKUybrqLPpv|d Xr+|yrqhUE&#039;);
&nbsp;
define(&#039;AUTH_SALT&#039;,        &#039;123423190847olqkfhladhfsldshafasdfasdf09a7f-90a87df98adfyapoiyaf9asd8f70a9s8d7f908a7sdf97W4qCdm~Ky%+%~PPa5b YEmDI%U[W!-B&#039;);
define(&#039;SECURE_AUTH_SALT&#039;, &#039;123423190847olqkfhladhfsldshafasdfasdf09a7f-90a87df98adfyapoiyaf9asd8f70a9s8d7f908a7sdf97W4qCdmad/7o6.AU3%9o-|Kqm]+eUqr-n~:ag&#039;);
define(&#039;LOGGED_IN_SALT&#039;,   &#039;123423190847olqkfhladhfsldshafasdfasdf09a7f-90a87df98adfyapoiyaf9asd8f70a9s8d7f908a7sdf97W4qCdmsLiCv@KJ{#wd(?qe(KcH3!&#039;);
define(&#039;NONCE_SALT&#039;,       &#039;123423190847olqkfhladhfsldshafasdfasdf09a7f-90a87df98adfyapoiyaf9asd8f70a9s8d7f908a7sdf97W4qCdmG9&gt;+wm 2)bS0Pd_+1rx0brX]ND8|&#039;);
define(&#039;SECRET_SALT&#039;,      &#039;123423190847olqkfhladhfsldshafasdfasdf09a7f-90a87df98adfyapoiyaf9asd8f70a9s8d7f908a7sdf97W4qCdm2&lt;&gt;))U|sty)+4vpWooKls/^[vN&#039;);
/**#@-*/</pre>
<hr class="C" />
<h2>Using SSL for Admin and Login</h2>
<p>SSL is kinda required from my point of view, it is just way to easy to sniff data off the wire otherwise.  At least with SSL you force them to use tools like burpsuite, paros proxy, webscarab, etc..</p>
<pre>/** @since 2.6.0  */
!defined(&#039;FORCE_SSL_ADMIN&#039;) &amp;&amp; define(&#039;FORCE_SSL_ADMIN&#039;, true);
&nbsp;
/** @since 2.6.0  */
!defined(&#039;FORCE_SSL_LOGIN&#039;) &amp;&amp; define(&#039;FORCE_SSL_LOGIN&#039;, true);</pre>
<h3>Mod_Rewrite to Force SSL</h3>
<p>This is pretty cool, it forces non-https for all urls except for /wp-admin and wp-login.php, which both require https.  It also checks for the logged_in_cookie, and if that is present in the request then it doesn't force non-https.  Kinda confusing if you don't have a <a href="http://www.askapache.com/htaccess/mod_rewrite-variables-cheatsheet.html">mod_rewrite cheatsheet</a>.</p>
<pre>RewriteCond %{THE_REQUEST} ^$ [OR]
RewriteCond %{REQUEST_URI} ^/(wp-admin|wp-login\.php).*$ [NC,OR]
RewriteCond %{HTTP_COOKIE} ^.*wp_li_sadfsdfasdf11b361cdsdfasdfasd=.*$ [NC]
RewriteRule .* - [S=1]
&nbsp;
RewriteCond %{HTTPS} =on [OR]
RewriteCond %{HTTP_HOST} !^www\.askapache\.com$ [NC]
RewriteRule .* http://%{SERVER_NAME}%{REQUEST_URI} [R=301,L]
&nbsp;
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /(wp-admin/.*|wp-login\.php.*)\ HTTP/ [NC]
RewriteCond %{HTTPS} !=on
RewriteRule .* https://%{SERVER_NAME}%{REQUEST_URI} [R=301,L]</pre>
<hr class="C" />
<h2>File System Permissions</h2>
<p><a class="IFR" href="http://www.askapache.com/security/chmod-umask-fileperms-stat-tricks.html"><img src="http://uploads.askapache.com/2008/11/danger-chmod-screenshot.png" alt="chmod, umask, file permissions test" title="chmod, umask, file permissions test" /></a>You can get a basic and solid intro on file permissions by reading: <a href="http://codex.wordpress.org/Changing_File_Permissions">Changing File Permissions</a>, or you can check out some of my <a href="http://www.askapache.com/security/chmod-umask-fileperms-stat-tricks.html">file permission research</a>.<br class="C" />
</p>
<pre>/** The permissions as octal number, usually 0644 for files, 0755 for dirs.
 *  http://codex.wordpress.org/Changing_File_Permissions
 *  if ( !$wp_filesystem-&gt;mkdir($remote_destination, FS_CHMOD_DIR) )
 */
!defined(&#039;FS_CHMOD_DIR&#039;) &amp;&amp; define(&#039;FS_CHMOD_DIR&#039;, (0755 &amp; ~ umask()));
!defined(&#039;FS_CHMOD_FILE&#039;) &amp;&amp; define(&#039;FS_CHMOD_FILE&#039;, (0644 &amp; ~ umask()));
/**#@-*/
&nbsp;
/** Define the timeouts for the connections. Only available after the construct is called to allow for per-transport overriding of the default. */
//stream_set_timeout( $stream, FS_TIMEOUT );
//!defined(&#039;FS_TIMEOUT&#039;) &amp;&amp; define(&#039;FS_TIMEOUT&#039;, 30);
&nbsp;
//$this-&gt;link = @ftp_connect($this-&gt;options[&#039;hostname&#039;], $this-&gt;options[&#039;port&#039;], FS_CONNECT_TIMEOUT);
//!defined(&#039;FS_CONNECT_TIMEOUT&#039;) &amp;&amp; define(&#039;FS_CONNECT_TIMEOUT&#039;, 30);
&nbsp;
// function get_filesystem_method($args = array(), $context = false) {
//  $method = defined(&#039;FS_METHOD&#039;) ? FS_METHOD : false; //Please ensure that this is either &#039;direct&#039;, &#039;ssh&#039;, &#039;ftpext&#039; or &#039;ftpsockets&#039;
//!defined(&#039;FS_METHOD&#039;) &amp;&amp; define(&#039;FS_METHOD&#039;, &#039;direct&#039;);
&nbsp;
/** These methods for the WordPress core, plugin, and theme upgrades try to determine the WordPress path, as reported by PHP, but symlink trickery can sometimes
 * &#039;muck this up&#039; so if you know the paths to the various folders on the server, as seen via your FTP user, you can manually define them in the wp-config.php file.
 * FS_METHOD forces the filesystem method. It should only be &quot;direct&quot;, &quot;ssh&quot;, &quot;ftpext&quot;, or &quot;ftpsockets&quot;.
 * FTP_BASE is the full path to the &quot;base&quot; folder of the WordPress installation.
 * FTP_CONTENT_DIR is the full path to the wp-content folder of the WordPress installation.
 * FTP_PLUGIN_DIR is the full path to the plugins folder of the WordPress installation.
 * FTP_PUBKEY is the full path to your SSH public key.
 * FTP_PRIKEY is the full path to your SSH private key.
 * FTP_USER is either user FTP or SSH username. Most likely these are the same, but use the appropriate one for the type of update you wish to do.
 * FTP_PASS is the password for the username entered for FTP_USER. If you are using SSH public key authentication this can be omitted.
 * FTP_HOST is the hostname:port combination for your SSH/FTP server. The standard FTP port is 21 and the standard SSH port is 22.
 */
//define(&#039;FS_METHOD&#039;, &#039;ftpext&#039;);
//define(&#039;FTP_BASE&#039;, &#039;/path/to/wordpress/&#039;);
//define(&#039;FTP_CONTENT_DIR&#039;, &#039;/path/to/wordpress/wp-content/&#039;);
//define(&#039;FTP_PLUGIN_DIR &#039;, &#039;/path/to/wordpress/wp-content/plugins/&#039;);
//define(&#039;FTP_PUBKEY&#039;, &#039;/home/username/.ssh/id_rsa.pub&#039;);
//define(&#039;FTP_PRIKEY&#039;, &#039;/home/username/.ssh/id_rsa&#039;);
//define(&#039;FTP_USER&#039;, &#039;username&#039;);
//define(&#039;FTP_PASS&#039;, &#039;password&#039;);
//define(&#039;FTP_HOST&#039;, &#039;ftp.example.org:21&#039;);
&nbsp;
/**
 * Block requests through the proxy.
 *
 * Those who are behind a proxy and want to prevent access to certain hosts may do so. This will
 * prevent plugins from working and core functionality, if you don&#039;t include api.wordpress.org.
 *
 * You block external URL requests by defining WP_HTTP_BLOCK_EXTERNAL in your wp-config.php file
 * and this will only allow localhost and your blog to make requests.
 * The constant WP_ACCESSIBLE_HOSTS will allow additional hosts to go through for requests. The format of the
 * WP_ACCESSIBLE_HOSTS constant is a comma separated list of hostnames to allow.
 *
 * @since 2.8.0
 * @link http://core.trac.wordpress.org/ticket/8927 Allow preventing external requests.
/** @since 2.9  */
//!defined(&#039;WP_HTTP_BLOCK_EXTERNAL&#039;) &amp;&amp; define( &#039;WP_HTTP_BLOCK_EXTERNAL&#039;, false );
&nbsp;
/*
 * The constant WP_ACCESSIBLE_HOSTS will allow additional hosts to go through for requests. The format of the
 * WP_ACCESSIBLE_HOSTS constant is a comma separated list of hostnames to allow.
 *
 * @since 2.8.0
 * @link http://core.trac.wordpress.org/ticket/8927 Allow preventing external requests.
 * $accessible_hosts = preg_split(&#039;|,\s*|&#039;, WP_ACCESSIBLE_HOSTS);
 * return !in_array( $check[&#039;host&#039;], $accessible_hosts ); //Inverse logic, If its in the array, then we can&#039;t access it.
 */
//!defined(&#039;WP_ACCESSIBLE_HOSTS&#039;) &amp;&amp; define( &#039;WP_ACCESSIBLE_HOSTS&#039;, &#039;askapache.com,askapache.org&#039; );</pre>
<hr class="C" />
<h3>Cookies!</h3>
<p>There&#8217;s always a little comfort in having non-default cookies for security (against auto-bots), and using shorter names also means smaller HTTP Packets.</p>
<p>The <code>$cookie_hash</code> is my hack to get around the fact that <code>COOKIEHASH</code> isn&#8217;t definable in <code>wp-config</code>.</p>
<pre>/**#@+
 * COOKIES
 * Used to guarantee unique hash cookies @since 1.5 */
$cookie_hash=md5(WP_SITEURL);
&nbsp;
/** Set a cookie now to see if they are supported by the browser.
 * setcookie(TEST_COOKIE, &#039;WP Cookie check&#039;, 0, COOKIEPATH, COOKIE_DOMAIN);
 * @since 2.3.0 */
!defined(&#039;TEST_COOKIE&#039;) &amp;&amp; define(&#039;TEST_COOKIE&#039;, &#039;wp_tc&#039;);
&nbsp;
/* @since 2.6.0 */
!defined(&#039;LOGGED_IN_COOKIE&#039;) &amp;&amp; define(&#039;LOGGED_IN_COOKIE&#039;, &#039;wp_li_&#039; . $cookie_hash);
&nbsp;
/* @since 2.6.0 */
!defined(&#039;SECURE_AUTH_COOKIE&#039;) &amp;&amp; define(&#039;SECURE_AUTH_COOKIE&#039;, &#039;wp_sa_&#039; . $cookie_hash);
&nbsp;
/* @since 2.5.0 */
!defined(&#039;AUTH_COOKIE&#039;) &amp;&amp; define(&#039;AUTH_COOKIE&#039;, &#039;wp_a_&#039; . $cookie_hash);
&nbsp;
/* @since 2.0.0 */
!defined(&#039;PASS_COOKIE&#039;) &amp;&amp; define(&#039;PASS_COOKIE&#039;, &#039;wp_p_&#039; . $cookie_hash);
&nbsp;
/* @since 2.0.0 */
!defined(&#039;USER_COOKIE&#039;) &amp;&amp; define(&#039;USER_COOKIE&#039;, &#039;wp_u_&#039; . $cookie_hash);
&nbsp;
/* ok unset this var, its not needed as COOKIEHASH will have this value, but is not definable in wp-config.php */
unset($cookie_hash);
&nbsp;
/** @since 1.2.0 */
!defined(&#039;COOKIEPATH&#039;) &amp;&amp; define(&#039;COOKIEPATH&#039;, preg_replace(&#039;|https?://[^/]+|i&#039;, &#039;&#039;, WP_HOME . &#039;/&#039; ) );
&nbsp;
/** @since 1.5.0 */
!defined(&#039;SITECOOKIEPATH&#039;) &amp;&amp; define(&#039;SITECOOKIEPATH&#039;, preg_replace(&#039;|https?://[^/]+|i&#039;, &#039;&#039;, WP_SITEURL . &#039;/&#039; ) );
&nbsp;
/** @since 2.6.0 */
!defined(&#039;ADMIN_COOKIE_PATH&#039;) &amp;&amp; define( &#039;ADMIN_COOKIE_PATH&#039;, SITECOOKIEPATH . &#039;wp-admin&#039; );
&nbsp;
/** @since 2.6.0 */
!defined(&#039;PLUGINS_COOKIE_PATH&#039;) &amp;&amp; define( &#039;PLUGINS_COOKIE_PATH&#039;, preg_replace(&#039;|https?://[^/]+|i&#039;, &#039;&#039;, WP_PLUGIN_URL)  );
&nbsp;
/** @since 2.0.0 */
!defined(&#039;COOKIE_DOMAIN&#039;) &amp;&amp; define(&#039;COOKIE_DOMAIN&#039;, $_SERVER[&#039;SERVER_NAME&#039;]);</pre>
<hr class="C" />
<pre>/**
  * The WP_CACHE setting, if true, includes the wp-content/advanced-cache.php script, when executing wp-settings.php.
  * For an advanced caching plugin to use, static because you would only want one
  * if ( defined(&#039;WP_CACHE&#039;) )@include WP_CONTENT_DIR . &#039;/advanced-cache.php&#039;;
  */
!defined(&#039;WP_CACHE&#039;) &amp;&amp; define(&#039;WP_CACHE&#039;, true);
&nbsp;
/** WordPress Localized Language, defaults to en_US.
 *
 * Change this to localize WordPress.  A corresponding MO file for the chosen
 * language must be installed to wp-content/languages. For example, install
 * de.mo to wp-content/languages and set WPLANG to &#039;de&#039; to enable German
 * language support. */
!defined(&#039;WPLANG&#039;) &amp;&amp; define (&#039;WPLANG&#039;, &#039;en_US&#039;);
&nbsp;
/** Stores the location of the language directory. First looks for language folder in WP_CONTENT_DIR
 *   and uses that folder if it exists. Or it uses the &quot;languages&quot; folder in WPINC. @since 2.1.0 */
//!defined(&#039;WP_LANG_DIR&#039;) &amp;&amp; define(&#039;WP_LANG_DIR&#039;, ABSPATH . WPINC . &#039;/languages&#039;);
&nbsp;
/** LANGDIR defines what directory the WPLANG .mo file resides. If LANGDIR is not defined WordPress looks first to wp-content/languages and then wp-includes/languages for the .mo defined by WPLANG file.  Old static relative path maintained for limited backwards compatibility - won&#039;t work in some cases*/
//!defined(&#039;LANGDIR&#039;) &amp;&amp; define(&#039;LANGDIR&#039;, &#039;wp-content/languages&#039;);
&nbsp;
/** Stores the location of the WordPress directory of functions, classes, and core content. @since 1.0.0 */
//!defined(&#039;WPINC&#039;) &amp;&amp; define(&#039;WPINC&#039;, &#039;wp-includes&#039;);</pre>
<hr class="C" />
<h2>WPMU Stuff</h2>
<p>I personally don&#8217;t use.</p>
<pre>/** Allows for the mu-plugins directory to be moved from the default location. @since 2.8.0 */
//!defined(&#039;WPMU_PLUGIN_DIR&#039;) &amp;&amp; define( &#039;WPMU_PLUGIN_DIR&#039;, WP_CONTENT_DIR . &#039;/mu-plugins&#039; ); // full path, no trailing slash
&nbsp;
/** Allows for the mu-plugins directory to be moved from the default location. @since 2.8.0 */
//!defined(&#039;WPMU_PLUGIN_URL&#039;) &amp;&amp; define( &#039;WPMU_PLUGIN_URL&#039;, WP_CONTENT_URL . &#039;/mu-plugins&#039; ); // full url, no trailing slash
&nbsp;
/** Allows for the mu-plugins directory to be moved from the default location. @since 2.8.0 */
//!defined( &#039;MUPLUGINDIR&#039; ) &amp;&amp; define( &#039;MUPLUGINDIR&#039;, &#039;wp-content/mu-plugins&#039; ); // Relative to ABSPATH.  For back compat.</pre>
<hr class="C" />
<h2>WordPress Database</h2>
<p>This is usually the only thing I have to manually edit when creating a new site, unless I just use the same DB and modify the $table_prefix, (farther down). I run everything I possibly can in UTF-8, but if you don&#8217;t already know alot about character sets, wow it is one of the most confusing things so you may want to save learning about that topic for another day.  Otherwise the following are helpful (<em>and show how confusing character sets are!</em>)</p>
<ul>
<li><a href="http://dev.mysql.com/doc/refman/5.0/en/charset-charsets.html">Character Sets and Collations MySQL Support</a></li>
<li><a href="http://codex.wordpress.org/Converting_Database_Character_Sets">Converting Database Character Sets</a></li>
<li><a href="http://dev.mysql.com/doc/refman/5.0/en/charset-unicode-sets.html">UTF-8 character sets</a> (<a href="http://en.wikipedia.org/wiki/UTF-8">UTF-8</a>)</li>
</ul>
<p>If you ever setup WP to use the builtin membership features, make sure you learn about the <code>CUSTOM_USER_TABLE</code> and <code>CUSTOM_USER_META_TABLE</code> constants, I&#8217;ve found them very helpful.</p>
<pre>/**#@+
 * MySQL settings
 */
/** The name of the database for WordPress */
define(&#039;DB_NAME&#039;, &#039;askapachewpblog75&#039;);
&nbsp;
/** The username to access the database */
define(&#039;DB_USER&#039;, &#039;askapache245d&#039;);
&nbsp;
/** The password for the username to access the database */
define(&#039;DB_PASSWORD&#039;, &#039;asdfklj2340&#039;);
&nbsp;
/** The hostname to connect to the database at */
define(&#039;DB_HOST&#039;, &#039;mysql.askapache.com&#039;);
&nbsp;
/** The charset of the database */
define(&#039;DB_CHARSET&#039;, &#039;utf8&#039;);
&nbsp;
/** The collation of the database */
define(&#039;DB_COLLATE&#039;, &#039;utf8_general_ci&#039;);</pre>
<hr class="C" />
<h2>$table_prefix</h2>
<p>The <code>$table_prefix</code> is the value placed in the front of your database tables. Change the value if you want to use something other than wp_ for your database prefix. Typically this is changed if you are <a href="http://codex.wordpress.org/Installing_Multiple_Blogs">installing multiple WordPress blogs</a> in the same database, and also for enhanced security.</p>
<p>Its a safe and good idea to change this value pre-installation to add more security to your WordPress blog. Exploits attempted against your WordPress blog by malicious crackers often are built with the premise that your blog uses the prefix wp_, by changing the value you mitigate some attack vectors. </p>
<pre>/**
 * WordPress Database Table prefix.
 *
 * You can have multiple installations in one database if you give each a unique
 * prefix. Only numbers, letters, and underscores please!
 */
$table_prefix  = &#039;ar15_&#039;;
&nbsp;
/** CUSTOM_USER_TABLE and CUSTOM_USER_META_TABLE are used to designated that the user and usermeta tables normally utilized by WordPress are not used, instead these values/tables are used to store your user information. */
//!defined(&#039;CUSTOM_USER_TABLE&#039;) &amp;&amp; define(&#039;CUSTOM_USER_TABLE&#039;, $table_prefix . &#039;my_users&#039;);
//!defined(&#039;CUSTOM_USER_META_TABLE&#039;) &amp;&amp; define(&#039;CUSTOM_USER_META_TABLE&#039;, $table_prefix . &#039;my_usermeta&#039;);</pre>
<h2>Setup PHP Ini Settings</h2>
<pre>&nbsp;
/** Turns the output of errors on or off, you really never want this on, you should only view errors by reading the log file. */
ini_set(&#039;display_errors&#039;, WP_DEBUG_DISPLAY);
&nbsp;
/** Tells whether script error messages should be logged to the server&#039;s error log or error_log. */
ini_set(&#039;log_errors&#039;, &#039;On&#039;);
&nbsp;
/** http://us.php.net/manual/en/timezones.php */
ini_set(&#039;date.timezone&#039;, &#039;America/Indianapolis&#039;);
&nbsp;
/** Where to log php errors */
ini_set(&#039;error_log&#039;, ASKAPACHE_ROOT . &#039;/logs/php_error.log&#039;);
&nbsp;
/** Set the memory limit, otherwise defaults to &#039;32M&#039; */
ini_set(&#039;memory_limit&#039;, WP_MEMORY_LIMIT);</pre>
<h2>Sessions are slow</h2>
<p>So I only use sessions when I have a specific use&#8230; In this case I need sessions only when one of the tools in the /online-tools/ directory is being used.  And that is for the <a href="http://www.askapache.com/security/php-captcha-anti-spam-example.html">captcha image</a>.  In the future I won&#8217;t ever use sessions.</p>
<pre>if(preg_match( &#039;#^/online-tools/#&#039;,$_SERVER[&#039;REQUEST_URI&#039;])) session_start();</pre>
<h2>Include Custom Files</h2>
<p>Sure you could use the my-hacks.php that WP allows, or you can just stick your functions in your <code>TEMPLATEPATH/functions.php</code> file, but they are executed only after the wp-settings.php file, which may be too late for your file.</p>
<p>In the past I&#8217;ve also used the <a href="http://us2.php.net/manual/en/ini.core.php#ini.auto-prepend-file">auto_prepend_file</a> settings to run my script before anything (index.php) but I ran into some issues on different hosts, and it wasn&#8217;t as portable.</p>
<p>This is useful because you can have a file with globally available functions that you can use in non-WP areas as well as WP areas.  I am moving away from this more and more as I learn more about classes and build plugins instead for portability.</p>
<pre>include_once ASKAPACHE_ROOT . &#039;/includes/myfunctions.inc&#039;;
&nbsp;
/** Sets up WordPress vars and included files. */
require_once(ABSPATH . &#039;wp-settings.php&#039;);
?&gt;</pre>
<h2>Some Useful PHP</h2>
<p>I am constantly trying to make my sites and code more portable, so I am using plugins alot more to accomplish things that I use to do with separate php.  Here are some examples of minimal php.</p>
<pre>add_filter(&quot;the_generator&quot;, create_function(&#039;$a&#039;,&#039;return &quot;&quot;;&#039;));
add_filter(&#039;the_content&#039;, create_function(&#039;$a&#039;, &#039;return ((is_feed())? $a.&quot;&lt;p&gt;&lt;a href=\&quot;&quot;.get_permalink().&quot;\&quot;&gt;&quot;.get_the_title().&quot;&lt;/a&gt; originally appeared on &quot;.get_bloginfo(&quot;name&quot;).&quot;.&lt;/p&gt;&quot; : $a);&#039;), 99999);
add_filter(&#039;excerpt_length&#039;, create_function(&#039;$a&#039;, &#039;return 300;&#039;),99);
add_filter(&#039;excerpt_more&#039;, create_function(&#039;$a&#039;, &#039;return &quot;&amp;hellip;&quot;;&#039;),99);
add_action( &#039;wp_head&#039;, create_function(&#039;$a&#039;,&#039;echo &quot;&lt;link rel=\&quot;pingback\&quot; href=\&quot;&#039;.get_bloginfo(&#039;pingback_url&#039;).&#039;\&quot; /&gt;\n&quot;;&#039;), 95 );
add_action( &#039;wp_head&#039;, create_function(&#039;$a&#039;,&#039;echo &quot;&lt;link rel=\&quot;schema.rss\&quot; href=\&quot;http://purl.org/rss/1.0/\&quot; /&gt;\n&quot;;&#039;), 96 );
add_action( &#039;wp_head&#039;, create_function(&#039;$a&#039;,&#039;echo &quot;&lt;link rel=\&quot;schema.rel\&quot; href=\&quot;http://purl.org/vocab/relationship/\&quot; /&gt;\n&quot;;&#039;), 97 );
add_action( &#039;wp_head&#039;, create_function(&#039;$a&#039;,&#039;echo &quot;&lt;link rel=\&quot;meta\&quot; type=\&quot;application/rdf+xml\&quot; href=\&quot;/foaf.rdf\&quot; /&gt;\n&quot;;&#039;), 98 );
add_action( &#039;wp_head&#039;, create_function(&#039;$a&#039;,&#039;echo &quot;&lt;link href=\&quot;/favicon.ico\&quot; rel=\&quot;shortcut icon\&quot; type=\&quot;image/x-icon\&quot; /&gt;\n&quot;;&#039;), 99 );</pre>
<h2>Debugging Note</h2>
<p><a href="http://wordpress.org/extend/plugins/askapache-debug-viewer/screenshots/"><img alt="AskApache Advanced Debugging Output" src="http://s.wordpress.org/extend/plugins/askapache-debug-viewer/screenshot-1.png?r=160129" title="AskApache Advanced Debugging Output" width="625" height="548" /></a>If you read this far than you probably know how important debugging is, but I sometimes like to stick the best tips deep in my articles to make sure only YOU find it.  GRTFM isn&#8217;t used on this site, it&#8217;s mostly a requirement because my writing can get pretty bad..  The point, debugging is more than a crucial requirement if you want to do anything cool.  Don&#8217;t worry I got you.. check my <a href="http://wordpress.org/extend/plugins/askapache-debug-viewer/">AskApache Debug Viewer Plugin from the official WP site</a>.  It&#8217;s pretty close to providing as verbose amount of information that I could possibly figure out how to get out of php, probably more than you have ever seen at least, I focused on quantity.  I use it all the time on new installs as there is no setup required and it tells me advanced information about the setup of the server, hacker code for sure.<br class="C" />
</p>
<p>Here&#8217;s a quick function to see set global vars, I just think this is interesting code.</p>
<pre>function askapache_global_debug(){
  global $_GET,$_POST,$_COOKIE,$_SESSION,$_ENV,$_FILES,$_SERVER,$_REQUEST,$HTTP_POST_FILES,$HTTP_POST_VARS,$HTTP_SERVER_VARS,$HTTP_RAW_POST_DATA,$HTTP_GET_VARS,$HTTP_COOKIE_VARS,$HTTP_ENV_VARS;
  $gv=create_function(&#039;$n&#039;,&#039;global $$n; ob_start(); if ( is_array($$n) &amp;&amp; sizeof($$n)&gt;0 &amp;&amp; print(&quot;[{$n}]\n&quot;) ) print_r($$n);return ob_get_clean();&#039;);
  foreach (array(&#039;_GET&#039;,&#039;_POST&#039;,&#039;_COOKIE&#039;,&#039;_SESSION&#039;,&#039;_ENV&#039;,&#039;_FILES&#039;,&#039;_SERVER&#039;,&#039;_REQUEST&#039;,&#039;HTTP_POST_FILES&#039;,&#039;HTTP_POST_VARS&#039;,&#039;HTTP_SERVER_VARS&#039;,&#039;HTTP_RAW_POST_DATA&#039;,&#039;HTTP_GET_VARS&#039;,&#039;HTTP_COOKIE_VARS&#039;,&#039;HTTP_ENV_VARS&#039;) as $k)echo $gv($k);
  print_r(get_defined_constants());
}</pre>
<p class="anote">Also check the WordPress Codex page: <a href="http://codex.wordpress.org/Editing_wp-config.php">Editing wp-config.php</a> and Perishable Press&#8217;s: <a href="http://perishablepress.com/press/2009/12/01/stupid-wordpress-tricks/">Stupid WordPress Tricks</a></p>
<p><a href="http://www.askapache.com/wordpress/advanced-wp-config-php-tweaks.html"></a><a href="http://www.askapache.com/wordpress/advanced-wp-config-php-tweaks.html">Advanced WordPress wp-config.php Tweaks</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/YPWuVAsst5Snarv9V_tGe7yLG88/0/da"><img src="http://feedads.g.doubleclick.net/~a/YPWuVAsst5Snarv9V_tGe7yLG88/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/YPWuVAsst5Snarv9V_tGe7yLG88/1/da"><img src="http://feedads.g.doubleclick.net/~a/YPWuVAsst5Snarv9V_tGe7yLG88/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=I3-QaJt-u1Q:cTfaWD2XFFE:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=I3-QaJt-u1Q:cTfaWD2XFFE:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=I3-QaJt-u1Q:cTfaWD2XFFE:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=I3-QaJt-u1Q:cTfaWD2XFFE:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=I3-QaJt-u1Q:cTfaWD2XFFE:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=I3-QaJt-u1Q:cTfaWD2XFFE:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=I3-QaJt-u1Q:cTfaWD2XFFE:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/wordpress/advanced-wp-config-php-tweaks.html/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		<feedburner:origLink>http://www.askapache.com/wordpress/advanced-wp-config-php-tweaks.html</feedburner:origLink></item>
		<item>
		<title>PortaPutty Auto-Reconnecting SSH Tunnels on an Encrypted TrueCrypt Portable USB Key w GPG</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/gQt9eNHOBbI/ssh-tunnels-truecrypt-gpg.html</link>
		<comments>http://www.askapache.com/hacking/ssh-tunnels-truecrypt-gpg.html#comments</comments>
		<pubDate>Tue, 23 Feb 2010 10:11:11 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Making Money]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Web Design]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Web Tools]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WiredTree]]></category>
		<category><![CDATA[401]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[ASP]]></category>
		<category><![CDATA[Backups]]></category>
		<category><![CDATA[Bandwidth]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[bash_profile]]></category>
		<category><![CDATA[Boot]]></category>
		<category><![CDATA[compression]]></category>
		<category><![CDATA[curl]]></category>
		<category><![CDATA[Defrag]]></category>
		<category><![CDATA[Email]]></category>
		<category><![CDATA[encryption]]></category>
		<category><![CDATA[filesystem]]></category>
		<category><![CDATA[Firefox]]></category>
		<category><![CDATA[Flash]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[Google]]></category>
		<category><![CDATA[GPG]]></category>
		<category><![CDATA[Hard Drive]]></category>
		<category><![CDATA[ionice]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Login]]></category>
		<category><![CDATA[Nice]]></category>
		<category><![CDATA[PageDefrag]]></category>
		<category><![CDATA[password]]></category>
		<category><![CDATA[Performance]]></category>
		<category><![CDATA[Pipelining]]></category>
		<category><![CDATA[Plink]]></category>
		<category><![CDATA[Port]]></category>
		<category><![CDATA[post]]></category>
		<category><![CDATA[Prompt]]></category>
		<category><![CDATA[Putty]]></category>
		<category><![CDATA[ram]]></category>
		<category><![CDATA[rsync]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[Shell]]></category>
		<category><![CDATA[SOCKS]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSH]]></category>
		<category><![CDATA[SSH Tunnels]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[trick]]></category>
		<category><![CDATA[TrueCrupt]]></category>
		<category><![CDATA[tutorial]]></category>
		<category><![CDATA[USB Drives]]></category>

		<guid isPermaLink="false">http://askapache.com/?p=4001</guid>
		<description><![CDATA[<p><a class="IFL" id="id6" href="http://www.askapache.com/hacking/ssh-tunnels-truecrypt-gpg.html"></a>Ok I just came back up to write the intro.. I'm trying to keep it short to avoid getting bogged down by the coolness of each step.  Here is what goes on.   When I logon to my XP machine at work, I bring my usb key and plug it in first.  On logging a window pops up first and it's a password prompt to mount my encrypted drive leonardo.  It also checks a keyfile that is located on my usb key, but all I do now is type in my password.  That causes my encrypted folder to be accessible to me like a normal drive, and it autoruns a startup batch file. <br /><br />The batch file causes <strong>Portable</strong> versions of Firefox (<em>all my bookmarks, my settings</em>) to load, and launches <strong>Portable</strong> Mozilla Thunderbird (IMAP makes this work well), which is my favorite program (<em>great GPG features and open-source!</em>).  Also Some Adobe CS4 software is loaded from the hard drive, like DreamWeaver.  In the background, a service we created executes a PortaPuttY plink command to create forwarded tunnels from various remote servers and accounts, all using key-based encryption.  These tunnels are automatically reconnected if they are disconnected, meaning you can use a socks 5 if you want or even better!<br class="C" /></p>
<p><strong>Part 1 of 5</strong></p>]]></description>
			<content:encoded><![CDATA[<p><a id="id6" class="IFL" href="http://www.tigerdirect.com/applications/SearchTools/item-details.asp?EdpNo=4329073&#038;CatId=3786" title="This ones over $400 dollars! 128GB!"></a>Ok I just came back up to write the intro.. I&#8217;m trying to keep it short to avoid getting bogged down by the coolness of each step.  Here is what goes on.   When I logon to my XP machine at work, I bring my usb key and plug it in first.  On logging a window pops up first and it&#8217;s a password prompt to mount my encrypted drive leonardo.  It also checks a keyfile that is located on my usb key, but all I do now is type in my password.  That causes my encrypted folder to be accessible to me like a normal drive, and it autoruns a startup batch file.  The batch file causes <strong>Portable</strong> versions of Firefox (<em>all my bookmarks, my settings</em>) to load, and launches <strong>Portable</strong> Mozilla Thunderbird (IMAP makes this work well), which is my favorite program (<em>great GPG features and open-source!</em>).  Also Some Adobe CS4 software is loaded from the hard drive, like DreamWeaver.<br class="C" /></p>
<p>The batch file also runs PortaPuttY plink to create forwarded tunnels from various remote servers and accounts, all using key-based encryption.  This includes dynamic SOCKS 4/5 tunnels, VPN tun device tunnels, and of course the basic SSH port forwarding tunnels that are so powerful.  These tunnels are automatically reconnected if they are disconnected, using simple windows builtin command-line tools.  And believe me it was not easy to figure out how to make this all work using plink ( essentially the same as putty minus the gui ), I literally had to use almost all of my Windows kung fu to finally end up with this.</p>
<h2>Using MyEnTunnel</h2>
<p>Initially I was using the <a href="http://nemesis2.qx.net">MyEnTunnel</a> program combined with a custom windows batch install script I wrote to handle the tunnels.</p>
<p>The tunnels are very important to making things easy while improving security.  It&#8217;s not easy to understand at first, but basically it means <strong>you can now connect to ANY IP address:port as if you were on that very machine connecting to localhost, like if you pinged yourself!</strong>.  The result is any traffic you want is now encrypted, and you can set up your servers to only accept connections from localhost, which could save you tons of memory, bandwidth, and security attack vectors to think about.   So I configure everything to use these tunnels as proxies, like Mozilla Thunderbird and Chrome, Firefox, Pidgeon, all portable versions and running from my encrypted usb drive.</p>
<p>This means you can walk into my house with that usb key, plug into any computer here, and surf the web/check your emails all across SSH&#8230; I know for a fact <strong>I wouldn&#8217;t be able to snoop that</strong> traffic!  There is a lot of exciting things going on around here, new servers and all.. Its going to take a couple more posts for me to finish this up, enjoy the article and comment.</p>
<h2>Buy a couple USB Mini Drives</h2>
<p>The first thing to do, is purchase a USB thumb drive..   My favorite store, <a href="http://www.tigerdirect.com/applications/category/category_slc.asp?Recs=30&#038;Nav=|c:379|lp:0.01:hp:24.99|&#038;Sort=4" title="Highly recommended, this is not an affiliate link">TigerDirect.com</a>, has over 104 tiny usb drives for under $24.. I&#8217;ve used them since the late 90&#8242;s.</p>
<p>I bought some 4GB PNY&#8217;s the size of a fingernail at a gas station and they are amazing, way faster than say a dvd drive.  Just try to do some research of the differences between the 16GB vs the $4 1GB drives.. You want speed because the whole drive will be encrypted.   <em>If you can afford the super excellent and crazy fast ones, hey send me one!</em> Buying cheap means you can buy 3 or 4 so you can always have backups.  This device will make you Internationally mobile, untethered from a box, maybe getting some work done at a cafe in Florenze, or at a beach hotel in Miami.  Keep dreaming, but that is more possible with a better organized system.</p>
<h3>Backup the USB Drive</h3>
<p>You only need to know 1 way that works, there are several.  The way I do backups is to copy the entire disk image of the usb, that way I can always access it in case of usb key failure, which does happen.  Free software like <a href="http://clonezilla.org/">CloneZilla live CD</a> with its crazy cluster computing power, or Self Image, which is free for both linux and Windows.  And you could never go wrong with <a href="http://www.symantec.com/norton/ghost">GHOST</a>, one of the first to make mega bucks in the market.. it&#8217;s some seriously impressive software <em>but not open-source</em>.  Even easier for some is to just set a cron job for dd to pipe the entire drive image to a remote computer using netcat, or sshfs, or curlftpfs, or just <strong>simple ssh</strong> like below.  Once setup (without stupid, bulky, dangerous software), the files on your encrypted usb don&#8217;t change often, otherwise I would want to sync a backup to happen automatically every X number of logins or days (<em>test logfile time in bash_profile?</em>)..</p>
<h4>SSH Back-ups To Remote Server</h4>
<p>Files and data on your drives slow it down tremendously, meaning a web server storing backups locally is slower than one storing them externally.</p>
<p>Notice how much safer this command is by optimizing both the <a href="http://www.askapache.com/linux-unix/optimize-nice-ionice.html">CPU and DISK I/O</a>..  Though it&#8217;s much smarter to create a new separate ssh user, one with no shell and a passwordless safer key-based encryption.  Then in your /etc/security/limits.conf file or your initscript you can cause that user to have <code>nice -19</code> and <code>ionice -c2 -n7</code> priority set all the time automatically, since sshd, compression, and disk writing are this accounts only job.  turboslow is an alias defined in a ssh_config file so you don&#8217;t have to type the host, port, and settings each time.</p>
<pre>#
# much better ways to do this on google!!!!!!!
#
ionice -c2 -n7 nice -n 19 dd if=/dev/sdb2 bs=1k conv=sync,noerror | gzip -c | ssh turboslow &quot;dd of=sdb2.gz bs=1k&quot;</pre>
<p>Note that you may decide it would be better to configure the ssh connection to a less CPU intensive algorithm, perhaps even <em>protocol 1</em> and <em>DES</em>.  That&#8217;s perfectly alright, but the tradeoff is that the encryption can be broken much quicker, and so you would have to implement a cron job to create new keys on both ends of the tunnel every few hours.. It&#8217;s really not a big deal to setup, kind of sweet way to use key-based encryption.  Also, important files ( those containing passwords, any database ) are encrypted before transport using private GPG keys, which don&#8217;t need to be changed.  The other thing to think about too is only letting your main PC send/write on the backup host, so the backup host is only authorized to rx and can never login back to yours. </p>
<p>Hey! the Internet is a dangerous place you better believe it!  And it&#8217;s only going to get more interesting with cloud computing&#8217;s breakthrough&#8217;s&#8230; More people who know they&#8217;re way around&#8230; I can always use an extra server, I&#8217;d love to expand my network another node without having to pay for it (free cloud computing?), so make sure your servers are locked up strenuously.  Not super perfect, just a little unique or creative in your defense to avoid any coming super-worm&#8217;s that may be employing vast arsenals of the deadliest attack-engines like metasploit..  Scarry rumors.</p>
<h4>Compression Speeds: PBZip2, Rzip, Lzop, Gzip</h4>
<p>Probably the fastest is to use rsync over ssh, which is what I&#8217;m doing, since the algorithms used by rsync are much faster and safer.  <a href="http://www.askapache.com/security/mirror-using-rsync-ssh.html">Rsync also lets you specify a compression program</a>, so depending on your machine you will want pbzip2 (for multi processors) or rzip which are the 2 fastest I know of, though I have had some reliability issues with rzip for gigabyte transfers.  Pbzip2 is amazing, blew me away the first time being 8x faster (8 CPUs) then <strong>anything</strong>.  You can get it and compile a static binary for your thumb drive if want at <a href="http://compression.ca/pbzip2/">Parallel BZIP2 (PBZIP2)</a>. Heavy code, re: this note by Jeff Gilchrist</p>
<p><quote><strong>NOTE</strong>: If you are looking for a parallel BZIP2 that works on cluster machines, you should check out <strong>MPIBZIP2</strong> <strong>which was designed for a distributed-memory message-passing architecture</strong>.</quote></p>
<pre>tar cpf &quot;$G&quot; &#45;-use-compress-prog=pbzip2 ./</pre>
<p><a href="http://uploads.askapache.com/2010/02/pbzip2.gif"><img src="http://uploads.askapache.com/2010/02/pbzip2.gif" alt="Parallel BZIP2 (PBZIP2)" title="pbzip2" class="size-medium wp-image-4002" /></a></p>
<h4>Benchmarking for Performance</h4>
<p>Finally a couple tips, you should get an idea what the device can do, format it a few times for linux and test it on windows, and vice versa.. Some drives are too small or too old and can only support fat32 filesystems on winblows, you DO NOT want fat32 because this drive is going to be 100% encrypted and then 100% transparently decrypted as you use it, </p>
<pre># note this is 512MB
dd if=/dev/sda1 of=/dev/null bs=512 count=1000000
512000000 bytes (512 MB) copied, 5.16588 s, 99.1 MB/s</pre>
<h2>Part II:  Encrypted AutoRunning USB Key with TrueCrypt</h2>
<p>Now this section anyone can do, it&#8217;s so easy on Windows.   What I&#8217;m going to show you how to do is get setup the right way super-fast.  There are many ways to use TrueCrypt, it&#8217;s one of the nicest built software programs&#8217;s I&#8217;ve ever used&#8230; Sadly, it is not licensed open-source, and that is often a deal-breaker for security-conscious folks or anti-pirate anarchists.  From the very helpful TrueCrypt web site:</p>
<blockquote cite="">
<ul type="disc">
<li>Creates a <strong>virtual encrypted disk</strong> within a file and mounts  it as a real disk. </li>
<li>Encrypts an<strong> entire partition or storage device</strong> such as USB flash drive or hard drive.</li>
<li>Encrypts a <strong>partition or drive where Windows is installed</strong> (<a href="http://www.truecrypt.org/docs/?s=system-encryption">pre-boot authentication</a>).</li>
<li>Encryption is <a href="http://www.truecrypt.org/docs/"><strong>automatic</strong>, <strong>real-time</strong> (on-the-fly) and <strong>transparent</strong></a>.</li>
<li> <a href="http://www.truecrypt.org/docs/?s=parallelization">Parallelization</a> and <a href="http://www.truecrypt.org/docs/?s=pipelining">pipelining</a> allow data to be read and written as fast as if the drive was not encrypted.</li>
<li>Provides <strong><a href="http://www.truecrypt.org/docs/?s=plausible-deniability">plausible deniability</a></strong>, in case an adversary  forces you to reveal the password: <strong><a href="http://www.truecrypt.org/hiddenvolume">Hidden volume</a></strong> (steganography) and <strong><a href="http://www.truecrypt.org/docs/?s=hidden-operating-system">hidden operating system</a></strong>.</li>
<li><a href="http://www.truecrypt.org/docs/?s=encryption-algorithms">Encryption algorithms</a>: <a href="http://www.truecrypt.org/docs/?s=aes">AES-256</a>, <a href="http://www.truecrypt.org/docs/?s=serpent">Serpent</a>, and <a href="http://www.truecrypt.org/docs/?s=twofish">Twofish</a>.  Mode of operation: <a href="http://www.truecrypt.org/docs/?s=modes-of-operation">XTS</a>.</li>
</ul>
</blockquote>
<h2>Further Reading</h2>
<ul>
<li><a href="http://ultra.ap.krakow.pl/~bar/DOC/ssh_backup.html">Network File Copy using SSH</a></li>
<li>Check out the trunk version of PuTTY:<code>~ svn co svn://svn.tartarus.org/sgt/putty</code>
</ul>
<hr class="C" />
<p>The real fun doesn&#8217;t start till all the automation starts, automating all of that from a couple batch files I wrote, one click setup.  Kind of like building your own knoppix for when you have to use Windows.  To begin this tutorial, setup a truecrypt traveller setup on your usb and also install the portaputty package onto the usb.  You do this by creating a 3GB or whatever file on the usb and then mounting that file like you would mount an iso file.   I will show the Windows Batch file I use and the tricks with Windows Volume names and how to consistently make it all work.   Then we will setup MyEnTunnel with a customized batch file that forces all puttys to use portaputty (<code>sweet hack stolen from sysinternals pagedefrag tool</code>).<strong>Stay Tuned!</strong></p>
<p><a href="http://www.askapache.com/hacking/ssh-tunnels-truecrypt-gpg.html"></a><a href="http://www.askapache.com/hacking/ssh-tunnels-truecrypt-gpg.html">PortaPutty Auto-Reconnecting SSH Tunnels on an Encrypted TrueCrypt Portable USB Key w GPG</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/lzJrkUNewGMT3Syqz0sxaqvQwwE/0/da"><img src="http://feedads.g.doubleclick.net/~a/lzJrkUNewGMT3Syqz0sxaqvQwwE/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/lzJrkUNewGMT3Syqz0sxaqvQwwE/1/da"><img src="http://feedads.g.doubleclick.net/~a/lzJrkUNewGMT3Syqz0sxaqvQwwE/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=gQt9eNHOBbI:qv-7kNlrM5o:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=gQt9eNHOBbI:qv-7kNlrM5o:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=gQt9eNHOBbI:qv-7kNlrM5o:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=gQt9eNHOBbI:qv-7kNlrM5o:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=gQt9eNHOBbI:qv-7kNlrM5o:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=gQt9eNHOBbI:qv-7kNlrM5o:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=gQt9eNHOBbI:qv-7kNlrM5o:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/hacking/ssh-tunnels-truecrypt-gpg.html/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		<feedburner:origLink>http://www.askapache.com/hacking/ssh-tunnels-truecrypt-gpg.html</feedburner:origLink></item>
		<item>
		<title>Optimize a Website for Speed, Security, and Easy Management</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/Y8I9sw7d4tY/optimize-website-files-cache-security.html</link>
		<comments>http://www.askapache.com/htaccess/optimize-website-files-cache-security.html#comments</comments>
		<pubDate>Fri, 19 Feb 2010 00:45:26 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[SEO]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Shell Scripting]]></category>
		<category><![CDATA[Web Design]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[301 Redirect]]></category>
		<category><![CDATA[admin]]></category>
		<category><![CDATA[Advanced]]></category>
		<category><![CDATA[Ajax]]></category>
		<category><![CDATA[apache server]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[Backups]]></category>
		<category><![CDATA[Bandwidth]]></category>
		<category><![CDATA[bleeding edge]]></category>
		<category><![CDATA[blog]]></category>
		<category><![CDATA[Cache-Control]]></category>
		<category><![CDATA[caching]]></category>
		<category><![CDATA[ColdFusion]]></category>
		<category><![CDATA[compression]]></category>
		<category><![CDATA[CSS]]></category>
		<category><![CDATA[Dig]]></category>
		<category><![CDATA[DNS]]></category>
		<category><![CDATA[errordocument]]></category>
		<category><![CDATA[Etags]]></category>
		<category><![CDATA[Examples]]></category>
		<category><![CDATA[expires header]]></category>
		<category><![CDATA[feed]]></category>
		<category><![CDATA[File Permissions]]></category>
		<category><![CDATA[Flash]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[hacks]]></category>
		<category><![CDATA[htaccess files]]></category>
		<category><![CDATA[Htpasswd]]></category>
		<category><![CDATA[HTTP Error]]></category>
		<category><![CDATA[HTTP Headers]]></category>
		<category><![CDATA[HTTP Status Codes]]></category>
		<category><![CDATA[HTTPS SSL]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Login]]></category>
		<category><![CDATA[Logs]]></category>
		<category><![CDATA[Mod_Rewrite]]></category>
		<category><![CDATA[Optimization]]></category>
		<category><![CDATA[optimizations]]></category>
		<category><![CDATA[optimized website]]></category>
		<category><![CDATA[password]]></category>
		<category><![CDATA[password protection]]></category>
		<category><![CDATA[PDF]]></category>
		<category><![CDATA[Performance]]></category>
		<category><![CDATA[php.ini]]></category>
		<category><![CDATA[Port]]></category>
		<category><![CDATA[post]]></category>
		<category><![CDATA[ram]]></category>
		<category><![CDATA[real deal]]></category>
		<category><![CDATA[Redirect]]></category>
		<category><![CDATA[Redirection]]></category>
		<category><![CDATA[Rewrite Tricks]]></category>
		<category><![CDATA[Robot]]></category>
		<category><![CDATA[robots]]></category>
		<category><![CDATA[robots.txt]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[search and replace]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[server config]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[SymLinks]]></category>
		<category><![CDATA[trial and error]]></category>
		<category><![CDATA[trick]]></category>
		<category><![CDATA[Web Development]]></category>
		<category><![CDATA[web server]]></category>
		<category><![CDATA[WordPress Plugins]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=1380</guid>
		<description><![CDATA[<p><a href="http://www.askapache.com/htaccess/optimize-website-files-cache-security.html" class="IFL hs hs37" title="Discover how to setup and manage a website from top to bottom for optimized speed, security, and simplicity"></a>Learn how to setup, configure, secure, optimize, and create a low-maintenance website the AskApache way.  I'm piecing together all the hacks, tricks, methods, and ideas discussed throughout this blog and all across Netdom and glueing them all together to show you how to have the most optimized, crazy fastest, and best website setup I can think of.<br class="C" /></p>]]></description>
			<content:encoded><![CDATA[<p><img class="IFL" src="http://uploads.askapache.com/2008/09/computerimg.jpg" alt="optimized server setup" title="optimized server setup" />Over the past 10 or so years I&#8217;ve been directly or indirectly involved in configuring/administrating/hacking thousands of websites, and I realized today that I&#8217;ve actually learned quite a bit about how to really make them work hard for me, instead of the other way around. It came as a mild shock to think of where I was back then vs. now because the improvements and optimizations are hundreds of smaller improvements, but taken together, the  optimization hacks I&#8217;ve found through trial and error and much reading are as Donald would say, <strong>YOOUUGE</strong> compared to a basic website setup.<br class="C" /></p>
<p class="cnote">I use this awesome skeleton setup for all my high-paying clients <em>sorry poor people!</em> and also of course on this blog, which I use as a bleeding-edge dev server for my crazy testing.  So realize that I&#8217;m already past this setup and using it to do cooler stuff.  In order for you to use these more advanced ideas, you first need to get up to speed on what I&#8217;m doing so you know what I&#8217;m talking about.  This article tries to help you accomplish that&#8230; remains to be seen.</p>
<h2>An Optimized Website, The Real Deal</h2>
<p>This first article is to give you some ideas and get you thinking and reading before the first article in this series comes out.  This series details how to setup, configure, secure, optimize, and manage a website the best possible way I can come up with.  It pieces together all the AskApache hacks and tricks and uses methods and ideas discussed all over this blog and all over the net and glues them all together to show you how to have the most optimized, fastest, best website setup I can think of.</p>
<p>Knowing the why and how behind the operation of a Web Server allows us to optimize that operation.  For this example we will be creating the website <code>www.askapache.com</code>, which will be running WordPress and php.  We will also set up <code>static.askapache.com</code> to serve all of our sites uploads, images, css and javascript files, flash files, etc. with advanced caching and security using Apache Server .htaccess files.  So lets get started and take a look at this site structure for a moment.</p>
<pre>/home/askapache.com
|&#45;- /home/askapache.com/backups/
|&#45;- /home/askapache.com/public_html/
|&#45;- /home/askapache.com/inc/
|&#45;- /home/askapache.com/logs/
|&#45;- /home/askapache.com/static/
|&#45;- /home/askapache.com/tmp/
|&#45;- /home/askapache.com/.htpasswd-basic
`&#45;- /home/askapache.com/.htpasswd-digest</pre>
<ul>
<li><code>/backups/</code> &#8211; For <a href="http://www.askapache.com/wordpress/encrypted-wordpress-site-backups.html">encrypted backups of WordPress database and site files</a>. And any other backups.</li>
<li><code>/public_html/</code> &#8211; The document root for <code>www.askapache.com</code></li>
<li><code>/inc/</code> &#8211; Folder to keep your php include files for extra security and easy management.</li>
<li><code>/logs/</code> &#8211; Save your php, apache, and other logs here or create symlinks to them.</li>
<li><code>/static/</code> &#8211; The document root for <code>static.askapache.com</code></li>
<li><code>/tmp/</code> &#8211; Only need this if your host doesn&#8217;t already have a /tmp folder</li>
</ul>
<hr class="HR0" />
<h2>Strong Security, Top to Bottom</h2>
<p><img class="IFL" src="http://uploads.askapache.com/2008/09/1023103_warning_icon_32.jpg" width="150" alt="Optimize a Website for Speed, Security, and Easy Management" title="Site Security with Apache" />Simply by implementing correct access permissions, file permissions, password protection and segmenting various folders and services we are already ahead of the game.  I&#8217;ve always taken security extremely seriously, so you can benefit from alot of the simple solutions I&#8217;m recommending for a really locked down site.<br class="C" /></p>
<p>Indeed, security is a major part of every step of this setup process, as security concerns are what drives a lot of the motivations I have for coming up with this setup in the first place.  We will be doing very simple but very effective site security like the following items, which is a short list compared to everything we will be doing.</p>
<ul>
<li>Fixing file permissions automatically</li>
<li>Searching for modified files on the server</li>
<li>Encrypting your backups</li>
<li>Get alerted to breakin attempts</li>
<li>Block tons of bad clients</li>
<li>Disallowing cgi scripts or any other handlers, just serve files.</li>
<li>Configuring PHP</li>
<li>Password Protection for certain areas</li>
</ul>
<h3>Ready for Warfare?</h3>
<p>My past work for an Internet Service Provider, followed by 4 years of auditing the security of organizations external/internal networks has given me a fresh perspective on website security, and I think it allows me to see what would really be effective at preventing and killing attacks.  In fact just last night I was once again doing some research into some off-the-wall security topics, and I discovered a new defense method that I will be writing about very soon.  I believe that this new method,  could be quickly adopted and implemented by hosting providers and software developers, which would result in us finally taking the Internet back from all those zombies and robots.  This method will be discussed in great detail soon, and will be a core part of this site setups security and optimization.</p>
<hr class="HR0" />
<h2>Built to <span style="color:red">Bleed Speed</span></h2>
<p><img class="IFL" src="http://uploads.askapache.com/2008/09/speedontheroadimg.jpg" width="150" alt="Optimize a Website for Speed, Security, and Easy Management" title="326255_speed_on_the_road" />Serve&#8217;s files as fast and efficiently as possible using advanced caching, HTTP Protocols, php/server configurations.<br class="C" /></p>
<p>Many of the articles and research on this blog is about improving the speed and efficiency of your website.  In fact that is why I am helping develop open-source software to block spammers from WordPress blogs&#8230; not because I&#8217;m bothered by the spam, but because they make the net slow!  So lets look at some of the ideas we&#8217;ll be implementing.</p>
<p>Many techniques I&#8217;ve been using and tweaking for several years, and recently many of them were included in the high-performance websites list.  Of course we will be taking a look at this list in practical terms, meaning almost all of it, the caching, compression, etc., will be automated in keeping with our &#8220;comfort&#8221; goal, which is to say we want to make the Web Developer and Server Admin&#8217;s lives as easy and comfy as possible.  After all, we do the work right?</p>
<ol>
<li>Reduce HTTP requests &#8211; <a href="http://www.askapache.com/htaccess/speed-up-sites-with-htaccess-caching.html" title="304 If Modified article">Reducing 304 requests with Cache-Control Headers</a></li>
<li>Use a customized php.ini &#8211; <a href="http://www.askapache.com/php/custom-phpini-tips-and-tricks.html">Creating and using a custom PHP.ini</a></li>
<li>Add an Expires header &#8211; <a href="http://www.askapache.com/htaccess/speed-up-your-site-with-caching-and-cache-control.html#caching-with-mod_expires" title="mod_expires Caching article">Caching with mod_expires on Apache</a></li>
<li>Gzip components</li>
<li>Make CSS and unobtrusive Javascript as external files not inline</li>
<li>Reduce DNS lookups &#8211; Use Static IP address, use a subdomain with static IP address for static content.</li>
<li>Minimize Javascript &#8211; Refactor the code, compress with <a href="http://dojotoolkit.org/docs/shrinksafe">dojo</a></li>
<li>Avoid external redirects &#8211; <a href="http://www.askapache.com/htaccess/mod_rewrite-tips-and-tricks.html" title="mod_rewrite internal redirection and rewrites">Use internal redirection with mod_rewrite</a>, <a href="http://www.askapache.com/htaccess/301-redirect-with-mod_rewrite-or-redirectmatch.html" title="301 Redirect with mod_rewrite or RedirectMatch">The correct way to redirect with 301</a></li>
<li>Turn off ETags &#8211; <a href="http://www.askapache.com/htaccess/using-http-headers-with-htaccess.html#prevent-caching-with-htaccess">Prevent Caching with htaccess</a></li>
<li>Make AJAX cacheable and small</li>
</ol>
<h3>AskApache.com, Fastest Site Ever!</h3>
<p>Ok it <em>might</em> not be the #1, but surely the top 10.. ;)</p>
<p>I&#8217;m very proud of the performance I am able to achieve on this site.  Very proud.  I started looking for ways to improve the wp-cache and wp-super-cache WordPress plugins, and came up with hacks for both of them.. but they still didn&#8217;t do what I wanted so I started from scratch and wrote my own caching plugin.</p>
<p>With much more advanced caching options and unquestionably higher performance and lower time usage on the machine.  I&#8217;m hesitant to release it to the public until I get faded on it.. I just really love it.. it has been running my site for several months now and I keep finding ways to improve it.. Stay tuned.</p>
<p>One feature it has is the ability to allow negotiation of a resource between apache and the client.  Think almost transparent mutli-lingual blogs, mutliple formats per document (look at the rdf for this page for an example*). But that plugin is the future and this is the present.. so back to it we go.</p>
<hr class="HR0" />
<h2>Pamper the Webmaster with Extreme Comfort</h2>
<p><img class="IFL" src="http://uploads.askapache.com/2008/09/wwwonthebeachimg.jpg" width="150" alt="Optimize a Website for Speed, Security, and Easy Management" title="Low Maintenance Web Development" />This section alone would make this setup appealing.  I have developed all types of techniques and methods to make my life as easy as possible.  I could literally DIE right now and this blog would continue to run and operate for years on its own.   The general philosophy that I have used to get to where I can goto the beach with my laptop and do all this crazy stuff is <strong>the idea of perfection</strong>.  That may sound a little put-offish, but it basically means I will focus in on one very specific area for improvement or research and just get sick with it.  Most of this blogs articles are enlightening examples of this in action.  I will take a relatively unknown or unused piece of code or software and experiment with it until I feel I have it down, then I move on to the next item of never-ending research.  Mostly I think this is just plain habit from when I was studying security.  I&#8217;m much better at this then that :)</p>
<h3>Apache ErrorDocuments</h3>
<p>The <a href="http://www.askapache.com/htaccess/apache-status-code-headers-errordocument.html">57 HTTP Status Codes and Apache ErrorDocuments</a> article is a prime example.  I was simply searching for an authoritative list of HTTP status codes, an issue not many web people find worth their time, and that search led to some of the most useful stuff I&#8217;ve found about the Web</p>
<p>This &#8220;Comfort&#8221; article will include multi-language, intelligent, and optimized error documents for handling any type of HTTP error with class and allow us to stop spammers, save bandwidth, redirect correctly, etc..  You will probably be surprised at all the uses an Apache ErrorDocument can have.. It IS one of the foundations of the HTTP-based Net after all.<br class="C" /></p>
<h3>Emphasis on Easy Upgrades</h3>
<p>The whole setup is geared to make hassle-free WordPress/PHP/application upgrades possible by keeping different types of files in separate places, keeping backups, other misc tricks and since all of these files are in /home/askapache.com, your FTP connection can still access every file easily.  Sometimes security and optimizing your server can lead to it being more of a pain to do updates, backups, and general maintenance.  This article tries to overwhelm the balance with a trifecta of goals.</p>
<h3>Move to a new host? Ok!</h3>
<p>Comfort to me also means being able to pack up the whole website and database and move to another web host in under an hour.  I can move the whole AskApache site to one of several other hosting providers accounts I have in about 30minutes.  If this was a clients site or I was getting paid more, I&#8217;d also be focused on round-robin DNS technology, balance-load setups, and just go crazy making it fast.</p>
<h3>Staying Online, Improving Uptime</h3>
<p>Ever since I started sharing information and software to stop all these resource hogging zombies attacking everything I&#8217;ve been attacked several times.  Normally I get over 10K exploit attempts or requests per day, which I pretty much block 100%.  But a few times they&#8217;ve actually tried to DDOS me off the net in a distributed attack.  I have implemented several &#8220;poor mans&#8221; techniques to put up your best effort at surviving, which I did.  Basically you want to configure your server to KILL connections just as fast as possible and prevent your server resources from skyrocketing and surpassing your quotas.  A skilled attacker could easily shut you down even without the use of a widespread botnet if they are clever, which could be devastating to your small blog or site if it goes down at a crucial instant.</p>
<hr class="HR0" />
<h2>Organization with Templates and Systems</h2>
<p>I used to work with a guy who did alot of the coldfusion programming for us, and I used to cringe every  time I was called in to upgrade a site or do a re-design.  Files and folders EVERYWHERE!  Literally images in every folder, multiple index.html, index1.html, index-old.html, and on and on it went.. It would take me hours just to reverse-engineer the site enough so I could modify files on it without having some unkown consequence happen.</p>
<h3>Do You Have a Cluttered Desktop?</h3>
<p>Everyone has this problem, what I do all the time is just grab everything on my desktop and put it in a folder named with the date.  Then the process repeats itself and invariably a few months later I&#8217;m looking at a cluttered screen again.</p>
<p>This absolutely is the worst thing that can happen to a website, worst for security, comfort for webmaster, and speed.  So this setup addresses that issue completely heads on.  With all the different pages, tools, and resources available on this blog, I can almost promise you that my site has less files than yours.  No small feat to be sure, but worth every second I spent researching how to do it now that its on and popping.</p>
<hr class="HR0" />
<h2>What&#8217;s a Website really?</h2>
<p>All hosts are different, but any host worth their salt is running some kind of <a href="http://www.askapache.com/linux-unix/">BSD/Linux</a> operating system, and that is good news because those operating systems all use very similarly excellent file/folder structures with huge organization systems.  If your web hosting provider is running on a Windows based operating system or other locked/proprietary software than this article is not for you and I would recommend switching hosts to a BSD/Linux open-source operating system.</p>
<h3>Listening for Requests with Web Hosting and DNS</h3>
<p>First you set your website up so it can start serving.</p>
<ol>
<li>You buy your domain name, which just gives you the right to use it.</li>
<li>You pay your webhost for an account on their machine running a Server connected to the Net <em>via a fast connection link</em>.</li>
<li>You pay a DNS provider to redirect requests for your domain  name to be sent to your webhosts machine running the server.</li>
</ol>
<h2>Sub-Domain for Serving Assets</h2>
<p>This is a very cool method I&#8217;ve been using more and more frequently because it makes updates, upgrades, and changes so much easier to manage.  And segmenting various parts of the site is smart security, and even smarter in the way of speeding up a website and keeping your <strong>servers running mean and lean</strong>.</p>
<h2>Full Site Structure Expanded</h2>
<pre>/home/askapache.com
|&#45;- /home/askapache.com/backups/
|&#45;- /home/askapache.com/public_html/
|   |&#45;- /home/askapache.com/public_html/about/
|   |&#45;- /home/askapache.com/public_html/admin/
|   |&#45;- /home/askapache.com/public_html/cgi-bin/
|   |&#45;- /home/askapache.com/public_html/.htaccess
|   |&#45;- /home/askapache.com/public_html/index.php
|   `&#45;- /home/askapache.com/public_html/robots.txt
|&#45;- /home/askapache.com/inc/
|   |&#45;- /home/askapache.com/inc/config.inc.php
|   `&#45;- /home/askapache.com/inc/settings.inc.php
|&#45;- /home/askapache.com/logs/
|   |&#45;- /home/askapache.com/logs/access.log
|   |&#45;- /home/askapache.com/logs/error.log
|   |&#45;- /home/askapache.com/logs/logins.log
|   |&#45;- /home/askapache.com/logs/modsec_audit.log
|   |&#45;- /home/askapache.com/logs/modsec_debug.log
|   `&#45;- /home/askapache.com/logs/php_error.log
|&#45;- /home/askapache.com/static/
|   |&#45;- /home/askapache.com/static/css/
|   |&#45;- /home/askapache.com/static/flv/
|   |&#45;- /home/askapache.com/static/img/
|   |&#45;- /home/askapache.com/static/js/
|   |&#45;- /home/askapache.com/static/mp3/
|   |&#45;- /home/askapache.com/static/pdf/
|   |&#45;- /home/askapache.com/static/swf/
|   |&#45;- /home/askapache.com/static/.htaccess
|   |&#45;- /home/askapache.com/static/index.html
|   `&#45;- /home/askapache.com/static/robots.txt
|&#45;- /home/askapache.com/tmp/
|&#45;- /home/askapache.com/.htpasswd-basic
`&#45;- /home/askapache.com/.htpasswd-digest</pre>
<h2>Full Expanded Structure</h2>
<pre>/home/askapache.com
|&#45;- /home/askapache.com/backups/
|&#45;- /home/askapache.com/public_html/
|   |&#45;- /home/askapache.com/public_html/about/
|   |   `&#45;- /home/askapache.com/public_html/about/index.html
|   |&#45;- /home/askapache.com/public_html/admin/
|   |   |&#45;- /home/askapache.com/public_html/admin/.htaccess
|   |   `&#45;- /home/askapache.com/public_html/admin/index.html
|   |&#45;- /home/askapache.com/public_html/cgi-bin/
|   |   |&#45;- /home/askapache.com/public_html/cgi-bin/bin/
|   |   |   |&#45;- /home/askapache.com/public_html/cgi-bin/bin/.htaccess
|   |   |   |&#45;- /home/askapache.com/public_html/cgi-bin/bin/php.cgi*
|   |   |   |&#45;- /home/askapache.com/public_html/cgi-bin/bin/php.ini
|   |   |   |&#45;- /home/askapache.com/public_html/cgi-bin/bin/php4.cgi*
|   |   |   `&#45;- /home/askapache.com/public_html/cgi-bin/bin/php5.cgi*
|   |   |&#45;- /home/askapache.com/public_html/cgi-bin/private/
|   |   |   |&#45;- /home/askapache.com/public_html/cgi-bin/private/.htaccess
|   |   |   |&#45;- /home/askapache.com/public_html/cgi-bin/private/debug.php
|   |   |   `&#45;- /home/askapache.com/public_html/cgi-bin/private/stats.php
|   |   |&#45;- /home/askapache.com/public_html/cgi-bin/.htaccess
|   |   |&#45;- /home/askapache.com/public_html/cgi-bin/login.php
|   |   |&#45;- /home/askapache.com/public_html/cgi-bin/printenv.cgi*
&nbsp;
|   |   `&#45;- /home/askapache.com/public_html/cgi-bin/redir.cgi*
|   |&#45;- /home/askapache.com/public_html/.htaccess
|   |&#45;- /home/askapache.com/public_html/index.php
|   `&#45;- /home/askapache.com/public_html/robots.txt
|&#45;- /home/askapache.com/inc/
|   |&#45;- /home/askapache.com/inc/config.php
|   `&#45;- /home/askapache.com/inc/functions.php
|&#45;- /home/askapache.com/logs/
|   |&#45;- /home/askapache.com/logs/access.log
|   |&#45;- /home/askapache.com/logs/error.log
|   |&#45;- /home/askapache.com/logs/logins.log
|   |&#45;- /home/askapache.com/logs/modsec_audit.log
|   |&#45;- /home/askapache.com/logs/modsec_debug.log
|   `&#45;- /home/askapache.com/logs/php_error.log
|&#45;- /home/askapache.com/static/
|   |&#45;- /home/askapache.com/static/css/
|   |   `&#45;- /home/askapache.com/static/css/apache.css
|   |&#45;- /home/askapache.com/static/flv/
|   |   `&#45;- /home/askapache.com/static/flv/apache.flv
|   |&#45;- /home/askapache.com/static/img/
|   |   |&#45;- /home/askapache.com/static/img/apache.gif
|   |   |&#45;- /home/askapache.com/static/img/apache.jpg
|   |   `&#45;- /home/askapache.com/static/img/apache.png
|   |&#45;- /home/askapache.com/static/js/
|   |   `&#45;- /home/askapache.com/static/js/apache.js
|   |&#45;- /home/askapache.com/static/mp3/
|   |   `&#45;- /home/askapache.com/static/mp3/apache.mp3
|   |&#45;- /home/askapache.com/static/pdf/
|   |   `&#45;- /home/askapache.com/static/pdf/apache.pdf
|   |&#45;- /home/askapache.com/static/swf/
|   |   `&#45;- /home/askapache.com/static/swf/apache.swf
|   |&#45;- /home/askapache.com/static/.htaccess
|   |&#45;- /home/askapache.com/static/index.html
|   `&#45;- /home/askapache.com/static/robots.txt
|&#45;- /home/askapache.com/tmp/
|&#45;- /home/askapache.com/.htpasswd-basic
`&#45;- /home/askapache.com/.htpasswd-digest</pre>
<p>The buzz about apache and open-source is very real, apache is becoming more of a discussed topic as people realize the power and importance of <q cite="LL Cool J">Doing it and Doing it and Doing it well.</q> &#8211;  <small><a href="http://www.webmonkey.com/blog/Jumpbox_Offers_an_Easier_Way_to_Install_Movable_Type">Movable Type Apache Installs made easy</a>, <a href="http://www.ubuntugeek.com/webalizer-apache-web-server-log-file-analysis-tool.html">Checking out Apache Web logs</a>, <a href="http://eventurebiz.com/blog/securing-securing-your-wordpress-blog-post-6-protecting-the-wp-configphp-file/">Securing WordPress with .htaccess</a>, <a href="http://marketingdefined.com/blog/wordpress/using-wordpress-permalink-redirect-plugins-correctly/">WordPress Permalinks and .htaccess</a>, <a href="http://corpocrat.com/2008/09/19/install-apache-mod_substitute/">New search and replace module for apache!</a>, <a href="http://www.csskarma.com/blog/creating-an-htaccess-template/">creating an .htaccess template</a>, <a href="http://www.thelinuxblog.com/htaccess-allow-from/">.htaccess allow directive</a></small></p>
<p class="anote">Check back in a week for the first article, or better yet subscribe to my <a href="http://www.askapache.com/feed/">rss feed</a> or use the comment form below to get notified.</p>
<p><a href="http://www.askapache.com/htaccess/optimize-website-files-cache-security.html"></a><a href="http://www.askapache.com/htaccess/optimize-website-files-cache-security.html">Optimize a Website for Speed, Security, and Easy Management</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/V4XDz34O3hioMEDesWWIOJPWV5k/0/da"><img src="http://feedads.g.doubleclick.net/~a/V4XDz34O3hioMEDesWWIOJPWV5k/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/V4XDz34O3hioMEDesWWIOJPWV5k/1/da"><img src="http://feedads.g.doubleclick.net/~a/V4XDz34O3hioMEDesWWIOJPWV5k/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=Y8I9sw7d4tY:CHW9AlTMvEI:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=Y8I9sw7d4tY:CHW9AlTMvEI:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=Y8I9sw7d4tY:CHW9AlTMvEI:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=Y8I9sw7d4tY:CHW9AlTMvEI:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=Y8I9sw7d4tY:CHW9AlTMvEI:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=Y8I9sw7d4tY:CHW9AlTMvEI:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=Y8I9sw7d4tY:CHW9AlTMvEI:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/htaccess/optimize-website-files-cache-security.html/feed/</wfw:commentRss>
		<slash:comments>9</slash:comments>
		<feedburner:origLink>http://www.askapache.com/htaccess/optimize-website-files-cache-security.html</feedburner:origLink></item>
		<item>
		<title>grilled cheese jam session now online</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/8Vdh5D5uBx0/grilled-cheese-jam-session-back-online.html</link>
		<comments>http://www.askapache.com/music/grilled-cheese-jam-session-back-online.html#comments</comments>
		<pubDate>Thu, 11 Feb 2010 14:12:24 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Featured]]></category>
		<category><![CDATA[Music]]></category>
		<category><![CDATA[Gaming]]></category>
		<category><![CDATA[Video]]></category>
		<category><![CDATA[YouTube]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3861</guid>
		<description><![CDATA[<div><div style="width:260px;height:173px;display:block;overflow:hidden;border:30px solid #fff;border-top-width:0px;float:left;"><p id="bayonetta1"></p></div><p>You've probably seen this.. one of THE coolest video games I've ever seen (though I haven't played).. Its tempting me back to <acronym title="Major League Gamers">MLG</acronym>..  Games are games today, but in the future Gaming Skill will be highly sought after.. So I check in with the gaming world occasionally, I'd hate to miss something like a new Duke-Nukem (<em>cancelled after 10 years in development and no releases</em>).<br /><br />I have around 10 really nice articles I've been working on for awhile now, my problem is that I am a perfectionist, so I keep finding improvements..   worth it.<br class="C" /></p></div>]]></description>
			<content:encoded><![CDATA[<div>
<div style="width:480px;height:320px;display:block;overflow:hidden;border:30px solid #fff;float:left;">
<p id="bayonetta"></p>
</div>
<h3><a href="http://www.youtube.com/watch?v=AlIztDOQfn0&#038;feature=related">Bayonetta: In For the Kill Extended Trailer</a></h3>
<p>Nice example of chaotic beats, but they make melody somehow, it&#8217;s rather an addictive beat. </p>
<p>What random chaos have I spent the last 6 months on?  Experiments with DNS, Fail-over technology for MySQL/DNS/WWW/MAIL servers for free or for very cheap, chrooting servers and of course testing new security idea&#8230;. But the exciting stuff for me personally is some very cool ways to make sure you are never unable to remotely access your server in case of catastrophic failure.. That&#8217;s what it&#8217;s all about for me you know, making things work so well that they run themselves and free up time for life!   I&#8217;m around a 1/4 of a century old..  I&#8217;m done playing around, it&#8217;s time to make some cash before they put me in an old-folks home..  My time is short, my cause is just.. We will prevail!    lol..  I&#8217;m 25 and I still got jokes!</p>
<p><strong>For 2010</strong> I have a few choice articles and ideas I&#8217;m debating about publishing.. I don&#8217;t want to give the wrong kind of people power, I want to give the power to the people &#8212; but at a certain point it takes a serious investment to actually empower yourself, whereas a company could afford to actually bring it to reality.. So who does the knowledge benefit then?  No, the only way is to get serious myself and beat the profiteers to the punch so to offer a service that would be dirt-cheap if it weren&#8217;t in the hands of gluttons.</p>
<p>I&#8217;ve been pursuing research into several new areas of web technology (no not a smartphone app!) over the past year trying to increase my business profits and quailty of service, and I am becoming more aware every day that I can do it better and cheaper!  Any industry always has those at the top who enjoy knowing things that keep them on top,  and try to prevent others from doing what they did..   It&#8217;s not like the information is so wizard-like that it&#8217;s just not possible for average folks to comprehend..   It&#8217;s just only discussed behind closed doors, masked in schools by tenure and a defined curriculum.  But since this is the Wild Wild Web the barriers can always be circumvented.   Stick around, I am <a href="http://www.askapache.com/about/#partnerup">already looking for partners</a> (both investors and linux/code kungfu masters).</p>
<p><strong>Enjoy the jam session ;)</strong><br class="C" /></p>
<div>
<div style="width:480px;height:320px;display:block;overflow:hidden;border:30px solid #fff;border-top-width:0px;float:left;">
<p id="bayonetta1">
</div>
<p>You&#8217;ve probably seen this.. one of THE coolest video games I&#8217;ve ever seen (though I haven&#8217;t played).. Its tempting me back to <acronym title="Major League Gamers">MLG</acronym>..  Games are games today, but in the future Gaming Skill will be highly sought after.. So I check in with the gaming world occasionally, I&#8217;d hate to miss something like a new Duke-Nukem (<em>cancelled after 10 years in development and no releases</em>).</p>
<p>I have around 10 really nice articles I&#8217;ve been working on for awhile now, my problem is that I am a perfectionist, so I keep finding improvements..   worth it.<br class="C" /></p>
</div>
<p><a href="http://www.askapache.com/music/grilled-cheese-jam-session-back-online.html"></a><a href="http://www.askapache.com/music/grilled-cheese-jam-session-back-online.html">grilled cheese jam session now online</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/f3D-22ZFKyAUJhb-u-OMRVwE5Hs/0/da"><img src="http://feedads.g.doubleclick.net/~a/f3D-22ZFKyAUJhb-u-OMRVwE5Hs/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/f3D-22ZFKyAUJhb-u-OMRVwE5Hs/1/da"><img src="http://feedads.g.doubleclick.net/~a/f3D-22ZFKyAUJhb-u-OMRVwE5Hs/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=8Vdh5D5uBx0:tIRU1fKLvj4:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=8Vdh5D5uBx0:tIRU1fKLvj4:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=8Vdh5D5uBx0:tIRU1fKLvj4:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=8Vdh5D5uBx0:tIRU1fKLvj4:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=8Vdh5D5uBx0:tIRU1fKLvj4:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=8Vdh5D5uBx0:tIRU1fKLvj4:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=8Vdh5D5uBx0:tIRU1fKLvj4:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/music/grilled-cheese-jam-session-back-online.html/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		<feedburner:origLink>http://www.askapache.com/music/grilled-cheese-jam-session-back-online.html</feedburner:origLink></item>
		<item>
		<title>Vetted – Top 3 WordPress Speed Plugins</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/SBHiZIMT-YQ/fastest-caching-plugins.html</link>
		<comments>http://www.askapache.com/wordpress/fastest-caching-plugins.html#comments</comments>
		<pubDate>Sun, 29 Nov 2009 19:14:16 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Apache]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[Featured]]></category>
		<category><![CDATA[Mod_Rewrite]]></category>
		<category><![CDATA[Review]]></category>
		<category><![CDATA[Server Administration]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[WordPress Plugins]]></category>
		<category><![CDATA[admin]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[AskApache Crazy Cache]]></category>
		<category><![CDATA[Bandwidth]]></category>
		<category><![CDATA[Bottleneck]]></category>
		<category><![CDATA[caching]]></category>
		<category><![CDATA[compression]]></category>
		<category><![CDATA[Dig]]></category>
		<category><![CDATA[filesystem]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[httpd]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[Networking]]></category>
		<category><![CDATA[password]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[post]]></category>
		<category><![CDATA[Private Server]]></category>
		<category><![CDATA[ram]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[WordPress Optimizing]]></category>
		<category><![CDATA[WordPress Speed]]></category>
		<category><![CDATA[WP-Super Cache]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3701</guid>
		<description><![CDATA[<p><a class="IFL" id="id15" href="http://www.askapache.com/wordpress/fastest-caching-plugins.html" title="Top 3 WordPress Plugins for a Faster Blog"></a>There are so many WordPress plugins out there now that I wanted to post my favorite 3 plugins for speeding up a WP-Powered blog.  These are the 3 plugins that I install for pretty much all of my WP-Powered sites, which I run about 300 now.  They work together to provide a very optimized blog for speed.<br /><br /><strong>DB-Cache Reloaded does something entirely different</strong>, it saves the mysql queries that are made to the WP-database, as well as the mysql results to static files, and then through php serves those cached-files instead of re-querying the mysql database. Most mysql databases are stored on separate servers, and although many are on the same local network there is a limit to how many queries, and how many connections can take place.<br /><br />So DB-Cache Reloaded basically makes WP-Super Cache work alot faster when generating the cache files, and DB-Cache Reloaded helps in a number of areas un-related to WP-Super Cache, like in the admin panel.  And DB-Cache without WP-Super-Cache is a joke because it still uses the application-level and php for everything.  <em>Gotta use both (or just WPSC)</em>.<br class="C" /></p>
]]></description>
			<content:encoded><![CDATA[<p>There are so many WordPress plugins out there now that I wanted to post my favorite 3 plugins for speeding up a WP-Powered blog (including one of <a href="http://wordpress.org/extend/plugins/profile/askapache">my plugins</a>).  These are the 3 plugins that I install for pretty much all of my WP-Powered sites, which I run about 300 now.  They work together to provide a very optimized blog for speed.</p>
<h2>Top 3 WordPress Speed Plugins</h2>
<ol class="TOC">
<li><a href="http://www.askapache.com/wordpress/fastest-caching-plugins.html#db-cache-reloaded">DB Cache Reloaded</a></li>
<li><a href="http://www.askapache.com/wordpress/fastest-caching-plugins.html#wp-super-cache">WP Super Cache</a></li>
<li><a href="http://www.askapache.com/wordpress/fastest-caching-plugins.html#crazy-cache">AskApache Crazy Cache</a></li>
</ol>
<h2>WP Caching Overview</h2>
<p>Each request to your blog has to fire up the php interpreter and query the mysql database to create the output that you see in your browser.  Using a plugin like WP Super Cache simply saves the output of that request as a static HTML file and serves that to a request instead of using php and mysql every time.  DB Cache Reloaded takes this a step further by optimizing the mysql queries.  Finally, AskApache Crazy Cache is used to keep a cache fully primed and ready.</p>
<h3>Why Caching?</h3>
<p>If you have a private server, or you want to keep your MEMORY, BANDWIDTH, and CPU usage down for your server, these plugins will be dramatic.  If you have a site that is updated maybe once a month and gets a very small amount of traffic, then the AskApache Crazy Cache would be redundant.  That plugin is geared for the heaviest traffic sites.</p>
<h3>Request and Response</h3>
<p>Most HTTP communication is initiated by a user agent (browser) and consists of a request to a resource on some origin server. In the simplest case, this may be accomplished via a single connection (v) between the user agent (UA) and the origin server (O).</p>
<pre>             request chain &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&gt;
          UA &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;-v&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;- O
             &lt;&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;- response chain</pre>
<p>If a browser requests a WP-driven page, the server generates the response (the outputted html) by loading a php interpreter or module to read the WP php files and load all the settings.  WP stores the settings in a mysql database and has to query the mysql database for all the data (like the content of your post that becomes html).  Finally php sends the output through the server back to the browser.  This is the norm for most PHP applications.  Every time an interpreter is loaded additional CPU and Memory are used.  And perhaps even more troublesome for shared-hosting using a virtual or network filesystem, each load causes many hard-disk accesses, additional processes, etc.</p>
<h3>Cache PHP</h3>
<p>By saving the php-generated output of a page to a static html file, your server can entirely skip loading a php interpreter or other process.  Originally servers were needed and created to essentially open a static file on disk and send that file back to the requesting user.  So servers are specialized for this as it&#8217;s their core function.</p>
<p><strong>WP-Super cache does this for you by saving the output into a static html file</strong>, and by instructing the server to skip loading php.  It basically only uses php for creating the cached version, in the same way that you can save this webpage as an html file, WP-Super cache saves all the WP-blog permalinks to static files.</p>
<p><strong>DB-Cache Reloaded does something entirely different</strong>, it saves the mysql queries that are made to the WP-database, as well as the mysql results to static files, and then through php serves those cached-files instead of re-querying the mysql database. Most mysql databases are stored on separate servers, and although many are on the same local network there is a limit to how many queries, and how many connections can take place.  But mysql is maybe the fastest thing I&#8217;ve seen, so your bottlenecks almost never happen there (if configured correctly).</p>
<p>So DB-Cache Reloaded basically makes WP-Super Cache work alot faster when generating the cache files, and DB-Cache Reloaded helps in a number of areas un-related to WP-Super Cache, like in the admin panel.  And DB-Cache without WP-Super-Cache is a joke because it still uses the application-level and php for everything.  <em>Gotta use both (or just WPSC)</em>.</p>
<p><strong>AskApache Crazy Cache is a plugin I wrote</strong> to do one thing very well, it runs at intervals via the WP-cron and forces WP-Super-Cache to create a static cache file for all the posts, pages, etc. on your site.  Without this WPSC likes to do dumb things like try to manage it&#8217;s own cache with stale files and expired files, which equals a lot more php interpreters getting loaded instead of cached static files.  For sites with more than a visit/page/10minutes this plugin keeps a full primed cache built by WPSC.</p>
<h3>Compression and WP-Super Cache</h3>
<p><strong>Enabling compression in WP-Super Cache</strong> is almost always a great idea.  I&#8217;ve never had a problem other than some php compat issues with not-updated php installations.  This option basically lets WP-Super Cache compress the generated output of a page and save that to the static file.  Normally Apache, Lighttpd, Nginx, etc. open the static file and compress it before it is sent to the browser, then the browser automatically decompresses it to view.  This happens so fast because it is run by the server.</p>
<p>This lets WPSC instruct your server to send the compressed version to all browsers that accept compression, and send the uncompressed static file to any other browsers.  So this is helpful because it eliminates your server having to do any transparent compressing, it can instead just focus on what it does best, serving static files.</p>
<p>PHP is an application so it requires memory, hard-drive access, and CPU time.  Check out the protocol hierarchy:</p>
<pre>       +&#45;&#45;-&#45;&#45;-+ +&#45;&#45;&#45;&#45;-+ +&#45;&#45;&#45;&#45;-+       +&#45;&#45;&#45;&#45;-+
       |Telnet| | FTP | |Voice|  &#46;..  |     |  Application Level
       +&#45;&#45;-&#45;&#45;-+ +&#45;&#45;&#45;&#45;-+ +&#45;&#45;&#45;&#45;-+       +&#45;&#45;&#45;&#45;-+
             |   |         |             |
            +&#45;&#45;&#45;&#45;-+     +&#45;&#45;&#45;&#45;-+       +&#45;&#45;&#45;&#45;-+
            | TCP |     | RTP |  &#46;..  |     |  Host Level
            +&#45;&#45;&#45;&#45;-+     +&#45;&#45;&#45;&#45;-+       +&#45;&#45;&#45;&#45;-+
               |           |             |
            +&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;-+
            |    Internet Protocol &amp; ICMP   |  Gateway Level
            +&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;-+
                           |
              +&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-+
              |   Local Network Protocol  |    Network Level
              +&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-+       </pre>
<p><a id="db-cache-reloaded" name="db-cache-reloaded"></a></p>
<h3>DB Cache Reloaded</h3>
<p><a href="http://wordpress.org/extend/plugins/db-cache-reloaded/">DB Cache Reloaded Plugin Page</a> &#8211; <a href="http://wordpress.org/tags/db-cache-reloaded?forum_id=10">News</a></p>
<p><a class="IFL" href="http://uploads.askapache.com/2009/11/db-cache-reloaded.png"><img src="http://uploads.askapache.com/2009/11/db-cache-reloaded-116x64.png" alt="DB Cache Reloaded" title="DB Cache Reloaded" width="116" height="64" /></a>This plugin caches every database query with given lifetime. It is much faster than other html caching plugins and uses less disk space for caching.</p>
<p>I think you&#8217;ve heard of WP-Cache or WP Super Cache, they are both top plugins for WordPress, which make your site faster and responsive. Forget about them &#8211; with DB Cache Reloaded your site will work much faster and will use less disk space for cached files. Your visitors will always get actual information in sidebars and server CPU loads will be as low as possible.<br class="C" /></p>
<blockquote cite="http://wordpress.org/extend/plugins/db-cache-reloaded/faq/">
<h4>Why is DB Cache Reloaded better than WP Super Cache?</h4>
<p>This plugin is based on a fundamentally different principle of caching queries to database instead of full pages, which optimises WordPress from the very beginning and uses less disk space for cache files because it saves only useful information. It saves information separately and also caches hidden requests to database.</p>
</blockquote>
<p><a id="wp-super-cache" name="wp-super-cache"></a></p>
<h3>WP Super Cache</h3>
<p><a href="http://wordpress.org/extend/plugins/wp-super-cache/">WP Super Cache Plugin Page</a> &#8211; <a href="http://wordpress.org/tags/wp-super-cache?forum_id=10">News</a></p>
<p><a class="IFL" href="http://uploads.askapache.com/2009/11/wp-super-cache.png"><img src="http://uploads.askapache.com/2009/11/wp-super-cache-116x61.png" alt="WP Super Cache" title="WP Super Cache" width="116" height="61" /></a>This plugin generates static html files from your dynamic WordPress blog. After a html file is generated your webserver will serve that file instead of processing the comparatively heavier and more expensive WordPress PHP scripts.</p>
<p>The static html files will be served to the vast majority of your users, but because a user&#8217;s details are displayed in the comment form after they leave a comment those requests are handled by PHP. Static files are served to:</p>
<p>&middot; Users who are not logged in.<br />&middot; Users who have not left a comment on your blog.<br />&middot; Or users who have not viewed a password protected post.</p>
<p>99% of your visitors will be served static html files. Those users who don&#8217;t see the static files will still benefit because they will see regular WP-Cache cached files and your server won&#8217;t be as busy as before. This plugin will help your server cope with a front page appearance on digg.com or other social networking site.<br class="C" /></p>
<blockquote cite="http://wordpress.org/extend/plugins/wp-super-cache/faq/">
<h4>Why is WP-Super-Cache better than WP-Cache?</h4>
<p>This plugin is based on the excellent WP-Cache plugin and therefore brings all the benefits of that plugin to WordPress. On top of that it creates copies of every page that is accessed on a blog in a form that is quickly served by the web server. It&#8217;s almost as quick as if the you had saved a page in your browser and uploaded it to replace your homepage.</p>
</blockquote>
<blockquote cite="http://wordpress.org/extend/plugins/wp-super-cache/faq/">
<h4>Will the Super Cache compression slow down my server?</h4>
<p>No, it will do the opposite in fact. Super Cache files are compressed and stored that way so the heavy compression is done only once. These files are generally much smaller and are sent to a visitor&#8217;s browser much more quickly than uncompressed html. As a result, your server spends less time talking over the network which saves CPU time and bandwidth, and can also serve the next request much more quickly.</p>
</blockquote>
<p><a id="crazy-cache" name="crazy-cache"></a></p>
<h3>AskApache Crazy Cache</h3>
<p><a href="http://wordpress.org/extend/plugins/askapache-crazy-cache/">AskApache Crazy Cache Plugin Page</a> &#8211; <a href="http://wordpress.org/tags/askapache-crazy-cache?forum_id=10">News</a></p>
<blockquote cite="http://wordpress.org/extend/plugins/askapache-crazy-cache/">
<p>
<p><a class="IFL" href="http://uploads.askapache.com/2009/11/askapache-crazy-cache.png"><img src="http://uploads.askapache.com/2009/11/askapache-crazy-cache-116x36.png" alt="AskApache Crazy Cache" title="AskApache Crazy Cache" width="116" height="36" /></a>This sweet little plugin does one thing very well. It caches all the posts on your entire blog at the same time, if you are using WP-Cache, WP-Super-Cache, or Hyper-Cache.<br class="C" /></p>
</p>
</blockquote>
<pre>
                              +&#45;&#45;-&#45;&#45;-&#45;&#45;-+ &#45;&#45;-&#45;&#45;-&#45;&#45;-\      active OPEN
                              |  CLOSED |            \    &#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-
                              +&#45;&#45;-&#45;&#45;-&#45;&#45;-+&lt;&#45;&#45;-&#45;&#45;-&#45;&#45;-\   \   create TCB
                                |     ^              \   \  snd SYN
                   passive OPEN |     |   CLOSE        \   \
                   &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;- |     | &#45;&#45;-&#45;&#45;-&#45;&#45;&#45;-       \   \
                    create TCB  |     | delete TCB         \   \
                                V     |                      \   \
                              +&#45;&#45;-&#45;&#45;-&#45;&#45;-+            CLOSE    |    \
                              |  LISTEN |          &#45;&#45;-&#45;&#45;-&#45;&#45;&#45;- |     |
                              +&#45;&#45;-&#45;&#45;-&#45;&#45;-+          delete TCB |     |
                   rcv SYN      |     |     SEND              |     |
                  &#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-   |     |    &#45;&#45;-&#45;&#45;&#45;-            |     V
 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+      snd SYN,ACK  /       \   snd SYN          +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
 |         |&lt;&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-           &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&gt;|         |
 |   SYN   |                    rcv SYN                     |   SYN   |
 |   RCVD  |&lt;&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-|   SENT  |
 |         |                    snd ACK                     |         |
 |         |&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-           &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;-|         |
 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+   rcv ACK of SYN  \       /  rcv SYN,ACK       +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
   |           &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-   |     |   &#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-
   |                  x         |     |     snd ACK
   |                            V     V
   |  CLOSE                   +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
   | &#45;&#45;-&#45;&#45;&#45;-                  |  ESTAB  |
   | snd FIN                  +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
   |                   CLOSE    |     |    rcv FIN
   V                  &#45;&#45;-&#45;&#45;&#45;-   |     |    &#45;&#45;-&#45;&#45;&#45;-
 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+          snd FIN  /       \   snd ACK          +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
 |  FIN    |&lt;&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-           &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&gt;|  CLOSE  |
 | WAIT-1  |&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-                              |   WAIT  |
 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+          rcv FIN  \                            +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
   | rcv ACK of FIN   &#45;&#45;-&#45;&#45;&#45;-   |                            CLOSE  |
   | &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;-   snd ACK   |                           &#45;&#45;-&#45;&#45;&#45;- |
   V        x                   V                           snd FIN V
 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+                  +&#45;&#45;-&#45;&#45;-&#45;&#45;-+                   +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
 |FINWAIT-2|                  | CLOSING |                   | LAST-ACK|
 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+                  +&#45;&#45;-&#45;&#45;-&#45;&#45;-+                   +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
   |                rcv ACK of FIN |                 rcv ACK of FIN |
   |  rcv FIN       &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;- |    Timeout=2MSL &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;&#45;&#45;- |
   |  &#45;&#45;-&#45;&#45;&#45;-              x       V    &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-        x       V
    \ snd ACK                 +&#45;&#45;-&#45;&#45;-&#45;&#45;-+delete TCB         +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
     &#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&gt;|TIME WAIT|&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&gt;| CLOSED  |
                              +&#45;&#45;-&#45;&#45;-&#45;&#45;-+                   +&#45;&#45;-&#45;&#45;-&#45;&#45;-+
&nbsp;
                      TCP Connection State Diagram</pre>
<p><a href="http://www.askapache.com/wordpress/fastest-caching-plugins.html"></a><a href="http://www.askapache.com/wordpress/fastest-caching-plugins.html">Vetted &#8211; Top 3 WordPress Speed Plugins</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/hrPds1sGthb0kOPiXjI6cGIK_9Y/0/da"><img src="http://feedads.g.doubleclick.net/~a/hrPds1sGthb0kOPiXjI6cGIK_9Y/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/hrPds1sGthb0kOPiXjI6cGIK_9Y/1/da"><img src="http://feedads.g.doubleclick.net/~a/hrPds1sGthb0kOPiXjI6cGIK_9Y/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SBHiZIMT-YQ:Ke-kTKoY07k:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=SBHiZIMT-YQ:Ke-kTKoY07k:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SBHiZIMT-YQ:Ke-kTKoY07k:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=SBHiZIMT-YQ:Ke-kTKoY07k:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SBHiZIMT-YQ:Ke-kTKoY07k:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=SBHiZIMT-YQ:Ke-kTKoY07k:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=SBHiZIMT-YQ:Ke-kTKoY07k:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/wordpress/fastest-caching-plugins.html/feed/</wfw:commentRss>
		<slash:comments>13</slash:comments>
		<feedburner:origLink>http://www.askapache.com/wordpress/fastest-caching-plugins.html</feedburner:origLink></item>
		<item>
		<title>Custom bash_profile for Advanced Shell Users</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/-67b1YGaPtY/bash_profile-functions-advanced-shell.html</link>
		<comments>http://www.askapache.com/linux-unix/bash_profile-functions-advanced-shell.html#comments</comments>
		<pubDate>Mon, 23 Nov 2009 20:32:26 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Featured]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Linux Unix BSD]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Shell Scripting]]></category>
		<category><![CDATA[Web Hosting]]></category>
		<category><![CDATA[.bashrc]]></category>
		<category><![CDATA[500]]></category>
		<category><![CDATA[admin]]></category>
		<category><![CDATA[Advanced]]></category>
		<category><![CDATA[Apache]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[Backups]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[bash alias]]></category>
		<category><![CDATA[bash_profile]]></category>
		<category><![CDATA[CCZE]]></category>
		<category><![CDATA[chmod]]></category>
		<category><![CDATA[CNAME]]></category>
		<category><![CDATA[Cookies]]></category>
		<category><![CDATA[curl]]></category>
		<category><![CDATA[Dig]]></category>
		<category><![CDATA[DreamHost]]></category>
		<category><![CDATA[Firefox]]></category>
		<category><![CDATA[Forms]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[Google]]></category>
		<category><![CDATA[GPG]]></category>
		<category><![CDATA[grep]]></category>
		<category><![CDATA[HostGator]]></category>
		<category><![CDATA[Htaccess]]></category>
		<category><![CDATA[Htpasswd]]></category>
		<category><![CDATA[HTTP Headers]]></category>
		<category><![CDATA[HTTPS SSL]]></category>
		<category><![CDATA[ionice]]></category>
		<category><![CDATA[iostat]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Networking]]></category>
		<category><![CDATA[Nice]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Port]]></category>
		<category><![CDATA[Prompt]]></category>
		<category><![CDATA[PS1]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[Redirect]]></category>
		<category><![CDATA[Redirection]]></category>
		<category><![CDATA[Renice]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[Shell]]></category>
		<category><![CDATA[shell script]]></category>
		<category><![CDATA[Socket]]></category>
		<category><![CDATA[SOCKS]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSH]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[SymLinks]]></category>
		<category><![CDATA[Ulimit]]></category>
		<category><![CDATA[Wget]]></category>
		<category><![CDATA[WiredTree]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[wp-config.php]]></category>
		<category><![CDATA[xargs]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3183</guid>
		<description><![CDATA[<p>Looking for some <strong>advanced uses for the shell</strong>?  Here is <del>some of</del> my best.  The shell is where 70% of my work takes place, and I have at least one terminal open almost 100% of the time, for viewing tailing color-coded logs, and of course for the SSH Tunnels that I use to route various networking through, like my email.  So I decided that to standardize and create a bash_profile containing the most time-saving and helpful functions that I could use on all the various hosting environments would really be some sweet sugar, so here is my constant Work-in-progress.</p>
<p>It works for all shells I encounter, including BackTrack, Debian, Knoppix, Arch Linux, etc.   Also works for many hosting environments I use including DreamHost, HostGator, WiredTree, and pretty much any linux VPS.</p>
<p>I also rely on this heavily from within shell scripts I write to access all the functions and stuff in this .bash_profile, and to do that I just do like:</p>
<pre>#!/bin/bash
&#160;
source ~/.bash_profile &#38;&#62;/dev/nulll
&#160;
pm &#34;PM is a function to output nice messages with color&#34;
yn &#34;Are you enjoying the shell&#34; &#38;&#38; pm &#34;Thats great!&#34; &#124;&#124; pm &#34;Perhaps you&#039;re better suited for DOS&#34;
yn &#34;Show Calendar&#34; &#38;&#38; aa_calendar
yn &#34;Show Fortune&#34; &#38;&#38; aa_fortune</pre>]]></description>
			<content:encoded><![CDATA[<p>Looking for some <strong>advanced uses for the shell</strong>?  Here is <del>some of</del> my best.  Works for all shells I encounter, including BackTrack, Debian, Knoppix, Arch Linux, etc.   Also works for many hosting environments I use including DreamHost, HostGator, WiredTree, and pretty much any linux VPS.</p>
<p class="anote">Want to get started?  Type the following in your shell to download the script and run it.  You should go over the code first and then you can just save it as your .bash_profile &#8211; whenever you want to get updated to the latest version just type aaup, a cool update function that auto dos2unix&#8217;s and runs via an exec command.</p>
<pre>curl -O http://static.askapache.com/askapache-bash-profile.txt &amp;&amp; source askapache-bash-profile.txt
Or if you trust me and my hosting provider (and you aren&#039;t on production)
curl -o ~/.bash_profile http://static.askapache.com/askapache-bash-profile.txt &amp;&amp; exec bash -l</pre>
<p>For those of you power users and server admins that use Bash, ksh, csh, vanilla sh, etc.., or if you are just passionate about shell scripting, because it allows you to get advanced tasks done fast and efficiently, not to mention automated automatically.  I give you my .bash_profile file.   You should edit it to fit your needs, (especially the exported vars like PATH, LDFLAGS, if you don&#8217;t understand something just comment it out) but it&#8217;s pretty universal because I work on alot of other people&#8217;s servers not to mention many different distros and platforms, and when I get hired to do some server work through a shell, I bring this script along for the ride.</p>
<h2>askapache-bash-profile.txt</h2>
<p>You can download the latest version: <a href="http://static.askapache.com/askapache-bash-profile.txt">http://static.askapache.com/askapache-bash-profile.txt</a></p>
<p>The functions and variables below are the way bash sees them, using declare -f, and alias, to make it easier for you to read and understand them.    The actual file at <a href="http://static.askapache.com/askapache-bash-profile.txt">http://static.askapache.com/askapache-bash-profile.txt</a> will always be the most updated version, as I use it personally.  And it has the whole file the way I wrote it, meaning many extra notes and much simpler to follow. Enjoy!</p>
<h2>Gist of the Script..</h2>
<p>I also rely on this heavily from within shell scripts I write to access all the functions and stuff in this .bash_profile, and to do that I just do like:</p>
<pre>#!/bin/bash
&nbsp;
source ~/.bash_profile &amp;&gt;/dev/nulll
&nbsp;
pm &quot;PM is a function to output nice messages with color&quot;
yn &quot;Are you enjoying the shell&quot; &amp;&amp; pm &quot;Thats great!&quot; || pm &quot;Perhaps you&#039;re better suited for DOS&quot;
yn &quot;Show Calendar&quot; &amp;&amp; aa_calendar
yn &quot;Show Fortune&quot; &amp;&amp; aa_fortune</pre>
<pre>alias chmod=&#039;command chmod -c&#039;
alias cpr=&#039;command cp -rpv&#039;
alias df=&#039;command df -kTh&#039;
alias df1=&#039;command df -iTa&#039;
alias diff=&#039;diff -up&#039;
alias dsiz=&#039;du -sk * | sort -n &#45;-&#039;
alias du=&#039;command du -kh&#039;
alias du1=&#039;echo *|tr &quot; &quot; &quot;\n&quot; |xargs -iFF command du -hs FF|sort&#039;
alias env=&#039;command env | sort&#039;
alias h=&#039;history&#039;
alias inice=&#039;ionice -c3 -n7 nice&#039;
alias j=&#039;jobs -l&#039;
alias la=&#039;command ls -Al &#45;-color=auto&#039;
alias lc=&#039;command ls -lAcr &#45;-color=auto&#039;
alias less=&#039;vless&#039;
alias lessc=&#039;ccze -A |`type -P less` -R&#039;
alias lk=&#039;command ls -lASr &#45;-color=auto&#039;
alias llh=&#039;ll -h&#039;
alias lll=&#039;stat -c %a\ %N\ %G\ %U ${PWD}/*|sort&#039;
alias lr=&#039;command ls -lAR &#45;-color=auto&#039;
alias lt=&#039;command ls -lAtr &#45;-color=auto&#039;
alias lu=&#039;command ls -lAur &#45;-color=auto&#039;
alias lx=&#039;command ls -lAXB &#45;-color=auto&#039;
alias mann=&#039;command man -H&#039;
alias n=&#039;/usr/bin/nano3&#039;
alias p=&#039;command ps -HAcl -F S -A f|uniq -w3&#039;
alias path=&#039;echo -e ${PATH//:/\\n}&#039;
alias php=&#039;php -d report_memleaks=1 -d report_zend_debug=1 -d log_errors=0 -d ignore_repeated_errors=0 -d ignore_repeated_source=0 -d error_reporting=30719 -d display_startup_errors=1 -d display_errors=1&#039;
alias pp=&#039;command ps -HAcl -F S -A f&#039;
alias ps1=&#039;command ps -lFA&#039;
alias ps2=&#039;command ps -H&#039;
alias resetw=&#039;echo $&#039;\&#039;&#039;\33[H\33[2J&#039;\&#039;&#039;&#039;
alias subash=&#039;sudo sh -c &#039;\&#039;&#039;export HOME=/root; cd /root; exec bash -l&#039;\&#039;&#039;&#039;
alias top=&#039;top -c&#039;
alias tree=&#039;command tree -Csuflapi&#039;
alias updatedb=&#039;( ( updatedb 2&gt;/dev/null ) &amp; )&#039;
alias vim=&#039;command vim &#45;-noplugin&#039;
alias who=&#039;command who -ar -pld&#039;
alias wtf=&#039;watch -n 1 w -hs&#039;</pre>
<pre>aa_aliases ()
{
    local F=`for i in $(alias|awk -F= &#039;{print $1}&#039;);do echo $i;done|sed -e :a -e &#039;s/^.\{1,15\}$/&amp; /;ta&#039;|tr &#039; &#039; &#039;\032&#039;`;
    i=1;
    for f in ${F};
    do
        echo -en &quot;$f&quot;;
        (( $i % 4 ==0 )) &amp;&amp; echo -en &quot;\n&quot;;
        i=$(( $i + 1));
    done | tr &#039;\032&#039; &quot; &quot;
}
aa_beep ()
{
    local i;
    for i in `seq 1 ${1:-5}`;
    do
        echo -en &quot;\a&quot; &amp;&amp; sleep 1;
    done
}
aa_calendar ()
{
    [[ -d /usr/share/calendar/ ]] &amp;&amp; echo -en &quot;\n${CC[4]}&quot; &amp;&amp; ( sed = $(echo /usr/share/calendar/calendar*) | sed -n &quot;/$(date +%m\\/%d\\\|%b\*\ %d)/p&quot; ) &amp;&amp; echo -en &quot;${R}&quot;
}
aa_current_users ()
{
    echo -n &quot;`command who -q |sed &#039;/^# users=\([0-9]*\).*/!d; s//\1/;q&#039;`&quot;
}
aa_find_exec ()
{
    find -L ${1:-.} -type f -perm +0100 2&gt;$N6 | xargs file | sed -e &#039;s%^\([^:]*\):\([^,]*\).*$%\1:\2%g&#039;
}
aa_fortune ()
{
    local FORTUNE=`command type -P fortune`;
    [[ -x $FORTUNE ]] &amp;&amp; echo -en &quot;\n${CC[5]}&quot; &amp;&amp; $FORTUNE -s &amp;&amp; echo -en &quot;${R}&quot;;
    [[ -x $FORTUNE ]] &amp;&amp; echo -en &quot;\n${CC[6]}&quot; &amp;&amp; $FORTUNE -s &amp;&amp; echo -en &quot;${R}&quot;;
    [[ -x $FORTUNE ]] &amp;&amp; echo -en &quot;\n${CC[7]}&quot; &amp;&amp; $FORTUNE -s &amp;&amp; echo -en &quot;${R}&quot;;
    [[ -x $FORTUNE ]] &amp;&amp; echo -en &quot;\n${CC[8]}&quot; &amp;&amp; $FORTUNE -s &amp;&amp; echo -e &quot;${R}&quot;
}
aa_free_mem ()
{
    echo -n &quot;`[[ -r /proc/meminfo ]] &amp;&amp; sed &#039;/^MemFree: */!d; s///;q&#039; /proc/meminfo`&quot;
}
aa_functions ()
{
    local F=`for i in $(declare -F | sed -e &#039;s/declare -f //g&#039;); do echo $i; done| sed -e :a -e &#039;s/^.\{1,25\}$/&amp; /;ta&#039;|tr &#039; &#039; &#039;\032&#039;`;
    i=1;
    for f in ${F};
    do
        echo -en &quot;$f&quot;;
        (( $i % 4 ==0 )) &amp;&amp; echo -en &quot;\n&quot;;
        i=$(( $i + 1));
    done | tr &#039;\032&#039; &quot; &quot;
}
aa_getsrc ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &lt;url&gt;&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    [[ -z &quot;$CPPFLAGS&quot; ]] &amp;&amp; pm &quot;Setting CPPFLAGS&quot; &amp;&amp; export CPPFLAGS=&quot;-I/usr/local/include/libxml2 -I/opt/libiconv/include&quot;;
    [[ -z &quot;$LD_FLAGS&quot; ]] &amp;&amp; pm &quot;Setting LD_FLAGS&quot; &amp;&amp; export LD_FLAGS=&quot;-L/usr/local/lib -L/usr/local/lib/python2.4/site-packages -L/usr/local/lib -lxml2 -lz -L/opt/libiconv/lib -liconv -lm&quot;;
    function aa_err ()
    {
        echo &#039;&#039;;
        local s;
        echo -en &quot;\n [ ${1:-Press any key to continue} ]\n&quot;;
        read -n 1 s
    };
    function aa_install ()
    {
        ./configure &#45;-help;
        ./configure &#45;-prefix=/usr/local &quot;$*&quot; &amp;&amp; make -j3 &amp;&amp; sudo make install || aa_err;
        echo -en &quot;\a&quot;
    };
    function aa_extract ()
    {
        case $1 in
            *.tar.bz2)
                tar xjf $1
            ;;
            *.tar.gz)
                tar xzf $1
            ;;
            *.tar)
                tar xf $1
            ;;
            *.tbz2)
                tar xjf $1
            ;;
            *.tgz)
                tar xzf $1
            ;;
            *.bz2)
                bunzip2 $1
            ;;
            *.rar)
                unrar x $1
            ;;
            *.gz)
                gunzip $1
            ;;
            *.zip)
                unzip $1
            ;;
            *.Z)
                uncompress $1
            ;;
            *.7z)
                7z x $1
            ;;
            *)
                aa_err
            ;;
        esac
    };
    local OD=`pwd -L`;
    local FN=$(echo $1 | sed -e &#039;s/^.*\/\([^\/]\{3,\}\)$/\1/g&#039;);
    local SN=$(echo $FN |  sed -e &#039;s/\(.\{1\}\)\([^-.]\{1,\}\).*/\1\2/g&#039;);
    echo -e &quot;OD: $OD \n1: $1 \nFN: $FN \nSN: $SN&quot; &amp;&amp; sleep 1;
    cd /opt/dist;
    ( curl -# -L -f -b c.txt &#45;-cookie-jar c.txt -m 400 -O -H &#039;Accept: */*&#039; -s -S -A &#039;Mozilla/5.0 (Windows NT 5.1; en-US; rv:1.9.1.5) Gecko/2009 Firefox/3.5.5&#039; -e &quot;$1&quot; &#45;-url &quot;$1&quot; || v_err &quot;CURL FAILED for $1&quot; );
    [[ -f &quot;$FN&quot; ]] &amp;&amp; aa_extract &quot;$FN&quot; || aa_err &quot;EXTRACTING FAILED for $FN, go manual it&quot;;
    [[ -d &quot;/opt/$SN&quot; ]] &amp;&amp; mv -v /opt/$SN /opt/.old-$SN;
    mv -v /opt/source/`echo $1|sed -e &#039;s/.*\/\(.*\)\.\([tgz7bar2v]*\)\(\.[tgz7bar2v]*\)$/\1/g&#039;` /opt/$SN || aa_err &quot;Please mv $1 to /opt/$SN&quot;;
    cd /opt/$SN &amp;&amp; command ls -lABls1c $AAC &amp;&amp; aa_install;
    cd $OD
}</pre>
<pre>aa_hexdump ()
{
    local EX;
    [[ $# -eq 1 ]] &amp;&amp; EX=exec;
    [[ -f &quot;$1&quot; ]] &amp;&amp; EX=&#039;cat &quot;$1&quot;&#039;;
    case ${2:-1} in
        0)
            $EX hexdump -C
        ;;
        1)
            $EX hexdump -Cc
        ;;
        2)
            $EX hexdump -Cx
        ;;
        3)
            $EX hexdump -C -e &#039;&quot;&quot;  10/1 &quot;&#039;\&#039;&#039;%_c&#039;\&#039;&#039;\t&quot; &quot;\n&quot;&#039; -e &#039;&quot;&quot; 10/1 &quot;0x%02x\t&quot; &quot;\n\n&quot;&#039;
        ;;
        4)
            $EX hexdump -e &#039;&quot;&quot;  10/1 &quot;&#039;\&#039;&#039;%_c&#039;\&#039;&#039;\t&quot; &quot;\n&quot;&#039;
        ;;
        5)
            $EX hexdump -e &#039;&quot;&quot;  10/1 &quot;&#039;\&#039;&#039;%_c&#039;\&#039;&#039;\t&quot; &quot;\n&quot;&#039; -e &#039;&quot;&quot; 10/1 &quot;0x%04x\t&quot; &quot;\n\n&quot;&#039;
        ;;
        6)
            $EX hexdump -e &#039;90/1 &quot;%_p&quot; &quot;\n&quot;&#039;
        ;;
        7)
            $EX hexdump -e &#039;1/1 &quot;%04_u&quot; &quot;%4_p&quot; &quot;   &quot; 1/1 &quot;%04x&quot; &quot;  &quot; 1/1 &quot;%04_c&quot;  &quot;\n&quot;&#039;
        ;;
        8)
            $EX hexdump -v -e &#039;&quot;x&quot; 1/1 &quot;%02X&quot; &quot; &quot;&#039;
        ;;
        9)
            $EX od -Ax -tx1 -v
        ;;
        10)
            $EX od -t o1z -w1 -Ao -v
        ;;
        11)
            $EX xxd -
        ;;
        12)
            $EX xxd -c1
        ;;
        13)
            $EX xxd -h
        ;;
        14)
            $EX
        ;;
    esac
}
aa_ips ()
{
    ahave ip &amp;&amp; ip -o -f inet addr 2&gt;&amp;1 | sed -e &#039;s/.*inet \([^/]*\).*/\1/g&#039; | sort -u;
    ahave ss &amp;&amp; ss -n 2&gt;&amp;1 | sed -e &#039;s/[^:]*\ \([0-9]*\.[0-9]*\.[0-9]*\.[0-9]*\)\:.*/\1/&#039; -e &#039;/^\([^0-9]\|127\.\|10\.\|172\.\)/d&#039; | sort -u;
    [[ -f &quot;$HOME/.cpanel/datastore/_sbin_ifconfig_-a&quot; ]] &amp;&amp; sed -e &#039;/inet/!d&#039; -e &#039;s/.*addr:\([0-9\.]*\).*/\1/g&#039; &quot;$HOME/.cpanel/datastore/_sbin_ifconfig_-a&quot; | sort -u;
    sed -e &#039;s/^\([0-9]*\.[0-9]*\.[0-9]*\.[0-9]*\).*/\1/&#039; -e &#039;/^\([^0-9]\|127\.\|10\.\|172\.\|$\)/d&#039; /etc/hosts | sort -u
}
aa_isalpha ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME str&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    case $1 in
        *[!a-zA-Z]* | &quot;&quot;)
            return -1
        ;;
        *)
            return 0
        ;;
    esac
}
aa_isdigit ()
{
    case $1 in
        *[!0-9]* | &quot;&quot;)
            return -1
        ;;
        *)
            return 0
        ;;
    esac
}
aa_mkdir ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    local e=0;
    for f in ${1+&quot;$@&quot;};
    do
        set fnord `echo &quot;:$f&quot;|sed -e &#039;s/^:\//%/&#039; -e &#039;s/^://&#039; -e &#039;s/\// /g&#039; -e &#039;s/^%/\//&#039;`;
        shift;
        p=;
        for d in ${1+&quot;$@&quot;};
        do
            p=&quot;$p$d&quot;;
            case &quot;$p&quot; in
                -*)
                    p=./$p
                ;;
                ?:)
                    p=&quot;$p/&quot;;
                    continue
                ;;
            esac;
            [[ ! -d &quot;$p&quot; ]] &amp;&amp; mkdir -v &quot;$p&quot; || e=$?;
            p=&quot;$p/&quot;;
        done;
    done;
    return $e
}
aa_motd ()
{
    [[ -r /etc/motd &amp;&amp; `cat /etc/motd |wc -l` -gt 7 ]] &amp;&amp; ( echo -e &quot;\n\n${CC[2]}`head -n 7 /etc/motd | tail -n 6`${R}\n&quot; ) &amp;&amp; return;
    ahave figlet &amp;&amp; figlet $HOSTNAME
}
aa_num_procs ()
{
    echo -n `command ps aux|wc -l`
}
aa_prompt ()
{
    AAPS[0]=&#039;\n\e[1;30m[\e[0;37m${SHLVL}\e[1;30m:\e[0;37m\j:\!\e[1;30m][\e[1;34m\u\e[0;34m@\e[1;34m\h\e[1;30m:\e[1;37m${SSHTTY/\/dev\/}\e[1;30m]\e[0;37m[\e[0;37m\w\e[0;37m]\e[1;30m\n\[${R}\]\$ &#039;;
    AAPS[1]=&#039;\n\e[1;30m[\e[0;37m${SHLVL}\e[1;30m:\e[0;37m\j:\!\e[1;30m][\e[0;32m\u\e[1;32m@\e[0;32m\h\e[1;30m:\e[1;37m${SSHTTY/\/dev\/}\e[1;30m]\e[0;37m[\e[0;37m\w\e[0;37m]\e[1;30m\n\[${R}\]\$ &#039;;
    AAPS[2]=&#039;\n\e[1;30m[\e[0;37m${SHLVL}\e[1;30m:\e[0;37m\j:\!\e[1;30m][\e[0;35m\u\e[1;35m@\e[0;35m\h\e[1;30m:\e[1;37m${SSHTTY/\/dev\/}\e[1;30m]\e[0;37m[\e[0;37m\w\e[0;37m]\e[1;30m\n\[${R}\]\$ &#039;;
    : ${PLVL=0};
    [[ &quot;${#AAPS[@]}&quot; -lt &quot;$PLVL&quot; || &quot;${#AAPS[@]}&quot; -eq &quot;$PLVL&quot; ]] &amp;&amp; PLVL=0;
    export PS1=${AAPS[$PLVL]} &amp;&amp; (( PLVL++ )) &amp;&amp; export PLVL;
    echo &quot;PLVL=$PLVL&quot;
}
aa_random_under ()
{
    echo $(( $RANDOM % ${1:-$RANDOM} + 1 ))
}
aa_safe_aliases ()
{
    local MYMVR=$(command type -t mymvmymv);
    [[ &quot;$MYMVR&quot; == &quot;alias&quot; ]] &amp;&amp; echo &quot;Turning Safe Aliases Off&quot; &amp;&amp; for fa in &quot;chmod&quot; &quot;mkdir&quot; &quot;rm&quot; &quot;cp&quot; &quot;mv&quot; &quot;mymv&quot;;
    do
        unalias $fa;
    done &amp;&amp; return;
    echo &quot;Turning Safe Aliases On&quot;;
    alias chmod=&#039;command chmod -c&#039;;
    alias mkdir=&#039;command mkdir -pv&#039;;
    alias rm=&#039;command rm -v&#039;;
    alias cp=&#039;command cp -v&#039;;
    alias mv=&#039;command mv -v&#039;;
    alias mymv=&#039;echo&#039;
}</pre>
<pre>aa_savehist ()
{
    history ${HISTCMD:-5000} | sed -e &#039;s/^[ 0-9]*\(.*\)/\1/g&#039; | tee -a $HISTFILEMASTER_C &gt;&gt;$HISTFILEMASTER;
    cat $HISTFILE | tee -a $HISTFILEMASTER_C &gt;&gt;$HISTFILEMASTER;
    history -w;
    echo
}
aa_show_all_colors ()
{
    for c in `seq 0 255`;
    do
        t=5;
        [[ $c -lt 108 ]] &amp;&amp; t=0;
        for i in `seq $t 5`;
        do
            echo -e &quot;\e[0;48;$i;${c}m|| $i:$c `seq -s+0 $(($COLUMNS/2))|tr -d &#039;[0-9]&#039;`\e[0m&quot;;
        done;
    done;
    echo;
    echo Table for 16-color terminal escape sequences.;
    echo Replace ESC with \\033 in bash.;
    echo;
    echo &quot;Background | Foreground colors&quot;;
    echo &quot;&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&quot;;
    for ((bg=40; bg&lt;=47; bg++))
    do
        for ((bold=0; bold&lt;=1; bold++))
        do
            echo -en &quot;\033[0m&quot;&quot; ESC[${bg}m   | &quot;;
            for ((fg=30; fg&lt;=37; fg++))
            do
                if [ $bold == &quot;0&quot; ]; then
                    echo -en &quot;\033[${bg}m\033[${fg}m [${fg}m  &quot;;
                else
                    echo -en &quot;\033[${bg}m\033[1;${fg}m [1;${fg}m&quot;;
                fi;
            done;
            echo -e &quot;\033[0m&quot;;
        done;
        echo &quot;&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;-&#45;&#45;- &quot;;
    done;
    echo;
    echo
}
aa_sleep ()
{
    echo -en &quot;${CC[6]}${3:-.}&quot;;
    while `command ps -p $1 &amp;&gt;/dev/null`; do
        echo -n &quot;${3:-.}&quot;;
        sleep ${3:-1};
    done;
    echo -e &quot;$R$X&quot; &amp;&amp; sleep 1 &amp;&amp; pd
}
aa_try_for_path ()
{
    local GP=$HOME/bin:$HOME/sbin;
    [[ -z &quot;$PATH&quot; || &quot;$PATH&quot; == &quot;/bin:/usr/bin&quot; ]] &amp;&amp; export PATH=&quot;/usr/local/bin:/usr/bin:/bin:/usr/bin/X11:/usr/games&quot;;
    local P=$PATH:$HOME/libexec;
    [[ &quot;$EUID&quot; -eq 0 ]] &amp;&amp; P=&quot;/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/bin/X11&quot;;
    P=${P}:/usr/local/bin:/usr/bin:/bin:/usr/bin/X11:/usr/games;
    P=${P}:/bin:/etc:/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/bin/mh:/usr/libexec;
    P=${P}:/usr/X11R6/bin:/usr/libexec:/etc/X11:/etc/X11/xinit;
    [[ &quot;$DREAMHOST&quot; == &quot;yes&quot; ]] &amp;&amp; ( P=${P}:/usr/local/dh/apache/template/bin:/usr/local/dh/apache2/template/bin;
    P=${P}:/usr/local/dh/apache2/template/build:/usr/local/dh/apache2/template/sbin;
    P=${P}:/usr/local/dh/bin:/usr/local/dh/java/bin:/usr/local/dh/java/jre/bin;
    P=${P}:/usr/lib/ruby/gems/1.8/bin:$HOME/.gem/ruby/1.8/bin );
    P=${P}:/usr/local/php5/bin;
    for p in ${P//:/ };
    do
        [[ -d &quot;${p}&quot; &amp;&amp; -x &quot;${p}&quot; ]] &amp;&amp; GP=${GP}:$p;
    done;
    export PATH=$( echo -en &quot;${GP//:/\\n}&quot; | sed -n &#039;G; s/\n/&amp;&amp;/; /^\([ -~]*\n\).*\n\1/d; h; P&#039; | tr &quot;\n&quot; : ).
}
aa_uniqhistory ()
{
    ( echo $HISTFILE;
    find $HISTFILEMASTER_DIR -type f 2&gt;$N6 ) | xargs -iFFF cat FFF 2&gt;$N6 | sed -e &#039;s/^[ \t]*//;s/[ \t]*$//&#039; -e &#039;/[^ \t]\{1,\}/!d&#039; | tr &#45;-squeeze &#039; &#039; | sort -u
}
aa_weather ()
{
    ahave lynx || return;
    local city weather=$HOME/.weather;
    echo -e &quot;${CC[3]}&quot;;
    local res=`pkill -9 -f 15m &amp;&gt;$N6 || echo -n`;
    [[ -r $weather ]] &amp;&amp; cat $weather &amp;&amp; ( ( sleep 15m &amp;&amp; command rm $HOME/.weather &gt;&amp;$N6 ) &amp; );
    [[ ! -r $weather ]] &amp;&amp; ( ( ( city=`lynx -dump http://api.hostip.info/get_html.php|sed -e &#039;/^City/!d&#039; -e &#039;s/City: \([^,]*\), \(.*\)/\1+\2/g&#039;` &amp;&amp; lynx -dump &quot;http://www.google.com/search?hl=en&amp;q=weather+${city}&quot; | sed -n &#039;/Weather for/,/Search Res/p&#039; | tr -d &#039;\260&#039; | sed -e &#039;/iGoogle/d&#039; -e &#039;s/^[ \t]*//;s/[ \t]*$//&#039; | sed &#039;$d&#039; | head -n 6 &gt;$weather ) &amp;  &gt;&amp;/dev/null ) );
    echo -e $R
}
aaup ()
{
    curl3 -0 -o ~/.bash_profile http://static.askapache.com/askapache-bash-profile.txt &amp;&amp; dos2unix -dv ~/.bash_profile &amp;&amp; ( rm -rf ~/{.bash_logout,.toprc,.lynxrc,.ncftp} || echo;
    echo ) &amp;&amp; aa_savehist &amp;&amp; exec bash -l
}
ahave ()
{
    unset -v ahave;
    command command type $1 &gt;&amp;$N6 &amp;&amp; ahave=&quot;yes&quot; || return 1
}
ahelp ()
{
    unset -v ahelp;
    [[ &quot;$#&quot; -gt &quot;0&quot; ]] &amp;&amp; [[ &quot;$1&quot; == &quot;-h&quot; || &quot;$1&quot; == &quot;&#45;-h&quot; || &quot;$1&quot; == &quot;&#45;-help&quot; || &quot;$1&quot; == &quot;-help&quot; || &quot;$1&quot; == &quot;-?&quot; ]] &amp;&amp; ahelp=&quot;yes&quot;
}
arepeat ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    local i max=$1;
    shift;
    for ((i=1; i &lt;= max ; i++))
    do
        eval &quot;$@&quot;;
    done
}
ascript_title ()
{
    ahave tput &amp;&amp; tput cup 0 3;
    clear;
    lin 0;
    echo -e &quot;| ${CC[${1:-2}]}                ___       __    ___                 __                  ${CC[0]} |&quot;;
    echo -e &quot;| ${CC[${1:-2}]}               / _ | ___ / /__ / _ | ___  ___ _____/ /  ___             ${CC[0]} |&quot;;
    echo -e &quot;| ${CC[${2:-9}]}              / __ |(_-&lt;/  &#039;_// __ |/ _ \/ _ \`/ __/ _ \/ -_)            ${CC[0]} |&quot;;
    echo -e &quot;| ${CC[${2:-9}]}             /_/ |_/___/_/\_\/_/ |_/ .__/\_,_/\__/_//_/\__/             ${CC[0]} |&quot;;
    echo -e &quot;| ${CC[${2:-9}]}                                  /_/                                   ${CC[0]} |&quot;;
    lin 1;
    lin 2 &quot;${USER} &quot;;
    lin 2 &quot;${1:-$AAPN} &quot;;
    lin 2 &quot;Version ${2:-$AAPV} - Built: ${3:-$AAPT} &quot;;
    lin 3
}
asetup_colors ()
{
    create_colors;
    ahave dircolors &amp;&amp; eval &quot;`dircolors -b`&quot;;
    export GREP_COLOR=&#039;
cho $R;
    [[ -r $HOME/.dircolors ]] &amp;&amp; eval &quot;`dircolors $HOME/.dircolors`&quot; || dircolors &#45;-print-database &gt;$HOME/.dircolors;
    local L=&quot;no=00:fi=00:di=01;34:ln=01;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:*.tar=01;31:*.tgz=01;31:*.svgz=01;31:*.arj=01;31:*.taz=01;31&quot;;
    L=&quot;${L}:*.lzh=01;31:*.lzma=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.rar=01;31:*.ace=01;31:*.zoo=01;31&quot;;
    L=&quot;${L}:*.7z=01;31:*.rz=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.mng=01;35&quot;;
    L=&quot;${L}:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35&quot;;
    L=&quot;${L}:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.cpio=01;31&quot;;
    export LS_COLORS=&quot;${L}:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.htaccess=01;31:*.htpasswd=01;31:*.htpasswda1=01;31:*config.php=01;31:*wp-config.php=01;31:&quot;
}</pre>
<pre>asetup_history ()
{
    export HISTFILE=${HISTFILE:-$HOME/.bash_history};
    export HISTCONTROL=${HISTCONTROL:-&#039;ignoreboth&#039;};
    export HISTSIZE=500;
    export HISTFILESIZE=500;
    export HISTIGNORE=&#039;clear:ls:ll:updatedb:top:h2:h1:h3:dir:cd ..:date:exit&#039;;
    unset HISTTIMEFORMAT;
    HISTFILEMASTER_DIR=$HOME/backups/.history;
    [[ ! -d &quot;$HISTFILEMASTER_DIR/&quot; ]] &amp;&amp; mkdir -pv $HISTFILEMASTER_DIR;
    [[ ! -r ${HISTFILE} ]] &amp;&amp; history -w $HISTFILE;
    HISTFILEMASTER=${HISTFILEMASTER_DIR}/combined.log;
    [[ ! -f $HISTFILEMASTER ]] &amp;&amp; history -r &amp;&amp; history -w $HISTFILEMASTER &amp;&amp; history -c &amp;&amp; echo &quot;&quot; &gt;$HISTFILE;
    export HISTFILEMASTER;
    HISTFILEMASTER_C=$HISTFILEMASTER_DIR/combined-uniq.log;
    [[ ! -f &quot;$HISTFILEMASTER_C&quot; ]] &amp;&amp; echo &quot;&quot; &gt;$HISTFILEMASTER_C;
    export HISTFILEMASTER_C
}
askapache ()
{
    ascript_title;
    aa_motd;
    aa_weather;
    ahave who &amp;&amp; pm &quot;Users&quot; &amp;&amp; pm &quot;Logged In&quot; 3;
    command who -ar -pld &amp;&amp; pm &quot;Current Limits&quot; 3;
    command ulimit -a;
    pm &quot;Machine stats&quot;;
    ahave uptime &amp;&amp; pm &quot;uptime&quot; 3 &amp;&amp; command uptime;
    [[ -d /proc ]] &amp;&amp; [[ -f /proc/meminfo ]] &amp;&amp; cat /proc/meminfo;
    ahave who &amp;&amp; pm &quot;Users&quot; 3 &amp;&amp; command who;
    pm &quot;Networking&quot;;
    ahave ip &amp;&amp; pm &quot;interfaces&quot; 3 &amp;&amp; ip -o addr | sed -e &#039;s/ \{1,\}/\t/g&#039;;
    [[ -r /proc/net/sockstat ]] &amp;&amp; pm &quot;Sockets&quot; 3 &amp;&amp; head -n 2 /proc/net/sockstat;
    ahave ss &amp;&amp; pm &quot;Networking Stats&quot; 3 &amp;&amp; ss -s;
    ahave netstat &amp;&amp; pm &quot;Routing Information&quot; 3 &amp;&amp; netstat -r;
    pm &quot;Disk&quot;;
    pm &quot;Mounts&quot; 3;
    command df -hai;
    ahave iostat &amp;&amp; pm &quot;I/O on Disks&quot; &amp;&amp; iostat -p ALL;
    pm &quot;Processes&quot;;
    pm &quot;process tree&quot; 3;
    command ps -HAcl -F S -A f | uniq -w3;
    ahave procinfo &amp;&amp; pm &quot;procinfo&quot; 3 &amp;&amp; procinfo | head -n 13 | tail -n 11;
    pm &quot;Functions&quot;;
    aa_functions;
    pm &quot;Aliases&quot;;
    aa_aliases
}
clean_exit ()
{
    lin 0;
    lin 1;
    lin 2 &quot;COMPLETED SUCCESSFULLY&quot;;
    lin 1;
    lin 3
}
cont ()
{
    local ans;
    echo -en &quot;\n\n ${CC[15]}[ ${1:-Press any key to continue} ]$R\n\n&quot;;
    read -n 1 ans;
    aa_beep 1
}
create_colors ()
{
    for i in `seq 0 7`;
    do
        ii=$(($i+7));
        CC[$i]=&quot;\033[1;3${i}m&quot;;
        CC[$ii]=&quot;\033[0;3${i}m&quot;;
    done;
    CC[15]=&quot;\033[30;42m&quot;;
    export R=`tput sgr0`;
    export X=&#039;&#039;;
    export CC
}</pre>
<pre>curl1 ()
{
    command curl -A &#039;Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.1.5) Gecko/20091102 Firefox/3.5.5&#039; -e -L -H &#039;Accept: */*&#039; &quot;$@&quot;
}
curl2 ()
{
    ( echo &quot;\n\nurl_effective:\t\t%{url_effective}\ncontent_type:\t\t%{content_type}&quot;;
    echo &quot;http_code:\t\t%{http_code}\t\tThe numerical code that was found in the last retrieved HTTPS page&quot;;
    echo &quot;http_connect:\t\t%{http_connect}\t\tThe numerical code that was found in the last response from a proxy to a curl CONNECT request&quot;;
    echo &quot;time_total:\t\t%{time_total}\t\tThe time will be displayed with millisecond resolution&quot;;
    echo &quot;time_namelookup:\t%{time_namelookup}\t\tThe time, in seconds, it took from the start until the name resolving was completed&quot;;
    echo &quot;time_connect:\t\t%{time_connect}\t\tThe time, in seconds, it took from the start until the connect to the remote host or proxy was completed&quot;;
    echo &quot;time_pretransfer:\t%{time_pretransfer}\t\tThe time, in seconds, it took from the start until the file transfer is just about to begin. This includes all pre-transfer commands and negotiations to the particular protocols involved&quot;;
    echo &quot;time_redirect:\t\t%{time_redirect}\t\tThe time, in seconds, it took for all redirection steps. time_redirect shows the complete execution time for multiple redirections&quot;;
    echo &quot;time_starttransfer:\t%{time_starttransfer}\t\tThe time, in seconds, it took from the start until the first byte is just about to be transferred. This includes time_pretransfer and also the time the server needs to calculate the result&quot;;
    echo &quot;size_download:\t\t%{size_download}\t\tThe total amount of bytes that were downloaded&quot;;
    echo &quot;size_upload:\t\t%{size_upload}\t\tThe total amount of bytes that were uploaded&quot;;
    echo &quot;size_header:\t\t%{size_header}\t\tThe total amount of bytes of the downloaded headers&quot;;
    echo &quot;size_request:\t\t%{size_request}\t\tThe total amount of bytes that were sent in the HTTP request&quot;;
    echo &quot;speed_download:\t\t%{speed_download}\tThe average download speed that curl measured for the complete download&quot;;
    echo &quot;speed_upload:\t\t%{speed_upload}\t\tThe average upload speed that curl measured for the complete upload&quot;;
    echo &quot;num_connects:\t\t%{num_connects}\t\tNumber of new connects made in the recent transfer&quot; ) | curl &quot;$@&quot; -w &#039;@-&#039;
}
curl3 ()
{
    ahave curl &amp;&amp; ( curl -A &#039;Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.1.5) Gecko/20091102 Firefox/3.5.5&#039; -e -L -b ~/.curl_cookie.$$ &#45;-cookie-jar ~/.curl_cookie.$$ -H &#039;Accept: */*&#039; &quot;$@&quot; );
    ahave curl || ( command wget `sed -e &#039;s/^-o /-O /g&#039; -e &#039;s/ -o / -O /g&#039; -e &#039;s/^&#45;-output /&#45;-output-file /g&#039; -e &#039;s/ &#45;-output / &#45;-output-file /g&#039; &lt;&lt;&lt; &quot;$@&quot;` )
}
cuttail ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    sed -n -e :a -e &quot;1,${2:-10}!{P;N;D;};N;ba&quot; $1
}
diffdirs ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    [[ &quot;$#&quot; -lt &quot;2&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME dir1 dir2&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    ahave colordiff &amp;&amp; colordiff -urp -w $1 $2
}
dirty_exit ()
{
    echo &quot;See ya..&quot;;
    sleep 1;
    exit
}
do_sleep ()
{
    local E D;
    echo -en &quot;${CC[6]}${3:-.}&quot;;
    while `command ps -p $RJ &amp;&gt;$N6`; do
        sleep ${2:-3};
        echo -en &quot;${3:-.}&quot;;
    done;
    echo -e &quot;${CC[0]}&quot; &amp;&amp; sleep 1 &amp;&amp; pd
}
dos2unixx ()
{
    [[ $# -eq 0 ]] &amp;&amp; exec tr -d &#039;\015\032&#039; || [[ ! -f &quot;$1&quot; ]] &amp;&amp; echo &quot;Not found: $1&quot; &amp;&amp; return;
    for f in &quot;$@&quot;;
    do
        [[ ! -f &quot;$f&quot; ]] &amp;&amp; continue;
        tr -d &#039;\015\032&#039; &lt;&quot;$f&quot; &gt;&quot;$f.t&quot; &amp;&amp; cmp &quot;$f&quot; &quot;$f.t&quot; &gt;$N6 &amp;&amp; rm -f &quot;$f.t&quot; || ( touch -r &quot;$f&quot; &quot;$f.t&quot; &amp;&amp; mv &quot;$f&quot; &quot;$f.b&quot; &amp;&amp; mv &quot;$f.t&quot; &quot;$f&quot; &amp;&amp; rm -f &quot;$f.b&quot; ) &gt;&amp;$N6;
    done
}
dump_ps_environment ()
{
    command ps aux | command grep ${USER:0:3} | command awk &#039;{print $2}&#039; | xargs -t -ipid /bin/sh -c &#039;test -r /proc/pid/environ &amp;&amp; cat /proc/pid/environ | tr &quot;\000&quot; &quot; &quot;&#039;
}
ex ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    until [[ -z &quot;$1&quot; ]]; do
        if [[ -f &quot;$1&quot; ]]; then
            pm &quot;Extracting $1 &#46;..&quot;;
            case $1 in
                *.tar.bz2)
                    tar xjf $1
                ;;
                *.tar.gz)
                    tar xzf $1
                ;;
                *.tar)
                    tar xf $1
                ;;
                *.tbz2)
                    tar xjf $1
                ;;
                *.tgz)
                    tar xzf $1
                ;;
                *.bz2)
                    bunzip2 $1
                ;;
                *.rar)
                    unrar x $1
                ;;
                *.gz)
                    gunzip $1
                ;;
                *.zip)
                    unzip $1
                ;;
                *.Z)
                    uncompress $1
                ;;
                *.7z)
                    7z x $1
                ;;
                *)
                    pm &quot;Don&#039;t know how to extract &#039;$1&#039;&quot;
                ;;
            esac;
        else
            pm &quot;&#039;$1&#039; is not a valid file&quot;;
        fi;
        shift;
    done
}
exitall ()
{
    aa_savehist;
    pkill -9 -t &quot;${SSH_TTY/\/dev\/}&quot;
}
figtest ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME word&quot; &amp;&amp; return 2;
    for a in /usr/share/figlet/*.flf;
    do
        r=`basename ${a%%.flf}`;
        echo -e &quot;${r}&quot;;
        figlet -t -f &quot;$r&quot; &quot;$1&quot;;
    done
}
find_symlinks ()
{
    local O=$IFS;
    IFS=&#039;&#039;;
    for file in &quot;$( find ${1:-`pwd`} -type l )&quot;;
    do
        echo &quot;$file&quot;;
    done | sort
}
get_crypt_user ()
{
    ahave gpg || return;
    local U=`gpg &#45;-list-keys|sed -e &#039;/^uid /!d&#039; -e &#039;s/^uid[ ]*\(.*\)/\1/g&#039;` || unknown;
    [[ $# -ne 0 ]] &amp;&amp; U=${U//\&lt;*};
    echo -n $U
}
get_latest_revision ()
{
    local URL=${1:-http://svn.automattic.com/wordpress/trunk};
    svn info $URL | grep ^Rev | sed -e &#039;s/Revision: \([0-9]*\)/\1/g&#039;
}
grepc ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    command grep &#45;-color=always &quot;$@&quot;
}
grepp ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    command grep -i &#45;-color=always &quot;$@&quot; -r .
}</pre>
<pre>h2 ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME query&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    command grep -h &quot;$@&quot; $HISTFILEMASTER_C
}
h2c ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME query&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    command grep &#45;-color=always -h &quot;$@&quot; $HISTFILEMASTER_C
}
h2i ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME query&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    command grep -h -i &quot;$@&quot; $HISTFILEMASTER_C
}
histfilemaster ()
{
    set -vx;
    history -a;
    [[ &quot;`wc -l &lt; $HISTFILE`&quot; -gt &quot;$HISTSIZE&quot; ]] &amp;&amp; ( cat $HISTFILE &gt;&gt;$HISTFILEMASTER;
    cat $HISTFILE &gt;`date +$HISTFILEMASTER_DIR/%m-%d-%y.history`;
    cat $HISTFILE $HISTFILEMASTER_C | sort | uniq &gt;$HISTFILEMASTER_DIR/hc.tmp;
    [[ &quot;`wc -l &lt; $HISTFILEMASTER_DIR/hc.tmp`&quot; -gt &quot;`wc -l &lt; $HISTFILEMASTER_C`&quot; ]] &amp;&amp; mv $HISTFILEMASTER_DIR/hc.tmp $HISTFILEMASTER_C || cat $HISTFILE &gt;&gt;$HISTFILEMASTER_C;
    echo &quot;&quot; &gt;$HISTFILE );
    set +vx
}
kill_jobs ()
{
    for i in `command jobs -p`;
    do
        kill -9 $i;
    done
}
l ()
{
    command ls -AhFp $AAC &quot;$@&quot;
}
la ()
{
    command du -kh * | awk &#039;{print $2,$1}&#039; | sort -n | tr &#039; &#039; &quot;\t&quot;
}
lin ()
{
    local L2 L1=&#039;__________________________________________________________________________&#039;;
    case ${1:-1} in
        0)
            echo -e &quot;\n ${CC[0]}${L1}&quot;
        ;;
        1)
            L2=`echo &#039;                                                                          &#039;`;
            echo -e &quot;${CC[0]}|${CC[34]}${L2}${CC[0]}|&quot;
        ;;
        2)
            echo -en &quot;${CC[0]}|${CC[34]}&quot;;
            echo -en &quot;${2:-1}&quot; | sed -e :a -e &#039;s/^.\{1,72\}$/ &amp; /;ta&#039; -e &quot;s/\(.*\)/\1/&quot;;
            echo -e &quot;${CC[0]} |&quot;
        ;;
        3)
            echo -e &quot;${CC[0]} ${L1} $R$X\n\n&quot;
        ;;
    esac
}
ll ()
{
    command ls -lABls1c $AAC &quot;$@&quot;
}
locate1 ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    command locate &quot;$@&quot; | xargs -iFF stat -c %a\ %A\ \ A\ %x\ \ M\ %y\ \ C\ %z\ \ %N FF
}
make_ionice ()
{
    ahave ionice || return;
    local theclass thenicelevel thepid;
    thepid=${1:-$$};
    theclass=${2:-3};
    thenicelevel=${3:-7};
    pm &quot;Making IONice class: $theclass, nicelevel: $thenicelevel, process: $thepid&quot;;
    pm 0 0;
    command ionice -c$theclass -n$thenicelevel -p $thepid;
    pd
}
make_nice ()
{
    ahave renice || return;
    local thenicelevel thepid;
    thepid=${1:-$$};
    thenicelevel=${2:-19};
    pm &quot;Making process $thepid $thenicelevel nice.&quot;;
    pm 0 0;
    command renice $thenicelevel -p $theppid;
    pd
}
nh ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &lt;command&gt;&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    nohup &quot;$@&quot; &gt;&amp;$N6 &amp; echo
}
nicest ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    local ncmd icmd=&#039;&#039;;
    ahave ionice &amp;&amp; icmd=&#039;ionice -c3 -n7&#039;;
    ahave nice &amp;&amp; ncmd=&#039;nice -n 19&#039;;
    $icmd $ncmd &quot;$@&quot;;
    ahave ionice
}
nob ()
{
    [[ $# -eq 0 ]] &amp;&amp; exec grep -v ^$ | sed -e &#039;/[^ \t]\{1,\}/!d&#039;
}
nobb ()
{
    [[ $# -eq 0 ]] &amp;&amp; exec sed -e &#039;s/^[ \t]*//;s/[ \t]*$//&#039; -e &#039;/[^ \t]\{1,\}/!d&#039;
}
nobl ()
{
    [[ $# -eq 0 ]] &amp;&amp; exec sed -e &#039;s/^[ \t]*//&#039;
}
nobt ()
{
    [[ $# -eq 0 ]] &amp;&amp; exec sed -e &#039;s/[ \t]*$//&#039;
}
pd ()
{
    echo -e &quot;\n ${CC[15]} ${1:-DONE} $R\n\n&quot;
}
pm ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    local I=${1:-3};
    echo -en &quot;$R\n&quot;;
    case ${2:-1} in
        0)
            echo -en &quot;${CC[6]}&#45;- $X$R&quot;
        ;;
        1)
            echo -e &quot;${CC[2]}&gt;&gt;&gt; $X$I$R&quot;
        ;;
        2)
            echo -en &quot;${CC[4]} &gt; $X$I$R&quot;
        ;;
        3)
            echo -e &quot;${CC[4]} :: $X$I$R&quot;
        ;;
    esac
}
print_ascii_chart ()
{
    for i in `seq 0 256`;
    do
        echo -e &quot;\\0$(( $i/64*100 + $i%64/8*10 + $i%8 ))&quot;;
    done
}
procinfo1 ()
{
    PI=($(strace -s1 procinfo -a 2&gt;&amp;1|sed -e &#039;/^op/!d&#039; -e &#039;/pro/!d&#039; -e &#039;/= -1/d&#039;|sed -e &#039;s%o.*&quot;/proc/\(.*\)&quot;.*% \1%g&#039;));
    for i in ${PI[*]};
    do
        echo -e &quot;\n&#45;&#45;-===[  /proc/$i  ]\n&quot; &amp;&amp; cat /proc/$i &amp;&amp; echo -e &quot;\n\n&quot;;
    done
}
ps ()
{
    [[ -z &quot;$1&quot; ]] &amp;&amp; command ps -Hacl -F S -A f &amp;&amp; return;
    command ps &quot;$@&quot;
}
pss ()
{
    local U PPS PL PX PXX UUS=($(command ps uax|awk &#039;{print $1}&#039;|command tail -n +2|sort|uniq));
    UL=$((${#UUS[@]} - 1));
    exec 6&gt;&amp;1;
    exec &gt;~/proc.$$;
    ps aux | grep ${USER:0:3} | awk &#039;{print $2}&#039; | xargs -t -ipid cat /proc/pid/environ;
    for UX in $(seq 0 1 $UUS);
    do
        U=${UUS[$UX]};
        PPS=($(pgrep -u ${U}));
        PL=$((${#PPS[@]} - 1));
        for PX in $(seq 0 1 $PL);
        do
            PXX=${PPS[$PX]};
            echo -e &quot;\n\n\n&#45;&#45;&#45;&#45;- PROCESS ID: ${PXX} &#45;&#45;&#45;&#45;-\n\n&quot;;
            cat /proc/${PXX}/cmdline 2&gt;$N6 || echo;
            echo -e &quot;\n\n&quot;;
            command tree -Csuflapi /proc/Q/${PXX};
        done;
    done;
    exec 1&gt;&amp;6 6&gt;&amp;-;
    cat ~/proc.$$ | more
}
psu ()
{
    command ps -Hcl -F S f -u ${1:-$USER}
}
pwd ()
{
    command pwd -LP &quot;$@&quot;
}
rmb ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME dirnametoremove&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    ( ( command rm -rf &quot;$@&quot; &gt;&amp;$N6 ) &amp; )
}
set_window_title ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    echo -n -e &quot;\033]0;$*\007&quot;
}
sleeper ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &lt;process id&gt;&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    echo -en &quot;\n${2:-.}&quot;;
    while `command ps -p $1 &amp;&gt;$N6`; do
        echo -n &quot;${2:-.}&quot;;
        sleep ${3:-1};
    done;
    echo
}
stat1 ()
{
    local D=${1:-$PWD/*};
    stat -c %a\ %A\ \ A\ %x\ \ M\ %y\ \ C\ %z\ \ %N ${D} | sed -e &#039;s/ [0-9:]\{8\}\.[0-9]\{9\} -[0-9]\+//g&#039; | tr -d &quot;\`\&#039;&quot; | sort -r
}
stat2 ()
{
    local D=${1:-$PWD/*};
    stat -c %a\ %A\ \ A\ %x\ \ M\ %y\ \ C\ %z\ \ %N ${D} | sed -e &#039;s/\.[0-9]\{9\} -[0-9]\+//g&#039; | tr -d &quot;\`\&#039;&quot; | sort -r
}
tard ()
{
    [[ &quot;$#&quot; -lt &quot;2&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME dest-file (auto adds tgz&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    yn &quot;Tarring $2 to $1&quot; &amp;&amp; ( ( command tar -zcpf &quot;$1&quot; &quot;$2&quot; &gt;&amp;$N6 ) &amp; )
}
test_colors ()
{
    echo -e &quot;$R&quot;;
    ahave tput &amp;&amp; tput sgr0;
    for ((i=0; i&lt;=${#CC[@]} - 1; i++))
    do
        echo -e &quot;${CC[$i]}[$i]\n$R&quot;;
    done
}
uniq2 ()
{
    [[ -f &quot;$1&quot; ]] &amp;&amp; sed = $1 | sed -n &#039;G; s/\n/&amp;&amp;/; /^\([ -~]*\n\).*\n\1/d; s/\n//; h; P&#039;
}
uniqf ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    awk &#039;!($0 in a) {a[$0];print}&#039; &quot;$1&quot;
}
uptime1 ()
{
    command uptime | sed &#039;/.*,  \([0-9]*\) users,  load average: \(.*\)/!d; s//[ \2, \1 users ]/;q&#039;
}
vless ()
{
    [[ $# -eq 0 ]] &amp;&amp; command vim &#45;-cmd &#039;let no_plugin_maps = 1&#039; -c &#039;runtime! macros/less.vim&#039; -;
    [[ $# -eq 0 ]] || command vim &#45;-cmd &#039;let no_plugin_maps = 1&#039; -c &#039;runtime! macros/less.vim&#039; &quot;$@&quot;
}
wcdir ()
{
    [[ &quot;$#&quot; -gt &quot;0&quot; &amp;&amp; $1 == *-h* ]] &amp;&amp; ahelp $1 &amp;&amp; echo &quot;Usage: $FUNCNAME&quot; &amp;&amp; return 2;
    find ${1:-.} -mindepth 1 -type d -print0 | xargs -0 -iFF sh -c &#039;echo `find &quot;FF&quot;/ -type f 2&gt;/dev/null|wc -l;echo &quot;FF&quot;`&#039; | sort -n | sed -e &#039;s/^\([0-9]*\) \(.*\)$/ \1\t\2/g&#039;
}
yes_no ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME Question&quot; 1&gt;&amp;2 &amp;&amp; return 2;
    local a YN=65;
    echo -en &quot;${1:-Answer} [Y/n] ?&quot;;
    read -n 1 a;
    case $a in
        [yY])
            YN=0
        ;;
    esac;
    return $YN
}
yn ()
{
    [[ &quot;$#&quot; -lt &quot;1&quot; ]] &amp;&amp; echo &quot;Usage: $FUNCNAME &quot; 1&gt;&amp;2 &amp;&amp; return 2;
    local a YN=65;
    echo -en &quot;\n ${CC[6]}@@ ${1:-Q} $R$X[y/N] ?$R&quot;;
    read -n 1 a;
    echo;
    case $a in
        [yY])
            echo -n &quot;Y&quot;;
            YN=0
        ;;
        *)
            echo -n &quot;N&quot;
        ;;
    esac;
    return $YN
}</pre>
<p><a href="http://uploads.askapache.com/2009/08/askapache-bash_profile.png"><img src="http://uploads.askapache.com/2009/08/askapache-bash_profile.png" alt="Custom bash profile for Advanced Shell Users" title="askapache-bash_profile" width="571" height="2879" /></a></p>
<p><a href="http://www.askapache.com/linux-unix/bash_profile-functions-advanced-shell.html"></a><a href="http://www.askapache.com/linux-unix/bash_profile-functions-advanced-shell.html">Custom bash_profile for Advanced Shell Users</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/o3Z8JeXazO-geS9uabSjYGY04P8/0/da"><img src="http://feedads.g.doubleclick.net/~a/o3Z8JeXazO-geS9uabSjYGY04P8/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/o3Z8JeXazO-geS9uabSjYGY04P8/1/da"><img src="http://feedads.g.doubleclick.net/~a/o3Z8JeXazO-geS9uabSjYGY04P8/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=-67b1YGaPtY:VofqY4LVTRU:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=-67b1YGaPtY:VofqY4LVTRU:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=-67b1YGaPtY:VofqY4LVTRU:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=-67b1YGaPtY:VofqY4LVTRU:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=-67b1YGaPtY:VofqY4LVTRU:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=-67b1YGaPtY:VofqY4LVTRU:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=-67b1YGaPtY:VofqY4LVTRU:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/linux-unix/bash_profile-functions-advanced-shell.html/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		<feedburner:origLink>http://www.askapache.com/linux-unix/bash_profile-functions-advanced-shell.html</feedburner:origLink></item>
		<item>
		<title>Update: Best Free Online Banking</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/nkschTaxZmw/free-online-banking.html</link>
		<comments>http://www.askapache.com/making-money/free-online-banking.html#comments</comments>
		<pubDate>Thu, 22 Oct 2009 04:12:35 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Making Money]]></category>
		<category><![CDATA[Review]]></category>
		<category><![CDATA[Web Tools]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[Apache]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[Online Banking]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3548</guid>
		<description><![CDATA[<p><strong>WaMu Reincarnation!</strong></p>
<p>Man I was bummed about WaMu folding, they had the best banking site I've seen, and I've worked on a few myself.  And of course the biggest reason to love WaMu was that they actually paid YOU to borrow your money to lend to other people.  Can you even imagine that level of decency existing in the world?  It's been taken to such a low level by Chase I almost forget how to spell it.</p>

<p>So I picked up my October issue of <a href="http://www.wired.com/">Wired</a> to try and forget about such tragedies, and on the first page I flipped to was a 1/3 page advertisement for a bank that didn't beat around the bush at all.  No fine print of any kind, just loud and clear message that they will pay you to be their banking customer.  I wasted no time and quickly checked out the site, and within 5 minutes of landing on their homepage I was a customer, and a very happy one.  Even the name of this bank makes it clear they are not in the Microsoft Family Business with Chase and the other corporate pirates.</p>]]></description>
			<content:encoded><![CDATA[<p>Way back when I wrote about my <a href="http://www.askapache.com/webmaster/best-free-online-banking.html">favorite free banking which was WaMu</a>.  I also mentioned how JP Morgan Chase basically ripped me off with fees.  I to this day hate them for so easily putting into practice a policy of ripping people off.  So guess what happened since then?  WaMu went bankrupt due to getting way overextended with NorthWest Mortgages, and guess who swooped in and bought them?  JP Morgan Chase.  I cried myself to sleep for weeks because I knew if Chase now had control over my WaMu account is was only a matter of time before they start charging me money to let others borrow my money.</p>
<p>Today something great and something horrible happened within 5 minutes of each other.  I got a letter from Chase and opened it in front of my computer as i am always prepared for the worst when dealing with scum like that.  So I quickly scanned the friendly letter and almost exploded, it was a very polite letter happily informing me that my 1.9% APR on my credit card originally gotten from WaMu is from now on going to be <strong>29.99%</strong>.  That is not a typo.</p>
<h2><img src="http://uploads.askapache.com/2009/10/logo.png" alt="Update: Best Free Online Banking" title="logo" width="72" height="41" class="alignnone size-full wp-image-3550" /> ally bank</h2>
<p><img src="http://uploads.askapache.com/2009/10/Compare_panel.jpg" alt="Update: Best Free Online Banking" title="Compare_panel" width="737" height="180" class="alignnone size-full wp-image-3551" /></p>
<p>One of the main reasons I wanted to share this on my blog is because take a look at that website!  Someone sure knows how to make money, there is alot to admire about this site for you marketers and developers alike.  But seriously, getting a money-market account with no minimums, no monthly fees, no direct-deposit requirements, and none of all those other made-up pirate words is pretty unheard of.  If I was a journalist I would want to know who it is that is behind this.  But knowing how the banking industry is it&#8217;s probably their idea of a &#8220;lead-generating-tool&#8221; that they can later just buy outright and stick it to all the &#8220;leads&#8221;.   It&#8217;s basically the same setup as PayPal and their optional money market account that I use, except unlike paypal you can send and receive money without them taking a big chunk.  And who ever heard of such a thing as a no-penalty CD that doesn&#8217;t have hidden costs?</p>
<p class="anote">Have you heard congress wants to make it legally required to inform your blog readers if you are getting paid to promote a product?<br />Well don&#8217;t worry about me, I never have been paid and I literally just opened my account 20 minutes ago.  I&#8217;m just anal about not having to pay a bank to let them lend it to others.  ally vs Chase is the same thing as Open Source vs Microsoft.</p>
<p>Any other ideas?</p>
<p><a href="http://www.askapache.com/making-money/free-online-banking.html"></a><a href="http://www.askapache.com/making-money/free-online-banking.html">Update: Best Free Online Banking</a> originally appeared on <cite>AskApache.com</cite> </p>
<p><a href="http://feedads.g.doubleclick.net/~a/xyjsLVefa-9zsTX3Qn3RuCDizWw/0/da"><img src="http://feedads.g.doubleclick.net/~a/xyjsLVefa-9zsTX3Qn3RuCDizWw/0/di" border="0" ismap="true"></img></a><br/>
<a href="http://feedads.g.doubleclick.net/~a/xyjsLVefa-9zsTX3Qn3RuCDizWw/1/da"><img src="http://feedads.g.doubleclick.net/~a/xyjsLVefa-9zsTX3Qn3RuCDizWw/1/di" border="0" ismap="true"></img></a></p><div class="feedflare">
<a href="http://feeds.askapache.com/~ff/apache/htaccess?a=nkschTaxZmw:IPoB95Mo_Ek:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=nkschTaxZmw:IPoB95Mo_Ek:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=nkschTaxZmw:IPoB95Mo_Ek:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=nkschTaxZmw:IPoB95Mo_Ek:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=nkschTaxZmw:IPoB95Mo_Ek:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.askapache.com/~ff/apache/htaccess?a=nkschTaxZmw:IPoB95Mo_Ek:gIN9vFwOqvQ"><img src="http://feeds.feedburner.com/~ff/apache/htaccess?i=nkschTaxZmw:IPoB95Mo_Ek:gIN9vFwOqvQ" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.askapache.com/making-money/free-online-banking.html/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		<feedburner:origLink>http://www.askapache.com/making-money/free-online-banking.html</feedburner:origLink></item>
		<item>
		<title>Firefox Add-ons for Web Developers</title>
		<link>http://feeds.askapache.com/~r/apache/htaccess/~3/9k_EdNItqeQ/best-firefox-addons-webdev.html</link>
		<comments>http://www.askapache.com/firefox/best-firefox-addons-webdev.html#comments</comments>
		<pubDate>Mon, 19 Oct 2009 00:14:07 +0000</pubDate>
		<dc:creator>AskApache</dc:creator>
				<category><![CDATA[Cache]]></category>
		<category><![CDATA[Firefox]]></category>
		<category><![CDATA[Google]]></category>
		<category><![CDATA[Hacking]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Making Money]]></category>
		<category><![CDATA[Music]]></category>
		<category><![CDATA[Review]]></category>
		<category><![CDATA[SEO]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Web Design]]></category>
		<category><![CDATA[Web Tools]]></category>
		<category><![CDATA[Webmaster]]></category>
		<category><![CDATA[Windows]]></category>
		<category><![CDATA[401]]></category>
		<category><![CDATA[403 Forbidden]]></category>
		<category><![CDATA[500]]></category>
		<category><![CDATA[Accessibility]]></category>
		<category><![CDATA[Advanced]]></category>
		<category><![CDATA[Ajax]]></category>
		<category><![CDATA[Apache]]></category>
		<category><![CDATA[askapache]]></category>
		<category><![CDATA[Backups]]></category>
		<category><![CDATA[caching]]></category>
		<category><![CDATA[CommandLine]]></category>
		<category><![CDATA[console]]></category>
		<category><![CDATA[Cookies]]></category>
		<category><![CDATA[CSS]]></category>
		<category><![CDATA[debugging]]></category>
		<category><![CDATA[Dig]]></category>
		<category><![CDATA[DNS]]></category>
		<category><![CDATA[Email]]></category>
		<category><![CDATA[encryption]]></category>
		<category><![CDATA[feed]]></category>
		<category><![CDATA[Firebug]]></category>
		<category><![CDATA[Flash]]></category>
		<category><![CDATA[Forms]]></category>
		<category><![CDATA[GET]]></category>
		<category><![CDATA[Gmail]]></category>
		<category><![CDATA[HTTP Headers]]></category>
		<category><![CDATA[HTTPS SSL]]></category>
		<category><![CDATA[Login]]></category>
		<category><![CDATA[Networking]]></category>
		<category><![CDATA[Nice]]></category>
		<category><![CDATA[Pagerank]]></category>
		<category><![CDATA[password]]></category>
		<category><![CDATA[Performance]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Port]]></category>
		<category><![CDATA[post]]></category>
		<category><![CDATA[ram]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[SOCKS]]></category>
		<category><![CDATA[Source Code]]></category>
		<category><![CDATA[SPEED]]></category>
		<category><![CDATA[SSH]]></category>
		<category><![CDATA[SSH Tunnels]]></category>
		<category><![CDATA[SSI]]></category>
		<category><![CDATA[stat]]></category>
		<category><![CDATA[tmpfs]]></category>
		<category><![CDATA[trick]]></category>
		<category><![CDATA[Username]]></category>
		<category><![CDATA[Web Development]]></category>
		<category><![CDATA[Wireshark]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[YSlow]]></category>

		<guid isPermaLink="false">http://www.askapache.com/?p=3301</guid>
		<description><![CDATA[<p><a href="http://www.askapache.com/firefox/best-firefox-addons-webdev.html" class="IFL"><img src="http://uploads.askapache.com/2009/10/askapache-firefox-cache-116x102.png" alt="askapache favorite addons" title="askapache favorite addons" width="116" height="102" /></a><a href="https://addons.mozilla.org/en-US/firefox/collection/advanced-webdevelopment">Advanced Web Development by AskApache</a> is a <dfn title="Collections are groups of related add-ons assembled for easy sharing">Firefox Collection</dfn> I created since I'm always trying new Addons out and using multiple computers and I wanted a quick and easy way to install my favorite's and keep a running list.  Firebug, YSlow, LastPass, and Web Developer are the only ones I always use regularly.<br /><br />I like the idea of the last.fm but it's not as powerful as the site, which is awesome.  <em>Lately listening to <a href="http://www.last.fm/listen/artist/Kings%2Bof%2BLeon/similarartists">Kings of Leon Radio</a>...</em><br class="C" /></p>]]></description>
			<content:encoded><![CDATA[<p><a class="IFL" href="https://addons.mozilla.org/en-US/firefox/collection/advanced-webdevelopment"><img src="https://addons.mozilla.org/en-US/firefox/images/collection_icon/27412/1253649941" title=" web cache" alt="Firefox Add ons for Web Developers" /></a><a href="https://addons.mozilla.org/en-US/firefox/collection/advanced-webdevelopment">Advanced Web Development by AskApache</a> is a <dfn title="Collections are groups of related add-ons assembled for easy sharing">Firefox Collection</dfn> I created for myself to make finding and installing my favorite Firefox Add-ons simple and easy.</p>
<h2>My Setup</h2>
<p><img class="IFL" src="http://uploads.askapache.com/2009/10/askapache-firefox-cache.png" alt="askapache favorite addons" title="askapache favorite addons" width="283" height="250" />As this screenshot shows, I only use a handful of add-ons at a time.  These buttons allow me to clear the DNS/Cookies/Cache for whichever site I&#8217;m on when I click it.  Very very helpful for me as a web designer.  The 4th button there is just a restart button.  Other than those, Firebug, YSlow, LastPass, and Web Developer are the only ones I always use regularly.</p>
<p>I like the idea of the last.fm but it&#8217;s not as powerful as the site, which is awesome.  Lately I&#8217;ve been listening to <a href="http://www.last.fm/listen/artist/Kings%2Bof%2BLeon/similarartists">Kings of Leon Radio</a>&#8230; <br class="C" /></p>
<h2>Slow Firefox</h2>
<p><strong>The more add-ons you have</strong>, disabled or not, the slower Firefox is. (<em>unless you are running your profile folder in TMPFS</em>).   Also, bookmarks and settings like that have a performance hit.  I have been using Firefox since it launched way back when, and I have always kept my bookmarks when moving to new machines and new installations..  So with over 5 thousand bookmarks I finally did some debugging and discovered that was a huge cause of Firefox acting slow.  Now I am trying to migrate them all over to Google&#8217;s Gmarks, which knowing Google will be awesome eventually.</p>
<h2>Multiple Firefox Installations, Sorta</h2>
<p>The solution to all these problems is to use <strong>separate Firefox profiles</strong> which use separate folders to store your profile-specific extensions and settings.  So I have profiles with upwards of 40 Addons installed and enabled, and another profile that is built for speed&#8230; It&#8217;s very very slow to be running Firebug and have multiple tabs open..  You can use the profilemanager to load them specific profiles from the command line.  I personally use separate icons on my Windows Quick Launch that I just modified the shortcut pointing to firefox to also have the profile commandline.   Note also that you can have multiple profiles open and running simultaneously.. This lets you do some crazy networking and other random hacks like having many Firefox instances running each of which is configured to use a separate SOCKS Proxy or network interface, so you can really open up those pipes for some intense txrx.</p>
<p>You can do some very powerful things with Firefox that most people are unaware of, if you are interested start with these:</p>
<ul>
<li><a href="https://developer.mozilla.org/en/Setting_up_extension_development_environment">Setting up an extension development environment</a></li>
<li><a href="https://developer.mozilla.org/en/Command_Line_Options">Firefox Command Line Options</a></li>
</ul>
<hr class="C" />
<h3>About This Collection</h3>
<p>Web Development Add-ons for Advanced Web Developers.  I personally use these to work on Sites, Servers, WordPress, Javascript, PHP, CSS, XHTML, validation, page-loading, SEO, optimizing, and much more.  <a href="https://addons.mozilla.org/en-US/firefox/users/login?to=en-US%2Ffirefox%2Fcollection%2Fadvanced-webdevelopment%3Fadvancedsearch%3D1%26show%3D100">Add this collection</a>.</p>
<p><strong>Created by:</strong><a href="https://addons.mozilla.org/en-US/firefox/user/145961">AskApache</a></p>
<p><strong>Updated:</strong>September 22, 2009 </p>
<h3>Share this Collection</h3>
<ul>
<li class="digg"><a href="https://addons.mozilla.org/en-US/firefox/collections/share/advanced-webdevelopment?service=digg">Digg this!</a></li>
<li class="facebook"><a href="https://addons.mozilla.org/en-US/firefox/collections/share/advanced-webdevelopment?service=facebook">Post to Facebook</a></li>
<li class="delicious"><a href="https://addons.mozilla.org/en-US/firefox/collections/share/advanced-webdevelopment?service=delicious">Add to Delicious</a></li>
<li class="myspace"><a href="https://addons.mozilla.org/en-US/firefox/collections/share/advanced-webdevelopment?service=myspace">Post to MySpace</a></li>
<li class="friendfeed"><a href="https://addons.mozilla.org/en-US/firefox/collections/share/advanced-webdevelopment?service=friendfeed">Share on FriendFeed</a></li>
<li class="twitter"><a href="https://addons.mozilla.org/en-US/firefox/collections/share/advanced-webdevelopment?service=twitter">Post to Twitter</a></li>
</ul>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/13316?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">History Tree</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/13316/1254409345" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Find any page you have visited quickly and easily. Shows your browsing history as a tree of tabs, with thumbnail screenshots of the web-pages in every tab you have opened. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/4882?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab Scope</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Preview and navigate tab contents through popup. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1480?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab Control</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Take control of your tabs!  Purposely lightweight extension with the following features&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5000?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">ShareThis</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5000/1248389010" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />ShareThis makes sharing any online content quick and easy. The ShareThis plugin allows you to share to any contact via email, text message, Facebook, Twitter and more.  You can also store your shares for later to reshare with the ShareThis ShareBox. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/12377?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FirePalette</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/12377/1244736178" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Adds a color picker to Firebug&#8217;s CSS panel. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/13000?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab History Menu</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/13000/1252809752" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />When click on the selected tab, a history menu corresponding to it will display. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/8426?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">SyncPlaces</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/8426/1252087590" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Synchronizes your bookmarks, passwords and password exceptions between browsers. Uses your own (or third party) web or ftp server so you have complete control and privacy. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10704?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">CSS Usage</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10704/1255464704" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Firebug extension to view which CSS rules are actually used. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/9641?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Inline Code Finder for Firebug</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/9641/1246025189" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Inline Code Finder is an add-on to Firebug, to be able to find HTML elements<br class="C" /></p>
<blockquote class="publisher-comment"><p>Provides some additional capabilities to firebug to find inline code as opposed to external files.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/4723?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Save Complete</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Saves a webpage completely, providing a better alternative to the flawed built-in save functionality of Firefox. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Another of my personal favorites, modifies the &#8220;Save complete page&#8221; option of firefox to truly be more complete, I don&#8217;t understand why firefox doesn&#8217;t already do this.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10615?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FireDownload</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10615/1249999245" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />The FireDownload extension for Firefox and Wyzo lets you manage and accelerate your web downloads up to 10x faster! With FireDownload, download acceleration is seamlessly displayed within the downloads window. Try the ultimate download accelerator! <br class="C" /></p>
<blockquote class="publisher-comment"><p>Pretty nice and unobtrusive download enhancer.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/13255?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Xmarks BYOS Edition</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/13255/1248393038" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Bookmark Sync &#8220;Bring Your Own Server&#8221; Edition (BYOS). For expert users who wish to sync their bookmarks and passwords using their own FTP or WebDAV server. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/13128?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FormBug</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />An extension to Firebug to make dealing with forms easier <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/13135?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Widerbug</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/13135/1247888469" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Firebug Evolved. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/11588?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">SyntaxHighlighter</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />a syntax highlighter, based on SyntaxHighlighter(http://code.google.com/p/syntaxhighlighter/), support lots of program languages. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Adds syntax highlighting, somewhat intensive.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2318?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Total Validator</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2318/1252747670" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Perform multiple validations and take screen shots in one go. This 5-in-1 validator works with external, internal, or local web pages using the Total Validator service or local copy of the desktop tool&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/115?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">ReloadEvery</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/115/1250716156" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Reloads web pages every so many seconds or minutes. The function is accessible via the context menu (menu you get when you right click on a web page) or via a drop down menu on the reload button &#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Love this plugin, replaces the reload button with a look-alike button with a drop-down menu that lets you enable automatic reloading of a tab (or all tabs) and set the number of seconds between reloads.  I&#8217;ve found it very useful for checking cookie behaviour and cache setups, its also nice if you want to keep checking a page for updates.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1985?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Window Resizer</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Resize your browser to various standard resolution sizes&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Quickly resize your window to the common sizes to see what a site looks like for users with that resolution.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/4415?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Font Finder</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Get all CSS styles of selected text in Firefox / Thunderbird&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Locate the fonts that are in use on a webpage.  Small and unobtrusive.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/12632?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FireQuery</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/12632/1248402877" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Firebug enhancements for jQuery (requires Firebug 1.3+) <br class="C" /></p>
<blockquote class="publisher-comment"><p>Adds jquery support, I usually keep disabled even though I personally use jquery for web development.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5362?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Alexa Sparky</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5362/1255562428" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Alexa Internet&#8217;s official add-on for Firefox!  Get Alexa data in your status bar. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Shows the alexa rank of a site, I like it but it does make new HTTP requests for each page, so I disable it alot for privacy or speed.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5392?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Dust-Me Selectors</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5392/1246551563" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Finds unused CSS selectors. <br class="C" /></p>
<blockquote class="publisher-comment"><p>One of the newer add-ons I&#8217;ve been using.  Lets you find which CSS rules are actually in use on a page, thus helping you to minimize and streamline CSS.  Very cool but it is a little resource intensive so by default I keep it disabled.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/11249?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">ToggleUseDocColors</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Toggles Tools-&gt;Options-&gt;Content-&gt;Colors:Allow pages to choose their own colors&#8230; option with a single keystroke (Ctrl+M) <br class="C" /></p>
<blockquote class="publisher-comment"><p>Use the documents colors or other.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3606?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FoxTor</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />FoxTor: Anonymous Web Browsing using the encrypted TOR network&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10434?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Bing</a></h4>
<p> <img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10434/1247527217" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />This is the only officially supported Bing add-on, provided by the Bing team in Microsoft. Bing is a search engine that finds and organizes the answers you need so you can make faster, more informed decisions. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/9640?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Inline Code Finder</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/9640/1245858044" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Inline Code Finder is a tool to traverse through all elements in a web page, and when it finds a HTML element with any of these, it will highlight them: * Inline JavaScript events * Inline style * javascript: links <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2648?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">MM3-ProxySwitch</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2648/1233685187" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />In the Firefox Browser (and other Mozilla programs) you can per default configure only the setting for one internet connection. With the MM3-ProxySwitch you can manage different configurations and simply switch over between these. <br class="C" /></p>
<blockquote class="publisher-comment"><p>If like me you often connect to websites by proxying firefox through SSH Tunnels, then you can use this MM3-ProxySwitch add-on to run 3 different instances of firefox (by using multiple firefox profiles) that EACH use a different Proxy.  This is useful if you want to MAX out your download speed by downloading using multiple tunnels to do the work. </p>
<p>            Also useful for just plain multiple proxy configurations, very easy, and super extremely unobtrusive and low-resource intensive.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6683?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Firecookie</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/6683/1251484013" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Firecookie is an extension for Firebug that makes possible to view and manage cookies in your browser <br class="C" /></p>
<blockquote class="publisher-comment"><p>One of my personal favorites, adds a tab to firebug that lets you view live cookies being set, deleted, and updated, and lets you edit, and delete cookies of a page LIVE.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/9780?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">RESTClient</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/9780/1250817670" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />RESTClient is a firefox extension use to visit and test RESTful/WebDav services. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5403?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Java Console 6.0.02</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5403/1189002765" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Java Console Extension for Java SE 1.6.0_02 (version 6 update 2). <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2325?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">RSS Ticker</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />RSS Ticker loads your Live Bookmarks and scrolls their entries across your screen while you surf. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Amazingly awesome add-on that scrolls rss feeds across a small area, helpful to keep track of various feeds and your own sites feeds.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6535?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab Sidebar</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/6535/1244499111" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Displays previews of your tabs in your sidebar. <br class="C" /></p>
<blockquote class="publisher-comment"><p>I like this one more than the tab preview add-ons, lets me find a tab quickly but only when I want by opening the sidebar.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/12065?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">CryptoFox</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/12065/1255638751" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />CryptoFox is an encryption/decryption tool for Mozilla Firefox, with dictionary attack support for cracking MD5 passwords. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/9027?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Bookmark Current Tab Set</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Adds options to quickly bookmark all tabs in a window and store them in a bookmark folder that is given the date (and optionally the time) as its name. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3362?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Update Scanner</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3362/1252360045" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Monitors web pages for updates. Useful for websites that don&#8217;t provide Atom or RSS feeds. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/139?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Image Zoom</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/139/1231445959" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Adds zoom functionality for images&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Simple image zooming functionality.  Small and useful add-on.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3780?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FaviconizeTab</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3780/1218612666" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />This extension adds a new &#8220;FaviconizeTab&#8221; option to the context menu of the tab&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Nice to Faviconize your most-often-used sites</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2489?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">CacheViewer</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />This extenion is GUI Front-end of &#8220;about:cache&#8221;&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Just a shortcut to the about:cache area.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6366?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FireGestures</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/6366/1254150116" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />A customizable mouse gestures extension which enables you to execute various commands and user scripts with five types of gestures. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/7189?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Firebug Net History Panel Overlay</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Adds history functionality to firebug net panel. Requires Firebug 1.2.0b4 or 1.2.0b6 For Firebug versions 1.1.* please use Net Panel Add-on Version 0.2.1 <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3880?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Add Bookmark Here ²</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3880/1253393237" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Add a menuitem &#8220;Add Bookmark Here&#8230;&#8221; to Bookmarks&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5914?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">DNS Cache</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5914/1246397200" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Allows you to disable and enable the DNS Cache of Firefox <br class="C" /></p>
<blockquote class="publisher-comment"><p>The final caching add-on that I absolutely LOVE.  Lets you add anywhere on your toolbar to clear the DNS cache of firefox.  I have  this, clear cache, and clear cookies next to each other on the far left of my bookmarks toolbar, I use them ALOT.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/7907?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Manage Folders</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/7907/1248060550" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Places a &#8220;Manage Folder&#8221; item on the context menu of bookmark folders, which opens the &#8220;Places Organizer&#8221; expanded to that folder. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2214?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">View Dependencies</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />View Dependencies adds a tab to the Page Info window, in which it lists all the files which were loaded to show the current page. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2275?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Torbutton</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2275/1249863832" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Torbutton provides a button to securely and easily enable or disable the browser&#8217;s use of Tor. It is currently the only addon that will safely manage your Tor browsing to prevent IP address leakage, cookie leakage, and general privacy attacks. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Quick way to switch firefox to use the TOR network (I recommend the free vidalia suite) which is useful for web developers that rely on an IP address in certain programming and setups.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5447?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab Kit</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5447/1249227762" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Tab grouping, vertical tab tree, multi-rows, and various tweaks for power users. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3559?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">QuickRestart</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3559/1241624360" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Ever needed to restart Firefox after enabling or disabling an extension, switching to a new theme, or modifying configuration files (such as userChrome.css or user.js)? This simple extension adds a &#8220;Restart Firefox&#8221; item to the &#8220;File&#8221; menu. You can also use the Ctrl+Alt+R keyboard shortcut, or the included toolbar button. <br class="C" /></p>
<blockquote class="publisher-comment"><p>A button you can place anywhere that restarts the browser just like you do after updating add-ons.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1759?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Organize Status Bar</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />This extension will enable you to organize your status bar icons.  You can now rearrange or remove any item (icon or text) in the Firefox status bar.  If your status bar is full and cluttered like mine was, give this a try. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Lets you rearrange the items on the status bar.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/722?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">NoScript</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/722/1255474235" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />The best security you can get in a web browser! Allow active content to run only from sites you trust, and protect yourself against XSS and Clickjacking attacks. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2109?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FEBE</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2109/1255569901" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />FEBE (Firefox Environment Backup Extension) allows you to quickly and easily backup your Firefox extensions.  In fact, it goes beyond just backing up &#8212; It will actually rebuild your extensions individually into installable .xpi files.  Now you can easily synchronize your office and home browsers. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Very helpful and well-designed add-on that lets you backup your entire firefox, or individual add-ons, or both!</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10897?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Check Places</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10897/1255544495" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Checks your bookmarks are valid and the pages still exist. Also checks for duplicates and for empty folders and can restore missing favicons. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1027?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">All-in-One Sidebar</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1027/1248433103" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />All-in-One Sidebar (AiOS) is an award-winning sidebar control, inspired by Opera&#8217;s. It lets you quickly switch between sidebar panels, view dialog windows such as downloads, extensions, and more in the sidebar, or view source or websites in the sidebar. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2888?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">GMarks</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />GMarks helps you sync &#038; manage your bookmarks with Google Bookmarks&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/11950?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Add-on Collector</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/11950/1252025520" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />There&#8217;s a new way to manage and find favorite add-ons. Comment, share, and sync collections, all from your browser. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Lets you get updates and makes it very easy to browse a collection such as this one.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2144?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Advanced Dork:</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2144/1249684650" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Advanced Dork: gives quick access to Google&#8217;s Advanced Operators directly from the context menu&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Very unobtrusively makes the advanced google search operators available.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2032?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Yahoo! Toolbar</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2032/1253720246" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Use Yahoo! and the web faster, safer, and easier with new mail notification, search suggestions, online bookmarks, free spyware scanning, and more&#8230; Save time with the new Yahoo! Toolbar 2.0, now in beta at toolbar.yahoo.com/beta. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3102?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Email This!</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3102/1253158256" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Email This! will send your recipient the link, title, &#038; highlighted text of the page you are viewing using GMail, Google Apps GMail, Yahoo, and Stand-Alone Mail Clients like Outlook Express, Thunderbird, &#038; More! If you hate toolbar buttons don’t fret because I&#8217;ve included a right-click pop-up menu and access keys! <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2062?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab To Window</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2062/1244572621" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Open a tab in a new window&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>I have wanted this type of functionality for soo long.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2323?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Cache View</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Cache View is a Firefox extension that displays Google&#8217;s Cache, Coral&#8217;s Cache, and Wayback Machine&#8217;s Cache cache of an open tab or selected link via a right-click or the Tools menu. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Useful to notice how often a page on your site is crawled and cached by these engines.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6984?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Lazarus: Form Recovery</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/6984/1252590349" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Never lose anything you type into a web form again! Lazarus securely auto-saves all forms as you type, so after a crash, server timeout, or whatever, you can go back to the form, right click, &#8220;recover form&#8221;, and breathe a sigh of relief. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Saves your form data securely as you enter it, and provides a way to recover that form data if your firefox crashes (more likely windows crashes) and that way you won&#8217;t lose anything you already entered.  This will slow down firefox alot though.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6132?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tab Preview</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Preview tab contents on mouseover <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6937?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Multirow Bookmarks Toolbar</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Multi Row Bookmarks Toolbar.<br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2517?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Googlepedia</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Shows you a relevant Wikipedia article along with your search results. Clicking links in the article will trigger new Google searches, making it a very useful research tool&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Adds wikipedia results right next to google results, very helpful to keep an eye on what is authoritative, and often get the best information fast.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1237?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">QuickJava</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Allows quick enable and disable of Java and Javascript from&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3082?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Undo Closed Tabs Button</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3082/1244495823" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Tired of going to History -&gt; Recently Closed Tabs just to undo a closed tab? Then this extension is for you!  This extension allows you to undo closed tabs via a toolbar and/or tab bar button or the right-click context menu. <br class="C" /></p>
<blockquote class="publisher-comment"><p>One of my personal favorites, adds back the most recently closed tab, very helpful.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10618?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Faviconiac Search Engines</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10618/1247849922" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Adds PNG favicons to some search engines and web directories, such as Google, Yahoo, Bing, Ask, Altavista, Wikipedia, AOL, Dmoz, Alexa, del.icio.us and others. <br class="C" /></p>
<blockquote class="publisher-comment"><p>This is helpful to get a better feel for search engine results by adding their sites favicon to the search results page, is somewhat HTTP Request intensive however.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3928?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Bookmark This Page Plus</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3928/1247125860" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Adds a menu item in each sub folder of the bookmarks menu to bookmark the current page. Just as seen in the Opera browser. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1595?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Remove Cookie(s) for Site</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1595/1214859152" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />A very simple extension to remove all the cookies of currently opened site. It adds an option to the Right Click menu of the page, and a toolbar button to perform this operation. It displays the status of operation in the status bar. <br class="C" /></p>
<blockquote class="publisher-comment"><p>This is invaluable, it removes all the cookies from whichever domain you are currently viewing.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/967?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Modify Headers</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Add, modify and filter http request headers.  You can modify the user agent string, add headers to spoof a mobile request (e.g. x-up-calling-line-id) and much more.  Take a look at the help tab of the Modify Headers window&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Pretty awesome, lets you modify the HTTP Headers your browser is sending, useful to check accessibility, server settings, language settings, etc.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2625?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">OPML Support</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />OPML Support adds OPML import/export functionality to the Firefox Bookmarks manager. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6647?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">HttpFox</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />An HTTP analyzer addon for Firefox <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/8879?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FoxTab</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/8879/1249840764" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />3D in your browser!  FoxTab brings innovative 3D functionality to your Firefox. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Super awesome cool.  If your machine is fast this is a really helpful add-on.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/655?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">View Source Chart</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/655/1246405984" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />View Source In Color-Coded Chart Get V2.8 w/ a brand new feature from jennifermadden.com <br class="C" /></p>
<blockquote class="publisher-comment"><p>One of my long-time, all-time favorites that lets you view the source code of a website, but in a color-coded and formatted view.  Very nice and helpful for (X)HTML developers.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/4072?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Smart Bookmarks Bar</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/4072/1234555016" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Not enough place on your bookmarks bar ?&#8230; Smart Bookmarks Bar extension comes right here by hiding bookmarks names and only showing icons. Bookmark names will be displayed on mouse over. <br class="C" /></p>
<blockquote class="publisher-comment"><p>For those who frequently use the bookmarks in the firefox bookmarks toolbar, this is a great way to show more in a cleaner way.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1433?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Extended Statusbar</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1433/1246438548" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />A Statusbar with speed, percentage, time and loaded size (similar to Opera&#8217;s one) <br class="C" /></p>
<blockquote class="publisher-comment"><p>Provides much more information unobtrusively on your statusbar, very cool!</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10300?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Email Yourself!</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10300/1253228434" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Email Yourself! allows you to email yourself the link, title, and a selected summary of the webpage you are viewing using GMail. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/125?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">SwitchProxy Tool</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />SwitchProxy lets you manage and switch between multiple proxy configurations&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2499?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">LiveClick</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Adds feed reading, notifications, favicons, and other enhancements to Live Bookmarks. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/7314?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Places&#8217; Tooltips</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />This addon enhances all the tooltips in Firefox. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/11173?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Multi Smart Search</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />&#8220;Multi smart search&#8221; displays a new context menu including all the installed search engine. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/9275?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">SortPlaces</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/9275/1252087512" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Sorts your bookmarks in a variety of ways. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/433?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Flashblock</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/433/1247913103" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Never be annoyed by a Flash animation again! Blocks Flash so it won&#8217;t get in your way, but if you want to see it, just click on&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Lets you block flash for all/specific websites/domains, which is pretty nice capability to test both your sites for non-flash viewers, and speeds up firefox.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6249?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Google Toolbar</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/6249/1237314369" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Take the power of Google with you anywhere on the Web <br class="C" /></p>
<blockquote class="publisher-comment"><p>A great add-on that lets you use hundreds of google tricks and tools.  Very helpful but also makes a lot of background HTTP requests so privacy-conscious or speed-freaks will want it disabled.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6622?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">DOM Inspector</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />DOM Inspector is a tool that can be used to inspect and edit the live DOM of any web document or XUL application. The DOM hierarchy can be navigated using a two-paned window that allows for a variety of different views on the document and all nodes within. Note:  This add-on depends on binary changes to Firefox, and will not work with Firefox 2. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Way to inspect the DOM of a page, useful for web developers.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6459?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Stay-Open Menu</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/6459/1250004873" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Enables multiple selections from Bookmarks Menu,  History Menu, or Smart Location Bar (awesomebar)  dropdown list, without reopening menu or using sidebar. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/710?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Menu Editor</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Customize application menus: Rearrange or remove menuitems from the main context menu (right-click menu) and main menubar (File Edit View etc.) <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/4838?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Multiple Tab Handler</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/4838/1251873082" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Provides feature to close multiple tabs. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1815?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Console²</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1815/1246698544" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Console² (pronounced Console Squared or Console Two) replaces the JavaScript Console with what could be the next generation Error Console. From v0.5 includes the Console Filter extension previously available separately from the Console² website. <br class="C" /></p>
<blockquote class="publisher-comment"><p>An advanced java script console.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/6271?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Bookmark Previews</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Bookmark Previews adds an album view and thumbnail view to the bookmarks manager. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Now this one is what I call genius.  Lets you view previews of your bookmarks!  Great if like me you have over a thousand bookmarks.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/8542?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">LastPass Password Manager</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/8542/1252161868" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />LastPass is a free online password manager and Form Filler that makes your web browsing easier and more secure.   LastPass supports IE and Firefox as Plugins (Opera, Safari, Chrome, iPhone, Opera Mini via Bookmarklets), allows you to import from every major password storage vendor and export too, captures passwords that other managers won&#8217;t including many AJAX forms, and allows you to make strong passwords easily.  Your sensitive data is encrypted _locally_ before upload so even LastPass cannot get access to it.  One Time Passwords &#038; Screen Keyboard help protect your master password. <br class="C" /></p>
<blockquote class="publisher-comment"><p>What can I say, this add-on is in my top 10 for sure, and I recommend it to all my friends and even my family.  Lets me create very secure passwords for sites that I don&#8217;t have to remember because lastpass remembers them for me, and stores them encrypted on both a usb medium I keep, and on their servers.  So when I use someone elses computer or reinstall firefox, I have all my usernames and passwords, and its just sooooooooooooooooo useful.  Get this add-on, it truly is a secure way to only have to remember 1 password from now on, thus LastPass.  The last password you need.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1956?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tabs Open Relative</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1956/1211284492" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Tabs Open Relative makes all new tabs open to the right of the current tab, rather than at the far right of the tab bar (optionally this only applies to links). <br class="C" /></p>
<blockquote class="publisher-comment"><p>This stops that annoying default of opening tabs wayy on the right.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/10909?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Coral IE Tab</a></h4>
<p> <img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/10909/1255054707" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />An enhanced version of IE Tab which enables you to use the embedded IE engine within tabs of Mozilla Firefox. It supports Adblock Plus in IE, and can sync cookies between IE and Firefox. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/966?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Tamper Data</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Use tamperdata to view and modify HTTP/HTTPS headers and post parameters&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Useful for checking form validation and security, lets you tamper data! lol</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/5369?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">YSlow</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/5369/1253220367" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />YSlow analyzes web pages and why they&#8217;re slow based on Yahoo!&#8217;s rules for high performance web sites. YSlow uses Yahoo!&#8217;s Smush.it service, which is subject to Smush.it Terms of Use: http://info.yahoo.com/legal/us/yahoo/smush_it/smush_it-4378.html <br class="C" /></p>
<blockquote class="publisher-comment"><p>One of the top 3 most important and helpful add-ons for firefox.  Web Developers who don&#8217;t use this one are simply irresponsible.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/539?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">MeasureIt</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Draw out a ruler to get the pixel width and height of any elements on a&#8230; <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/271?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">ColorZilla</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/271/1234546689" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Advanced Eyedropper, ColorPicker, Page Zoomer and other colorful goodies&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>A must-have add-on for anyone using CSS or developing websites, very amazing, highly capable add-on.  The one issue is that is is somewhat of a resource-hog.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/748?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Greasemonkey</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/748/1253968926" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Allows you to customize the way a webpage displays using small bits of JavaScript. &#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Lets you use user-contributed javascripts (or your own of course) that modifies the behavior and/or appearance of many different websites.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/684?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FireFTP</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/684/1254121244" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />FireFTP is a free, secure, cross-platform FTP client for Mozilla Firefox which provides easy and intuitive access to FTP servers. <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/7943?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Pixel Perfect</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/7943/1254757574" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Pixel Perfect is a Firefox/Firebug extension that allows web developers and designers to easily overlay a web composition over top of the developed HTML. * Requires Firebug <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/60?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Web Developer</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/60/1252695377" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />The Web Developer extension adds a menu and a toolbar with various web developer tools. <br class="C" /></p>
<blockquote class="publisher-comment"><p>This add-on is 1 of the top 2 most important add-ons for web developers.  The other is firebug.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1843?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Firebug</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1843/1254249333" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Firebug integrates with Firefox to put a wealth of development tools at your fingertips while you browse. You can edit, debug, and monitor CSS, HTML, and JavaScript live in any web page&#8230; Firebug 1.4 requires Firefox 3.0 or higher. <br class="C" /></p>
<blockquote class="publisher-comment"><p>By far, without a doubt, the single most important and valuable add on for ANY web developer.  This is the one that is definitely required.  The features are too numerous to name here.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3829?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Live HTTP Headers</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3829/1245295166" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />View HTTP headers of a page and while&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>Very helpful for those that don&#8217;t have and use wireshark.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/2464?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FoxyProxy</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/2464/1254948830" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />FoxyProxy is an advanced proxy management tool that completely replaces Firefox&#8217;s limited proxying capabilities. It offers more features than SwitchProxy, ProxyButton, QuickProxy, xyzproxy, ProxyTex, TorButton, etc. <br class="C" /></p>
<blockquote class="publisher-comment"><p>The most complete proxifying tool for firefox, multiple configurations possible.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/321?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">SearchStatus</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/321/1254725500" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Display the Google PageRank, Alexa rank, Compete ranking and SEOmoz Linkscape mozRank anywhere in your browser, along with fast keyword density analyser, keyword/nofollow highlighting, backward/related links, Alexa info and more. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Adds a very unobtrusive way to check the pagerank, and several other SEO statistics but only when you click a button (if configured that way) very helpful occasionally.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/201?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">DownThemAll!</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/201/1253178038" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />The first and only download manager/accelerator built inside Firefox! <br class="C" /></p>
<blockquote class="publisher-comment"><p>Very nice, easy, fast, and unobtrusive add-on that lets you download all files of a certain type to a certain save location, lets you use builtin filters or configure your own using basic REGEX.  Very helpful.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/1801?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Clear Cache Button</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/1801/1248704772" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Adds a clear cache toolbar button. After installing the extension, find the clear cache button in the toolbar customization&#8230; <br class="C" /></p>
<blockquote class="publisher-comment"><p>A button you can add to your toolbar that clears your firefox cache (not cookies or history) which is invaluable for web developers.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/12006?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Wolfram Alpha Google</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/12006/1254285310" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Display Wolfram Alpha results in Google searches. No need to switch search engines when you can use both at once! <br class="C" /></p>
<blockquote class="publisher-comment"><p>The new search is a glimpse at the future of computing.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/3895?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Personal Menu</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/3895/1253278678" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />&#8220;Menus Toolbar&#8221; item is now available in Toolbar Context Menu and you may hide it forever! <br class="C" /></p>
<blockquote class="publisher-comment"><p>Lets you go beyond firefox builtin menu editing and create a custom toolbar.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/7613?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Jiffy</a></h4>
<p><img src="https://addons.mozilla.org/img/default_icon.png" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title="default icon web cache" />Adds a new panel to Firebug for displaying timing measurements for JavaScript applications. <br class="C" /></p>
<blockquote class="publisher-comment"><p>Adds the ability to time or profile your javascript, I usually leave disabled.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/9603?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">FireRainbow</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/9603/1248403194" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Javascript syntax highlighting for Firebug 1.3+ <br class="C" /></p>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/7684?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">Fire.fm</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/7684/1254412991" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />Fire.fm gives you access to the extensive music library on Last.fm. Last.fm gives free radio to the US, UK, and Germany, plus subscriber-based service to the rest of the world. Listen to your favorite music and discover new artists in the process. <br class="C" /></p>
<blockquote class="publisher-comment"><p>What would work be without free streaming music that is customizable and recommends music based on your history.  Conveniently can be added to your status bar, or your toolbar.</p>
</blockquote>
</div>
<hr class="C" />
<div class="item-info">
<h4><a href="https://addons.mozilla.org/en-US/firefox/addon/138?collection_uuid=2f6fd413%26%2345%3B1146%26%2345%3Bad49%26%2345%3B1cca%26%2345%3B84102bff60fb">StumbleUpon</a></h4>
<p><img src="https://addons.mozilla.org/en-US/firefox/images/addon_icon/138/1248392473" alt="Firefox Add ons for Web Developers" height="32" width="32" class="IFL" title=" web cache" />StumbleUpon discovers web sites based on your interests, learns what you like and brings you more. <br cla