介绍如何使用Docker构建镜像,并经过阿里云镜像服务分发到ECS服务器,运行该镜像。linux
容器技术
容器是一个容许咱们在资源隔离的过程当中,运行应用程序和其依赖项的 、轻量的 、操做系统级别的虚拟化技术, 运行应用程序所需的全部必要组件都打包为单个镜像,这个镜像是能够重复使用的。当镜像运行时,它是运行在独立的环境中,并不会和其余的应用共享主机操做系统的内存、CPU或磁盘。这保证了容器内的进程不会影响到容器外的任何进程。golang
镜像仓库(Registry)
Docker的镜像存储中心一般被称为Registry。当您须要获取本身私有镜像时,首先须要登陆Registry,而后拉取镜像。修改过镜像以后,您能够再次将镜像推送回Registry中去。或者在本地经过Docker镜像构建的功能生成镜像,再推送到Registry中。docker
容器镜像服务ACR(Alibaba Cloud Container Registry)
阿里云容器镜像服务ACR默认实例版提供基础的容器镜像服务,包括安全的应用镜像托管能力、精确的镜像安全扫描功能、稳定的国内外镜像构建服务以及便捷的镜像受权功能,从而方便用户进行镜像全生命周期管理。shell
1.打开系统自带的终端工具。
Windows:CMD或Powershell。
MAC:Terminal。json
ssh root@123.123.123.123
命令显示结果以下:centos
3.输入yes,赞成继续后将会提示输入登陆密码。 密码为已建立的云服务的ECS的登陆密码。安全
Docker 是一个开源的容器引擎,用于建立、管理和编排容器,能够轻松为任何应用建立一个轻量级、可移植、自给自足的容器。本步骤将在ECS上部署一个Docker服务,并配置DockerHub的镜像加速器。服务器
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
yum makecache fast && yum -y install docker-ce
systemctl start docker
tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["https://registry.docker-cn.com"] } EOF
systemctl restart docker
本步骤操做将在工做空间下建立一个基于Golang的HelloWorld代码文件和一个用来构建运行Hello代码所需环境镜像的Dockerfile文件。网络
mkdir -p /tmp/demo && cd /tmp/demo
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
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
本步骤将指导您使用Docker基本命令构建和运行镜app
docker build . -t demo:v1
命令运行结果以下所示:
说明:
参数.表示指定当前路径做为构建上下文,即Dockerfile所在的本地路径。
参数-t demo:v1指定镜像名称和标签。
docker run -d -p 8000:80 demo:v1
命令运行结果以下所示:
说明:
参数-d设置容器运行模式为后台运行。
参数-p 8000:80将容器内部使用的网络端口映射到主机上,其中8000为主机端口,80为容器内部使用端口。
curl localhost:8000
命令运行结果以下所示:
4.使用docker rm命令删除容器。
docker rm -f $(docker ps -a | grep "demo:v1" | awk '{print $1}')
命令运行结果以下所示:
本步骤操做将指导您使用本身的阿里云帐号开通容器镜像服务并建立镜像仓库。阿里云容器镜像服务默认实例版可无偿使用,其使用限制请参见容器镜像服务计费说明。
1.使用您的阿里云主帐号登陆容器镜像服务控制台。
2.【前往开通】》单击【设置Registry登陆密码】》设置阿里云Docker Registry登陆密码,而后单击 【肯定】 。
3.在容器镜像服务控制台,依次单击 【默认实例】 > 【命名空间】 > 【建立命名空间】,在 【建立命名空间】 弹框中填写命令空间名称,而后单击 【肯定】 。
本步骤操做将本地镜像推送到远程仓库中,并运行远程仓库中的指定版本镜像。请将本步骤命令中涉及的远程镜像地址替换为步骤六中建立的镜像仓库的公网地址。
1.执行如下命令登陆到阿里云Docker Registry。
docker login --username="用户名" registry.cn-hangzhou.aliyuncs.com
说明: 请将下面命令中的用户名替换为您的阿里云帐号全名,回车后输入远程镜像仓库密码,密码为步骤六开通服务时设置的密码。
请登陆阿里云用户中心查看您的主帐号用户名称。
命令运行结果以下所示:
2.标记本地镜像,将其纳入远程仓库。
docker tag demo:v1 registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1
3.将本地镜像推送到远程仓库。
docker push registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1
命令运行结果以下所示:
docker pull registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1
命令运行结果以下所示:
docker run -d -p 8000:80 registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1
命令运行结果以下所示:
curl localhost:8000
命令运行结果以下所示: