質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.20%

mastdonをFreeBSDにインストールしたらエラーが出る

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,450
退会済みユーザー

退会済みユーザー

FreeBSDにmastdonを入れたらエラーが出る

参考サイト

http://qiita.com/bezeklik/items/1a8530d530613acd665c

求む解決方法

コマンドライン(sed等)で修正できること

エラーメッセージ

以下の部分がすべてです。

Gem::Ext::BuildError: ERROR: Failed to build gem native extension.

current directory:
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/bootsnap-0.2.14/ext/bootsnap
/usr/local/bin/ruby24 -r ./siteconf20170525-13026-1ifyvot.rb extconf.rb
creating Makefile

current directory:
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/bootsnap-0.2.14/ext/bootsnap
make "DESTDIR=" clean

current directory:
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/bootsnap-0.2.14/ext/bootsnap
make "DESTDIR="
compiling bootsnap.c
bootsnap.c:3:10: fatal error: 'sys/xattr.h' file not found
#include <sys/xattr.h>
         ^
1 error generated.
*** Error code 1

Stop.
make: stopped in
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/bootsnap-0.2.14/ext/bootsnap

make failed, exit code 1

Gem files will remain installed in
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/bootsnap-0.2.14 for
inspection.
Results logged to
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/extensions/amd64-freebsd-10/2.4/bootsnap-0.2.14/gem_make.out

An error occurred while installing bootsnap (0.2.14), and Bundler cannot
continue.
Make sure that `gem install bootsnap -v '0.2.14'` succeeds before bundling.

In Gemfile:
  bootsnap

この後、bootsnap関係(config/boot.rb含む)を削除

Gem::Ext::BuildError: ERROR: Failed to build gem native extension.

current directory:
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/cld3-3.1.2/ext/cld3
/usr/local/bin/ruby24 -r ./siteconf20170525-87190-1e0reit.rb extconf.rb
Failed to locate protobuf
*** 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/local/bin/$(RUBY_BASE_NAME)24
        --with-protobuf-config
        --without-protobuf-config
        --with-pkg-config
        --without-pkg-config

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

/usr/home/mastdon/live/vendor/bundle/ruby/2.4/extensions/amd64-freebsd-10/2.4/cld3-3.1.2/mkmf.log

extconf failed, exit code 1

Gem files will remain installed in
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/gems/cld3-3.1.2 for inspection.
Results logged to
/usr/home/mastdon/live/vendor/bundle/ruby/2.4/extensions/amd64-freebsd-10/2.4/cld3-3.1.2/gem_make.out

An error occurred while installing cld3 (3.1.2), and Bundler cannot continue.
Make sure that `gem install cld3 -v '3.1.2'` succeeds before bundling.

In Gemfile:
  cld3


この後、cld3関係をすべて削除

Mastdonをインストールするまでに行ったコマンド

freebsd-update fetch
freebsd-update install
reboot

pkg install svnup
ee /usr/local/etc/svnup.conf
svnup ports -v 3
echo 'WITH="" WITHOUT="X11"' >> /etc/make.conf
echo 'DEFAULT_VERSIONS=ruby=2.4' >> /etc/make.conf

cd /usr/ports/ports-mgmt/portupgrade && make config-recursive install clean
cd /usr/ports/devel/git && make config-recursive install clean
cd /usr/ports/graphics/ImageMagick && make config-recursive install clean
cd /usr/ports/multimedia/ffmpeg && make config-recursive install clean
cd /usr/ports/databases/redis && make config-recursive install clean
cd /usr/ports/databases/postgresql96-server && make config-recursive install clean
cd /usr/ports/databases/postgresql96-contrib && make config-recursive install clean
cd /var/db/postgres/data96
su - postgres -c 'initdb -D ./data96 -E UTF8'
service postgresql onestart
su - postgres -c 'psql -c "CREATE USER mastodon CREATEDB;"'
cp /var/db/postgres/data96/postgresql.conf.bak /var/db/postgres/data96/postgresql.conf
sed -i.org '/shared_preload_libraries/ s/^#//' /var/db/postgres/data96/postgresql.conf
sed -i.org "/shared_preload_libraries/ s/''/'pg_stat_statements'/" /var/db/postgres/data96/postgresql.conf
service postgresql onerestart
cd /usr/ports/www/nginx && make config-recursive install clean
cd /usr/ports/www/node && make config-recursive install clean
cd /usr/ports/www/yarn && make config-recursive install clean
cd /usr/ports/sysutils/rubygem-bundler && make config-recursive install clean

Mastdonをインストールするときのコマンド

pw useradd mastdon
su - mastdon
mkdir -p /home/mastdon
cd /home/mastdon
git clone https://github.com/tootsuite/mastodon.git live && cd live
bundle install --deployment --without development test
#↑ここでエラーが出ます
#yarn install

調査したURL

下記すべてを調査しましたが、不明でした。
https://github.com/openwrt/packages/issues/1703
https://github.com/Shopify/bootsnap/issues/32

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

+1

このエラーの原因となっているbootsnapにPRが上がっていました

先行するIssueによれば、FreeBSDでは同じ機能がsys/extattr.hにある上に関数のシグネチャも異なるということです。

そして、bootsnapはあくまで起動高速化のためのライブラリなので、Gemfileやコード(config/boot.rbの4行目以降を全削除)から外せば、遅くはなるもののとりあえず起動はできると思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/05/25 15:20

    cld3でも同じような問題が発生しました。
    bootsnap及びcld3を削除して、対処してみました。

    これ以外のエラーらしいものもあるのですが、比較環境用として、一度CentOS7から出直してみます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.20%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る