一,docker简介html
1.docker和kvm的区别node
2.docker基于paas,邮箱就是,go开发,基于内核python
3.更快交付与部署mysql
4.更轻松的迁移和扩展(环境一致性)nginx
5.高效的资源利用git
6.docker安装github
一、简化配置web
二、代码流水线管理redis
三、开发效率 (为开发人员瞬间顺被环境)sql
四、应用隔离
五、服务器整合
六、debug能力
七、多租户
八、快速部署
面向产品: 快速的产品交付
面向开发: 简化环境配置
面向测试: 多版本测试
面向运维: 环境一致性
面向架构: 自动化扩容(微服务)
一、技术储备
别人都在搞,咱们公司也不能落后
二、提高自身自身能力
运维人员都会我这也得跟上节奏
三、符合当前业务需求
这点顾名思义
四、无技术栈和技术债
之前从未使用虚拟机等相关技术,而且架构符合SOA松耦合
二,docker容器简单操做
1.docker pull alpine (下载镜像)
2.docker search nginx(搜索镜像)
3.docker images(查看本机镜像)
4.docker save nginx > /tmp/nginx.tar.gz (导出)
5.docker load < /tmp/nginx.tar.gz(导入)
6.docker daemon --help(查看帮助)
7.docker run nginx sh(启动容器)
8.docker ps (正在运行的容器有哪些)
9.docker ps -a (全部的容器,包括没有运行的)
10.docker rm 容器ID (删除容器,可是不能删除正在运行的容器)
11.docker rm -f (删除正在运行的容器)
12.docker run -it —name mynginx nginx (—name 自定义容器名)
13.docker inspect 容器名/容器ID (查看容器详细信息)
14.docker run -it —rm —name mynginx nginx(—rm 退出就删除容器)
15.docker attach mynginx(进入容器里面少用)
16.docker exec -it mynginx sh(也是进入容器)
17.docker run -it -d —name mynginx nginx(在后台运行)
18.docker logs -f mynginx (查看myninx的日志)
三,docker镜像制做
简单制做办法(不推荐,测试,麻烦)
1.首先pull一个基础镜像出来。
2.而后run起来,建立启动一个容器
3.配置镜像,安装nginx
4.配置nginx vi /etc/nginx/nginx.conf,
5.作好后的容器提交成新镜像
6.启动本身作的镜像
7.把本地的镜像文件上传到网上https://hub.docker.com
⚠️.本身作镜像尽可能少安装包,体积越小越好
⚠️.server端挂,全部容器都挂
⚠️.docker kill xxx
⚠️.docker stop xxx
四,docker网络入门
docker run -it -d --name mynginx -P nginx
docker run --name mynginx2413 -d -p 80:80 mynginx:v1 nginx
docker run --name mynginx2413 -d -p 80:80/udp mynginx:v1 nginx
docker run --name mynginx2416 -d -p 127.0.0.1:80:80 mynginx:v1 nginx
docker run --name mynginx2416 -d -p 127.0.0.1::80 mynginx:v1 nginx
docker run --name web1 -d -p 8888:80 mynginx:v1 nginx
docker run --name web2 --link web1:shop_web -d -p 8888:80 mynginx:v1 nginx
docker run -it --rm --net=host nginx
docker run -it --rm --net=none nginx
三种驱动方式 sandbox cnm endpont network
五种链接方式 bridge(默认+指定) host(默认) ovwelay remote null(默认)
五,docker实现跨主机互联
环境准备:
宿主机网络
v1:192.168.1.10
v2:192.168.1.11
docker镜像网络
d1:192.168.200.1/28
d2:192.168.101.1/28
/etc/docker/daemon.json文件,添加内容 "bip": "ip/netmask",千万不要和宿主机在同一个网络
添加两条路由:
在v1上面添加
route add -net 192.168.101.0/28 gw 192.168.1.11
在v2上面添加
route add -net 192.168.200.0/28 gw 192.168.1.10
至此,不一样主机内的容器就能够互相通讯了
六,docker数据管理
只要在docker run命令后面跟上-
v
参数便可建立一个数据卷,
能够跟多个-V参数来建立多个数据卷,
建立好数据卷后就能够经过--volumes-from参数来挂载该数据卷了无论该容器是否运行,也能够在Dockerfile中经过volume指令来增长一个或则多个数据卷若是有一些数据想在多个容器间共享,或者想在一些临时性的容器中使用该数据,那么最好的方案就是你建立一个数据卷容器,而后从该临时性的容器中挂载该数据卷容器的数据。
这样,即便删除了刚开始的第一个数据卷容器或者中间层的数据卷容器,只要有其余容器使用数据卷,数据卷都不会被删除的。不能使用docker
export
、save、
cp
等命令来备份数据卷的内容,由于数据卷是存在于镜像以外的。备份的方法能够是建立一个新容器,挂载数据卷容器,同时挂载一个本地目录,
而后把远程数据卷容器的数据卷经过备份命令备份到映射的本地目录里面。以下:
# docker run -rm --volumes-from DATA -v $(pwd):/backup busybox tar cvf /backup/backup.tar /data
Docker Volume数据卷能够实现:
1)绕过“拷贝写”系统,以达到本地磁盘IO的性能,(好比运行一个容器,在容器中对数据卷修改内容,会直接改变宿主机上的数据卷中的内容,因此是本地磁盘IO的性能,而不是先在容器中写一份,最后还要将容器中的修改的内容拷贝出来进行同步。)
2)绕过“拷贝写”系统,有些文件不须要在docker commit打包进镜像文件。
3)数据卷能够在容器间共享和重用数据
4)数据卷能够在宿主和容器间共享数据
5)数据卷数据改变是直接修改的
6)数据卷是持续性的,直到没有容器使用它们。即使是初始的数据卷容器或中间层的数据卷容器删除了,只要还有其余的容器使用数据卷,那么里面的数据都不会丢失。
备份node
卷中全部的数据为
test
.
tar
执行完成以后删除容器--
rm
docker run --
rm
--volumes-from test4 -
v
$(
pwd
):
/backup
ubuntu:14.04
tar
xvf
/backup/test
.
tar
-C /
Volume 只有在下列状况下才能被删除:
1)docker
rm
-
v
删除容器时添加了-
v
选项
2)docker run --
rm
运行容器时添加了--
rm
选项
七,dockerfile编写(其实也是属于容器制做)
Dockerfile分为四部分:基础镜像信息、镜像建立者信息、镜像操做指令、容器启动执行指令。
1)FROM(指定基础image)
2)MAINTAINER(用来指定镜像建立者信息)
3)RUN(安装软件用)
4)CMD(设置container启动时执行的操做)
5)ENTRYPOINT(设置container启动时执行的操做)
6)USER(设置container容器的用户)
7)EXPOSE(指定容器须要映射到宿主机器的端口)
8)ENV(用于设置环境变量)
9)ADD(从src复制文件到container的dest路径)
10)VOLUME(指定挂载点)
11)WORKDIR(切换目录)
12)ONBUILD(在子镜像中执行)
Dockerfile写好了,须要转换成镜像:
进入容器,检查容器内的nginx程序是否已启动
编辑好配置以后,记得要重启容器,使得配置生效
docker restart bobo_nginx
须要注意的是:
1)一旦使用-
v
参数建立容器时添加映射关系后,就必定要当心宿主机映射目录下的操做,由于此时两边时实时同步的,别一不当心就删除或修改了数据。
2)修改映射文件后,涉及到服务配置文件的,要记得使用docker restart重启容器,使之生效!
3)一旦容器建立后,启动报错,要记得使用docker logs 查看容器日志
4)在作映射关系前,要先建立一个初始容器,将容器里要映射的文件或目录先docker
cp
拷贝到宿主机的对应目录下,接着删除初始容器,而后再使用
-
v
参数进行带有映射目录关系的容器建立。建立后,就能够操做宿主机映射后的文件了。
八,docker私库搭建
1.拉取镜像
docker pull registry
2.提高安全
cd /opt
mkdir auth
docker run ‐‐entrypoint htpasswd registry:2 ‐Bbn liyongli 123456 > auth/htpasswd (建立用户名密码加密数据)
2.建立和启动一个容器
docker run ‐d ‐p 6000:5000 ‐‐restart=always ‐‐name registry1 \
‐v `pwd`/auth:/auth \
‐e "REGISTRY_AUTH=htpasswd" \
‐e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \
‐e REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd \
registr
九,docker容器编排
使用Compose 基本上分为三步:
1.Dockerfile 定义应用的运行环境
2.docker-compose.yml 定义组成应用的各服务
3.docker-compose up 启动整个应用
安装Compose
两种docker-compose安装方式
a.从github上下载docker-compose二进制文件安装
b.pip安装
配置文件详解
docker-compose.yml 配置文件详
version: "3" ###Compose目前为止有三个版本分别为Version 1,Version 2,Version 3,Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1未来会被弃用。
services:
redis:
image: redis:alpine
ports:
- "6379"
networks:
- frontend
deploy:
replicas: 2
update_config:
parallelism: 2
delay: 10s
restart_policy:
condition: on-failure
db:
image: postgres:9.4
volumes:
- db-data:/var/lib/postgresql/data
networks:
- backend
deploy:
placement:
constraints: [node.role == manager]
vote:
image: dockersamples/examplevotingapp_vote:before
ports:
- 5000:80
networks:
- frontend
depends_on:
- redis
deploy:
replicas: 2
update_config:
parallelism: 2
restart_policy:
condition: on-failure
result:
image: dockersamples/examplevotingapp_result:before
ports:
- 5001:80
networks:
- backend
depends_on:
- db
deploy:
replicas: 1
update_config:
parallelism: 2
delay: 10s
restart_policy:
condition: on-failure
worker:
image: dockersamples/examplevotingapp_worker
networks:
- frontend
- backend
deploy:
mode: replicated
replicas: 1
labels: [APP=VOTING]
restart_policy:
condition: on-failure
delay: 10s
max_attempts: 3
window: 120s
placement:
constraints: [node.role == manager]
visualizer:
image: dockersamples/visualizer:stable
ports:
- "8080:8080"
stop_grace_period: 1m30s
volumes:
- "/var/run/docker.sock:/var/run/docker.sock"
deploy:
placement:
constraints: [node.role == manager]
networks:
frontend:
backend:
volumes:
db-data:
一份标准配置文件应该包含 version、services、networks 三大部分,其中最关键的就是 services 和 networks 两个部分
3.二、版本
Compose目前为止有三个版本分别为Version 1,Version 2,Version 3,Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1未来会被弃用。
3.三、配置选项
1.bulid
服务除了能够基于指定的镜像,还能够基于一份 Dockerfile,在使用 up 启动之时执行构建任务,这个构建标签就是 build,它能够指定 Dockerfile 所在文件夹的路径。Compose 将会利用它自动构建这个镜像,而后使用这个镜像启动服务容器
build: /path/to/build/dir
也能够是相对路径
build: ./dir
设定上下文根目录,而后以该目录为准指定 Dockerfile
build:
context: ../
dockerfile: path/of/Dockerfile
2. context
context 选项能够是 Dockerfile 的文件路径,也能够是到连接到 git 仓库的url,当提供的值是相对路径时,它被解析为相对于撰写文件的路径,此目录也是发送到 Docker 守护进程的 context
build:
context: ./dir
3. dockerfile
使用此 dockerfile 文件来构建,必须指定构建路径
build:
context: .
dockerfile: Dockerfile-alternate
4.image
services:
web:
image: nginx
在 services 标签下的第二级标签是 web,这个名字是用户本身自定义,它就是服务名称。
image 则是指定服务的镜像名称或镜像 ID。若是镜像在本地不存在,Compose 将会尝试拉取这个镜像。
例以下面这些格式都是能够的:
image: redis
image: ubuntu:14.04
image: tutum/influxdb
image: a4bc65fd
5. args
添加构建参数,这些参数是仅在构建过程当中可访问的环境变量
首先, 在Dockerfile中指定参数:
ARG fendo
ARG password
RUN echo "Build number: $fendo"
RUN script-requiring-password.sh "$password"
而后指定 build 下的参数,能够传递映射或列表
build:
context: .
args:
fendo: 1
password: fendo
或
build:
context: .
args:
- fendo=1
- password=fendo
指定构建参数时能够省略该值,在这种状况下,构建时的值默认构成运行环境中的值
args:
- fendo
- password
6.command
使用 command 能够覆盖容器启动后默认执行的命令。
command: bundle exec thin -p 3000
该命令也能够是一个列表,方法相似于 dockerfile:
command: ["bundle", "exec", "thin", "-p", "3000"]
7.container_name
Compose 的容器名称格式是:<项目名称><服务名称><序号>
虽然能够自定义项目名称、服务名称,可是若是你想彻底控制容器的命名,可使用这个标签指定:
container_name: app
这样容器的名字就指定为 app 了。
8.depends_on
在使用 Compose 时,最大的好处就是少打启动命令,可是通常项目容器启动的顺序是有要求的,若是直接从上到下启动容器,必然会由于容器依赖问题而启动失败。
例如在没启动数据库容器的时候启动了应用容器,这时候应用容器会由于找不到数据库而退出,为了不这种状况咱们须要加入一个标签,就是 depends_on,这个标签解决了容器的依赖、启动前后的问题。
例以下面容器会先启动 redis 和 db 两个服务,最后才启动 web 服务:
version: '3'
services:
web:
build: .
depends_on:
- db
- redis
redis:
image: redis
db:
image: postgres
注意的是,默认状况下使用 docker-compose up web 这样的方式启动 web 服务时,也会启动 redis 和 db 两个服务,由于在配置文件中定义了依赖关系。
9.pid
pid: "host"
将PID模式设置为主机PID模式,跟主机系统共享进程命名空间。容器使用这个标签将可以访问和操纵其余容器和宿主机的名称空间。
10.ports
映射端口的标签。
使用HOST:CONTAINER格式或者只是指定容器的端口,宿主机会随机映射端口。
ports:
- "3000"
- "8000:8000"
- "49100:22"
- "127.0.0.1:8001:8001"
注意:当使用HOST:CONTAINER格式来映射端口时,若是你使用的容器端口小于60你可能会获得错误得结果,由于YAML将会解析xx:yy这种数字格式为60进制。因此建议采用字符串格式。
11.extra_hosts
添加主机名的标签,就是往/etc/hosts文件中添加一些记录,与Docker client的--add-host相似:
extra_hosts:
- "somehost:162.242.195.82"
- "otherhost:50.31.209.229"
启动以后查看容器内部hosts:
162.242.195.82 somehost
50.31.209.229 otherhost
12.volumes
挂载一个目录或者一个已存在的数据卷容器,能够直接使用 [HOST:CONTAINER] 这样的格式,或者使用 [HOST:CONTAINER:ro] 这样的格式,后者对于容器来讲,数据卷是只读的,这样能够有效保护宿主机的文件系统。
Compose的数据卷指定路径能够是相对路径,使用 . 或者 .. 来指定相对目录。
数据卷的格式能够是下面多种形式:
volumes:
// 只是指定一个路径,Docker 会自动在建立一个数据卷(这个路径是容器内部的)。
- /var/lib/mysql
// 使用绝对路径挂载数据卷
- /opt/data:/var/lib/mysql
// 以 Compose 配置文件为中心的相对路径做为数据卷挂载到容器。
- ./cache:/tmp/cache
// 使用用户的相对路径(~/ 表示的目录是 /home/<用户目录>/ 或者 /root/)。
- ~/configs:/etc/configs/:ro
// 已经存在的命名的数据卷。
- datavolume:/var/lib/mysql
若是你不使用宿主机的路径,你能够指定一个volume_driver。
volume_driver: mydriver