我目前正在尝试将一组包含数据的 JSON 文件导入我在 IBM Bluemix/Compose 上托管的 mongo 数据库。
我有一个脚本,它通过创建文件然后运行 mongoimport 命令将文件导入数据库,这对我的本地数据库(实际上偶尔对 Compose 数据库)非常有效,但是大多数时候我得到以下错误-
2017-05-09T14:59:02.508+0100 Failed: error connecting to db server: SSL errors: x509 certificate routines:X509_STORE_add_cert:cert already in hash table x509 certificate
2017-05-09T14:59:02.508+0100 imported 0 documents
我的 mongoimport 命令如下所示 -
mongoimport --batchSize 100 --ssl --sslAllowInvalidCertificates --host *censored* --collection Personnel --file data/TestData/Personnel_WICS.json -u admin -p *censored* -d MY_DB --authenticationDatabase admin
这是 mongoimport 错误吗?也许是 Compose 的问题?还是我对命令的操作不正确?
我应该注意到,我导入的文件大小在 3mb-100mb 之间,但即使通过拆分文件来减小较大的文件大小似乎也无济于事。
我的导入脚本在前一个导入命令完成后立即运行一个导入命令,像这样运行多个背靠背导入可能会出现问题吗?
最佳答案
对于将来发现此问题的任何人 - 看起来这可能是由于我正在运行 mongoimport 命令的机器与 compose 中托管的 mongo 数据库之间的 mongo 版本不匹配造成的。
编写数据库版本:3.2
构建服务器机器(运行 mongoimport):3.4
降级构建服务器版本已解决问题。
关于mongodb - Mongo导入错误: X509_STORE_add_cert:cert already in hash table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43872139/
我在事件管理员编辑页面中有嵌套资源,但我只想允许管理员编辑现有资源的内容,而不是添加新的嵌套资源。我的代码看起来像这样:formdo|f|f.inputsdof.input:authorf.input:contentf.has_many:commentsdo|comment_form|comment_form.input:contentcomment_form.input:_destroy,as::boolean,required:false,label:'Remove'endendf.actionsend但它在输入下添加了“添加新评论”按钮。我怎样才能禁用它,并只为主窗体保留f.ac
为了防止在迁移到生产站点期间出现数据库事务错误,我们遵循了https://github.com/LendingHome/zero_downtime_migrations中列出的建议。(具体由https://robots.thoughtbot.com/how-to-create-postgres-indexes-concurrently-in概述),但在特别大的表上创建索引期间,即使是索引创建的“并发”方法也会锁定表并导致该表上的任何ActiveRecord创建或更新导致各自的事务失败有PG::InFailedSqlTransaction异常。下面是我们运行Rails4.2(使用Acti
我曾经收到以下错误:OpenSSL::SSL::SSLError:SSL_connectreturned=1errno=0state=SSLv3readservercertificateB:certificateverifyfailedfromC:/Ruby1.9.2/lib/ruby/1.9.1/net/http.rb:678:in`connect'通读后this,我发现修复是从here下载cacert.pem文件.该帖子建议做这样的事情:ENV['SSL_CERT_FILE']=File.join(File.dirname(__FILE__),"cacert.pem")而且,确实,
ActiveRecordStore允许您在单个单元格内序列化参数。即classUser现在所有访问器都在用户表的“选项”列中序列化。u=User.newu.option2='someoption'u.option2#=>'someoption'这对我的应用程序非常有用,因为我必须每天创建许多表单,其中90%的表单是相同的(用户名、爱好、兴趣等),然后10%是无模式的(random_option_here,another_random_option_in_another_form)。我也永远不需要按无模式选项进行排序。我所做的是为90%的始终相同的表单字段创建了1个表,然后我有另一个表包
每当我实例化一个新的ActiveRecord模型(一个尚未持久化到数据库中的模型)并尝试访问构建模型上的一些各种关联时,Rails查询构建器有时会:将(1=0)谓词添加到查询的where子句。在select语句中添加“distinct”子句。我认为这只会在has_many:through关联连接两个或多个表时发生。我想知道为什么它添加了(1=0)谓词以及distinct子句。对于(1=0)谓词,新模型是否已保存到数据库应该无关紧要(对吧?)。我不知道为什么要添加distinct子句。我在下面有一个简单的例子。classAssignment#s.assignment_attachment
我在我的Rails应用程序中应用了rails_admingem。我想删除特定模型编辑表单中一些不必要的按钮,并添加我自己的自定义按钮。请查看屏幕截图,了解我要删除的内容。 最佳答案 @montells复制https://github.com/sferik/rails_admin/blob/master/app/views/rails_admin/main/_submit_buttons.html.haml这个页面在你的repo中,位于“views/rails_admin/main/_submit_buttons.html.haml”
我正在使用UbuntuServer10,Ruby1.9.2当我尝试要求'mongo'时它给我这个错误:irb(main):001:0>require'mongo'LoadError:nosuchfiletoload--opensslfrom/usr/local/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in`require'from/usr/local/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in`require'from/usr/local/lib
我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多
我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序
我正在尝试为像这样的ActiveRecord模型提供一组非常通用的命名范围:moduleScopesdefself.included(base)base.class_evaldonamed_scope:not_older_than,lambda{|interval|{:conditions=>["#{table_name}.created_at>=?",interval.ago]}endendendActiveRecord::Base.send(:include,Scopes)classUser如果命名范围应该是通用的,我们需要指定*table_name*以防止命名问题,如果它们是来自