<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	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/"
	>

<channel>
	<title>Sean&#039;s Blog &#187; mod_python</title>
	<atom:link href="http://seanbehan.com/tag/mod_python/feed/" rel="self" type="application/rss+xml" />
	<link>http://seanbehan.com</link>
	<description>Web Programming, Ruby on Rails, Wordpress, PHP from Burlington, Vermont</description>
	<lastBuildDate>Wed, 18 Jan 2012 21:44:54 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Mod_Python and Web.py on Ubuntu</title>
		<link>http://seanbehan.com/python/mod_python-and-web-py-on-ubuntu/</link>
		<comments>http://seanbehan.com/python/mod_python-and-web-py-on-ubuntu/#comments</comments>
		<pubDate>Wed, 09 Dec 2009 16:17:16 +0000</pubDate>
		<dc:creator>bseanvt</dc:creator>
				<category><![CDATA[Python]]></category>
		<category><![CDATA[.htacess]]></category>
		<category><![CDATA[apache]]></category>
		<category><![CDATA[framework]]></category>
		<category><![CDATA[modpython_gateway]]></category>
		<category><![CDATA[mod_python]]></category>
		<category><![CDATA[mod_rewrite]]></category>
		<category><![CDATA[web.py]]></category>

		<guid isPermaLink="false">http://seanbehan.com/?p=664</guid>
		<description><![CDATA[Download First install mod_python for Apache and then restart/reload the server. apt-get install libapache2-mod-python /etc/init.d/apache2 force-reload apache2ctl restart Next grab the web.py framework from webpy.org. You can grab the tar or use easy_install depending on your setup. wget http://webpy.org/static/web.py-0.33.tar.gz tar xzvf web.py.tar.gz cd web sudo python setup.py install # or if you use easy_install easy_install [...]]]></description>
			<content:encoded><![CDATA[<div style="height:33px;" class="really_simple_share robots-nocontent snap_nopreview"><div class="really_simple_share_facebook_like" style="width:px;">
				<iframe src="http://www.facebook.com/plugins/like.php?href=http%3A%2F%2Fseanbehan.com%2Fpython%2Fmod_python-and-web-py-on-ubuntu%2F&amp;layout=button_count&amp;show_faces=false&amp;width=&amp;action=like&amp;colorscheme=light&amp;send=false&amp;height=27" 
						scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:px; height:27px;" allowTransparency="true"></iframe>
				</div><div class="really_simple_share_twitter" style="width:px;">
					<a href="http://twitter.com/share" class="twitter-share-button" data-count="horizontal" 
						data-text="Mod_Python and Web.py on Ubuntu" data-url="http://seanbehan.com/python/mod_python-and-web-py-on-ubuntu/" 
						data-via="" ></a> 
				</div></div>
		<div style="clear:both;"></div><h3>Download</h3>
<p>First install mod_python for Apache and then restart/reload the server.</p>
<pre class="wp-code-highlight prettyprint">
apt-get install libapache2-mod-python
/etc/init.d/apache2 force-reload
apache2ctl restart
</pre>
<p>Next grab the web.py framework from webpy.org. You can grab the tar or use easy_install depending on your setup.</p>
<pre class="wp-code-highlight prettyprint">
wget http://webpy.org/static/web.py-0.33.tar.gz
tar xzvf web.py.tar.gz
cd web
sudo python setup.py install
# or if you use easy_install
easy_install web.py
</pre>
<p>Download this file <a href="http://www.aminus.net/browser/modpython_gateway.py?rev=106&#038;format=raw">http://www.aminus.net/browser/modpython_gateway.py?rev=106&#038;format=raw</a> This python package can (with this version) go anywhere in your python path &#8220;sys.path&#8221;. However, I placed it in the wsgiref directory. I&#8217;m running python2.6 so I did the following</p>
<pre class="wp-code-highlight prettyprint">
# after downloading
mv modpython_gateway.py /usr/lib/python2.6/wsgiref/modpython_gateway.py
</pre>
<p>It&#8217;s important to remember that in the VirtualHost file you create the PythonHandler directive will need to reference this module. If you place it outside of the wsgiref directory remember to change the directive as well.</p>
<h3>The VirtualHost</h3>
<p>Now we need to create a VirtualHost for our application. You can run web.py apps without apache and this is good for development mode. To do this the command is</p>
<pre class="wp-code-highlight prettyprint">
python pcode.py 4567
</pre>
<p>where the pcode.py is your web.py application filename and the 4567 is the port number you want to start the server on. I think it defaults to 8080. If you&#8217;re running apache or another web server port 80 will be in use. This is where mod_python (or cgi or fastcgi) come into play.</p>
<pre class="wp-code-highlight prettyprint">
&amp;lt;VirtualHost *&amp;gt;
  ServerName py.seanbehan.com
  DocumentRoot /var/www/python/myapp

   #Aliases can trip you up! Pay attention here
   Alias /myapp /var/www/python/myapp
   &amp;lt;Directory /var/www/python/myapp&amp;gt;
      &amp;lt;IfModule python_module&amp;gt;
        PythonPath &quot;sys.path +['/var/www/python/myapp']&quot;
        AddHandler python-program .py
        # modpython_gateway is a file you'll need to download and place in wsgiref
        PythonHandler wsgiref.modpython_gateway::handler
        # This is your python program
        PythonOption wsgi.application pcode::main
        PythonOption SCRIPT_NAME /myapp
        PythonDebug on
      &amp;lt;/IfModule&amp;gt;
    &amp;lt;/Directory&amp;gt;
&amp;lt;/VirtualHost&amp;gt;
</pre>
<h3>Web.py Application</h3>
<p>Web.py applications can be very simple. Everything can be placed in one file. In this example I created a file &#8220;pcode.py&#8221; and saved it to &#8220;/var/www/python/myapp/pcode.py&#8221;. The contents look like this</p>
<pre class="wp-code-highlight prettyprint">
import web #this is the web.py frameword
web.webapi.internalerror = web.debugerror #lets capture errors for debugging

# map paths to classes
urls = (
    &quot;/&quot;, &quot;hello&quot;
)

# this is the main from the PythonOption wsgi.application pcode::main from our VirtualHost
main = web.application(urls, globals()).wsgifunc()

class hello:
    def GET(self):
        #  web.header... otherwise you'll be prompted to save the file rather than view it in the browser
        web.header('Content-type','text/html')
        yield &quot;Finally got web.py to work!&quot;

if __name__ == &quot;__main__&quot;:
    main.run()
</pre>
<p>Save the file, reload apache and visit the location on the web (In my case py.seanbehan.com/pcode.py/). Remember to include that last &#8220;/&#8221; after the pcode.py. You might get a  &#8220;not found&#8221; message from web.py otherwise.</p>
<h3>Pretty URLs</h3>
<p>You can get pretty urls like &#8220;py.seanbehan.com/hello/world&#8221; if you use the mod_rewrite apache module.</p>
<pre class="wp-code-highlight prettyprint">
a2enmod rewrite
</pre>
<p>You can either set up the rewrite rules in your VirtualHost or in a .htaccess file. I&#8217;ll do the .htaccess so I don&#8217;t have to reload the server for the changes to take effect.</p>
<p>In the same directory as your pcode.py file create a file &#8220;.htaccess&#8221; and in it place this code</p>
<pre class="wp-code-highlight prettyprint">
&amp;lt;IfModule mod_rewrite.c&amp;gt;
  RewriteEngine on
  RewriteBase /
  RewriteCond %{REQUEST_URI} !^/icons
  RewriteCond %{REQUEST_URI} !^/favicon.ico$
  RewriteCond %{REQUEST_URI} !^(/.*)+code.py/
  RewriteRule ^(.*)$ pcode.py/$1 [PT]
&amp;lt;/IfModule&amp;gt;
</pre>
<h3>Troubleshooting</h3>
<p>I ran into some trouble with the Alias in the VirtualHost file. It looks like this</p>
<pre class="wp-code-highlight prettyprint">
Alias /myapp /var/www/python/myapp
</pre>
<p>This will map incoming urls to the full path on the filesystem so that your python program will run properly. I kept getting the not found error message from web.py without it. There might be a better way to set this up but this is how I got it to work.</p>
<p>Here are some additional resources I found helpful<br />
<a href="http://wiki.slicehost.com/doku.php?id=install_mod_wsgi_on_ubuntu_gutsy">http://wiki.slicehost.com/doku.php?id=install_mod_wsgi_on_ubuntu_gutsy<br />
</a><br />
<a href="http://webpy.org/install">http://webpy.org/install</a><br />
<a href="http://dready.org/blog/2009/01/29/webpy-with-mod_python-on-apache/">http://dready.org/blog/2009/01/29/webpy-with-mod_python-on-apache/</a><br />
<a href="http://www.devisland.net/help/webpy.shtml">http://www.devisland.net/help/webpy.shtml</a></p>
]]></content:encoded>
			<wfw:commentRss>http://seanbehan.com/python/mod_python-and-web-py-on-ubuntu/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
	</channel>
</rss>

