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

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

ただいまの
回答率

88.10%

[mmap() failed: [12] Cannot allocate memory]エラーを解決したい

解決済

回答 1

投稿

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

退会済みユーザー

前提・実現したいこと

下記のコマンドを完了させたいのですが、次に記載するエラーが出て完了できない。

$ composer require maatwebsite/excel

発生している問題・エラーメッセージ

$ composer require maatwebsite/excel
mmap() failed: [12] Cannot allocate memory
PHP Fatal error:  Out of memory (allocated 691974144) (tried to allocate 25853038 bytes) in phar:///usr/local/bin/composer/src/Composer/Util/RemoteFilesystem.php on line 462

試したこと

メモリが足りていないと思い、メモリ上限を上げて、apacheを再起動し、上限が変わっていることを確認。

$ sudo vi php.ini
memory_limit => 125M -> 2G へ変更
$ sudo service httpd restart
$ php -i | grep memory_limit
memory_limit => 2G => 2G


再度同様のコマンドを実行するが、結果が変わらない。。

$ composer require maatwebsite/excel
mmap() failed: [12] Cannot allocate memory
PHP Fatal error:  Out of memory (allocated 691974144) (tried to allocate 25853038 bytes) in phar:///usr/local/bin/composer/src/Composer/Util/RemoteFilesystem.php on line 462

自分の考え

(allocated 691974144) (tried to allocate 25853038 bytes) 
上記の文面は、すでにメモリを691974144使っているが、あと25853038足りないと意味と認識していますが、
上限を上げたにもかかわらず同じエラー文言が表示されているということは、
・変更する箇所を間違えている
・変更しているが、変更内容が反映されていない
のどちらかと思っているのですが、どうにもわからずこちらに質問させて頂いた次第です。

もしどなたか助けて頂ければ幸いです。
どうぞよろしくお願い致します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

composerコマンドで使用するphp.iniはapacheで使用しているものと同じものとは限らないので、
php -i |grep ini
あたりでphp-cliが使用しているphp.iniのパスを確認してそれを修正するか、
php -c 今回修正したphp.iniのフルパス composer.pharのフルパス require パッケージ名
という感じでiniを指定して実行してみてください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/06/17 12:16

    コメントありがとうございます。不慣れのため大変助かります。

    アドバイスを参考に以下のことを行いました。
    ```
    $ php -i | grep php.ini
    Configuration File (php.ini) Path => /etc/php-7.2.conf:/etc
    Loaded Configuration File => /etc/php.ini
    /etc/php-7.2.d/php.ini
    ```
    という結果でしたので、
    /etc/php-7.2.d/php.iniのmemory_limitの設定を確認すると2Gにはなっていました。
    ```
    $ sudo vi /etc/php-7.2.d/php.ini
    memory_limit => 2G
    ```

    ということでもうひとつの方法を試そうと以下のようにコマンドを叩いたら別のエラーが出ました。
    ```
    $ php -c /etc/php.ini /usr/local/bin/composer require maatwebsite/excel
    Using version ^3.1 for maatwebsite/excel
    ./composer.json has been created
    Loading composer repositories with package information
    Updating dependencies (including require-dev)

    mmap() failed: [12] Cannot allocate memory
    Segmentation fault
    ```
    「Segmentation fault」はセグメンテーション違反ということでしたので、自分の叩いたコマンドが悪いのかと思ったのですが、ググってもどう解決すればいいか現状わかっていない状態です。

    もし何かやり方がまちがっているようでしたら教えていただければ幸いです。

    キャンセル

  • 2020/06/17 13:10

    OSのメモリそのものが足りないとかは無いですか?
    その場合は、swapを数GB設定すれば(実行時の速度は遅くなりますが)解決することが多いです。
    あとは、AWS等のクラウド環境なら一時的にメモリの多いインスタンスに変更するとかですね。(かなり多いメモリを持っているインスタンスでも、1時間なら10円とかそれくらいの値段なので、設定をいじるより楽だと思います)

    キャンセル

  • 2020/06/19 15:49

    ありがとうございます!
    AWSでしたのでアドバイス通りインスタンスタイプを変更して試したらいけました!
    タイプがmicroでしたが、smallにしてもまだ足りなかったためmiddleでようやくいけましたw
    お忙しい中アドバイス頂きましてありがとうございました!

    手順の参考サイト
    http://chuu-information.com/cloud/post-1126/

    キャンセル

  • 2020/06/19 15:53

    解決して良かったです。
    フィードバックありがとうございます

    キャンセル

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

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

関連した質問

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