2009-09-10 07:50:51 +00:00
|
|
|
Running the Tornado Blog example app
|
|
|
|
====================================
|
|
|
|
This demo is a simple blogging engine that uses MySQL to store posts and
|
|
|
|
Google Accounts for author authentication. Since it depends on MySQL, you
|
|
|
|
need to set up MySQL and the database schema for the demo to run.
|
|
|
|
|
2015-03-28 19:27:56 +00:00
|
|
|
If you have `docker` and `docker-compose` installed, the demo and all
|
|
|
|
its prerequisites can be installed with `docker-compose up`.
|
|
|
|
|
2009-09-10 07:50:51 +00:00
|
|
|
1. Install prerequisites and build tornado
|
|
|
|
|
|
|
|
See http://www.tornadoweb.org/ for installation instructions. If you can
|
|
|
|
run the "helloworld" example application, your environment is set up
|
|
|
|
correctly.
|
|
|
|
|
|
|
|
2. Install MySQL if needed
|
|
|
|
|
|
|
|
Consult the documentation for your platform. Under Ubuntu Linux you
|
|
|
|
can run "apt-get install mysql". Under OS X you can download the
|
|
|
|
MySQL PKG file from http://dev.mysql.com/downloads/mysql/
|
|
|
|
|
2012-09-16 21:02:49 +00:00
|
|
|
3. Install Python prerequisites
|
|
|
|
|
2013-03-03 16:56:47 +00:00
|
|
|
Install the packages MySQL-python, torndb, and markdown (e.g. using pip or
|
2014-10-12 00:07:54 +00:00
|
|
|
easy_install). Note that these packages currently only work on
|
|
|
|
Python 2. Tornado supports Python 3, but this blog demo does not.
|
2012-09-16 21:02:49 +00:00
|
|
|
|
2009-09-10 07:50:51 +00:00
|
|
|
3. Connect to MySQL and create a database and user for the blog.
|
|
|
|
|
|
|
|
Connect to MySQL as a user that can create databases and users:
|
|
|
|
mysql -u root
|
|
|
|
|
|
|
|
Create a database named "blog":
|
|
|
|
mysql> CREATE DATABASE blog;
|
|
|
|
|
|
|
|
Allow the "blog" user to connect with the password "blog":
|
|
|
|
mysql> GRANT ALL PRIVILEGES ON blog.* TO 'blog'@'localhost' IDENTIFIED BY 'blog';
|
|
|
|
|
|
|
|
4. Create the tables in your new database.
|
|
|
|
|
|
|
|
You can use the provided schema.sql file by running this command:
|
|
|
|
mysql --user=blog --password=blog --database=blog < schema.sql
|
|
|
|
|
|
|
|
You can run the above command again later if you want to delete the
|
|
|
|
contents of the blog and start over after testing.
|
|
|
|
|
|
|
|
5. Run the blog example
|
|
|
|
|
|
|
|
With the default user, password, and database you can just run:
|
|
|
|
./blog.py
|
|
|
|
|
|
|
|
If you've changed anything, you can alter the default MySQL settings
|
|
|
|
with arguments on the command line, e.g.:
|
|
|
|
./blog.py --mysql_user=casey --mysql_password=happiness --mysql_database=foodblog
|
|
|
|
|
|
|
|
6. Visit your new blog
|
|
|
|
|
|
|
|
Open http://localhost:8888/ in your web browser. You will be redirected to
|
|
|
|
a Google account sign-in page because the blog uses Google accounts for
|
|
|
|
authentication.
|
|
|
|
|
|
|
|
Currently the first user to connect will automatically be given the
|
2012-09-16 21:02:49 +00:00
|
|
|
ability to create and edit posts.
|
2009-09-10 07:50:51 +00:00
|
|
|
|
|
|
|
Once you've created one blog post, subsequent users will not be
|
|
|
|
prompted to sign in.
|