<?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>KenKinder.com &#187; MySQL</title>
	<atom:link href="http://kenkinder.com/tag/mysql/feed/" rel="self" type="application/rss+xml" />
	<link>http://kenkinder.com</link>
	<description>Ken Kinder&#039;s personal website</description>
	<lastBuildDate>Mon, 14 Jun 2010 22:27:25 +0000</lastBuildDate>
	
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>MySQL (MySQLdb) sessions on CherryPy</title>
		<link>http://kenkinder.com/2008/12/29/mysql-mysqldb-sessions-on-cherrypy/</link>
		<comments>http://kenkinder.com/2008/12/29/mysql-mysqldb-sessions-on-cherrypy/#comments</comments>
		<pubDate>Mon, 29 Dec 2008 23:44:40 +0000</pubDate>
		<dc:creator>Ken Kinder</dc:creator>
				<category><![CDATA[Python]]></category>
		<category><![CDATA[CherryPy]]></category>
		<category><![CDATA[MySQL]]></category>
		<category><![CDATA[MySQLdb]]></category>

		<guid isPermaLink="false">http://kenkinder.com/?p=163</guid>
		<description><![CDATA[No such module existed, so I wrote one. Using it is pretty simple:


&#34;&#34;&#34;
Example code using mysqlsession.py
&#34;&#34;&#34;
from mysqlsession import MySQLSession
import cherrypy
import logging
&#160;
logging.basicConfig&#40;level=logging.DEBUG&#41;
&#160;
sessionInfo = &#123;
    'tools.sessions.on': True,
    'tools.sessions.storage_type': &#34;Mysql&#34;,
    'tools.sessions.connect_arguments': &#123;'db': 'sessions'&#125;,
    'tools.sessions.table_name': 'session'
&#125;
&#160;
cherrypy.config.update&#40;sessionInfo&#41;
&#160;
class HelloWorld:
    def index&#40;self&#41;:
      [...]]]></description>
			<content:encoded><![CDATA[<p>No such module existed, so I wrote one. Using it is pretty simple:</p>
<p><span id="more-163"></span></p>

<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;
Example code using mysqlsession.py
&quot;&quot;&quot;</span>
<span style="color: #ff7700;font-weight:bold;">from</span> mysqlsession <span style="color: #ff7700;font-weight:bold;">import</span> MySQLSession
<span style="color: #ff7700;font-weight:bold;">import</span> cherrypy
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">logging</span>
&nbsp;
<span style="color: #dc143c;">logging</span>.<span style="color: black;">basicConfig</span><span style="color: black;">&#40;</span>level=<span style="color: #dc143c;">logging</span>.<span style="color: black;">DEBUG</span><span style="color: black;">&#41;</span>
&nbsp;
sessionInfo = <span style="color: black;">&#123;</span>
    <span style="color: #483d8b;">'tools.sessions.on'</span>: <span style="color: #008000;">True</span>,
    <span style="color: #483d8b;">'tools.sessions.storage_type'</span>: <span style="color: #483d8b;">&quot;Mysql&quot;</span>,
    <span style="color: #483d8b;">'tools.sessions.connect_arguments'</span>: <span style="color: black;">&#123;</span><span style="color: #483d8b;">'db'</span>: <span style="color: #483d8b;">'sessions'</span><span style="color: black;">&#125;</span>,
    <span style="color: #483d8b;">'tools.sessions.table_name'</span>: <span style="color: #483d8b;">'session'</span>
<span style="color: black;">&#125;</span>
&nbsp;
cherrypy.<span style="color: black;">config</span>.<span style="color: black;">update</span><span style="color: black;">&#40;</span>sessionInfo<span style="color: black;">&#41;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">class</span> HelloWorld:
    <span style="color: #ff7700;font-weight:bold;">def</span> index<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
        v = cherrypy.<span style="color: black;">session</span>.<span style="color: black;">get</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'v'</span>, <span style="color: #ff4500;">1</span><span style="color: black;">&#41;</span>
        cherrypy.<span style="color: black;">session</span><span style="color: black;">&#91;</span><span style="color: #483d8b;">'v'</span><span style="color: black;">&#93;</span> = v+<span style="color: #ff4500;">1</span>
        <span style="color: #ff7700;font-weight:bold;">return</span> <span style="color: #483d8b;">&quot;Hello world! %s&quot;</span> <span style="color: #66cc66;">%</span> v
&nbsp;
    index.<span style="color: black;">exposed</span> = <span style="color: #008000;">True</span>
&nbsp;
cherrypy.<span style="color: black;">quickstart</span><span style="color: black;">&#40;</span>HelloWorld<span style="color: black;">&#40;</span><span style="color: black;">&#41;</span><span style="color: black;">&#41;</span></pre></div></div>

<p>Download the module: <a href="/wp-content/uploads/2008/12/mysqlsession.py.zip">mysqlsession.py</a></p>
<p>I would publish it formally, but I&#8217;m going to see if I can just have it added to the CherryPy project.</p>
<p>UPDATE: I took out the table locking and used InnoDB select-for-update locking.</p>
]]></content:encoded>
			<wfw:commentRss>http://kenkinder.com/2008/12/29/mysql-mysqldb-sessions-on-cherrypy/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
