AWS App Runner "Create Failed" on health check
Asked Answered
E

5

8

I'm creating my first app on AWS App Runner. I have a simple nginx Docker image that works locally by serving html on localhost:8080.

When I try to deploy it, the result is "Create Failed". Upon digging into the CloudWatch logs, I see that the health check failed. The health check is configured to ping the root of the service "/" at port 8080.

Eydie answered 24/9, 2021 at 23:42 Comment(1)
Happens to me as well. Wired enough, when I create a new App Runner instance with the exact same configurations, health check passes through and the service is being created successfully. Did you get your hands around it eventually?Scalawag
E
4

I was able to resolve this by deleting my App Runner app (this is currently the only way to change the configuration-- see this issue), then creating a new one and specifying the health check to ping port 80.

Eydie answered 24/9, 2021 at 23:42 Comment(0)
L
3

Are you getting this error:

10-21-2021 02:13:32 PM [AppRunner] Health check on port '80' failed. Service is rolling back. Check your configured port number. For more information, read the application logs.
10-21-2021 02:07:40 PM [AppRunner] Performing health check on port '80'.
10-21-2021 02:07:30 PM [AppRunner] Provisioning instances and deploying image.
10-21-2021 02:07:20 PM [AppRunner] Successfully pulled image from ECR.
10-21-2021 02:04:58 PM [AppRunner] Service status is set to OPERATION_IN_PROGRESS.
10-21-2021 02:04:57 PM [AppRunner] Service creation started.

If you are building on an M1 mac by chance? If so that's probably the reason. The image that's being built is of the ARM architecture, and App Runner or Fargate is an x86 runtime.

Aws is working on fixing this issue here: #1949

In the meantime, there's a workaround, you can prefix copilot commands with the DOCKER_DEFAULT_PLATFORM=linux/amd64

For example:

DOCKER_DEFAULT_PLATFORM=linux/amd64 copilot deploy

So basically when you build your docker image just use:

You can use buildx (mobi) which suipport cli for platform.

docker build --platform linux/amd64 -t your-docker-image-name .

Hope that helps, and sorry for the trouble 🙏

Leafstalk answered 18/11, 2022 at 0:4 Comment(0)
C
1

When creating the app, the default port is 8080, but the default basic nginx server listens on port 80. So, when creating the app, you should change the port to 80.

Cookstove answered 7/10, 2023 at 22:55 Comment(0)
G
1
  1. Comment/remove the EXPOSE port from docker file
  2. Set port in apprunner to 80
  3. The port that your services starts on should also be 80.

i dont know why expose causes the issue.

Greenness answered 29/10, 2023 at 5:24 Comment(1)
Above worked, however I have to do following updates... In the next.config.js, update/add following const nextConfig = { output: "standalone", ....... In Dockerfile, add HOSTNAME env # EXPOSE 3000 # ENV PORT 3000 ENV HOSTNAME "0.0.0.0"Adamek
D
0

Does your application come up fine locally when running as a docker container?

The localhost needs to point to 0.0.0.0 ip rather than 127.0.0.1 or localhost to work on apprunner

Dumps answered 27/6, 2023 at 19:26 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.