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
启动容器,通过浏览器输入网址访问