Allowed memory size of xxxx bytes exhausted (tried to allocate xxxx bytes)が発生したので、PHPのメモリはどこで管理されているものなのか調べた

この記事は公開されてから半年以上経過しています (公開日2019年11月16日)。

php-fpmを動かしていて以下のようなエラーが出た時には、memory_limit 以上にメモリを割り当てようとしているためだと思う。

Allowed memory size of xxxx bytes exhausted (tried to allocate xxxx bytes) ...

ここでpsでプロセスのメモリ使用状態を見た時に、php.inimemory_limitで設定した値以上にphp-fpmプロセスがメモリを確保しているように見えるときがある。
例えば、memory_limit16Mにしていた時のプロセスの状態を見ると、メモリは36860(36M)割り当てられているように見えるけど、php-fpmは普通に動いている。
psで見える物理メモリは実際に書き込まれたときに増えるはずなので実メモリに36M程度割り当てられていることになる…はず。

hoge       28849  0.0  3.4 427360 36860 ?        S    Dec22   2:37  \_ php-fpm: pool example.com

そもそもphp-fpmはどのようにメモリを確保しているのか知らない…とか思い始めたので調べてみた。

続きを読む »

Terraform v0.12がリリースされたのでAWS Providerをv0.11.14 からアップグレードした時の備忘録

この記事は公開されてから半年以上経過しています (公開日2019年11月10日)。

Terraform v0.l2がリリースされたのでAWS Providerをv0.11.14 からアップグレードした。

基本的に下記オフィシャルドキュメントの通りで、アップグレードには v0.12 に付属されているヘルパーコマンドを使う。
その時の手順を記載する。

続きを読む »