前情提要:

Paas(平台及服务)公司Heroku是个可以把我们写好的App部署到网际网络的好地方。而本篇是我从自己的上一篇文章:将Ruby on Rails项目部署到Heroku遇到的问题,当时困扰了快两小时,好在搜寻完解法搞定完后,就兴奋地延伸为一篇文章了!找到点子写文章果然是遇到bug的最佳副产品

Heroku的数据库是使用PostgreSQL,而这篇文章有说明为什么不用SQLite在Heroku。

但Rails框架在我们的电脑本机rails new app设定时,为了初学者快速理解学习,预设是SQLite。

所以如果没有变更数据库,直接把Rails push到Heroku上去,就会出现问题。

看完这篇数据库的文章比较,以一句话来大概解释比较sqlite与PostgreSQL,sqlite缺乏额外优化性能的灵活性,且同一时间只允许一个写入操作;可扩展的PostgreSQL提供了可靠性和数据完整性,因此是更好的选择。

[问题]

我在本机的Ruby on Rails项目所用的数据库是SQLite,当时还未想到之后会部署到Heroku。

因此,在上篇文章做到Step3 >>步骤B.建立Heroku gem:修改我的本地文件夹里的gem file,当我新增一个gem叫做'pg'这个步骤时…

问题出现了!本机遇到的错误讯息:No connection pool for ActiveRecord::Base

[解法]

Step1.修改rails项目的/config/Gemfile

Pg套件,让我们在Ruby上使用关联式数据库PostgreSQL的界面的好帮手。

(Pg套件详细数据:http://www.leafor.com

我们可以/config/Gemfile加上这几行代码,

让在Heroku上线时候跑的是PostgreSQL,而在本机的时候还是跑SQLite。

Rails应用程序预设提供了三种不同的执行模式:

development environment:开发模式,用在你的开发的时候

test environment:测试模式,用在执行测试程序时

production environment:正式上线模式,用在实际的上线运作环境

group:production do

gem 'pg'

end

group:development,:test do

gem 'sqlite3'

end

或是写成:

gem 'sqlite3',group::development

gem 'pg',group::production

[注意]gem 'pg'后面要加逗号,啊!不然就会向我一样出现Syntax error…

欣慰的是,用错误讯息搜寻关键字,发现在stackoverflow上也有人跟我犯过同样的错误XD

https://stackoverflow.com/questions/18684527/gemfile22-syntax-error-unexpected-tidentifier-expecting-end-of-input

Step2.跑bundle install,再重启rails server。

记得,每次在Gemfile修改套件数据,都要跑bundle install处理套件相依性问题。

(如果你在本机,想避免安装任何在production环境下跑的gem,可输入:bundle install --without production)

而每次跑完bundle都要先用control+ c关掉Terminal页面的服务器,

再重启服务器rails s之后,如下图:localhost数据库的问题已解决了:

但你还是看不到首页的数据:

Step3.部署到Heroku:git push heroku master

最后两步:push!git push heroku master,

还要跑完heroku rake db:migrate指令才会生效喔!

(如果转换数据库之前有些bug,run指令的时候会提示哪些字段可能出了问题。)

首页成功显示数据库!

==

后记:

遇到这个bug让我提早了解跟ruby on rails相关的数据库概念,是一个很有价值的坑(bgrayart)!

如果你想在本机建立rails app的当下,直接设定成PostgreSQL而非SQLite(节省之后deploy的麻烦~),可以参考这篇文章:

Rails使用PostgreSQL

[Ting's笔记Day5]在部署到Heroku之前,将Rails项目从SQLite设定为PostgreSQL的更多相关文章

  1. [Ting's笔记Day4]将Ruby on Rails项目部署到Heroku

    今天想笔记的是把自己写的Ruby on Rails项目部署(Deploy)到Heroku! Heroku是Salesforce公司旗下的云端服务商,支持多种程序语言像是Ruby,PHP,Python等 ...

  2. [Ting's笔记Day8]活用套件carrierwave gem:(3)Deploy图片上传功能到Heroku网站

    前情提要: 身为Ruby新手村民,创造稳定且持续的学习步调很重要,我用的方法就是一周在IT邦写三篇笔记,希望藉由把笔记和遇到的bug记录下来的过程,能帮助到未来想用Ruby on Rails架站的新手 ...

  3. python笔记 - day5

    python笔记 - day5 参考: http://www.cnblogs.com/wupeiqi/articles/5484747.html http://www.cnblogs.com/alex ...

  4. (转)ZooKeeper 笔记(1) 安装部署及hello world

    ZooKeeper 笔记(1) 安装部署及hello world   先给一堆学习文档,方便以后查看 官网文档地址大全: OverView(概述) http://zookeeper.apache.or ...

  5. ActionBarSherlock学习笔记 第一篇——部署

    ActionBarSherlock学习笔记 第一篇--部署          ActionBarSherlock是JakeWharton编写的一个开源框架,使用这个框架,可以实现在所有的Android ...

  6. OGG学习笔记04-OGG复制部署快速参考

    OGG学习笔记04-OGG复制部署快速参考 源端:Oracle 10.2.0.5 RAC + ASM 节点1 Public IP地址:192.168.1.27 目标端:Oracle 10.2.0.5 ...

  7. [Ting's笔记Day9]活用套件Carrierwave gem:(4)使用Imagemagick修改图片大小

    前情提要: 这几天我都在实验Carrierwave这套图片上传套件,也顺利部署到Heroku架站正式环境了.:) 接下来我遇到了新的问题:要如何在上传的时候,让Carrierwave gem大型siz ...

  8. [Ting's笔记Day7]活用套件carrierwave gem:(2)利用Amazon S3架设图片服务器

    来到第7篇了!培养写作习惯真是不容易:) 在我的上一篇文章活用套件carrierwave gem:(1)在Rails实现图片上传功能,上传图片功能已经完成啦!但是目前图片仅能上传在自己的本地文件夹内孤 ...

  9. 将 django部署到 heroku上

    为什么要这样做,因为我并没有弄懂,使用传统和推荐的方法来部署django.刚好我手里有这么一份教程我就按照这么做了. 1. 访问 http://heroku.com/ 完成一个注册,注册需要一个国外的 ...

随机推荐

  1. 内存泄露java.lang.OutOfMemoryError: PermGen space解决方法

    PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被 ...

  2. xshell连接linux主机时,出现错误:Could not connect to '***.***.***.***' (port 22)

    xshell连接linux主机时,会出现错误:Could not connect to '192.168.89.144' (port 22): Connection failed. 但是这时能ping ...

  3. s21day11 python笔记

    s21day11 python笔记 一.函数小高级 函数名可以当作变量来使用 #示例一: def func(): print(123) func_list = [func, func, func] # ...

  4. 小妖精的完美游戏教室——人工智能,A*算法,引言

    今天也要直播魔法,求科学的! 欢迎来到小妖精Balous的完美游戏教室! 经过前两周的学习,相信米娜桑已经对状态机有所了解了呢~虽然状态机能够实现几乎所有的人工智能,但是,在实践中,你们有没有发现,自 ...

  5. 分布式高并发下Actor模型

    分布式高并发下Actor模型 写在开始 一般来说有两种策略用来在并发线程中进行通信:共享数据和消息传递.使用共享数据方式的并发编程面临的最大的一个问题就是数据条件竞争.处理各种锁的问题是让人十分头痛的 ...

  6. python 使用gevent模块实现手动挡切换多协程。

    from greenlet import greenlet def test1(): print(12) g2.switch()#切换到协程g2执行,保存执行状态 print(23) g2.switc ...

  7. nodejs----初期学习笔记

    //一 回调函数 //require---命令//Node 使用了大量的回调函数,Node 所有 API 都支持回调函数.//例如,我们可以一边读取文件,一边执行其他命令,在文件读取完成后,我们将文件 ...

  8. immutable.js使用总结

    1. immutable相当于 JSON.parse 和 JSON.stringify: 2.引入redux中,除了 在最外层 reducer中  import { combineReducers } ...

  9. Django学习笔记之URL与视图

    视图 视图一般都写在app的views.py中.并且视图的第一个参数永远都是request(一个HttpRequest)对象.这个对象存储了这个http请求的所有信息,其中包括携带的参数以及一些头部信 ...

  10. JAVA常用工具类异常处理

    1异常的定义 异常就是与我们编译相违背在过程中出现的逻辑或忘记一些赋值等等 分为编译时错误和运行时错误 运行时异常 我们一般处理的时Exception异常: 异常处理 异常处理可以通过关键字try,c ...