侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Ruby on Rails框架程序连接MongoDB的教程

数据库  /  管理员 发布于 5年前   239

前边有介绍mongodb的安装以及ror项目的搭建,现在进行一下整合。

1.创建项目

创建项目时不再使用rails active_record支持

rails new todo -O

2.我们将要使用MongoMapper来驱动MongoDB到Rails

编辑GemFile,增加下面的内容

gem"mongo_mapper"

然后  执行 bundle install 安装gem

bundle install

3.添加数据库链接

在config/initializer下面新建一个mongo.rb文件,指定全局的数据库信息:

MongoMapper.connection = Mongo::Connection.new('localhost', 27017)MongoMapper.database ='todo'#通过指定Rails运行环境参数,我们可以在不同的运行环境下创建互不干扰的数据,为了简单起见,没有为不同的环境指定不同的数据
if defined?(PhusionPassenger)  PhusionPassenger.on_event(:starting_worker_process)do|forked|    MongoMapper.connection.connectifforked  endend

完成以上步骤后,启动程序:

$ rails server
**Notice: C extension not loaded. This is required for optimum MongoDB Ruby driver performance.You can install the extension as follows:
gem install bson_ext
If you continue to receive this message after installing, make sure that thebson_ext gem is in your load path and that the bson_ext and mongo gems are of the same version.=> Booting WEBrick=> Rails 3.0.10 application starting in development on http://0.0.0.0:3000=> Call with -d to detach=> Ctrl-C to shutdown server[2011-10-19 23:36:14] INFO WEBrick 1.3.1[2011-10-19 23:36:14] INFO ruby 1.9.2 (2011-07-09) [x86_64-linux][2011-10-19 23:36:14] INFO WEBrick::HTTPServer#start: pid=19595 port=3000

从上面输出中可以看到bson_ext库没有加载。按照提示安装该库即可(别忘了在gemfile中添加gem):

再次启动程序,Notice提示消息消失,启动正常。在浏览器输入:http://127.0.0.1:3000,就可以看到如下页面

4.添加页面和处理逻辑

通过rails的generate命令来生成页面、控制器和模型层文件(个人还是喜欢自己手动创建,这里为了演示方便)

rails generate scaffold project name:string --orm=mongo_mapper

由于我们使用mongo作为数据库。那么,我们需要把ActiveRecord的model,改成MongoMapper的类型,也就是把继承关系从ActiveRecord::Base变成MongoMapper::Document。我们使用key这个方法标明该MongoMapper的字段属性。我们的属性是name,再加上这个字段的类型String,那么定义如下:

classProject  include MongoMapper::Document  key:name,Stringend

通过以上的修改,我们就已经拥有了所有添加,更新,删除和列表的操作

5.数据查看

可以通过命令mongo进入mongodb数据库进行数据的查询

mongo //进入数据库use todo //切换库db.projects.find() //执行查询
6.其他

MongoMapper和ActiveRecord是完全相同的。甚至,MongoMapper还是支持ActiveRecord的验证方式如下

validates_presence_of:name

由于MongoDB没有schema-less(数据版本记录)我们可以非常容易的添加和更改model的属性,而不需要执行任何migrations的操作。比如,我们需要添加一个priority的属性,我们仅仅需要的是修改Project model如下:

classProject  include MongoMapper::Document  key:name,String,:required=>true  key:priority,Integerend

表之间的关联对于MongoDB这里稍微有点区别,我们需要ObjectId类型来存储所有id。

至于,处理不同表之前的关联,我们可以像ActiveRecord一样定义belongs_to,当然,稍微有点不同,在Project中我们需要定义has_many :tasks,在MongoMapper中需要用many代替。

我目前也就做到这里。有时间再去深入研究其他的功能。

PS:Ruby编写MongoDB备份脚本(fsync & lock)

#!/usr/local/bin/ruby# date:    06-12-2014# auther: lucifer# use fsync and lock to the file-system before backup the file-system# mongo-ruby-driver version > 1.10.0require 'mongo'require 'fileutils'require 'date'include Mongoinclude BSON# the members of replcation-set# test mongodb server version 2.6.0# host = "192.168.11.51"# The port of members# If the port is 27017 by default then otherport don't need to assignment# otherport = ""# port = otherport.length != 0 ? otherport : MongoClient::DEFAULT_PORT# opts = {:pool_size => 5, :pool_timeout => 10}# Create a new connection# client = MongoClient.new(host, port, opts)uri_string = "mongodb://caoqing:[email protected]:27017/admin"client = MongoClient.from_uri(uri = "#{uri_string}")db = client['admin']# fsync and lock the databasecmd = OrderedHash.newcmd[:fsync] = 1cmd[:lock] = true# p cmddb.command(cmd)# datafile pathd = "/var/lib/mongo"# dir = Dir.new("#{d}")# entries = dir.entries# entries.delete_if { |entry| entry =~ /^\./}# convert the relative path to the full path# entries.map! { |entry| File.join(dir.path, entry) }# maintain only the type of file# entries.delete_if { |entry| !File.file?(entry) }# p entriesstart = Date.today.to_sprev = (Date.today - 7).to_sdest = "/backup/#{start}"sour = "/backup/#{prev}"FileUtils.rm_rf("#{sour}") if File::exist?("#{sour}")Dir.mkdir("#{dest}", 0755) unless File::exist?("#{dest}")FileUtils.cp_r Dir.glob("#{d}/**"), dest if client.locked?puts "*" * 20puts "\tbackup complete"puts "*" * 20# DB::SYSTEM_COMMAND_COLLECTION# unlock the databasedb["$cmd.sys.unlock"].find_oneclient.close


  • 上一条:
    perl操作MongoDB报错undefined symbol: HeUTF8解决方法
    下一条:
    C#实现String字符串转化为SQL语句中的In后接的参数详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客