проблема установки пакета: отсутствует mysql.h - PullRequest
30 голосов
/ 07 мая 2011

в моем 32-разрядном Mac OSX 10.6 я могу установить gem mysql2 довольно легко, но не на 64-битный сервер mini mac 10.6.

Я установил MySQL 5.5.11 на проблемный сервер, в то время как на моем домашнем компьютере Mac MySQL 5.5.0.m2 Каким-то образом, когда я запускаю пакетную установку, на сервере он пытается установить mysql2.0.3.2, а дома - mysql2.0.2.6

Пожалуйста, не говорите мне

env ARCHFLAGS = "- arch x86_64" sudo gem install mysql2 --version '= 0.2.6' - --with-mysql-config = / usr / local / mysql / bin / mysql_config

Я пробовал это, не работает.

Включение / usr / local / mysql / bin в $ PATH также не помогает.

Код ошибки:

    Installing mysql2 (0.3.2) with native extensions /Users/administrator/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/installer.rb:533:in `rescue in block in build_extensions': ERROR: Failed to build gem native extension. (Gem::Installer::ExtensionBuildError)

        /Users/administrator/.rvm/rubies/ruby-1.9.2-p180/bin/ruby extconf.rb 
checking for rb_thread_blocking_region()... yes
checking for mysql.h... no
checking for mysql/mysql.h... no
-----
mysql.h is missing.  please check your installation of mysql and try again.
-----
*** 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=/Users/administrator/.rvm/rubies/ruby-1.9.2-p180/bin/ruby
    --with-mysql-config
    --without-mysql-config


Gem files will remain installed in /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/mysql2-0.3.2 for inspection.
Results logged to /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/mysql2-0.3.2/ext/mysql2/gem_make.out
    from /Users/administrator/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/installer.rb:511:in `block in build_extensions'
    from /Users/administrator/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/installer.rb:486:in `each'
    from /Users/administrator/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/installer.rb:486:in `build_extensions'
    from /Users/administrator/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/installer.rb:159:in `install'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/source.rb:96:in `install'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/installer.rb:55:in `block in run'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/spec_set.rb:12:in `block in each'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/spec_set.rb:12:in `each'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/spec_set.rb:12:in `each'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/installer.rb:44:in `run'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/installer.rb:8:in `install'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/cli.rb:225:in `install'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/vendor/thor/task.rb:22:in `run'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/vendor/thor/invocation.rb:118:in `invoke_task'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/vendor/thor.rb:246:in `dispatch'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/lib/bundler/vendor/thor/base.rb:389:in `start'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/gems/bundler-1.0.12/bin/bundle:13:in `<top (required)>'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/bin/bundle:19:in `load'
    from /Users/administrator/.rvm/gems/ruby-1.9.2-p180/bin/bundle:19:in `<main>'

Ответы [ 12 ]

91 голосов
/ 23 июня 2013

Я перепробовал все решения, размещенные здесь, но не повезло.Я пару раз переустанавливал mysql с homebrew и все равно не повезло.Затем я наткнулся на сообщение в блоге с решением.

Я отредактировал файл mysql_config в /usr/local/Cellar/mysql/5.6.12/bin и удалил параметры W-компилятора -Wno-null-conversion и -Wno-unused-private-field для cflags и cxxflags.

Это решило проблему с gem install mysql2 и bundle install

Ссылка: http://www.randomactsofsentience.com/2013/05/gem-install-mysql2-missing-mysqlh-on-os.html

29 голосов
/ 10 июня 2012

Я установил комплект на репозиторий Redmine и получил то же сообщение об ошибке:

mysql.h отсутствует.пожалуйста, проверьте вашу установку mysql и попробуйте снова.

Запуск Fedora 16 64 бит, все что я сделал, это установил mysql-devel (пакет разработки) из дистрибутива rpm и проблема была решена!

Так что я думаю, что вы можете просто

yum install mysql-devel

или apt-получить недостающий пакет devel.

8 голосов
/ 24 июля 2013

для людей, которые не использовали brew для установки mysql и используют mysql 5.6 и выше:

согласно этому ответу

вам нужно отредактировать mysql_configкоторый был помещен в моем случае здесь: /usr/local/mysql-5.6.12-osx10.7-x86_64/bin

и изменить cflags и cxxflags на:

cflags="-I$pkgincludedir  -Wall -Os -g -fno-strict-aliasing -DDBUG_OFF " #note: end space!
cxxflags="-I$pkgincludedir  -Wall -Os -g -fno-strict-aliasing -DDBUG_OFF " #note: end space!

после этой манипуляции

$ gem install mysql2 -v '0.3.13'

идетбезотказно

4 голосов
/ 27 сентября 2011

Ок, ребята, для меня решение было:

$ sudo brew install mysql

$ sudo env ARCHFLAGS="-arch i386" gem install mysql -- \
  --with-mysql-dir=/usr/local/mysql --with-mysql-lib=/usr/local/mysql/lib \
  --with-mysql-include=/usr/local/mysql/include

источник: http://wonko.com/post/how-to-install-the-mysqlruby-gem-on-mac-os-x-leopard

ИЛИ:

$sudo env ARCHFLAGS="-arch x86_64" gem install mysql -- \
  --with-mysql-dir=/usr/local/mysql --with-mysql-lib=/usr/local/mysql/lib \
  --with-mysql-include=/usr/local/mysql/include

Если ваша версия mysql 64Bits

После этого у меня было много проблем, потому что, если я хочу создать базу данных:

$: bundle exec rake db:reset

я получал эту ошибку:

dyld: lazy symbol binding failed: Symbol not found: _mysql_init
  Referenced from: /Users/workdreamer/Sites/cavortify/implementation/cavortify/mysql/ruby/1.8/gems/mysql-2.8.1/lib/mysql_api.bundle
  Expected in: flat namespace

dyld: Symbol not found: _mysql_init
  Referenced from: /Users/workdreamer/Sites/cavortify/implementation/cavortify/mysql/ruby/1.8/gems/mysql-2.8.1/lib/mysql_api.bundle
  Expected in: flat namespace

Решение: Вкл.ваш gemfile добавить: gem "ruby-mysql"

Хорошо, полтора дня, чтобы найти решение.

Хорошего дня!

2 голосов
/ 20 февраля 2012

Этот метод для Rails 3.1.0 (и, надеюсь, работает) на 64-битной машине. Я использовал на Ruby-1.9.2-p180.

Этот блог ответил на это: http://www.tatvartha.com/2010/10/installing-mysql-gem-with-bundler-on-snow-leopard/

В основном, метод выше: $ sudo env ARCHFLAGS = "- arch x86_64" gem install mysql - --with-mysql-config = / usr / local / mysql / bin / mysql_config

может работать, но без упаковщика.

Чтобы сделать это с помощью компоновщика, сначала необходимо запустить это на терминале:

bundle config build.mysql2 --with-mysql-config=/usr/local/mysql/bin/mysql_config

Обратите внимание, что «mysql2» не «mysql», как показано в этом блоге.

Это добавляет конфигурацию в файл ~ / .bundle / config

Затем добавьте это в ~ / .bash_profile:

export ARCHFLAGS="-arch x86_64"

То же самое с сообщением bundler о запуске команды в верхней части этого поста.

1 голос
/ 19 мая 2015

Для Мариадб:

sudo apt-get install libmariadbclient18 libmariadbclient-dev

Тогда

gem install mysql2

может быть успешно установлен.

1 голос
/ 14 мая 2013

Это сработало для меня на моем Mac OSX Lion:

sudo env ARCHFLAGS="-I/usr/local/include/mysql/mysql  -pipe -fPIC    -D_P1003_1B_VISIBLE -DSIGNAL_WITH_VIO_CLOSE -DSIGNALS_DONT_BREAK_READ -DIGNORE_SIGHUP_SIGQUIT  -DDONT_DECLARE_CXA_PURE_VIRTUAL" gem install mysql -- --with-mysql-dir=/usr/local/mysql --with-mysql-lib=/usr/local/lib/mysql/mysql --with-mysql-include=/usr/local/include/mysql/mysql --with-mysql-config=/usr/local/bin/mysql_config

Этот блог ответил на это .

1 голос
/ 24 апреля 2012

Единственный способ заставить это работать - это установить x64 версию mysql.Я просто использовал .dmg, расположенный здесь http://dev.mysql.com/downloads/mysql/, и он работал как шарм.Хотел бы я получить 4 часа назад, что потребовалось, чтобы понять это.

0 голосов
/ 07 марта 2015

Для тех, кто в Fedora 21, и вы уже установили mysql-devel:

yum install redhat-rpm-config

решил проблему для меня. увидеть: Redhat Docs

0 голосов
/ 18 октября 2013

Моя проблема была результатом первой установки MySql через загружаемый бинарный файл. Первоначально он был установлен в версии 5.5.28. Затем я попытался установить с помощью доморощенного. Заваривать установленную версию 5.6.x. ОДНАКО в процессе установки с помощью homebrew, символическая ссылка для / usr / local / mysql все еще указывала на 5.5.28.

Обновите символическую ссылку до версии, установленной через homebrew.

ex: / usr / local / mysql -> /usr/local/Cellar/mysql/5.6.13/

Это может быть только частью решения.

...