Соединение с БД Oracle на Ruby on Rails
Моя основная база данных - это локальная база данных mysql, однако я бы хотел иногда подключаться к базе данных Oracle непосредственно в коде моих приложений.
База данных oracle размещена на другом сервере RHEL.
Я неудачно попытался установить гем ruby-OCI8 (ОШИБКА: не удалось создать собственное расширение гема).
Мне интересно, должна ли база данных oracle быть локальной, чтобы использовать этот драгоценный камень, или есть ли более эффективные способы достижения этого.
gem install ruby-oci8
Building native extensions. This could take a while...
ERROR: Error installing ruby-oci8:
ERROR: Failed to build gem native extension.
/usr/bin/ruby extconf.rb
checking for load library path...
LD_LIBRARY_PATH...
checking /opt/instantclient... yes
/opt/instantclient/libclntsh.so.11.1 looks like an instant client.
checking for cc... *** extconf.rb failed ***
Could not create Makefile due to some reason, probably lack of
necessary libraries and/or headers. Check the mkmf.log file for more
details. You may need configuration options.
Provided configuration options:
--with-opt-dir
--without-opt-dir
--with-opt-include
--without-opt-include=${opt-dir}/include
--with-opt-lib
--without-opt-lib=${opt-dir}/lib
--with-make-prog
--without-make-prog
--srcdir=.
--curdir
--ruby=/usr/bin/ruby
--with-instant-client
--without-instant-client
./oraconf.rb:562:in `check_cc': RuntimeError (RuntimeError)
from ./oraconf.rb:549:in `init'
from ./oraconf.rb:1001:in `initialize'
from ./oraconf.rb:343:in `new'
from ./oraconf.rb:343:in `get'
from extconf.rb:18
ng
---------------------------------------------------
Error Message:
C compiler doesn't work correctly.
Backtrace:
./oraconf.rb:562:in `check_cc'
./oraconf.rb:549:in `init'
./oraconf.rb:1001:in `initialize'
./oraconf.rb:343:in `new'
./oraconf.rb:343:in `get'
extconf.rb:18
---------------------------------------------------
See:
* http://ruby-oci8.rubyforge.org/en/HowToInstall.html
* http://ruby-oci8.rubyforge.org/en/ReportInstallProblem.html
Я проверил файл mkmf.log:
"gcc -o conftest -I. -I/usr/lib64/ruby/1.8/x86_64-linux -I. -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fs tack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -fno-strict-aliasing -fPIC conftest.c -L. -L/usr/lib64 -L. -rdynamic -Wl,-export-dynamic -lruby-static -lpthread -lrt -ldl -lcrypt -lm -lc"
/usr/bin/ld: skipping incompatible /usr/lib/libruby-static.a when searching for -lruby-static
/usr/bin/ld: cannot find -lruby-static
collect2: ld returned 1 exit status
checked program was:
/* begin */
1: int main() { return 0; }
8 /* end */
3 ответа
Сначала вам нужно установить Oracle Instant Client - выбрать соответствующие 32-битные или 64-битные бинарные файлы Linux. Для безопасности используйте старую версию 10.2.0.4, которую я использую во всех своих проектах Ruby и Oracle. Установите пакеты Basic, SDK и SQL*Plus.
Затем включите каталог установки Oracle Instant Client в переменную среды LD_LIBRARY_PATH, чтобы динамические библиотеки Oracle Instant Client находились в пути загрузки.
Затем попробуйте установить гем ruby-oci8.
После этого установите гем activerecord-oracle_enhanced-adapter для доступа к базе данных Oracle из ActiveRecord.
Я опубликовал инструкции по установке ruby-oci8 на Mac OS X - большинство из этого относится и к Linux (DYLD_LIBRARY_PATH на Mac соответствует LD_LIBRARY_PATH на Linux).
Кроме того, я создал рецепт Sprinkle для автоматической установки клиента Oracle в Linux - возможно, это не лучший способ начать с этого, но в случае, если вы хотите создать сценарии автоматической установки сервера, вы можете взглянуть на него.
Вы можете установить гем ruby-oci8, как показано ниже,
LD_LIBRARY_PATH = / local / home / soundar / instantclient_11_2 gem install ruby-oci8
Примечание: LD_LIBRARY_PATH - это переменная окружения, устанавливаемая путем к каталогу клиента Oracle.
Посмотрите, поможет ли это сообщение в блоге пройти установку драгоценного камня OCI http://jessehu.wordpress.com/2008/07/03/ruby-oci8-gem-available-2/