Невозможно запустить сервер SOLR (Ruby on Rails) - PullRequest
2 голосов
/ 14 февраля 2011

Я использую sunspot_rails и sunspot gems в своем приложении Rails3 и следую инструкциям по установке sunspot на https://github.com/outoftime/sunspot, Я не могу запустить свой сервер sunspot.

Когда я вхожу в свой каталог, запускаю bundler, а затем запускаю rake sunspot: solr: start Я получаю следующую ошибку

Emil@Emil-PC /cygdrive/c/work/pilarhq
$ rake sunspot:solr:start
(in /cygdrive/c/work/pilarhq)
DEPRECATION WARNING: You are using the old router DSL which will be removed in R
ails 3.1. Please check how to update your routes file at: http://www.engineyard.
com/blog/2010/the-lowdown-on-routes-in-rails-3/. (called from /cygdrive/c/work/p
ilarhq/config/routes.rb:1)
      2 [main] ruby 4824 C:\cygwin\bin\ruby.exe: *** fatal error - unable to rem
ap C:\cygwin\bin\cyglber-2-3-0.dll to same address as parent: 0x360000 != 0x3800
00
Stack trace:
Frame     Function  Args
023F9538  6102749B  (023F9538, 00000000, 00000000, 00000000)
023F9828  6102749B  (61177B80, 00008000, 00000000, 61179977)
023FA858  61004AFB  (611A136C, 6123FF54, 00360000, 00380000)
End of stack trace
      2 [main] ruby 4500 C:\cygwin\bin\ruby.exe: *** fatal error - unable to rem
ap C:\cygwin\bin\cyglber-2-3-0.dll to same address as parent: 0x360000 != 0x3E00
00
Stack trace:
Frame     Function  Args
023FB0F8  6102749B  (023FB0F8, 00000000, 00000000, 00000000)
023FB3E8  6102749B  (61177B80, 00008000, 00000000, 61179977)
023FC418  61004AFB  (611A136C, 6123FF54, 00360000, 003E0000)
End of stack trace
      2 [main] ruby 4612 fork: child 4824 - died waiting for dll loading, errno
11
      4 [main] ruby 580 fork: child 4500 - died waiting for dll loading, errno 1
1
/usr/lib/ruby/gems/1.8/gems/sunspot-1.2.0/lib/sunspot/server.rb:42:in `fork': Re
source temporarily unavailable - fork(2) (rake aborted!Errno::EAGAIN)

Resource temporarily unavailable - fork(2)      from /usr/lib/ruby/gems/1.8/gems
/sunspot-1.2.0/lib/sunspot/server.rb:42:in `start'
$
in `fork'
        from /usr/lib/ruby/gems/1.8/gems/sunspot-1.2.0/lib/sunspot/server.rb:41:
in `start'
        from /usr/lib/ruby/gems/1.8/gems/sunspot_rails-1.2.0/lib/sunspot/rails/s
erver.rb:10:in `start'
        from /usr/lib/ruby/gems/1.8/gems/sunspot_rails-1.2.0/lib/sunspot/rails/t
asks.rb:8
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:636:in `call'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:636:in `execute'

        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:631:in `each'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:631:in `execute'

        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:597:in `invoke_w
ith_call_chain'
        from /usr/lib/ruby/1.8/monitor.rb:242:in `synchronize'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:590:in `invoke_w
ith_call_chain'ygdrive/c/work/pilarhq
$       from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:583:in `invoke'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2051:in `invoke_
task'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2029:in `top_lev
el'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2029:in `each'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2029:in `top_lev
el'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2068:in `standar
d_exception_handling'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2023:in `top_lev
el'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2001:in `run'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:2068:in `standar
d_exception_handling'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:1998:in `run'
        from /usr/lib/ruby/gems/1.8/gems/rake-0.8.7/bin/rake:31
        from /usr/bin/rake:19:in `load'
        from /usr/bin/rake:19

(я использую Cygwin намашина Windows ... если это поможет)

Ответы [ 2 ]

3 голосов
/ 05 мая 2011

Я нашел http://www.garethhunt.com/2008/02/11/cygwin-died-waiting-for-dll-loading/ и должен был сделать следующее:

  1. закрыть все окна Cygwin
  2. вызов c: \ cygwin \ usr \ bin \ ash из Run (Win-R)
  3. звоните rebaseall оттуда
2 голосов
/ 06 июля 2011

Я столкнулся с чем-то похожим (Windows 7 enterprise, используя cygwin и rails) и обнаружил, что простой подход rebaseall не работает.Короче говоря, проблема в том, что rebaseall не обязательно знает все .dll и .so, которые он должен исправить.Решение состоит в том, чтобы создать свой собственный список и запустить rebaseall для этого списка, используя опцию -T.Для меня окончательно сработал процесс:

  1. в оболочке cygwin: find /bin /lib /usr -iname '*.so' > /tmp/to_rebase.lst
  2. в оболочке cygwin: find /bin /lib /usr -iname '*.dll' >> /tmp/to_rebase.lst
  3. выход из всех cygwinобстреливает и останавливает все процессы cygwin
  4. запускается от имени администратора C: \ cygwin \ bin \ ash.exe
  5. /bin/rebaseall -T /tmp/to_rebase.lst
  6. exit ash
  7. перезагрузите компьютер
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...