奇妙的 Docker 使用技巧十连发

仅需十个步骤,让我们走进 Docker 的奇妙世界。Docker is amazing!

Docker十技巧

Step 1  创建一个 Docker 文件

Dockerfile 包括您要执行以创建镜像的命令列表。 这个文件中最常见的命令如下: FROMMAINTAINER 通常出现在文件第一行,用于选择基础镜像和说明维护人信息,例如: 

FROM ubuntu:14.04 MAINTAINER Moshe Kaplan

RUN: 运行shell命令 

RUN apt-get update

ADD: 将本地目录中的文件添加到docker镜像中 

ADD unicorn.rb /app/config/unicorn.rb

ENV: 添加环境变量 

ENV RAILS_ENV staging

Step 2  确保在 Docker 文件中有一个永远执行的命令 

只要最后一个命令停止运行,Docker 镜像就会停止。 如果您没有服务或运行守护进程(或者您不会将此镜像用作基础镜像),那么请添加无限循环。

CMD while true; do sleep 1000; done

Step 3  在目标机器上安装 Docker 

这就是为什么你需要 Chef / Ansible / Puppet 的原因

sudo yum -y install docker & sudo service docker start

在 ubuntu 系统中:

sudo apt-get update &&

sudo apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D &&

sudo apt-add-repository 'deb https://apt.dockerproject.org/repo ubuntu-xenial main' &&

sudo apt-get update &&

apt-cache policy docker-engine &&

sudo apt-get install -y docker-engine

sudo systemctl status docker

Step 4  构建和标记镜像

sudo docker build -t my_company/my_app . sudo docker rm my_app

在运行 Docker 容器时,使用-p标志将内部端口映射到实际的外部端口

sudo docker create -p 80:80 --name my_app my_company/my_app

Step 5  运行并检查您的镜像 

启动容器: 

sudo docker start my_app sudo docker run -d -v /home/ubuntu/java:/home/ubuntu/java bat/spark

列出正在执行的容器: 

sudo docker ps -a

显示日志: 

sudo docker logs my_app

链接正在运行的容器:

sudo docker exec -it my_app /bin/bash

停止容器: 

sudo docker stop my_app

Step 6  在 github 上执行任务 

如果要从 github 获取代码并提供捆绑的应用程序,请使用以下命令:

sudo vi ~/.ssh/id_rsa sudo chmod 600 ~/.ssh/id_rsa git clone git@github.com:company/repository.git cd repository bundle exec rake assets:precompile

Step 7  使用AWS ECR AWS 

ECR是一种存储库解决方案,可用于将构建的镜像部署在各种解决方案(如 CodeBuild)中 设置凭证: 

aws configure

添加到 ECR: 

sudo $(aws ecr get-login --region us-east-1) sudo docker build -t lemonade_app . sudo docker tag my_app:latest AWS_ID.dkr.ecr.us-east-1.amazonaws.com/my_app:latest sudo docker push AWS_ID.dkr.ecr.us-east-1.amazonaws.com/my_app:latest

Step 8  添加卷 

如果要为底层主机添加卷(例如对于 DB 持久性数据),则应该在镜像内定义映射卷: RUN 

mkdir -p /data VOLUME ["/data"]

并将其映射到运行的容器: 

sudo docker run -d -v /data:/data bat/spark

请注意,您还可以将卷映射到另一个docker容器,以便您可以在容器之间共享数据(例如unix套接字): 

源容器: 

sudo docker create -v /dbdata --name dbstore training/postgres /bin/true

目标容器: 

sudo docker run -d --volumes-from dbstore --name db1 training/postgres

Step 9  将主机添加到/ etc / hosts文件 

只要在运行命令中添加: 

sudo docker run -d --add-host=SERVER_NAME:127.0.0.1 bat/spark

Step 10  调试应用程序



留言