仅需十个步骤,让我们走进 Docker 的奇妙世界。Docker is amazing!
Step 1 创建一个 Docker 文件
Dockerfile 包括您要执行以创建镜像的命令列表。 这个文件中最常见的命令如下: FROM 和 MAINTAINER 通常出现在文件第一行,用于选择基础镜像和说明维护人信息,例如:
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 调试应用程序