Ruby on Rails 實戰聖經阅读(二)
1.操作系统 centos5.4
 
 2.安装ruby
 
 yum install ruby
 
 会安装得到 1.8.5
 
 如果你公司用的是1.8.X就无所谓了,
 
 拿这个学习就行了
 
 如果你们公司用的是1.9.X,那么你需要去下载源码进行安装。【你会很悲剧的发现下载已被伟大祖国的万里长城封锁了】
 
 我这里使用1.8.5学习就ok了
 
 3.安装rails
 
 yum -y install rubygem-rails.noarch
 
 4.看看安装完毕的成果
 
 [root@localhost projects]# ruby -v
 
 ruby 1.8.5 (2006-08-25) [x86_64-linux]
 
 [root@localhost projects]# rails -v
 
 Rails 2.1.1
 
 5.建立rails档案
 
 mkdir projects
 
 cd projects
 
 rails new demo 
 
 圣经说:
 
 如果出現建立出來的目錄不是demo而是new,表示你的Rails版本是舊版的,請輸入rails -v檢查Rails的版本必須是3.0以上。不是的話,請回上一章末執行gem install rails安裝Rails 3
 
  老版本就老版本吧
 
 不管他
 
 6.启动服务器 ./script/server 
 
 [root@localhost new]# ./script/server 
 
 => Booting WEBrick...
 
 => Rails 2.1.1 application started on http://0.0.0.0:3000
 
 => Ctrl-C to shutdown server; call with --help for options
 
 [2013-07-16 09:29:45] INFO  WEBrick 1.3.1
 
 [2013-07-16 09:29:45] INFO  ruby 1.8.5 (2006-08-25) [x86_64-linux]
 
 [2013-07-16 09:29:45] INFO  WEBrick::HTTPServer#start: pid=17229 port=3000
 
 8.访问一下
 
 本地访问:
 
 [root@localhost ~]# curl "127.0.0.1:3000"
 
 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
 
         "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
 <html>
 
   <head>
 
     <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
 
     <title>Ruby on Rails: Welcome aboard</title>
 
     <style type="text/css" media="screen">
 
       body {
 
         margin: 0;
 
         margin-bottom: 25px;
 
         padding: 0;
 
         background-color: #f0f0f0;
 
         font-family: "Lucida Grande", "Bitstream Vera Sans", "Verdana";
 
         font-size: 13px;
 
         color: #333;
 
       }
 
       
 
       h1 {
 
         font-size: 28px;
 
         color: #000;
 
       }
 
       
 
       a  {color: #03c}
 
       a:hover {
 
         background-color: #03c;
 
         color: white;
 
         text-decoration: none;
 
       }
 
       
 
       
 
       #page {
 
         background-color: #f0f0f0;
 
         width: 750px;
 
         margin: 0;
 
         margin-left: auto;
 
         margin-right: auto;
 
       }
 
       
 
       #content {
 
         float: left;
 
         background-color: white;
 
         border: 3px solid #aaa;
 
         border-top: none;
 
         padding: 25px;
 
         width: 500px;
 
       }
 
       
 
       #sidebar {
 
         float: right;
 
         width: 175px;
 
       }
 
  
 
       #footer {
 
         clear: both;
 
       }
 
       
 
  
 
       #header, #about, #getting-started {
 
         padding-left: 75px;
 
         padding-right: 30px;
 
       }
 
  
 
  
 
       #header {
 
         background-image: url("images/rails.png");
 
         background-repeat: no-repeat;
 
         background-position: top left;
 
         height: 64px;
 
       }
 
       #header h1, #header h2 {margin: 0}
 
       #header h2 {
 
         color: #888;
 
         font-weight: normal;
 
         font-size: 16px;
 
       }
 
       
 
       
 
       #about h3 {
 
         margin: 0;
 
         margin-bottom: 10px;
 
         font-size: 14px;
 
       }
 
       
 
       #about-content {
 
         background-color: #ffd;
 
         border: 1px solid #fc0;
 
         margin-left: -11px;
 
       }
 
       #about-content table {
 
         margin-top: 10px;
 
         margin-bottom: 10px;
 
         font-size: 11px;
 
         border-collapse: collapse;
 
       }
 
       #about-content td {
 
         padding: 10px;
 
         padding-top: 3px;
 
         padding-bottom: 3px;
 
       }
 
       #about-content td.name  {color: #555}
 
       #about-content td.value {color: #000}
 
       
 
       #about-content.failure {
 
         background-color: #fcc;
 
         border: 1px solid #f00;
 
       }
 
       #about-content.failure p {
 
         margin: 0;
 
         padding: 10px;
 
       }
 
       
 
       
 
       #getting-started {
 
         border-top: 1px solid #ccc;
 
         margin-top: 25px;
 
         padding-top: 15px;
 
       }
 
       #getting-started h1 {
 
         margin: 0;
 
         font-size: 20px;
 
       }
 
       #getting-started h2 {
 
         margin: 0;
 
         font-size: 14px;
 
         font-weight: normal;
 
         color: #333;
 
         margin-bottom: 25px;
 
       }
 
       #getting-started ol {
 
         margin-left: 0;
 
         padding-left: 0;
 
       }
 
       #getting-started li {
 
         font-size: 18px;
 
         color: #888;
 
         margin-bottom: 25px;
 
       }
 
       #getting-started li h2 {
 
         margin: 0;
 
         font-weight: normal;
 
         font-size: 18px;
 
         color: #333;
 
       }
 
       #getting-started li p {
 
         color: #555;
 
         font-size: 13px;
 
       }
 
       
 
       
 
       #search {
 
         margin: 0;
 
         padding-top: 10px;
 
         padding-bottom: 10px;
 
         font-size: 11px;
 
       }
 
       #search input {
 
         font-size: 11px;
 
         margin: 2px;
 
       }
 
       #search-text {width: 170px}
 
       
 
       
 
       #sidebar ul {
 
         margin-left: 0;
 
         padding-left: 0;
 
       }
 
       #sidebar ul h3 {
 
         margin-top: 25px;
 
         font-size: 16px;
 
         padding-bottom: 10px;
 
         border-bottom: 1px solid #ccc;
 
       }
 
       #sidebar li {
 
         list-style-type: none;
 
       }
 
       #sidebar ul.links li {
 
         margin-bottom: 5px;
 
       }
 
       
 
     </style>
 
     <script type="text/javascript" src="javascripts/prototype.js"></script>
 
     <script type="text/javascript" src="javascripts/effects.js"></script>
 
     <script type="text/javascript">
 
       function about() {
 
         if (Element.empty('about-content')) {
 
           new Ajax.Updater('about-content', 'rails/info/properties', {
 
             method:     'get',
 
             onFailure:  function() {Element.classNames('about-content').add('failure')},
 
             onComplete: function() {new Effect.BlindDown('about-content', {duration: 0.25})}
 
           });
 
         } else {
 
           new Effect[Element.visible('about-content') ? 
 
             'BlindUp' : 'BlindDown']('about-content', {duration: 0.25});
 
         }
 
       }
 
       
 
       window.onload = function() {
 
         $('search-text').value = '';
 
         $('search').onsubmit = function() {
 
           $('search-text').value = 'site:rubyonrails.org ' + $F('search-text');
 
         }
 
       }
 
     </script>
 
   </head>
 
   <body>
 
     <div id="page">
 
       <div id="sidebar">
 
         <ul id="sidebar-items">
 
           <li>
 
             <form id="search" action="http://www.google.com/search" method="get">
 
               <input type="hidden" name="hl" value="en" />
 
               <input type="text" id="search-text" name="q" value="site:rubyonrails.org " />
 
               <input type="submit" value="Search" /> the Rails site
 
             </form>
 
           </li>
 
         
 
           <li>
 
             <h3>Join the community</h3>
 
             <ul class="links">
 
               <li><a href="http://www.rubyonrails.org/">Ruby on Rails</a></li>
 
               <li><a href="http://weblog.rubyonrails.org/">Official weblog</a></li>
 
               <li><a href="http://wiki.rubyonrails.org/">Wiki</a></li>
 
             </ul>
 
           </li>
 
           
 
           <li>
 
             <h3>Browse the documentation</h3>
 
             <ul class="links">
 
               <li><a href="http://api.rubyonrails.org/">Rails API</a></li>
 
               <li><a href="http://stdlib.rubyonrails.org/">Ruby standard library</a></li>
 
               <li><a href="http://corelib.rubyonrails.org/">Ruby core</a></li>
 
             </ul>
 
           </li>
 
         </ul>
 
       </div>
 
  
 
       <div id="content">
 
         <div id="header">
 
           <h1>Welcome aboard</h1>
 
           <h2>You’re riding Ruby on Rails!</h2>
 
         </div>
 
  
 
         <div id="about">
 
           <h3><a href="rails/info/properties" onclick="about(); return false">About your application’s environment</a></h3>
 
           <div id="about-content" style="display: none"></div>
 
         </div>
 
         
 
         <div id="getting-started">
 
           <h1>Getting started</h1>
 
           <h2>Here’s how to get rolling:</h2>
 
           
 
           <ol>          
 
             <li>
 
               <h2>Use <tt>script/generate</tt> to create your models and controllers</h2>
 
               <p>To see all available options, run it without parameters.</p>
 
             </li>
 
             
 
             <li>
 
               <h2>Set up a default route and remove or rename this file</h2>
 
               <p>Routes are set up in config/routes.rb.</p>
 
             </li>
 
  
 
             <li>
 
               <h2>Create your database</h2>
 
               <p>Run <tt>rake db:migrate</tt> to create your database. If you're not using SQLite (the default), edit <tt>config/database.yml</tt> with your username and password.</p>
 
             </li>
 
           </ol>
 
         </div>
 
       </div>
 
       
 
       <div id="footer"> </div>
 
     </div>
 
   </body>
 
 </html>
 
 远程访问:有问题
 
 
 
判断是iptables造成
 
 </html>[root@localhost ~]# iptables -L
 
 Chain INPUT (policy ACCEPT)
 
 target     prot opt source               destination         
 
 RH-Firewall-1-INPUT  all  --  anywhere             anywhere            
 
  
 
 Chain FORWARD (policy ACCEPT)
 
 target     prot opt source               destination         
 
 RH-Firewall-1-INPUT  all  --  anywhere             anywhere            
 
  
 
 Chain OUTPUT (policy ACCEPT)
 
 target     prot opt source               destination         
 
  
 
 Chain RH-Firewall-1-INPUT (2 references)
 
 target     prot opt source               destination         
 
 ACCEPT     all  --  anywhere             anywhere            
 
 ACCEPT     icmp --  anywhere             anywhere            icmp any 
 
 ACCEPT     esp  --  anywhere             anywhere            
 
 ACCEPT     ah   --  anywhere             anywhere            
 
 ACCEPT     udp  --  anywhere             224.0.0.251         udp dpt:mdns 
 
 ACCEPT     udp  --  anywhere             anywhere            udp dpt:ipp 
 
 ACCEPT     tcp  --  anywhere             anywhere            tcp dpt:ipp 
 
 ACCEPT     all  --  anywhere             anywhere            state RELATED,ESTABLISHED 
 
 ACCEPT     tcp  --  anywhere             anywhere            state NEW tcp dpt:ssh 
 
 ACCEPT     tcp  --  anywhere             anywhere            state NEW tcp dpt:https 
 
 ACCEPT     tcp  --  anywhere             anywhere            state NEW tcp dpt:http 
 
 REJECT     all  --  anywhere             anywhere            reject-with icmp-host-prohibited 
 
 关闭防火墙
 
 iptables -F
再次访问没问题了
Ruby on Rails 實戰聖經阅读(二)的更多相关文章
- Ruby on Rails 實戰聖經阅读(三)
		由于是1.8.x:圣经的1.9.3差太多,所以另外按1.8.X来创建hello world 第一個Hello World!! 1. 创建项目rails -d mysql first 2.创建控制器 ... 
- 如何从 0 开始学 ruby on rails (漫步版)
		如何从 0 开始学 ruby on rails (漫步版) ruby 是一门编程语言,ruby on rails 是 ruby 的一个 web 框架,简称 rails. 有很多人对 rails 感兴 ... 
- 如何从 0 开始学 Ruby on Rails
		如何从 0 开始学 Ruby on Rails (漫步版)Ruby 是一门编程语言,Ruby on Rails 是 Ruby 的一个 web 框架,简称 Rails. 有很多人对 Rails 感兴趣, ... 
- (转) 如何从 0 开始学 ruby on rails (漫步版)
		原文:http://readful.com/post/12322300571/0-ruby-on-rails ruby 是一门编程语言,ruby on rails 是 ruby 的一个 web 框架, ... 
- 《Ruby on Rails教程》学习笔记
		本文是我在阅读 Ruby on Rails 教程的简体中文版时所做的摘录,以及学习时寻找的补充知识.补充知识主要来自于 Ruby on Rails 實戰聖經. Asset Pipeline 在最新版 ... 
- [转]2010 Ruby on Rails 書單 與 練習作業
		原帖:http://wp.xdite.net/?p=1754 ========= 學習 Ruby on Rails 最快的途徑無非是直接使用 Rails 撰寫產品.而這個過程中若有 mentor 指導 ... 
- ruby on rails on windows
		这次想系统学会rails,最终目标是将redmine改造成顺手的工具,主要的手段就是开发redmine插件.虽然网上都推荐使用类Unix系统,可手头只有win7系统,就安装了. 难免会遇到这样那样的问 ... 
- 10个基于 Ruby on Rails 构建的顶级站点
		本文系国内 ITOM 行业领军企业 OneAPM 工程师翻译整理自 Raviraj Hegde 的文章 Top Sites Built with Ruby on Rails. 就其本身而言,Ruby ... 
- Ruby on Rails创始人DHH谈如何进行混合移动APP开发
		混合型APP兼具原生型APP软件良好用户交互体验的优势和网页型APP软件跨平台开发的优势,并且其开发成本和网页型APP软件接近,其开发效率也远高于原生型APP软件.混合型APP已经被众多企业所认可.最 ... 
随机推荐
- HDOJ 3635 并查集- 路径压缩,带秩合并
			思路来源:http://blog.csdn.net/niushuai666/article/details/6990421 题目大意: 初始时,有n个龙珠,编号从1到n,分别对应的放在编号从1到n的城 ... 
- 转:MySql的commit和rollback
			从功能上划分,SQL 语言可以分为DDL,DML和DCL三大类.1. DDL(Data Definition Language) 数据定义语言,用于定义和管理 SQL 数据库中的所有对象的语言 ... 
- WeCenter 社交化问答社区程序 | WeCenter 是一款知识型的社交化问答社区程序,专注于社区内容的整理、归类、检索和再发行
			WeCenter 社交化问答社区程序 | WeCenter 是一款知识型的社交化问答社区程序,专注于社区内容的整理.归类.检索和再发行 为什么选择 WeCenter 程序? 让您的社区更智能地运作,强 ... 
- pomelo 协议
			分析的是hybridconnector,使用的chatofpomelo-websocket(pomelo为0.7.0) 參考:https://github.com/NetEase/pomelo/wik ... 
- mongodb进阶一之高级查询
			上篇文章我们讲了mongodb的crud基本操作 http://blog.csdn.net/stronglyh/article/details/46812579 这篇我们来说说mongodb的进阶-- ... 
- NanShan即时通讯论——HTML5的优势与劣势
			原文:NanShan即时通讯论--HTML5的优势与劣势 NanShan即时通讯 学习html时才是XHTML 1.0,接着是 HTML4.01,再到HTML5,如今HTML5 開始吸引越来越多的人的 ... 
- php内存分析
			1.一般来说,php倒不需要进行内存分析,但是遇到大循环时内存吃紧时就得要进行内存分析了,看看在哪里吃掉了内存. $m1 = memory_get_usage(); $m2 = memory_get_ ... 
- sublime2 c++的一些使用配置
			1 下载安装好tdw gcc后,配置好环境变量后,配置sublime2. tools->build system-> new build system... 里面输入: { "c ... 
- ASP.NET给Table动态添加删除行,并且得到控件的值
			ASP.NET给Table动态添加控件并且得到控件的值 由于跟老师做一个小的项目,可是我自己又不太懂js,所以一直为动态建立表格并且能动态的取值和赋值感到苦恼.起初在网上找到了一些js资源,解决了动态 ... 
- 为学Linux,我看了这些书
			为学Linux,我看了这些书 去年开始,抱着学习的态度开始了我的Linux学习,到现在,差不多一年了,收获很多,不敢说精通Linux,但是,还是对得起"略懂"这两个字的.这一年 ... 
