ဝန်ဆောင်မှုတစ်ခု မထုတ်လုပ်မီ၊ ရှုပ်ထွေးသော တီးမှုတ်သူများနှင့် CI/CD များခေတ်တွင်၊ ကတိကဝတ်မှ စမ်းသပ်မှုများနှင့် ပေးပို့ခြင်းအထိ သွားရမည့် ခရီးရှည်တစ်ခုရှိသည်။ ယခင်က၊ သင်သည် FTP မှတစ်ဆင့် ဖိုင်အသစ်များကို အပ်လုဒ်လုပ်နိုင်သည် (ထိုသို့မည်သူမျှ မလုပ်တော့ဘဲ၊ ဟုတ်တယ်မဟုတ်လား)၊ နှင့် "ဖြန့်ကျက်ခြင်း" လုပ်ငန်းစဉ်သည် စက္ကန့်ပိုင်းကြာခဲ့သည်။ ယခု သင်သည် ပေါင်းစည်းရန် တောင်းဆိုချက်တစ်ခုကို ဖန်တီးပြီး အသုံးပြုသူများထံ ရောက်ရှိရန် အင်္ဂါရပ်အတွက် အချိန်အကြာကြီး စောင့်ရမည်ဖြစ်ပါသည်။
ဤလမ်းကြောင်း၏တစ်စိတ်တစ်ပိုင်းသည် Docker ပုံတစ်ခုတည်ဆောက်ခြင်းဖြစ်သည်။ တခါတရံတွင် စည်းဝေးပွဲသည် မိနစ်များစွာကြာပြီး တစ်ခါတစ်ရံတွင် မိနစ်ဆယ်ချီကြာပြီး ပုံမှန်ဟုခေါ်ဆို၍မရပေ။ ဤဆောင်းပါးတွင်၊ ကျွန်ုပ်တို့သည် ရုပ်ပုံတစ်ခုသို့ ထုပ်ပိုးမည့် ရိုးရှင်းသော အပလီကေးရှင်းတစ်ခုကို ယူမည်ဖြစ်ပြီး၊ တည်ဆောက်မှုကို အရှိန်မြှင့်ရန် နည်းလမ်းများစွာကို အသုံးပြုကာ ဤနည်းလမ်းများ အလုပ်လုပ်ပုံ၏ ကွဲပြားချက်များကို ကြည့်ရှုပါမည်။
ကျွန်ုပ်တို့တွင် မီဒီယာဝဘ်ဆိုဒ်များကို ဖန်တီးခြင်းနှင့် ပံ့ပိုးပေးခြင်းတွင် အတွေ့အကြုံကောင်းများရှိသည်။
ကျွန်ုပ်တို့သည် GitLab သို့ ဖြန့်ကျက်ထားသည်။ ကျွန်ုပ်တို့သည် ပုံများကို စုဆောင်းပြီး ၎င်းတို့အား GitLab Registry သို့ တွန်းပို့ကာ ထုတ်လုပ်ရေးသို့ ဖြန့်ချီပါ။ ဤစာရင်းတွင် အရှည်ဆုံးအရာမှာ ပုံများကို စုစည်းခြင်း ဖြစ်သည်။ ဥပမာ- ပိုမိုကောင်းမွန်အောင်မလုပ်ဆောင်ဘဲ၊ backend တည်ဆောက်မှုတစ်ခုစီသည် 14 မိနစ်ကြာသည်။
အဆုံးတွင်၊ ကျွန်ုပ်တို့သည် ဤကဲ့သို့အသက်မရှင်နိုင်တော့ကြောင်း သိသာထင်ရှားလာကာ ရုပ်ပုံများကို စုဆောင်းရန် အဘယ်ကြောင့် ဤမျှကြာကြာနေရသည်ကို အဖြေရှာရန် ထိုင်နေပါသည်။ ရလဒ်အနေဖြင့်၊ ကျွန်ုပ်တို့သည် ပရိသတ်အချိန်ကို စက္ကန့် 30 သို့လျှော့ချနိုင်ခဲ့သည်။
ဤဆောင်းပါးအတွက်၊ Reminder ၏ပတ်ဝန်းကျင်နှင့် ဆက်စပ်မှုမဖြစ်စေရန်၊ ဗလာ Angular အပလီကေးရှင်းကို စုစည်းခြင်း၏ ဥပမာကို ကြည့်ကြပါစို့။ ထို့ကြောင့် ကျွန်ုပ်တို့၏ အက်ပ်လီကေးရှင်းကို ဖန်တီးကြပါစို့။
ng n app
၎င်းတွင် PWA ထည့်ပါ (ကျွန်ုပ်တို့သည် တိုးတက်သည်)။
ng add @angular/pwa --project app
npm ပက်ကေ့ဂျ်ပေါင်း တစ်သန်းကို ဒေါင်းလုဒ်လုပ်နေချိန်မှာ၊ docker ပုံ ဘယ်လိုအလုပ်လုပ်လဲဆိုတာ အဖြေရှာကြည့်ရအောင်။ Docker သည် အပလီကေးရှင်းများကို ထုပ်ပိုးပြီး ၎င်းတို့ကို ကွန်တိန်နာဟုခေါ်သော သီးခြားပတ်ဝန်းကျင်တွင် လုပ်ဆောင်နိုင်စေသည်။ သီးခြားခွဲထားခြင်းကြောင့်၊ သင်သည် ဆာဗာတစ်ခုတွင် ကွန်တိန်နာများစွာကို တစ်ပြိုင်နက်တည်း လုပ်ဆောင်နိုင်သည်။ ကွန်တိန်နာများသည် စနစ် kernel ပေါ်တွင် တိုက်ရိုက်လည်ပတ်သောကြောင့် virtual machines များထက် များစွာပိုမိုပေါ့ပါးပါသည်။ ကျွန်ုပ်တို့၏ အပလီကေးရှင်းဖြင့် ကွန်တိန်နာတစ်ခုအား လုပ်ဆောင်ရန်၊ ကျွန်ုပ်တို့၏ အပလီကေးရှင်းလည်ပတ်ရန်အတွက် လိုအပ်သည့်အရာအားလုံးကို ထုပ်ပိုးမည့် ပုံတစ်ပုံဖန်တီးရန် လိုအပ်ပါသည်။ အခြေခံအားဖြင့် ပုံသည် ဖိုင်စနစ်၏ ကော်ပီဖြစ်သည်။ ဥပမာအားဖြင့်၊ Dockerfile ကိုယူပါ။
FROM node:12.16.2
WORKDIR /app
COPY . .
RUN npm ci
RUN npm run build --prod
Dockerfile သည် ညွှန်ကြားချက်အစုတစ်ခုဖြစ်သည်။ ၎င်းတို့တစ်ခုစီကို လုပ်ဆောင်ခြင်းဖြင့် Docker သည် ဖိုင်စနစ်တွင် အပြောင်းအလဲများကို သိမ်းဆည်းပြီး ၎င်းတို့ကို ယခင်အရာများပေါ်တွင် ထပ်ပေးမည်ဖြစ်သည်။ အဖွဲ့တစ်ဖွဲ့စီသည် ၎င်း၏ကိုယ်ပိုင်အလွှာကို ဖန်တီးသည်။ ပြီးသွားသောပုံသည် အလွှာများ ပေါင်းစပ်ထားသည်။
သိရန်အရေးကြီးသည်- Docker အလွှာတစ်ခုစီသည် ကက်ရှ်လုပ်နိုင်သည်။ နောက်ဆုံးတည်ဆောက်ပြီးကတည်းက ဘာမှမပြောင်းလဲခဲ့ပါက၊ ထို့နောက် command ကိုလုပ်ဆောင်မည့်အစား docker သည် အဆင်သင့်လုပ်ထားသော layer ကိုယူပါမည်။ တည်ဆောက်မှုအမြန်နှုန်း၏ အဓိက တိုးနှုန်းမှာ ကက်ရှ်အသုံးပြုခြင်းကြောင့် ဖြစ်မည်ဖြစ်သောကြောင့် တည်ဆောက်မှုအမြန်နှုန်းကို တိုင်းတာရာတွင် အဆင်သင့်လုပ်ထားသော ကက်ရှ်တစ်ခုဖြင့် ရုပ်ပုံတစ်ခုကို တည်ဆောက်ရန် အထူးအာရုံစိုက်ပါမည်။ ဒါကြောင့် တစ်ဆင့်ပြီးတစ်ဆင့်၊
- ယခင်လုပ်ဆောင်မှုများသည် စမ်းသပ်မှုကို မထိခိုက်စေရန်အတွက် စက်တွင်းရှိ ပုံများကို ဖျက်ပစ်ပါသည်။
docker rmi $(docker images -q)
- ကျွန်ုပ်တို့သည် ပထမဆုံး အကြိမ် တည်ဆောက်မှုကို စတင်ခဲ့ပါသည်။
time docker build -t app .
- ကျွန်ုပ်တို့သည် src/index.html ဖိုင်ကိုပြောင်းသည် - ကျွန်ုပ်တို့သည် ပရိုဂရမ်မာတစ်ဦး၏အလုပ်ကို အတုယူပါသည်။
- ကျွန်တော်တို့က ဒုတိယ အကြိမ် ဆောက်တာပါ။
time docker build -t app .
တည်ဆောက်ပုံများအတွက် ပတ်၀န်းကျင်ကို မှန်ကန်စွာ စီစဉ်သတ်မှတ်ထားပါက (အောက်ပါအချက်အပေါ်တွင် ပိုမို၍) တည်ဆောက်မှုစတင်သောအခါ၊ Docker သည် ဘုတ်ပေါ်တွင် ကက်ရှ်အမြောက်အများ ရှိနှင့်ပြီးဖြစ်သည်။ ကျွန်ုပ်တို့၏တာဝန်မှာ ကက်ရှ်ကို မည်သို့အသုံးပြုရမည်ကို လေ့လာရန်ဖြစ်ပြီး တည်ဆောက်မှုကို တတ်နိုင်သမျှ မြန်မြန်သွားစေရန် ဖြစ်သည်။ ကက်ရှ်မပါဘဲ တည်ဆောက်မှုကို လုပ်ဆောင်ခြင်း—ပထမအကြိမ်—တစ်ကြိမ်သာ ဖြစ်ပွားသည်ဟု ကျွန်ုပ်တို့ ယူဆသောကြောင့်၊ ထို့ကြောင့် ပထမအကြိမ်သည် မည်မျှနှေးကွေးသည်ကို လျစ်လျူရှုနိုင်သည်။ စမ်းသပ်မှုများတွင်၊ တည်ဆောက်မှု၏ဒုတိယအပြေးသည် ကျွန်ုပ်တို့အတွက် အရေးကြီးသည်၊ ကက်ရှ်များကို ပူနွေးပြီး ကျွန်ုပ်တို့၏ကိတ်မုန့်ဖုတ်ရန် အသင့်ဖြစ်သောအခါတွင် ကျွန်ုပ်တို့အတွက် အရေးကြီးပါသည်။ သို့သော်၊ အချို့သောအကြံပြုချက်များသည် ပထမတည်ဆောက်မှုအပေါ် သက်ရောက်မှုရှိမည်ဖြစ်သည်။
အထက်တွင်ဖော်ပြထားသော Dockerfile ကို ပရောဂျက်ဖိုင်တွဲတွင် ထားကာ တည်ဆောက်မှုကို စတင်ကြပါစို့။ ဖတ်ရှုရလွယ်ကူစေရန်အတွက် စာရင်းအားလုံးကို စုစည်းထားပါသည်။
$ time docker build -t app .
Sending build context to Docker daemon 409MB
Step 1/5 : FROM node:12.16.2
Status: Downloaded newer image for node:12.16.2
Step 2/5 : WORKDIR /app
Step 3/5 : COPY . .
Step 4/5 : RUN npm ci
added 1357 packages in 22.47s
Step 5/5 : RUN npm run build --prod
Date: 2020-04-16T19:20:09.664Z - Hash: fffa0fddaa3425c55dd3 - Time: 37581ms
Successfully built c8c279335f46
Successfully tagged app:latest
real 5m4.541s
user 0m0.000s
sys 0m0.000s
ကျွန်ုပ်တို့သည် src/index.html ၏ အကြောင်းအရာများကို ပြောင်းလဲပြီး ဒုတိယ အကြိမ် လုပ်ဆောင်သည်။
$ time docker build -t app .
Sending build context to Docker daemon 409MB
Step 1/5 : FROM node:12.16.2
Step 2/5 : WORKDIR /app
---> Using cache
Step 3/5 : COPY . .
Step 4/5 : RUN npm ci
added 1357 packages in 22.47s
Step 5/5 : RUN npm run build --prod
Date: 2020-04-16T19:26:26.587Z - Hash: fffa0fddaa3425c55dd3 - Time: 37902ms
Successfully built 79f335df92d3
Successfully tagged app:latest
real 3m33.262s
user 0m0.000s
sys 0m0.000s
ကျွန်ုပ်တို့တွင် ပုံရှိမရှိကြည့်ရန် command ကို run ပါ။ docker images
:
REPOSITORY TAG IMAGE ID CREATED SIZE
app latest 79f335df92d3 About a minute ago 1.74GB
မတည်ဆောက်မီ၊ docker သည် လက်ရှိအခြေအနေရှိ ဖိုင်အားလုံးကိုယူကာ ၎င်း၏ daemon သို့ ပို့ပေးသည်။ Sending build context to Docker daemon 409MB
. build context ကို build command အတွက် နောက်ဆုံး argument အဖြစ် သတ်မှတ်သည်။ ကျွန်ုပ်တို့၏အခြေအနေတွင်၊ ၎င်းသည် လက်ရှိလမ်းညွှန် - “.”၊ - နှင့် Docker သည် ဤဖိုင်တွဲတွင် ကျွန်ုပ်တို့ရှိရှိသမျှအားလုံးကို ဆွဲယူသည်။ 409 MB က အများကြီးဆိုတော့ ဘယ်လိုပြင်ရမလဲ စဉ်းစားကြည့်ရအောင်။
ကာရံ ဆက်စပ်မှု
အကြောင်းအရာကို လျှော့ချရန်၊ ရွေးချယ်စရာ နှစ်ခုရှိသည်။ သို့မဟုတ် စည်းဝေးပွဲအတွက် လိုအပ်သောဖိုင်အားလုံးကို သီးခြားဖိုင်တွဲတစ်ခုတွင် ထားကာ docker အကြောင်းအရာကို ဤဖိုဒါသို့ ညွှန်ပြပါ။ ၎င်းသည် အမြဲတမ်း အဆင်ပြေနိုင်မည်မဟုတ်သောကြောင့် ခြွင်းချက်များကို သတ်မှတ်ရန် ဖြစ်နိုင်သည်- အကြောင်းအရာထဲသို့ ဆွဲငင်မထည့်သင့်ပါ။ ဒါကိုလုပ်ဖို့၊ ပရောဂျက်မှာ .dockerignore ဖိုင်ကို ထည့်ပြီး တည်ဆောက်မှုအတွက် မလိုအပ်တဲ့အရာကို ဖော်ပြပါ-
.git
/node_modules
တည်ဆောက်မှုကို ထပ်မံလုပ်ဆောင်ပါ-
$ time docker build -t app .
Sending build context to Docker daemon 607.2kB
Step 1/5 : FROM node:12.16.2
Step 2/5 : WORKDIR /app
---> Using cache
Step 3/5 : COPY . .
Step 4/5 : RUN npm ci
added 1357 packages in 22.47s
Step 5/5 : RUN npm run build --prod
Date: 2020-04-16T19:33:54.338Z - Hash: fffa0fddaa3425c55dd3 - Time: 37313ms
Successfully built 4942f010792a
Successfully tagged app:latest
real 1m47.763s
user 0m0.000s
sys 0m0.000s
607.2 KB က 409 MB ထက် အများကြီး ပိုကောင်းပါတယ်။ ရုပ်ပုံအရွယ်အစားကိုလည်း 1.74 မှ 1.38 GB သို့ လျှော့ချခဲ့သည်။
REPOSITORY TAG IMAGE ID CREATED SIZE
app latest 4942f010792a 3 minutes ago 1.38GB
ပုံ၏အရွယ်အစားကို နောက်ထပ်လျှော့ချရန် ကြိုးစားကြပါစို့။
Alpine သုံးတယ်။
ပုံအရွယ်အစားကို သိမ်းဆည်းရန် အခြားနည်းလမ်းမှာ သေးငယ်သော parent image ကို အသုံးပြုခြင်း ဖြစ်သည်။ မိဘပုံသဏ္ဍာန်သည် ကျွန်ုပ်တို့၏ပုံသဏ္ဌာန်ကို ပြင်ဆင်ထားသည့် အခြေခံပုံဖြစ်သည်။ အောက်ဆုံးအလွှာကို command ဖြင့်သတ်မှတ်သည်။ FROM
Dockerfile ထဲမှာ။ ကျွန်ုပ်တို့၏အခြေအနေတွင်၊ ကျွန်ုပ်တို့သည် nodejs ထည့်သွင်းထားပြီးဖြစ်သော Ubuntu-based image ကိုအသုံးပြုနေပါသည်။ ပြီးတော့ အလေးချိန်...
$ docker images -a | grep node
node 12.16.2 406aa3abbc6c 17 minutes ago 916MB
... တစ်ဂီဂါဘိုက်နီးပါး။ Alpine Linux ကို အခြေခံထားသော ပုံတစ်ပုံကို အသုံးပြုခြင်းဖြင့် အသံပမာဏကို သိသိသာသာ လျှော့ချနိုင်သည်။ Alpine သည် အလွန်သေးငယ်သော Linux တစ်ခုဖြစ်သည်။ alpine ကိုအခြေခံထားသော nodej များအတွက် docker ပုံသည် 88.5 MB သာရှိသည်။ ထို့ကြောင့် အိမ်များတွင် ကျွန်ုပ်တို့၏ အသက်ဝင်သော ပုံရိပ်ကို အစားထိုးလိုက်ကြပါစို့။
FROM node:12.16.2-alpine3.11
RUN apk --no-cache --update --virtual build-dependencies add
python
make
g++
WORKDIR /app
COPY . .
RUN npm ci
RUN npm run build --prod
အက်ပလီကေးရှင်းကိုတည်ဆောက်ရန် လိုအပ်သည့်အရာအချို့ကို ကျွန်ုပ်တို့ထည့်သွင်းခဲ့ရသည်။ ဟုတ်ကဲ့၊ Angular သည် Python ¯(°_o)/¯ မပါဘဲ တည်ဆောက်မည်မဟုတ်ပါ။
ဒါပေမယ့် ပုံအရွယ်အစားက 150 MB အထိ ကျဆင်းသွားပါတယ် ။
REPOSITORY TAG IMAGE ID CREATED SIZE
app latest aa031edc315a 22 minutes ago 761MB
ဒီထက်ပိုပြီး သွားကြရအောင်။
Multistage တပ်ဆင်မှု
ပုံမှာပါတဲ့ အရာတိုင်းဟာ ထုတ်လုပ်မှုအတွက် လိုအပ်တာမဟုတ်ပါဘူး။
$ docker run app ls -lah
total 576K
drwxr-xr-x 1 root root 4.0K Apr 16 19:54 .
drwxr-xr-x 1 root root 4.0K Apr 16 20:00 ..
-rwxr-xr-x 1 root root 19 Apr 17 2020 .dockerignore
-rwxr-xr-x 1 root root 246 Apr 17 2020 .editorconfig
-rwxr-xr-x 1 root root 631 Apr 17 2020 .gitignore
-rwxr-xr-x 1 root root 181 Apr 17 2020 Dockerfile
-rwxr-xr-x 1 root root 1020 Apr 17 2020 README.md
-rwxr-xr-x 1 root root 3.6K Apr 17 2020 angular.json
-rwxr-xr-x 1 root root 429 Apr 17 2020 browserslist
drwxr-xr-x 3 root root 4.0K Apr 16 19:54 dist
drwxr-xr-x 3 root root 4.0K Apr 17 2020 e2e
-rwxr-xr-x 1 root root 1015 Apr 17 2020 karma.conf.js
-rwxr-xr-x 1 root root 620 Apr 17 2020 ngsw-config.json
drwxr-xr-x 1 root root 4.0K Apr 16 19:54 node_modules
-rwxr-xr-x 1 root root 494.9K Apr 17 2020 package-lock.json
-rwxr-xr-x 1 root root 1.3K Apr 17 2020 package.json
drwxr-xr-x 5 root root 4.0K Apr 17 2020 src
-rwxr-xr-x 1 root root 210 Apr 17 2020 tsconfig.app.json
-rwxr-xr-x 1 root root 489 Apr 17 2020 tsconfig.json
-rwxr-xr-x 1 root root 270 Apr 17 2020 tsconfig.spec.json
-rwxr-xr-x 1 root root 1.9K Apr 17 2020 tslint.json
နှင့် docker run app ls -lah
ကျွန်ုပ်တို့၏ပုံသဏ္ဌာန်ကို အခြေခံ၍ ကွန်တိန်နာတစ်လုံးကို လွှင့်တင်ခဲ့သည်။ app
ပြီးတော့ အဲဒီအမိန့်ကို လိုက်နာတယ်။ ls -lah
ထို့နောက် ကွန်တိန်နာသည် ၎င်း၏လုပ်ငန်းကို ပြီးမြောက်စေသည်။
ထုတ်လုပ်ရေးတွင် ဖိုင်တွဲတစ်ခုသာ လိုအပ်ပါသည်။ dist
. ဤကိစ္စတွင်၊ ဖိုင်များကိုတစ်နည်းနည်းဖြင့်ပြင်ပသို့ပေးရန်လိုအပ်သည်။ သင်သည် nodej များတွင် HTTP server အချို့ကို run နိုင်သည်။ ဒါပေမယ့် ပိုလွယ်အောင်လုပ်မယ်။ "y" စာလုံးလေးလုံးပါသော ရုရှားစကားလုံးကို ခန့်မှန်းပါ။ မှန်တယ်! Ynzhynyksy ။ nginx နဲ့ ပုံတစ်ပုံရိုက်ရအောင်၊ ဖိုဒါတစ်ခုထည့်လိုက်ပါ။ dist
နှင့် အသေးစားပြင်ဆင်မှု
server {
listen 80 default_server;
server_name localhost;
charset utf-8;
root /app/dist;
location / {
try_files $uri $uri/ /index.html;
}
}
Multi-stage တည်ဆောက်မှုသည် ကျွန်ုပ်တို့အား ဤအရာအားလုံးကို လုပ်ဆောင်ရန် ကူညီပေးပါမည်။ ကျွန်ုပ်တို့၏ Dockerfile ကိုပြောင်းလဲကြပါစို့။
FROM node:12.16.2-alpine3.11 as builder
RUN apk --no-cache --update --virtual build-dependencies add
python
make
g++
WORKDIR /app
COPY . .
RUN npm ci
RUN npm run build --prod
FROM nginx:1.17.10-alpine
RUN rm /etc/nginx/conf.d/default.conf
COPY nginx/static.conf /etc/nginx/conf.d
COPY --from=builder /app/dist/app .
ယခု ကျွန်ုပ်တို့တွင် ညွှန်ကြားချက်နှစ်ခုရှိသည်။ FROM
Dockerfile တွင်၊ ၎င်းတို့ တစ်ခုစီသည် မတူညီသော တည်ဆောက်မှု အဆင့်တစ်ခုကို လုပ်ဆောင်သည်။ ကျွန်တော်တို့က ပထမတစ်ယောက်ခေါ်တယ်။ builder
သို့သော် နောက်ဆုံး FROM မှစတင်၍ ကျွန်ုပ်တို့၏နောက်ဆုံးပုံအား ပြင်ဆင်ပါမည်။ နောက်ဆုံးအဆင့်မှာ nginx ဖြင့် ယခင်အဆင့်ရှိ ကျွန်ုပ်တို့၏ စည်းဝေးပွဲ၏ အစိတ်အပိုင်းကို နောက်ဆုံးပုံသို့ ကူးယူရန်ဖြစ်သည်။ ပုံ၏အရွယ်အစားသည် သိသိသာသာ လျော့ကျသွားသည်-
REPOSITORY TAG IMAGE ID CREATED SIZE
app latest 2c6c5da07802 29 minutes ago 36MB
ကျွန်ုပ်တို့၏ပုံသဏ္ဍာန်ဖြင့် ကွန်တိန်နာကို လည်ပတ်ပြီး အရာအားလုံး အဆင်ပြေကြောင်း သေချာပါစေ။
docker run -p8080:80 app
-p8080:80 ရွေးချယ်မှုကို အသုံးပြု၍ ကျွန်ုပ်တို့သည် ကျွန်ုပ်တို့၏ host machine တွင် port 8080 ကို nginx လည်ပတ်သည့် container အတွင်း၌ port 80 သို့ ပို့လိုက်ပါသည်။ browser တွင်ဖွင့်ပါ။
ရုပ်ပုံအရွယ်အစားကို 1.74 GB မှ 36 MB သို့ လျှော့ချခြင်းသည် သင့်အပလီကေးရှင်းကို ထုတ်လုပ်ရန် လိုအပ်သည့်အချိန်ကို သိသိသာသာ လျှော့ချပေးသည်။ ဒါပေမယ့် ပရိသတ်အချိန်ကို ပြန်သွားကြည့်ရအောင်။
$ time docker build -t app .
Sending build context to Docker daemon 608.8kB
Step 1/11 : FROM node:12.16.2-alpine3.11 as builder
Step 2/11 : RUN apk --no-cache --update --virtual build-dependencies add python make g++
---> Using cache
Step 3/11 : WORKDIR /app
---> Using cache
Step 4/11 : COPY . .
Step 5/11 : RUN npm ci
added 1357 packages in 47.338s
Step 6/11 : RUN npm run build --prod
Date: 2020-04-16T21:16:03.899Z - Hash: fffa0fddaa3425c55dd3 - Time: 39948ms
---> 27f1479221e4
Step 7/11 : FROM nginx:stable-alpine
Step 8/11 : WORKDIR /app
---> Using cache
Step 9/11 : RUN rm /etc/nginx/conf.d/default.conf
---> Using cache
Step 10/11 : COPY nginx/static.conf /etc/nginx/conf.d
---> Using cache
Step 11/11 : COPY --from=builder /app/dist/app .
Successfully built d201471c91ad
Successfully tagged app:latest
real 2m17.700s
user 0m0.000s
sys 0m0.000s
အလွှာများ၏ အစီအစဥ်ကို ပြောင်းလဲခြင်း။
ကျွန်ုပ်တို့၏ပထမအဆင့်သုံးဆင့်ကို သိမ်းဆည်းထားပါသည် (အရိပ်အမြွက် Using cache
) စတုတ္ထအဆင့်တွင်၊ ပရောဂျက်ဖိုင်များအားလုံးကို ကူးယူပြီး ပဉ္စမအဆင့်တွင် မှီခိုမှုကို ထည့်သွင်းထားသည်။ RUN npm ci
- 47.338s အထိ။ အလွန်ရှားရှားပါးပါး ပြောင်းလဲပါက မှီခိုမှုများအား အဘယ်ကြောင့် ပြန်လည်ထည့်သွင်းပါသနည်း။ သူတို့ ဘာကြောင့် ကက်မချတာလဲ ဆိုတာ အဖြေရှာကြည့်ရအောင်။ အဓိကအချက်မှာ Docker သည် command နှင့် ၎င်းနှင့်ဆက်စပ်နေသောဖိုင်များ ပြောင်းလဲခြင်းရှိမရှိကို အလွှာအလိုက် အလွှာတစ်ခုစီ စစ်ဆေးမည်ဖြစ်သည်။ စတုတ္ထအဆင့်တွင်၊ ကျွန်ုပ်တို့သည် ကျွန်ုပ်တို့၏ပရောဂျက်၏ဖိုင်များအားလုံးကို ကူးယူပြီး ၎င်းတို့တွင် အပြောင်းအလဲများရှိသည်၊ ထို့ကြောင့် Docker သည် ဤအလွှာကို cache မှမယူရုံသာမက နောက်ဆက်တွဲဖိုင်များအားလုံးကိုလည်း မယူပါ။ Dockerfile ကို အနည်းငယ် အပြောင်းအလဲ လုပ်ကြည့်ရအောင်။
FROM node:12.16.2-alpine3.11 as builder
RUN apk --no-cache --update --virtual build-dependencies add
python
make
g++
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build --prod
FROM nginx:1.17.10-alpine
RUN rm /etc/nginx/conf.d/default.conf
COPY nginx/static.conf /etc/nginx/conf.d
COPY --from=builder /app/dist/app .
ပထမဦးစွာ၊ package.json နှင့် package-lock.json ကို ကူးယူပြီး၊ ထို့နောက် မှီခိုအားထားမှုများကို ထည့်သွင်းပြီး ပရောဂျက်တစ်ခုလုံးကို ကူးယူပြီးနောက်မှသာ ဖြစ်သည်။ ရလဒ်အနေနှင့်:
$ time docker build -t app .
Sending build context to Docker daemon 608.8kB
Step 1/12 : FROM node:12.16.2-alpine3.11 as builder
Step 2/12 : RUN apk --no-cache --update --virtual build-dependencies add python make g++
---> Using cache
Step 3/12 : WORKDIR /app
---> Using cache
Step 4/12 : COPY package*.json ./
---> Using cache
Step 5/12 : RUN npm ci
---> Using cache
Step 6/12 : COPY . .
Step 7/12 : RUN npm run build --prod
Date: 2020-04-16T21:29:44.770Z - Hash: fffa0fddaa3425c55dd3 - Time: 38287ms
---> 1b9448c73558
Step 8/12 : FROM nginx:stable-alpine
Step 9/12 : WORKDIR /app
---> Using cache
Step 10/12 : RUN rm /etc/nginx/conf.d/default.conf
---> Using cache
Step 11/12 : COPY nginx/static.conf /etc/nginx/conf.d
---> Using cache
Step 12/12 : COPY --from=builder /app/dist/app .
Successfully built a44dd7c217c3
Successfully tagged app:latest
real 0m46.497s
user 0m0.000s
sys 0m0.000s
46 မိနစ်အစား 3 စက္ကန့် - ပိုကောင်းပါတယ်။ အလွှာများ၏ မှန်ကန်သော အစီအစဥ်သည် အရေးကြီးသည်- ဦးစွာ မပြောင်းလဲသောအရာများကို ကူးယူသည်၊ ထို့နောက် ရှားရှားပါးပါး အပြောင်းအလဲများ နှင့် နောက်ဆုံးတွင် မကြာခဏ ပြောင်းလဲမှုများ။
ထို့နောက် CI/CD စနစ်များတွင် ပုံများ စုစည်းမှုဆိုင်ရာ စကားလုံးအချို့။
ကက်ရှ်အတွက် ယခင်ပုံများကို အသုံးပြုခြင်း။
အကယ်၍ ကျွန်ုပ်တို့ တည်ဆောက်ရန်အတွက် SaaS ဖြေရှင်းချက် တစ်မျိုးမျိုးကို အသုံးပြုပါက၊ ဒေသခံ Docker cache သည် သန့်ရှင်းလတ်ဆတ်နေပေမည်။ ဖုတ်ထားသော အလွှာများရရှိရန် docker အား နေရာပေးရန်အတွက် ယခင်တည်ဆောက်ထားသော ပုံအား ပေးလိုက်ပါ။
GitHub Actions တွင် ကျွန်ုပ်တို့၏ အပလီကေးရှင်းကို တည်ဆောက်ခြင်း၏ ဥပမာကို ကြည့်ကြပါစို့။ ကျွန်ုပ်တို့သည် ဤ config ကိုအသုံးပြုသည်။
on:
push:
branches:
- master
name: Test docker build
jobs:
deploy:
name: Build
runs-on: ubuntu-latest
env:
IMAGE_NAME: docker.pkg.github.com/${{ github.repository }}/app
IMAGE_TAG: ${{ github.sha }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Login to GitHub Packages
env:
TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
docker login docker.pkg.github.com -u $GITHUB_ACTOR -p $TOKEN
- name: Build
run: |
docker build
-t $IMAGE_NAME:$IMAGE_TAG
-t $IMAGE_NAME:latest
.
- name: Push image to GitHub Packages
run: |
docker push $IMAGE_NAME:latest
docker push $IMAGE_NAME:$IMAGE_TAG
- name: Logout
run: |
docker logout docker.pkg.github.com
ပုံကို နှစ်မိနစ်နှင့် 20 စက္ကန့်အတွင်း စုစည်းပြီး GitHub Packages သို့ တွန်းပို့သည်-
ခုနက တည်ဆောက်ထားတဲ့ ပုံတွေပေါ်မှာ အခြေခံထားတဲ့ cache ကို အသုံးပြုဖို့အတွက် build ကို ပြောင်းကြည့်ရအောင်။
on:
push:
branches:
- master
name: Test docker build
jobs:
deploy:
name: Build
runs-on: ubuntu-latest
env:
IMAGE_NAME: docker.pkg.github.com/${{ github.repository }}/app
IMAGE_TAG: ${{ github.sha }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Login to GitHub Packages
env:
TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
docker login docker.pkg.github.com -u $GITHUB_ACTOR -p $TOKEN
- name: Pull latest images
run: |
docker pull $IMAGE_NAME:latest || true
docker pull $IMAGE_NAME-builder-stage:latest || true
- name: Images list
run: |
docker images
- name: Build
run: |
docker build
--target builder
--cache-from $IMAGE_NAME-builder-stage:latest
-t $IMAGE_NAME-builder-stage
.
docker build
--cache-from $IMAGE_NAME-builder-stage:latest
--cache-from $IMAGE_NAME:latest
-t $IMAGE_NAME:$IMAGE_TAG
-t $IMAGE_NAME:latest
.
- name: Push image to GitHub Packages
run: |
docker push $IMAGE_NAME-builder-stage:latest
docker push $IMAGE_NAME:latest
docker push $IMAGE_NAME:$IMAGE_TAG
- name: Logout
run: |
docker logout docker.pkg.github.com
ပထမဦးစွာ ကျွန်ုပ်တို့သည် အဘယ်ကြောင့် command နှစ်ခုကို စတင်အသုံးပြုသည်ကို ပြောပြလိုပါသည်။ build
. အမှန်မှာ multistage assembly တစ်ခုတွင် ထွက်ပေါ်လာသော image သည် နောက်ဆုံးအဆင့်မှ layer အစုအဝေးတစ်ခု ဖြစ်လိမ့်မည်။ ဤကိစ္စတွင်၊ ယခင်အလွှာများမှ အလွှာများကို ပုံတွင် ထည့်သွင်းမည်မဟုတ်ပါ။ ထို့ကြောင့်၊ ယခင်တည်ဆောက်မှုတစ်ခုမှနောက်ဆုံးပုံကိုအသုံးပြုသောအခါ၊ Docker သည် nodejs (Builder အဆင့်) ဖြင့် image ကိုတည်ဆောက်ရန်အဆင်သင့်အလွှာများကိုရှာဖွေနိုင်လိမ့်မည်မဟုတ်ပါ။ ဤပြဿနာကိုဖြေရှင်းရန်အတွက် အလယ်အလတ်ပုံတစ်ခုကို ဖန်တီးထားသည်။ $IMAGE_NAME-builder-stage
၎င်းကို ကက်ရှ်ရင်းမြစ်အဖြစ် နောက်ဆက်တွဲတည်ဆောက်မှုတွင် အသုံးပြုနိုင်ရန် GitHub Packages သို့ တွန်းပို့ပါသည်။
စုစုပေါင်း စုဝေးချိန်ကို တစ်မိနစ်ခွဲသို့ လျှော့ချခဲ့သည်။ ယခင်ပုံများကိုဆွဲရန် မိနစ်ဝက်ကြာသည်။
ကြိုတင်ပြင်ဆင်ခြင်း။
သန့်ရှင်းသော Docker cache ၏ပြဿနာကိုဖြေရှင်းရန် နောက်တစ်နည်းမှာ အလွှာအချို့ကို အခြားသော Dockerfile သို့ ရွှေ့ပြီး သီးခြားတည်ဆောက်ကာ Container Registry ထဲသို့ တွန်းချပြီး ၎င်းကို မိဘအဖြစ် အသုံးပြုရန်ဖြစ်သည်။
Angular အပလီကေးရှင်းတစ်ခုတည်ဆောက်ရန် ကျွန်ုပ်တို့၏ကိုယ်ပိုင် nodejs ပုံကို ဖန်တီးပါသည်။ ပရောဂျက်တွင် Dockerfile.node ဖန်တီးပါ။
FROM node:12.16.2-alpine3.11
RUN apk --no-cache --update --virtual build-dependencies add
python
make
g++
ကျွန်ုပ်တို့သည် Docker Hub တွင် အများသူငှာပုံတစ်ခုကို စုဆောင်းပြီး တွန်းပို့သည်-
docker build -t exsmund/node-for-angular -f Dockerfile.node .
docker push exsmund/node-for-angular:latest
ယခု ကျွန်ုပ်တို့၏ ပင်မ Dockerfile တွင် ကျွန်ုပ်တို့သည် ပြီးမြောက်သောပုံကို အသုံးပြုသည်-
FROM exsmund/node-for-angular:latest as builder
...
ကျွန်ုပ်တို့၏ဥပမာတွင်၊ တည်ဆောက်ချိန်သည် လျော့နည်းသွားခြင်းမရှိသော်လည်း သင့်တွင် ပရောဂျက်များစွာရှိပြီး ၎င်းတို့တစ်ခုစီတွင် တူညီသောမှီခိုမှုတစ်ခုကို ထည့်သွင်းရပါက ကြိုတင်တည်ဆောက်ထားသောပုံများသည် အသုံးဝင်နိုင်ပါသည်။
docker ပုံများတည်ဆောက်မှုကို အရှိန်မြှင့်ရန်အတွက် နည်းလမ်းများစွာကို ကျွန်ုပ်တို့ကြည့်ရှုခဲ့သည်။ အကယ်၍ သင်သည် ဖြန့်ကျက်မှုကို လျင်မြန်စွာ လုပ်ဆောင်လိုပါက သင့်ပရောဂျက်တွင် ၎င်းကို အသုံးပြုကြည့်ပါ-
- အကြောင်းအရာကို လျှော့ချခြင်း၊
- သေးငယ်သောမိဘပုံများအသုံးပြုမှု;
- စင်မြင့်စည်းဝေးပွဲ;
- ကက်ရှ်ကို ထိရောက်စွာ အသုံးပြုနိုင်ရန် Dockerfile အတွင်းရှိ ညွှန်ကြားချက်များ အစီအစဥ်ကို ပြောင်းလဲခြင်း၊
- CI/CD စနစ်များတွင် ကက်ရှ်တစ်ခု တည်ဆောက်ခြင်း၊
- ရုပ်ပုံများကို အကြိုဖန်တီးခြင်း။
ဥပမာသည် Docker အလုပ်လုပ်ပုံကို ပိုမိုရှင်းလင်းစေမည်ဟု မျှော်လင့်ပြီး သင်၏အသုံးချမှုကို အကောင်းဆုံးပုံစံသတ်မှတ်နိုင်လိမ့်မည်ဖြစ်သည်။ ဆောင်းပါးမှနမူနာများဖြင့် ကစားရန်အတွက် သိုလှောင်ခန်းတစ်ခုကို ဖန်တီးထားသည်။
source: www.habr.com