-
-
Notifications
You must be signed in to change notification settings - Fork 211
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
Updated and optimised Dockerfile and modified dockerignore #1245
base: main
Are you sure you want to change the base?
Conversation
built with Refined Cloudflare Pages Action⚡ Cloudflare Pages Deployment
|
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #1245 +/- ##
=========================================
Coverage 100.00% 100.00%
=========================================
Files 10 10
Lines 373 373
Branches 94 94
=========================================
Hits 373 373 ☔ View full report in Codecov by Sentry. |
Thank you @abhayymishraa for the PR. One questions.... Dockerfile will become compatible with Windows machines also? |
@DhairyaMajmudar i ran a test in my friend's system (windows 11 ) . it worked smoothly |
@DhairyaMajmudar done ✔️ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is unmaintainable. If this is the best way to install yarn, I think it's too soon to move away from corepack. Corepack isn't gone yet and it appears that Yarn doesn't have a reasonable path to installing without it yet. I say we wait until this situation improves before trying to remove corepack.
yes , The curl is the way to get that specific package without any problem although i have a alternative i found out recently looking forward to soon make a pr with the changes |
@@ -2,16 +2,31 @@ FROM node:20-alpine | |||
|
|||
WORKDIR /app | |||
|
|||
COPY package*.json ./ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Don't remove this step, for docker optimisation we use multi copying technique, where we first copy dependency files (This creates a layer in image) and run the command for installing them (this creates another layer). Whenever changes are made to codebase which doesn't include changes with dependency files the first layer is cached and reused.
In our case it will be COPY package.json yarn.lock
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually if we do that the docker file will stop working i don't know what happens but if i install their then i get this error node modules not found
docker run -it -p 3000:3000 json-schema
Usage Error: Couldn't find the node_modules state file - running an install might help (findPackageLocation)
$ yarn run [--inspect] [--inspect-brk] [-T,--top-level] [-B,--binaries-only] [--require #0] <scriptName> ...
What kind of change does this PR introduce?
Issue Number:
Screenshots/videos:
If relevant, did you update the documentation?
N/A
Summary
The Dockerfile has been optimized to include proper Yarn 4.4.0 installation from source, enhanced cleanup processes to
reduce image size, improved environment file handling, and explicit command execution, resulting in a more efficient and
reliable container build process.
Does this PR introduce a breaking change?
N/A