Ruby 2.6.5和PostgreSQL pg-gem分段错误

时间:2019-11-28 13:28:48

标签: ruby postgresql ruby-on-rails-6

在控制台上,我无法执行任何涉及数据库的操作。我遇到了细分错误。

.rbenv/versions/2.6.5/lib/ruby/gems/2.6.0/gems/pg-1.1.4/lib/pg.rb:56: [BUG] Segmentation fault at 0x0000000000000110 ruby 2.6.5p114 (2019-10-01 revision 67812) [x86_64-darwin18]

这实际上是可能需要数据库的任何操作,包括MyModel.new。

-- Control frame information ----------------------------------------------- c:0071 p:---- s:0406 e:000405 CFUNC :initialize c:0070 p:---- s:0403 e:000402 CFUNC :new c:0069 p:0016 s:0398 e:000397 METHOD /Users/xxx/.rbenv/versions/2.6.5/lib/ruby/gems/2.6.0/gems/pg-1.1.4/lib/pg.rb:56 c:0068 p:0107 s:0393 e:000392 METHOD /Users/xxx/.rbenv/versions/2.6.5/lib/ruby/gems/2.6.0/gems/activerecord-6.0.1/lib/active_record/connection_adapters/postgres

我已经卸载并重新安装了pg gem。并重建数据库。并重新启动PostgreSQL。

我看到其他人在Puma下运行时报告了该问题,但是我的配置在Puma下运行,在控制台下失败了!

为清楚起见进行编辑:

是的,使用捆绑器。

使用rails cbundle exec rails c启动rails控制台具有相同的堆栈跟踪效果(段错误)。

Gemfile.lock具有pg (1.1.4)

我重新捆绑,指定捆绑路径。现在,堆栈跟踪具有该捆绑软件路径,因此我猜默认情况下捆绑软件使用的是rbenv路径。

1 个答案:

答案 0 :(得分:9)

根据问题的注释部分中链接的https://github.com/ged/ruby-pg/issues/291,将gssencmode: disable添加到database.yml可以停止分段错误。我仅在developmenttest环境选项下添加了它,因为我不在其他环境中使用OS X:

default: &default
  adapter: postgresql

development:
  <<: *default
  gssencmode: disable
test:
  <<: *default
  gssencmode: disable

gssencmode已在Postgresql 12中添加:

  

gssencmode

     

此选项确定是否与服务器协商安全GSS TCP / IP连接的优先级。

这里跟踪了潜在的错误https://www.postgresql.org/message-id/93f7379b-2e2f-db0c-980e-07ebd5de92ff%40crunchydata.com