docker 小结
Docker 是一个开源的容器引擎,它有助于更快地交付产品。
Docker 可将应用程序和基础设施层隔离,并且将基础设施当作程序一样进行管理。使用 Docker,可以更快地打包,测试以及部署应用程序,并可以缩短从编程到部署运行代码的周期。
安装
-
ubuntu
wget -qO- https://get.docker.com/ | sh
当要以非
root
用户可以直接运行docker
时,需要执行sudo usermod -aG docker runoob
命令,然后重新登陆,否则会报错或者安装 Docker 社区版仓库
sudo apt-get -y install \ apt-transport-https \ ca-certificates \ curl 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" sudo apt-get update #在 Ubuntu 上安装最新的 Docker 社区版 sudo apt-get -y install docker-ce #测试你的 Docker 社区版是否安装成功 sudo docker run hello-world
-
启动
sudo service docker start
-
测试运行
hello-world
docker run hello-world
-
镜像加速
鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决,比如网易的镜像地址。
新版的
Docker
使用/etc/docker/daemon.json
(Linux
)或者%programdata%\docker\config\daemon.json
(Windows
)来配置Daemon
。请在该配置文件中加入(没有该文件的话,请先建一个):
{"registry-mirrors": ["http://hub-mirror.c.163.com"] }
或者注册阿里云账户
访问 https://cr.console.aliyun.com… 可以获得自己的加速器 https://××××××.mirror.aliyuncs.com
针对
Docker
客户端版本大于1.10.0
的用户,可以通过修改daemon
配置文件/etc/docker/daemon.json
来使用加速器:sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-'EOF' {"registry-mirrors": ["https://6fzym3rt.mirror.aliyuncs.com"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker
-
普通用户加入 docker 组
有时候,不想每次输入
sudo
,这时,我们可以将用户加入docker
组。当然,这是不安全的,官方不推荐这样做。# 创建 docker 组(如果没有的话)sudo groupadd docker # 将当前用户加入 docker 组 sudo gpasswd -a ${USER} docker # 重新启动 docker 服务 sudo service docker restart 或 sudo systemctl restart docker # 当前用户退出系统重新登陆 su root su franson # 运行 docker 命令 docker ps
容器
-
运行
docker run alpine:latest /bin/echo "Hello world"
-
运行交互式的容器
docker run -i -t -v /test:/soft ubuntu:15.10 /bin/bash
各个参数解析:
-t: 在新容器内指定一个伪终端或终端。-i: 允许你对容器内的标准输入 (STDIN) 进行交互。-v: 挂载容器,前者是宿主机中目录,后者是容器内目录,再加个 `:` 的话,是权限
-
启动容器(后台模式)
docker run -d ubuntu:15.10 /bin/sh -c "while true; do echo hello world; sleep 1; done"
这时,容器在后台运行,当前输入容器不会打印
hello world
,只会返回一个ID
号,通过它,可以使用docker logs $ID
来查看输出内容。docker logs -f $ID
可以让dokcer logs
像使用tail -f
一样来输出容器内部的标准输出。指定
-p
标识来绑定指定端口。默认开放5000
,映射到主机端口32769
上。docker run -d -p 5000:5000 xx/1.0 node app.js
已经停止的:
docker start container_id
正地运行的重启:
docker restart
进入容器:
docker exec -it container_id /bin/bash
特权方式:
docker run -it --privileged -v /test:/soft centos /bin/bash
-
查看容器
docker ps # 正在运行的 docker ps -a # 所有的 docker ps -l # 最后一次创建的 docker top determined_swanson # 查看进程 docker inspect determined_swanson # 底层信息
-
停止容器
docker stop container_id docker stop $(docker ps -a -q) # 停止所有容器
-
移除容器
docker rm container_id docker rm $(docker ps -a -q) # 删除所有未运行 Docker 容器
镜像
-
查看镜像
# 查看所有镜像 docker images # 搜索服务器上可用的镜像 docker search httpd
-
创建镜像
# 下载 docker pull httpd # 最小镜像 alpine
当我们从
docker
镜像仓库中下载的镜像不能满足我们的需求时,我们可以通过以下两种方式对镜像进行更改。- 从已经创建的容器中更新镜像,并且提交这个镜像,详见
更新
- 使用
Dockerfile
指令来创建一个新的镜像docker build -t xx:1.0 .
- 从已经创建的容器中更新镜像,并且提交这个镜像,详见
参数说明:-t:指定要创建的目标镜像名
.:`Dockerfile` 文件所在目录,可以指定 `Dockerfile` 的绝对路径
-
更新
更新镜像之前,我们需要使用镜像来创建一个容器。
docker run -t -i ubuntu:15.10 /bin/bash
在运行的容器内进行操作,输入
exit
命令来退出这个容器。此时这个容器,是按我们的需求更改的容器。我们可以通过命令docker commit
来提交容器副本。docker commit -m="has update" -a="runoob" e218edb10161 runoob/ubuntu:v2
各个参数说明:
-m: 提交的描述信息
-a: 指定镜像作者
e218edb10161:容器 ID
runoob/ubuntu:v2: 指定要创建的目标镜像名
-
删除
# 删除特定镜像 docker rmi id # 删除所有未打 tag 的镜像 docker rmi $(docker images -q | awk '/^<none>/ { print $3}') # 删除所有镜像 docker rmi $(docker images -q) # 删除没有使用的镜像 docker rmi -f $(docker images | grep "<none>" | awk "{print \$3}")
-
设置镜像标签
docker tag 860c279d2fec runoob/centos:dev
Dockerfile 样例
# 用这个文件生成 gitlab-ci 需要的 docker 容器
# 同时需要有个 jdk-8u161-linux-x64.tar.gz 文件放在与它同级的目录下
# 构建镜像:docker build -t xx:1.0 .
# 创建容器:docker run -t -i xx:1.0 /bin/bash
FROM node:9
# 指定制作我们的镜像的联系人信息(镜像创建者)MAINTAINER jw
# 将根目录下的文件都 copy 到 container(运行此镜像的容器)文件系统的 app 文件夹下
ADD . /app/
# cd 到 app 文件夹下
WORKDIR /app
#apt-get update
RUN apt-get update && apt-get install sshpass
#生成 ssh 的 key
RUN ssh-keygen -t rsa
#将 jre 包移动到 /usr/lib/jvm/ 目录下并解压
RUN mkdir /usr/lib/jvm \
&& mv /app/jdk-8u161-linux-x64.tar.gz /usr/lib/jvm \
&& cd /usr/lib/jvm \
&& tar -xzvf jdk-8u161-linux-x64.tar.gz
#设置路径
RUN update-alternatives --install "/usr/bin/java" "java" "/usr/lib/jvm/jdk1.8.0_161/jre/bin/java" 1 \
&& update-alternatives --set java /usr/lib/jvm/jdk1.8.0_161/jre/bin/java
# 安装淘宝镜像
RUN npm install cnpm -g --registry=https://registry.npm.taobao.org
# 配置环境变量
ENV JAVA_HOME /usr/lib/jvm/jre
ENV HOST 0.0.0.0
ENV PORT 8000
# 容器对外暴露的端口号
EXPOSE 8000
# 容器启动时执行的命令,类似 npm run start
#CMD ["npm", "start"]
ssh
使用 sshpass
来调用外部的命令:
sshpass -p 密码 ssh 用户名 @IP -p 22 -o StrictHostKeyChecking=no 'ls /root'
远程文件同步到当前目录(.)下
scp -r 192.168.1.140:/opt/docker-volume/php/owncloud/apps/edu_video.tar.gz .
从主机复制到容器
docker cp host_path containerID:container_path
从容器复制到主机
docker cp containerID:container_path host_path
生成 ssh
ssh-keygen -t rsa
scp -r /root/.ssh/id_rsa.pub 目标 IP:/root/.ssh/authorized_keys