## Creating a New Rails Project If you follow this guide, you’ll create a Rails project called blog, a (very) simple weblog. Before you can start building the application, you need to make sure that you have Rails itself installed. ### Installing Rails In most cases, the easiest way to install Rails is to take advantage of RubyGems: Usually run this as the root user: # gem install rails
If you’re working on Windows, you should be aware that the vast majority of Rails development is done in Unix environments. While Ruby and Rails themselves install easily using for example Ruby Installer, the supporting ecosystem often assumes you are able to build C-based rubygems and work in a command window. If at all possible, we suggest that you install a Linux virtual machine and use that for Rails development, instead of using Windows.
### Creating the Blog Application The best way to use this guide is to follow each step as it happens, no code or step needed to make this example application has been left out, so you can literally follow along step by step. If you need to see the completed code, you can download it from [Getting Started Code](http://github.com/mikel/getting-started-code). To begin, open a terminal, navigate to a folder where you have rights to create files, and type: $ rails new blog This will create a Rails application called Blog in a directory called blog.
You can see all of the switches that the Rails application builder accepts by running rails -h
.
File/Folder | Purpose |
---|---|
Gemfile | This file allows you to specify what gem dependencies are needed for your Rails application. |
README.rdoc | This is a brief instruction manual for your application. Use it to tell others what your application does, how to set it up, and so on. |
Rakefile | This file contains batch jobs that can be run from the terminal. |
app/ | Contains the controllers, models, and views for your application. You’ll focus on this folder for the remainder of this guide. |
config/ | Configure your application’s runtime rules, routes, database, and more. |
config.ru | Rack configuration for Rack based servers used to start the application. |
db/ | Shows your current database schema, as well as the database migrations. You’ll learn about migrations shortly. |
doc/ | In-depth documentation for your application. |
lib/ | Extended modules for your application (not covered in this guide). |
log/ | Application log files. |
public/ | The only folder seen to the world as-is. This is where your images, javascript, stylesheets (CSS), and other static files go. |
script/ | Contains the rails script that starts your app and can contain other scripts you use to deploy or run your application. |
test/ | Unit tests, fixtures, and other test apparatus. |
tmp/ | Temporary files. |
vendor/ | A place for all third-party code. In a typical Rails application, this includes Ruby Gems, the Rails source code (if you install it into your project) and plugins containing additional prepackaged functionality. |
In this guide we are using an SQLite3 database for data storage, because it is a zero configuration database that just works. Rails also supports MySQL and PostgreSQL “out of the box”, and has plugins for many database systems. If you are using a database in a production environment Rails most likely has an adapter for it.
### Configuring a MySQL Database If you choose to use MySQL instead of the shipped Sqlite3 database, your `config/database.yml` will look a little different. Here’s the development section: @@@ yaml development: adapter: mysql2 encoding: utf8 database: blog_development pool: 5 username: root password: socket: /tmp/mysql.sock @@@ If your development computer’s MySQL installation includes a root user with an empty password, this configuration should work for you. Otherwise, change the username and password in the `development` section as appropriate. ### Configuring a PostgreSQL Database Finally if you choose to use PostgreSQL, your config/database.yml will be customized to use PostgreSQL databases: @@@ yaml development: adapter: postgresql encoding: unicode database: blog_development pool: 5 username: blog password: @@@ Change the username and password in the `development` section as appropriate. ### Creating the Database Now that you have your database configured, it’s time to have Rails create an empty database for you. You can do this by running a rake command: $ rake db:create This will create your development and test SQLite3 databases inside the `db/` folder.
Rake is a general-purpose command-runner that Rails uses for many things. You can see the list of available rake commands in your application by running rake -T
.