Heroku app recompiles after restarts using Elixir 1.15

I upgraded to Elixir 1.15 and am having issues deploying on Heroku now. Whenever the app restarts, the whole application recompiles. On our large application, this recompile takes longer than 30 seconds, which causes the app to crash.

I’m able to reproduce this on a bare bones Phoenix app. The line where it says “Compiling 15 files” should not be happening during a restart.

2023-07-06T14:42:59.587968+00:00 heroku[web.1]: Restarting
2023-07-06T14:42:59.650735+00:00 heroku[web.1]: State changed from up to starting
2023-07-06T14:43:00.295043+00:00 heroku[web.1]: Stopping all processes with SIGTERM
2023-07-06T14:43:00.322078+00:00 app[web.1]: 14:43:00.321 [notice] SIGTERM received - shutting down
2023-07-06T14:43:00.322086+00:00 app[web.1]: 
2023-07-06T14:43:01.502645+00:00 heroku[web.1]: Process exited with status 0
2023-07-06T14:43:03.720077+00:00 heroku[web.1]: Starting process with command `mix phx.server`
2023-07-06T14:43:05.363804+00:00 app[web.1]: Compiling 15 files (.ex)

Where should I report this issue? I don’t know if it’s something specific to Elixir or if the Heroku buildpack we’re using needs to be updated to support Elixir 1.15. GitHub - HashNuke/heroku-buildpack-elixir: Heroku Buildpack for Elixir with nitro boost

Have you considered deploying elixir through mix releases on heroku? That should prevent having to recompile and also bring some other benefits.

It might not answer your question but i can recommend looking i to it as this problem will reoccur even if you manage to solve it for now :slight_smile:. I would post links but I’m currently on my phone so i have limited resources. I will try to do so later

Thanks for the suggestion. I was able to get our app running on Heroku with mix releases with minimal changes. One thing that seems a bit odd is that the app recompiles during Heroku’s release phase when we run migrations. It only does this in 1.15 and not 1.14, so it think there’s still something “off” here. The app at least starts up, but adds a few minutes to deploy time.

Yes, running the migrations through mix will force recompilation. There is a way around it though, i think its described quite well under the phoenix release docs. In short its a helper function that is called via the release through the eval command

If you haven’t found it already: Deploying with Releases — Phoenix v1.7.6 :slight_smile:

That’s perfect. Thanks for your help!