容器管理工具
以往 SD 架構伺服器時,要根據服務的伺服器、資料庫的伺服器、語言引擎的伺服器、應用程式這四種彼此需要的依賴程式庫和中介軟體,安裝完成,還要進行環境設定,調整更新這些軟體的版本號,以及確保應用程式和軟體間的相容性過程相當繁瑣。
Docker Client (CLI)
API (Restful)
Docker Server (Daemon)
Core Modules:
-
Network
-
Data Volumes
-
Contaniner
-
Image
問題甚至暴露在開發環境與部屬環境之間存在的差異性,倘若系統很大,微服務更多,那後果難以想像。
-
install docker for mac & sign up an account
-
git clone https://github.com/docker/doodle.git
-
~$ cd doodle/cheers2019
-
cheers2019$ docker build -t doodle/cheers2019 .
容器能夠解決軟體移植和程式間去耦合性的問題,並且能全權控制容器,包含容器對資源消耗的限制。
Usage: docker build [OPTIONS] PATH | URL | - Build an image from a Dockerfile
Sending build context to Docker daemon // means docker server
1.11-alpine: Pulling from library/golang // works like Git
Status: Downloaded newer image for golang:1.11-alpine ---> e116d2efa2ab (6 碼)
FROM golang:1.11-alpine AS builder (Company/AppName: ID)
RUN apk add
Resolving Middleware & Dependency
WORKDIR /project
COPY cheers.go
RUN CGO_ENABLED=0 GOOS=linux go build -a -ldflags '-extldflags "-static"' -o cheers cheers.go
FROM scratch
COPY --from=builder /project/cheers /cheers
ENTRYPOINT ["/cheers"]
Successfully built e17fa186f882
Successfully tagged queens/cheers2019:latest
Namespace/Repository: ID
queens/cheers2019:latest
(Company/AppName: version)
-
cheers2019$ docker run -it --rm queens/cheers2019
透過容器技術的封裝,藉此移植應用程式於跨平台上運行 (不依賴原有執行環境)。
-
cheers2019$ docker login
-
cheers2019$ docker push queens/cheers2019 // target
The push refers to repository [docker.io/queens/cheers2019] 4092464d0de4: Pushed (12 碼) latest: digest: sha256:6fbe80f193
-
cheers2019$ docker run -d -p 80:80 --name
以上指定了容器外部暴露的連結埠!
僅透過一命令,能完成軟題從 A 平台部署到 B 平台過程,而不需要根據 Localhost 進行 env 設定, 大幅度提升了分散式機器的跨平台部署的效率和成果。