-
Notifications
You must be signed in to change notification settings - Fork 302
Troubleshooting
Having a problem when installing or using RubyInstaller? Life is full of glitches and details, we all know that.
Here you'll find a list of the common issues some users have experienced and some guidance to help solve them. Please feel free to add your own experiences and resolutions!
For further help, refer to the RubyInstaller mailing list
[[TOC]]
By default, RubyInstaller will not alter the PATH
used by the system to
find applications/executables. This is done to avoid messing with your
installation.
If you want this particular version of Ruby be available everywhere, you will need to select the correct option during installation:
Note: Please remember this option will only affect new Command Prompt windows and not existing ones. Close any window you have open first.
We discovered that under some scenarios, users that previously had Cygwin installed in the system are affected during installation of gems that require compilation.
Please check that no leftover of your cygwin install remains in your home
directory, specially any .bash_profile
or .bashrc
file.
You can read more about this issue on this thread
There has been reports of users unable to install any gem unless UAC is disabled or the command prompt is executed as Administrator.
Users facing this issue are Windows 7 Ultimate (32bits) that in the majority upgraded from previous Release Candidate to RTM versions.
Microsoft's KB970789 might provide some details (under the manual section) to fix the issue.
Another alternative, while radical, is format the NTFS harddrive where Ruby is installed.
This is not a Ruby or RubyInstaller issue but instead one from incorrect filesystem permissions.
Another source of this issue could be the installation of either Cygwin or E-Text Editor, as described here and better findings here
Looks like @VirtualStore@ folder looses the proper permissions and is locking out any 32bits application running on Windows x64 bits due the automatic file redirection.
Just re-run the DevKit installation, using the --force
switch if necessary
to restore DevKit functionality.
There might be lot of reasons why it could fail. Either the gem require compilation, which means the installation of Development Kit, the gem is not compatible with the platform (see Gem List for compatibility) or there is another unknown error.
When installing a gem, if it fail, please take a closer look to the output
of gem env
command:
RubyGems Environment:
- RUBYGEMS VERSION: 1.3.5
- RUBY VERSION: 1.8.7 (2010-01-10 patchlevel 249) [i386-mingw32]
- INSTALLATION DIRECTORY: C:/Ruby187/lib/ruby/gems/1.8
- RUBY EXECUTABLE: C:/Ruby187/bin/ruby.exe
- EXECUTABLE DIRECTORY: C:/Ruby187/bin
- RUBYGEMS PLATFORMS:
- ruby
- x86-mingw32
- GEM PATHS:
- C:/Ruby187/lib/ruby/gems/1.8
- C:/Users/Luis/.gem/ruby/1.8
- GEM CONFIGURATION:
- :update_sources => true
- :verbose => true
- :benchmark => false
- :backtrace => false
- :bulk_threshold => 1000
- :sources => ["http://rubygems.org"]
- "install" => "--no-ri --no-rdoc --env-shebang"
- "update" => "--no-ri --no-rdoc --env-shebang"
- REMOTE SOURCES:
- http://rubygems.org
Specially, pay attention to INSTALLATION DIRECTORY
and GEM PATH
If you notice those directories contain spaces, it might be because you installed Ruby in a folder with spaces (highly not recommended) or because another environment variable in your system is interfering. Directories with spaces often cause problems for the DevKit's GCC compiler.
For example, when trying to smoke test the DevKit install by trying to
install the rdiscount gem, investigation of the mkmf.log
file shows that
GCC can't find files required to build if Ruby is installed to a directory
containing spaces (C:\bad ruby192
in this example):
# file: C:\bad ruby192\lib\ruby\gems\1.9.1\gems\rdiscount-1.6.8\ext\mkmf.log
"gcc -o conftest -IC:/bad ruby192/include/ruby-1.9.1/i386-mingw32 -I"C:/bad ruby192/include/ruby-1.9.1"/ruby/backward
-I"C:/bad ruby192/include/ruby-1.9.1" -I. -O3 -g -Wextra -Wno-unused-parameter -Wno-parentheses -Wpointer-arith
-Wwrite-strings -Wno-missing-field-initializers -Wno-long-long conftest.c -L. -LC:/bad ruby192/lib -L.
-lmsvcrt-ruby191-static -lshell32 -lws2_32 "
gcc: error: ruby192/include/ruby-1.9.1/i386-mingw32: No such file or directory
gcc: error: ruby192/lib: No such file or directory
checked program was:
/* begin */
1: #include "ruby.h"
2:
3: #include <winsock2.h>
4: #include <windows.h>
5: int main() {return 0;}
/* end */
Also check that HOME
variable is actually pointing to your home folder.
Use GEM_HOME
and GEM_PATH
to alter where RubyGems install gems, read
their docs here
See another example of this issue here
To be able to install and compile certain RubyGems with RubyInstaller, you need to have the Development Kit installed. While the DevKit is based on MinGW and MSYS, it is not recommended use a different version than the one provided by RubyInstaller Team.
Do not confuse MSYS with Cygwin. While Cygwin contains GCC, make and other tools also available in the Development Kit, is not the same and having it in the @PATH@ will interfere with the correct behavior of RubyInstaller.
At all times avoid having cygwin in your PATH when working with RubyInstaller and the Development Kit.
Under certain versions of Windows Vista, you might find unable to compile gems even after correct installation of RubyInstaller and the DevKit.
If you receive this message:
C:/Ruby192/lib/ruby/1.9.1/mkmf.rb:368:in `try_do': The complier failed
to generate an executable file. (RuntimeError)
You have to install development tools first.
And you dig into mkmf.log
(found inside the gem directory) you will see
something like this:
"gcc -o conftest -IC:/Ruby192/include/ruby-1.9.1/i386-mingw32 -IC:/Ruby192/include/ruby-1.9.1/ruby/backward
-IC:/Ruby192/include/ruby-1.9.1 -I. -O3 -g -Wextra -Wno-unused-parameter -Wno-parentheses -Wpointer-arith
-Wwrite-strings -Wno-missing-field-initializers -Wno-long-long conftest.c -L. -LC:/Ruby192/lib -L.
-lmsvcrt-ruby191-static -lshell32 -lws2_32 "
gcc: CreateProcess: No such file or directory
Which indicates an error of GCC to invoke one of it's internal processes.
A simple workaround to this issue will be add an special directory to the
PATH
, like this:
C:\>SET PATH=%PATH%;C:\DevKit\mingw\libexec\gcc\mingw32\4.5.1
Please adjust C:\DevKit
accordingly to your DevKit installation directory
and 4.5.1
to the version of the DevKit you installed (e.g. 3.4.5, 4.5.1).
This is a known bug of GCC on Windows Vista and a request for better message already existfor MinGW project.
You can find all the details of this issue on our group here.
You've installed both RubyInstaller and DevKit following Development-Kit but during gem installation, you receive a message like this:
C:\devkit>gem install rdiscount --platform=ruby
Temporarily enhancing PATH to include DevKit...
Building native extensions. This could take a while...
ERROR: Error installing rdiscount:
ERROR: Failed to build gem native extension.
C:/ruby/bin/ruby.exe extconf.rb
C:/ruby/bin/ruby.exe: No such file or directory -- extconf.rb
(LoadError)
Or sometimes just this:
ERROR: Error installing rdiscount:
ERROR: Failed to build gem native extension.
C:/Ruby187/bin/ruby.exe extconf.rb
This has been reported to our group here and here.
After a long back and forth investigation, we found two possible causes for
this issue: COMSPEC
environment variable (scenario A) and AutoRun
registry setting (scenario B), both described below:
Using a command prompt, invoke the following command:
SET COMSPEC
The default output of that should look like:
ComSpec=C:\Windows\system32\cmd.exe
If in the output includes something different than cmd.exe
as executable,
then please adjust it to use cmd.exe
. Please note that the variable must
contain a full path to the cmd.exe
executable and relative paths will fail.
Some tools might change your command processor command, which interferes with Ruby invoking child processes.
The non-processed variable (that you will find inside System Properties -
Environment variables) is: %SystemRoot%\system32\cmd.exe
Change that and try to install the gem again.
If the problem persist, invoke the following commands in the same command prompt:
REG QUERY "HKCU\Software\Microsoft\Command Processor" /s
REG QUERY "HKLM\Software\Microsoft\Command Processor" /s
REG QUERY "HKCU\Software\Wow6432Node\Microsoft\Command Processor" /s
REG QUERY "HKLM\Software\Wow6432Node\Microsoft\Command Processor" /s
Execute each line individually. Once you run it, will see something like this:
HKEY_CURRENT_USER\Software\Microsoft\Command Processor
CompletionChar REG_DWORD 0x9
DefaultColor REG_DWORD 0x0
EnableExtensions REG_DWORD 0x1
PathCompletionChar REG_DWORD 0x9
The columns of information are Key, Type and Value. If you see a key
named AutoRun
, there is a chance this is the culprit of the error you're
receiving.
AutoRun
interferes with Ruby messing with child process executing and by
result, affecting gem installation. Please remove it with the following command:
REG DELETE "HKCU\Software\Microsoft\Command Processor" /v AutoRun
Once you're done, try opening a new command prompt and executing gem installation again.
Under certain versions of Windows, specially on Server editions, you might
encounter that Ruby generates random segfaults attempting to use extensions
like zlib
or openssl
, which are normal when using RubyGems.
Symptom: invoking gem install
will produce something like the following:
C:\Users\sysadmin>gem install mysql
C:/Ruby186/lib/ruby/1.8/i386-mingw32/openssl.so: [BUG] Segmentation fault
ruby 1.8.6 (2010-02-04) [i386-mingw32]
If that is the case, DEP(Data Execution Prevention) might be interfering with Ruby extension loading mechanism. DEP is on by default in the Server editions of Windows.
This is covered by KB875352 which provides you details on different modes of execution.
At this time, Ruby executable needs to be added to DEP exclusion list for it to work properly. Please see your Operating System documentation (or the above Knowledge Base article).
An attempt to bundle install
an application can throw an error like the
following:
C:/Dev/Ruby193/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require': 193: %1 is not a valid Win32 application. - C:/Dev/Ruby193/lib/ruby/1.9.1/i386-mingw32/digest/sha1.so (LoadError)
from C:/Dev/Ruby193/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler/definition.rb:1:in `<top (required)>'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler.rb:138:in `definition'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler/cli.rb:219:in `install'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler/vendor/thor/task.rb:22:in `run'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler/vendor/thor/invocation.rb:118:in `invoke_task'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler/vendor/thor.rb:263:in `dispatch'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/lib/bundler/vendor/thor/base.rb:386:in `start'
from C:/Dev/Ruby193/lib/ruby/gems/1.9.1/gems/bundler-1.0.22/bin/bundle:13:in `<top (required)>'
from C:/Dev/Ruby193/bin/bundle:19:in `load'
from C:/Dev/Ruby193/bin/bundle:19:in `<main>'
Which seems to be synthesized as:
require "bundler"
require "digest/sha1"
puts Digest::SHA1.hexdigest('Test')
After investigation, having tools that alter loading DLLs (like FRAPS or Detours) can affect loading Ruby's extensions.
It is recommended you disable/uninstall FRAPS.
This has been reported as Issue #102
This issue normally happens under 64bits editions of Windows with 64bits installations of MySQL server (5.0, 5.1 or 5.5)
RubyInstaller, at this time is provided only in 32bits, meaning that it
cannot link or use 64bits libraries like libmysql.dll
present in a 64bits
installation of MySQL.
To workaround this issue, you need to download a 32bits version of these libraries and use them during gem installation:
gem install mysql --platform=ruby -- --with-mysql-include=X:\include --with-mysql-lib=X:\lib\opt
Where X:\
needs to be replaced with a path without spaces where the
32bits version of MySQL was extracted. --platform=ruby
will force the
compilation and avoid the installation of the binary version of the gem.
Remember to uninstall any previous version using gem uninstall mysql --all
before.
If you can't find a 32bits version of MySQL, I recommend you download
MySQL Connector/C, which is an
independent version of libmysql.dll
that do not tie you to a version
specific MySQL API.
Once compiled and installed, copy libmysql.dll
from lib
into your Ruby's
bin
directory.
You can find a complete walk-through of both MySQL Server installation and the gem installation on this post
Setup:
- Windows 7
- Users home directory is set to a mapped network drive (e.g. H: is mapped to a network drive, environment variable HOMEDRIVE=H:)
- The network drive is not currently accessible (such as only being accessible on a company network)
- Fresh install of RailsInstaller 2.0.0
Symptoms:
Upon creating an application rails new MYAPP
, the last step bundle install
fails with the following error message:
C:/Ruby/.../rubygems/spec_fetcher.rb:54:in `stat': No such file or directory - H:/ (Errno::ENOENT)
from C:/Ruby/.../rubygems/spec_fetcher.rb:54:in `initialize'
Or when doing simple gem install GEMNAME
with the following message:
ERROR: While executing gem ... (Errno::EINVAL)
Invalid argument - H:/</pre>
Cause:
If HOME
environment variable is not set, Ruby tries to use a combination
of HOMEDRIVE
and HOMEPATH
(e.g. the unaccessible network drive) and fails.
Workaround:
On the command line, execute SET HOME=%USERPROFILE%
, which will tell Ruby
to use your user profile directory (C:\Users\xyz) as the home directory.
Native gem installations may fail due to a system's existing DLLs conflicting with the DevKit's integrated DLLs. For example, after installing the DevKit you may try to natively compile the @rdiscount@ gem as described in the DevKit tutorial and see an error similar to the following:
C:\Users\user>gem install rdiscount --platform=ruby
Building native extensions. This could take a while...
ERROR: Error installing rdiscount:
ERROR: Failed to build gem native extension.
C:/Ruby192/bin/ruby.exe extconf.rb
checking for random()... *** 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.
...
C:/Ruby192/lib/ruby/1.9.1/mkmf.rb:368:in `try_do': The compiler failed to generate an executable file. (RuntimeError)
You have to install development tools first.
from C:/Ruby192/lib/ruby/1.9.1/mkmf.rb:435:in `try_link0'
from C:/Ruby192/lib/ruby/1.9.1/mkmf.rb:440:in `try_link'
from C:/Ruby192/lib/ruby/1.9.1/mkmf.rb:552:in `try_func'
...
If you attempt to install rdiscount
from the Command Prompt (as opposed to
PowerShell) you may also see this error directly before the previously
mentioned gem installation failure:
as.exe - Entry Point Not Found
The procedure entry point libiconv_set_relocation_prefix could not be
located in the dynamic link library libiconv-2.dll
This failure is due to the native gem compile/install process using a version
of libiconv-2.dll
other than the one integrated into the DevKit due to how
Windows searches for DLLs. More information on the order in which Windows chooses DLLs.
This can be worked around by searching your computer for the file
libiconv-2.dll
and renaming, deleting, or otherwise moving any found
instances out of the way and re-running the native gem install process. At
least one user has reported
finding a duplicate libiconv-2.dll
DLL in the C:\Windows\SysWOW64
directory when attempting to install rdiscount
on Windows 7 64bit.
It is recommended that if you don't know why or what put the libiconv-2.dll
file in the directory in which you found it, that you move it back after you
compile whatever gems you need. This will possibly prevent other applications
from breaking.
Ruby 2.0.0 and newer requires a newer DevKit (as described in the downloads page).
This DevKit has been prepared for processors capable of newer set of instructions (called Nocona found since Pentium 4 processors)
This could be your case if you encounter output similar to the following when inspecting gem installation failures:
conftest.c:1:0: internal compiler error: Illegal instruction
Please submit a full bug report, with preprocessed source if appropriate.
See <mingw-w64-public@lists.sourceforge.net> for instructions.
If your computer is older than the minimum requirement, you will need to build your own version of DevKit (following these instructions) and Ruby to match the support on your system.
References: headius/ruby-atomic#36 and RubyInstaller thread
On Windows 7, running ./configure
in the MinGW terminal gave several of
the following errors:
checking size of uint32_t... rm: cannot lstat `conftest.exe': Permission denied
0
Cause:
This is caused by background locking/activity on the files being created.
./configure
phase generates a lot of conftest.exe files and quickly
removes it.
Solutions:
This issue happens when Application Experience Service is disabled on a Windows 7 installation.
See this page for further details.
It is recommended you enable Application Experience Service.
If you have a slow or aggressive antivirus software running, disable your
antivirus software and use rake ruby19
from a plain cmd.exe
.
Place all temporary files on RAMdisk, thus avoiding locking issues of spinning disks.