Docker的相关使用及实践

简介: Docker的相关使用及实践

A.搭建Docker服务。

  1. 安装Docker的依赖库。

yum install -y yum-utils device-mapper-persistent-data lvm2

  1. 添加Docker CE的软件源信息。

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

  1. 安装Docker CE。

yum makecache fast &&
yum -y install docker-ce

  1. 启动Docker服务。

systemctl start docker

  1. 配置DockerHub镜像加速器。

tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://registry.docker-cn.com"]
}
EOF

  1. 重启Docker服务。

systemctl restart docker

B.准备应用代码和Dockerfile
在工作空间下创建一个基于Golang的HelloWorld代码文件和一个用来构建运行Hello代码所需环境镜像的Dockerfile文件。

  1. 创建工作空间。

mkdir -p /tmp/demo && cd /tmp/demo

  1. 在工作空间下创建HelloWorld代码文件,用来在容器环境中监听HTTP服务,输出HelloWorld字符串。

cat > /tmp/demo/main.go << EOF
package main

import (

    "fmt"
    "net/http"

)

func main() {

    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
            fmt.Fprintf(w, "Hello! World\n")
    })

    fmt.Println("start to serve...")
    http.ListenAndServe(":80", nil)

}
EOF

  1. 在工作空间下创建Dockerfile文件。

cat > /tmp/demo/Dockerfile << EOF
FROM golang:1.12-alpine

change current working dir

WORKDIR /go/src/app

copy main.go into /go/src/app

COPY . .

go build and install the app

RUN go install -v ./...

run the app by default

CMD ["app"]
EOF

C. 本地构建镜像并运行镜像

  1. 使用docker build命令构建镜像。

docker build . -t demo:v1

Sending build context to Docker daemon 3.072kB

Step 1/5 : FROM golang:1.12-alpine

1.12-alpine: Pulling from library/golang

c9b1b535fdd9: Pull complete

cbb0d8da1b30: Pull complete

d909eff28200: Pull complete

665fbbf998e4: Pull complete

4985b1919860: Pull complete

Digest: sha256:3f8e3ad3e7c128d29ac3004ac8314967c5ddbfa5bfa7caa59b0de493fc01686a

Status: Downloaded newer image for golang:1.12-alpine

---> 76bddfb5e55e

Step 2/5 : WORKDIR /go/src/app

---> Running in 267b6eaa6339

Removing intermediate container 267b6eaa6339

---> b945a18744ab

Step 3/5 : COPY . .

---> 38bf768aed84

Step 4/5 : RUN go install -v ./...

---> Running in ca02c0e66ee8

app

Removing intermediate container ca02c0e66ee8

---> 6105ed5cc6f7

Step 5/5 : CMD ["app"]

---> Running in 5bc835f7b9de

Removing intermediate container 5bc835f7b9de

---> dfeafa2824e6

Successfully built dfeafa2824e6

Successfully tagged demo:v1

  1. 使用docker run命令运行镜像。

docker run -d -p 8000:80 demo:v1

[root@iZuf670yt5j8prmz4bkmpgZ demo]# docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

e897cc02550c demo:v1 "app" 11 seconds ago Up 11 seconds 0.0.0.0:8000->80/tcp brave_wescoff

  1. 使用curl工具访问容器中的HelloWorld服务。

curl localhost:8000

D. 推送镜像

  1. 登录到阿里云Docker Registry。

[root@iZuf670yt5j8prmz4bkmpgZ ~]# docker login --username="XXX@XXX.com" registry.cn-shanghai.aliyuncs.com

Password:

WARNING! Your password will be stored unencrypted in /root/.docker/config.json.

Configure a credential helper to remove this warning. See

https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded

  1. 标记本地镜像,将其归入远程仓库。

[root@iZuf670yt5j8prmz4bkmpgZ ~]# docker image ls

REPOSITORY TAG IMAGE ID CREATED SIZE

demo v1 dfeafa2824e6 13 minutes ago 354MB

golang 1.12-alpine 76bddfb5e55e 2 years ago 346MB

docker tag 76bddfb5e55e registry.cn-shanghai.aliyuncs.com/space_test001/demo:v1

[root@iZuf670yt5j8prmz4bkmpgZ ~]# docker image ls

REPOSITORY TAG IMAGE ID CREATED SIZE

demo v1 dfeafa2824e6 14 minutes ago 354MB

golang 1.12-alpine 76bddfb5e55e 2 years ago 346MB

registry.cn-shanghai.aliyuncs.com/space_test001/demo v1 76bddfb5e55e 2 years ago 346MB

  1. 将本地镜像推送到远程仓库。

docker push registry.cn-shanghai.aliyuncs.com/space_test001/demo:v1

The push refers to repository [registry.cn-shanghai.aliyuncs.com/space_test001/demo]

7306dca01e79: Pushed

3957f7032fc4: Pushed

12c4e92b2d48: Pushed

45182158f5da: Pushed

5216338b40a7: Pushed

v1: digest: sha256:1782cafde43390b032f960c0fad3def745fac18994ced169003cb56e9a93c028 size: 1365

  1. 拉取指定版本的远程镜像。

docker pull registry.cn-shanghai.aliyuncs.com/space_test001/demo:v1

相关文章
|
3月前
|
Kubernetes Devops 持续交付
DevOps实践:使用Docker和Kubernetes实现持续集成和部署网络安全的守护盾:加密技术与安全意识的重要性
【8月更文挑战第27天】本文将引导读者理解并应用DevOps的核心理念,通过Docker和Kubernetes的实战案例,深入探讨如何在现代软件开发中实现自动化的持续集成和部署。文章不仅提供理论知识,还结合真实示例,旨在帮助开发者提升效率,优化工作流程。
|
1月前
|
Linux 持续交付 Docker
掌握Docker:从入门到实践
Docker 是一个开源容器引擎,允许开发者将应用及其依赖打包成可移植的容器,在任意 Linux 机器上运行。本文从基本概念入手,详细介绍 Docker 的安装、基本操作、镜像构建及 Docker Compose 的使用,并通过实战案例展示如何部署 Web 应用、构建微服务架构及实现 CI/CD。通过学习,你将掌握 Docker 的核心功能,提升应用开发和部署效率。
|
2月前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
230 69
|
16天前
|
Kubernetes 持续交付 Docker
探索DevOps实践:利用Docker与Kubernetes实现微服务架构的自动化部署
【10月更文挑战第18天】探索DevOps实践:利用Docker与Kubernetes实现微服务架构的自动化部署
61 2
|
24天前
|
存储 运维 云计算
探索Docker容器化:从入门到实践
在这个快速发展的云计算时代,Docker容器化技术正在改变应用的开发、部署和管理方式。本文旨在为初学者提供一个关于Docker的全面入门指南,并通过实践案例展示Docker在实际开发中的应用。我们将一起了解Docker的核心概念、基本操作、网络和存储,以及如何构建和部署一个简单的Web应用。无论你是开发者还是运维人员,本文都会帮助你快速掌握Docker的核心技能。
|
25天前
|
运维 JavaScript 虚拟化
探索容器化技术:Docker的实践与应用
【10月更文挑战第9天】探索容器化技术:Docker的实践与应用
47 3
|
1月前
|
Ubuntu Linux 虚拟化
Docker入门实践(一)
Docker入门实践(一)
|
1月前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker与Kubernetes入门
【9月更文挑战第30天】在云计算的浪潮中,云原生技术正以前所未有的速度重塑着软件开发和运维领域。本文将通过深入浅出的方式,带你了解云原生的核心组件——Docker容器和Kubernetes集群,并探索它们如何助力现代应用的构建、部署和管理。从Docker的基本命令到Kubernetes的资源调度,我们将一起开启云原生技术的奇妙之旅。
|
20天前
|
运维 Kubernetes 监控
掌握Docker容器化技术:构建、部署与管理的高效实践
【10月更文挑战第14天】掌握Docker容器化技术:构建、部署与管理的高效实践
34 0
|
22天前
|
JavaScript 前端开发 Docker
拿下奇怪的前端报错(二):nvm不可用报错`GLIBC_2.27‘‘GLIBCXX_3.4.20‘not Found?+ 使用docker构建多个前端项目实践
本文介绍了在多版本Node.js环境中使用nvm进行版本管理和遇到的问题,以及通过Docker化构建流程来解决兼容性问题的方法。文中详细描述了构建Docker镜像、启动临时容器复制构建产物的具体步骤,有效解决了不同项目对Node.js版本的不同需求。