Docker 入门

1 Docker安装

参照官方文档,本篇基于Ubuntu 14.04
AUFS存储
为了让 Docker 使用 aufs 存储,推荐安装 linux-image-extra 软件包

$ sudo apt-get install \
    linux-image-extra-$(uname -r) \
    linux-image-extra-virtual

在 Ubuntu 14.04上安装Docker,需要安装 apparmor $ sudo apt-get install apparmor
更新APT镜像源
首先需要安装 apt-transport-https 包支持 https 协议的源

$ sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    software-properties-common

添加源的 gpg 密钥curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
添加源

sudo add-apt-repository \
   "deb [arch=amd64] https://download.docker.com/linux/ubuntu \
   $(lsb_release -cs) \
   stable"

安装Docker
更新源sudo apt-get update
安装docker sudo apt-get install docker-ce
其他安装命令

sudo apt-get install -y docker.io
curl -s https://get.docker.com | sh

添加当前用户到docker组避免每次输sudo sudo usermod -aG docker your-user
常用命令

docker version  ##查看版本信息
sudo docker run hello-world ##验证hello world
sudo service docker start  ##启动docker服务
sudo service docker stop  ##关闭docker服务

2 Docker操作

2.1 查看docker信息

# 查看docker版本  
$docker version  
# 显示docker系统的信息  
$docker info 

2.2 对image的操作

# 检索image  
$docker search image_name  
# 下载image  
$docker pull image_name  
# 列出镜像列表; -a, --all=false Show all images; --no-trunc=false Don't truncate output; -q, --quiet=false Only show numeric IDs  
$docker images  
# 删除一个或者多个镜像; -f, --force=false Force; --no-prune=false Do not delete untagged parents  
$docker rmi image_name  
# 显示一个镜像的历史; --no-trunc=false Don't truncate output; -q, --quiet=false Only show numeric IDs  
$docker history image_name  

2.3 启动容器

# 在容器中运行"echo"命令,输出"hello word"  
$docker run image_name echo "hello word"  
# 交互式进入容器中  
$docker run -i -t image_name /bin/bash  
# 在容器中安装新的程序  
$docker run image_name apt-get install -y app_name  

2.4 查看容器

# 列出当前所有正在运行的container  
$docker ps  
# 列出所有的container  
$docker ps -a  
# 列出最近一次启动的container  
$docker ps -l  

2.5 保存对容器的修改

# 保存对容器的修改; -a, --author="" Author; -m, --message="" Commit message  
$docker commit ID new_image_name  

2.6 对容器的操作

# 删除所有容器  
$docker rm `docker ps -a -q`  
# 删除单个容器; -f, --force=false; -l, --link=false Remove the specified link and not the underlying container; -v, --volumes=false Remove the volumes associated to the container  
$docker rm Name/ID  
# 停止、启动、杀死一个容器  
$docker stop Name/ID  
$docker start Name/ID  
$docker kill Name/ID  
# 从一个容器中取日志; -f, --follow=false Follow log output; -t, --timestamps=false Show timestamps  
$docker logs Name/ID  
# 列出一个容器里面被改变的文件或者目录,list列表会显示出三种事件,A 增加的,D 删除的,C 被改变的  
$docker diff Name/ID  
# 显示一个运行的容器里面的进程信息  
$docker top Name/ID  
# 从容器里面拷贝文件/目录到本地一个路径  
$docker cp Name:/container_path to_path  
$docker cp ID:/container_path to_path  
# 重启一个正在运行的容器; -t, --time=10 Number of seconds to try to stop for before killing the container, Default=10  
$docker restart Name/ID  
# 附加到一个运行的容器上面; --no-stdin=false Do not attach stdin; --sig-proxy=true Proxify all received signal to the process  
$docker attach ID 

2.7 保存和加载镜像

# 保存镜像到一个tar包; -o, --output="" Write to an file  
$docker save image_name -o file_path  
# 加载一个tar包格式的镜像; -i, --input="" Read from a tar archive file  
$docker load -i file_path  
# 机器a  
$docker save image_name > /home/save.tar  
# 使用scp将save.tar拷到机器b上,然后:  
$docker load < /home/save.tar  

2.8 登录registry server

# 登陆registry server; -e, --email="" Email; -p, --password="" Password; -u, --username="" Username  
$docker login 

2.9 发布image

# 发布docker镜像  
$docker push new_image_name 

2.10 根据Dockerfile 构建出一个容器

#build  
      --no-cache=false Do not use cache when building the image  
      -q, --quiet=false Suppress the verbose output generated by the containers  
      --rm=true Remove intermediate containers after a successful build  
      -t, --tag="" Repository name (and optionally a tag) to be applied to the resulting image in case of success  
$docker build -t image_name Dockerfile_path  

3 Docker 运行

3.1 Docker 运行Nginx

国内Docker镜像

网易云   https://c.163.com/hub
阿里云   https://dev.aliyun.com/list.html

从网易云拉取镜像 docker pull hub.c.163.com/library/nginx:latest
后台运行Nginx容器

docker run -d -p 8080:80 hub.c.163.com/library/nginx  ##`-d`表示后台运行,`-p 8080:80` 将主机8080端口映射到container的80端口
docker run -d --name nginx -v /usr/share/nginx/html hub.c.163.com/library/nginx  ##挂载主机目录运行nginx
docker inspect nginx ##检查容器信息,挂载的是本机/var/lib/docker/volumes
docker run -d  -v $PWD/code: /usr/share/nginx/html ##将本地code目录挂载到容器/usr/share/nginx/html目录
docker create -v $PWD/data:/var/mydata --name data_container ubuntu 
docker run -it --volumes-from data_container ubuntu /bin/bash

查看端口状态 netstat -na|grep 8080,使用浏览器登陆查看是否运行成功

3.2 制作Java web应用镜像

下载相关

下载JPress war包  `https://github.com/JpressProjects/jpress/tree/alpha/wars`
下载Tomcat镜像   `docker pull hub.c.163.com/library/tomcat:latest`
下载mysql镜像    `docker pull hub.c.163.com/library/mysql:latest`

Build镜像
创建Dockerfile文件如下,以tomcat镜像为基础,copy当前目录下jpress.war文件到container中的/usr/local/tomcat/webapps目录

from hub.c.163.com/library/tomcat
MAINTAINER zll
COPY jpress.war /usr/local/tomcat/webapps/

以当前目录的dockerfile文件 Build镜像 docker build -t jpress:latest .
运行容器
运行mysql镜像 docker run -d -p 8089:3306 -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_DATABASE=jpress hub.c.163.com/library/mysql
运行jpress镜像 docker run -d -p 8088:8080 jpress
重启jpress容器 docker restart xxxx,通过浏览器访问

3.3 Docker Compose

安装

sudo curl -L https://github.com/docker/compose/releases/download/1.21.0/docker-compose-$(uname -s)-$(uname -m) -o /usr/local/bin/docker-compose
sudo chmod a+x /usr/local/bin/docker-compose ##添加执行权限 
docker-compose --version  检查是否安装成功
docker-compose up -d ##启动 -d表示不输出日志
docker-compose build ##构建
docker-compose stop ##停止
docker-compose rm ##删除容器

创建docker-compose.yml文件,

version: '3.1'

services:

  ghost:
    image: ghost:latest
    restart: always
    ports:
      - 8080:2368
    environment:
      # see https://docs.ghost.org/docs/config#section-running-ghost-with-config-env-variables
      database__client: mysql
      database__connection__host: db
      database__connection__user: root
      database__connection__password: example
      database__connection__database: ghost

  db:
    image: mysql:5.7
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: example

在yml文件目录下docker-compose up -d启动容器,通过浏览器输入网址访问

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容