2016-11-13 7 views
1

Synology DiskStation DS216j에서 Ruby 스크립트를 실행하려고합니다. 나는 성공적 OPKG/Entware-ng를 통해 루비 2.3.1를 설치하는 관리하지만 기본 확장명을 가진 보석을 설치하려고하면 오류가 발생합니다 :Synology DiskStation DS216j에 Ruby gem을 설치하려고하는데 Ruby 헤더 파일을 찾을 수 없습니다.

$ sudo gem install io-console 

Building native extensions. This could take a while... 
ERROR: Error installing io-console: 
    ERROR: Failed to build gem native extension. 

    current directory: /volume1/@entware-ng/opt/lib/ruby/gems/2.3/gems/io-console-0.4.6 
/opt/bin/ruby -r ./siteconf20161113-31591-ucvjgl.rb extconf.rb 
*** 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=/opt/bin/$(RUBY_BASE_NAME) 
/opt/lib/ruby/2.3/mkmf.rb:456:in `try_do': The compiler failed to generate an executable file. (RuntimeError) 
You have to install development tools first. 
    from /opt/lib/ruby/2.3/mkmf.rb:571:in `block in try_compile' 
    from /opt/lib/ruby/2.3/mkmf.rb:524:in `with_werror' 
    from /opt/lib/ruby/2.3/mkmf.rb:571:in `try_compile' 
    from /opt/lib/ruby/2.3/mkmf.rb:835:in `macro_defined?' 
    from extconf.rb:7:in `<main>' 

To see why this extension failed to compile, please check the mkmf.log which can be found here: 

    /opt/lib/ruby/gems/2.3/extensions/arm-linux/2.3/io-console-0.4.6/mkmf.log 

extconf failed, exit code 1 

Gem files will remain installed in /opt/lib/ruby/gems/2.3/gems/io-console-0.4.6 for inspection. 
Results logged to /opt/lib/ruby/gems/2.3/extensions/arm-linux/2.3/io-console-0.4.6/gem_make.out 

/opt/lib/ruby/gems/2.3/extensions/arm-linux/2.3/io-console-0.4.6/mkmf.log의 내용 :

"arm-openwrt-linux-gnueabi-gcc -o conftest -I/opt/include/ruby-2.3/arm-linux-gnu -I/opt/include/ruby-2.3/ruby/backward -I/opt/include/ruby-2.3 -I. -I/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/include -I/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/include -I/media/ware3/Entware-ng.2016.08/staging_dir/toolchain-arm_cortex-a9_gcc-5.4.0_glibc-2.23_eabi/usr/include -I/media/ware3/Entware-ng.2016.08/staging_dir/toolchain-arm_cortex-a9_gcc-5.4.0_glibc-2.23_eabi/include -I/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libiconv-full/include -I/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libintl-full/include -D_FILE_OFFSET_BITS=64 -O2 -pipe -march=armv7-a -mtune=cortex-a9 -fno-caller-saves -fhonour-copts -Wno-error=unused-but-set-variable -Wno-error=unused-result -mfloat-abi=soft -I/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libiconv-full/include -I/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libintl-full/include -fPIC conftest.c -L. -L/opt/lib -L. -L/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib -L/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/lib -Wl,-rpath,/opt/lib -Wl,-rpath-link=/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib -Wl,--dynamic-linker=/opt/lib/ld-linux.so.3 -L/media/ware3/Entware-ng.2016.08/staging_dir/toolchain-arm_cortex-a9_gcc-5.4.0_glibc-2.23_eabi/usr/lib -L/media/ware3/Entware-ng.2016.08/staging_dir/toolchain-arm_cortex-a9_gcc-5.4.0_glibc-2.23_eabi/lib -L/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libiconv-full/lib -Wl,-rpath-link=/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libiconv-full/lib -L/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libintl-full/lib -Wl,-rpath-link=/media/ware3/Entware-ng.2016.08/staging_dir/target-arm_cortex-a9_glibc-2.23_eabi/opt/lib/libintl-full/lib -L/media/ware3/Entware-ng.2016.08/build_dir/target-arm_cortex-a9_glibc-2.23_eabi/ruby-2.3.1 -fstack-protector -rdynamic -Wl,-export-dynamic  -lruby -lpthread -lgmp -ldl -lcrypt -lm -lc" 
/opt/bin/ld: cannot find -lruby 
collect2: error: ld returned 1 exit status 
checked program was: 
/* begin */ 
1: #include "ruby.h" 
2: 
3: int main(int argc, char **argv) 
4: { 
5: return 0; 
6: } 
/* end */ 

/opt/bin/ld: cannot find -lruby이 될 것으로 보인다 여기 진짜 실수.

인터넷 검색이 루비 소스 코드/헤더 which I did를 설치 권장 결과 :

$ wget -qO- http://pkg.entware.net/binaries/armv7/include/include.tar.gz | tar xvz -C /opt/include 

[snip] 

$ ls -lah /opt/include/ruby-2.3/ 

drwxr-xr-x 4 1000  1000  4.0K Aug 19 12:42 . 
drwxr-xr-x 179 root  root  20.0K Oct 10 09:32 .. 
drwxr-xr-x 3 1000  1000  4.0K Aug 19 12:42 arm-linux-gnu 
drwxr-xr-x 3 1000  1000  4.0K Aug 19 12:42 ruby 
-rw-r--r-- 1 1000  1000   868 Jul 11 2012 ruby.h 

그래서 나는 진짜 문제는 추측 : 어떻게 루비 헤더 파일이 /opt/include/ruby-2.3/에 있다고 /opt/bin/ld을 알 수 있습니까?

감사합니다. 감사합니다.

답변

1

/opt/bin/ld: cannot find -lruby은 링커가 헤더가 아닌 Ruby 라이브러리을 찾을 수 없다는 것을 의미합니다. /opt/lib/libruby.so 또는 정적 라이브러리 /opt/lib/libruby-static.a에 컴파일 된 공유 오브젝트 라이브러리가 필요합니다.

+0

할렐루야! 그것은 효과가있다! '/ opt/lib/libruby.so.2.3.0'을 사용했기 때문에'/ opt/lib/libruby.so' 파일과 심볼릭 링크를 해 주었고 성공적으로 gem을 설치할 수있었습니다! 정말 고마워!! :) –