Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[IMPROVE] Dockerfile to support hot-reload #74

Open
wants to merge 9 commits into
base: main
Choose a base branch
from

Conversation

SarveshLimaye
Copy link
Contributor

Fixes : #48

Added volumes in docker-compose.yml to support hot reload in next-js

@Dnouv
Copy link
Member

Dnouv commented Jan 5, 2023

Hey @SarveshLimaye

Thanks for the PR. Did you also fix the BUILD_KIT issue? If not, can you please research more about it and try to come up with a solution?

@SarveshLimaye
Copy link
Contributor Author

SarveshLimaye commented Jan 6, 2023

Hey @Dnouv , I have not fixed the BUILD_KIT issue. in this pr. The issue is still open on the docker/buildx github repository , so there is no official solution available to this. Currently, BuildKit only supports four network modes: "bridge", "host", "none" and "container:<name|id>". So I guess it's not possible to solve this error unless there is some support added in the official docker repository, but we can obviously find some way around.

After reading the discussions I found this way around to be super useful -

We can create a new sh and try to run it in DOCKERFILE. The sh can be similar to the following - moby/buildkit#978 (comment)

Since there is no official solution available to this, we need to try out a lot of different ways on a separate branch. I think it would be better if we try to solve the BUILD_KIT issue on a different PR. Do let me know if you find any better solution.
Thank you !

@Dnouv
Copy link
Member

Dnouv commented Jan 9, 2023

@SarveshLimaye ok, sounds good. I tried out this PR (with DOCKER_BUILDKIT=0). However, there were a few errors, and I was not able to build Docker Image.
The error:

Error occurred prerendering page "/conferences/create/basic-detail". Read more: https://nextjs.org/docs/messages/prerender-error
FetchError: request to http://localhost:1337/api/top-nav-item failed, reason: connect ECONNREFUSED 127.0.0.1:1337

Please pull the latest changes from the main before trying to build. The localhost:1337 is already up and running.

Also, you will have to add a new dockerfile for the development environment, since as you can find here we are doing a production build, and AFAIK NextJS won't watch for file changes in the production build.

Please look into this issue. Thank you!

@SarveshLimaye
Copy link
Contributor Author

@Dnouv I have added Docker file for development environment. Could you pls take a look at changes ?

@SarveshLimaye
Copy link
Contributor Author

SarveshLimaye commented Jan 14, 2023

Hey @Dnouv , I have fixed all the errors and everything is working fine. Could you please take a look ?

screen-capture.2.webm

app/lib/api.js Outdated Show resolved Hide resolved
@Dnouv
Copy link
Member

Dnouv commented Jan 21, 2023

Nicely done, @SarveshLimaye !

However, could you please take a look, this does not seem to work on Gitpod, I always get this error:

image

Once this is fixed the PR is good to merge. I have tried building the new Dockerfile, and it works quite well.

Thank you!

@SarveshLimaye
Copy link
Contributor Author

Hey @Dnouv, Thanks for the review. I once encountered this error when I tried building the docker file without starting the backend server.

I just tested building the dockerfile on gitpod and its working fine .

screen-capture.6.webm

@Dnouv
Copy link
Member

Dnouv commented Jan 22, 2023

Any idea why that occurs?

@SarveshLimaye
Copy link
Contributor Author

@Dnouv AFAIK it can happen because of the following reasons -

  1. not setting the DOCKER_BUILDKIT = 0
  2. When we don't provide the GITPOD with permissions to make this port public.
  3. Pretty obvious one ig - When the backend server is not up and running.

@Dnouv
Copy link
Member

Dnouv commented Jan 22, 2023

Oh ok, I am trying once again with all the backend up and running.

@Dnouv
Copy link
Member

Dnouv commented Jan 22, 2023

@SarveshLimaye, you see here, I have set the NEXT_PUBLIC_STRAPI_URL to localhost, however, in the Client-side app it is still trying to connect to - http://172.28.0.1:1337/api/carousels
image

@Dnouv
Copy link
Member

Dnouv commented Feb 2, 2023

Hey @SarveshLimaye
Please fix this error, it occurs because you forgot to import the assets directory, to see the error visits /conferences page:

error - ./pages/conferences/index.js:5:0
app-app-1  | Module not found: Can't resolve '../../assets/event_logo.svg'
app-app-1  |   3 | import EventHome from "../../components/conferences/EventHome";
app-app-1  |   4 | import Image from "next/image";
app-app-1  | > 5 | import eventLogo from "../../assets/event_logo.svg";

Also, update the docs to incorporate this method of starting the development environment. If possible, try to make changes in the startNext.sh such that:

sh startNext.sh localhost --docker

Should start a docker development image of NextJS.

Please rename docker-compose.development.yml to docker-compose.dev.yml

And lastly, please don't make the NextJS fix on port 3000 so that if the user's local port 3000 is occupied, the NextJS can run on any other port

ports:
      - "3000:3000"
 should be
 ports:
      - "$NEXTJS_PORT:3000"

This is the variable that is set to the available port you only need to pass this on to the Docker Compose.

Once these changes are done, please ping me. Thank you!

@SarveshLimaye
Copy link
Contributor Author

@Dnouv I am really not sure how to make changes in startNext.sh to start the docker development image of NextJs using command sh startNext.sh localhost --docker

Also, I just had a question related to updating docs. Should I update docs to the same steps as we are running the dockerfile now . Something like -
cd app
docker-compose -f docker-compose.dev.yml up --build

or wait until we find a way to build dockerfile using this command - sh startNext.sh localhost --docker and then update the docs
Other than this I have done all the changes .
Thank You !

@SarveshLimaye
Copy link
Contributor Author

@Dnouv all the suggested changes done !

@SarveshLimaye SarveshLimaye requested a review from Dnouv February 10, 2023 07:26
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[TODO] Dockerize the NextJS Development Environment
2 participants