微信号:daocloudpublic

介绍:分享Docker及容器技术相关信息,助力开发者和企业云海扬帆!本公众号由DaoCloud负责运营.

译见 | 奇妙的 Docker 使用技巧十连发

2017-06-23 18:18 夏岩&杨雪颖编译

在「译见」往期的文章里已经非常详尽地为你展现了关于 Docker 是凭借哪些优势突出重围,又是如何在大型企业的真实场景中实际运用。那么今天将带你实操,仅需十个步骤,走进 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  调试应用程序




相关推荐:

揭秘网红 Docker 的十大竞争优势

译见|你用 Spotify 听的音乐,也流经 Docker 之手?

点击 阅读原文

 
道客船长 更多文章 译见|构建用户管理微服务(三):实现和测试存储库 船长推荐 | 微服务入门指南 关于“微服务”和“FinTech”,DaoCloud 带您与行业大咖乌镇论道! 奇妙的 Docker 使用技巧十连发!|航海日志 Vol.16 老爸,我想对你说...
猜您喜欢 聊聊Java数据库开发的那点事儿 《大数据原理与实践》课程实践教程2:TOS应用组件 数据科学家每天都在做些什么? 黑客怪狗:声讨乐天只是想以黑客的方式表达“爱国”|长篇报道 我所理解的 PHP Trait