docker基础篇
一,docker简介
1.docker和kvm的区别
-
- 快,启动和停止可以秒级实现,kvm启动要数分钟
- 对系统资源利用率少,一台主机可以同时运行几百甚至几千个docker容器
- 方便用户获取,分发和更新应用镜像,存储复用,增量更新
2.docker基于paas,邮箱就是,go开发,基于内核
3.更快交付与部署
4.更轻松的迁移和扩展(环境一致性)
5.高效的资源利用
6.docker安装
-
- a.配置epel源
- b.yum install docker -y
- c.systemctl enable docker
- d.vim /usr/lib/systemd/system/docker.service(配置第三方仓库,用阿里云的)
- e.systemctl daemon-reload
- f.systemctl start docker
1、简化配置
2、代码流水线管理
3、开发效率 (为开发人员瞬间顺被环境)
4、应用隔离
5、服务器整合
6、debug能力
7、多租户
8、快速部署
面向产品: 快速的产品交付
面向开发: 简化环境配置
面向测试: 多版本测试
面向运维: 环境一致性
面向架构: 自动化扩容(微服务)
1、技术储备
别人都在搞,我们公司也不能落后
2、提升自身自身能力
运维人员都会我这也得跟上节奏
3、符合当前业务需求
这点顾名思义
4、无技术栈和技术债
以前从未使用虚拟机等相关技术,并且架构符合SOA松耦合
二,docker容器简单操作
1.docker pull alpine (下载镜像)
2.docker search nginx(搜索镜像)
-
-
- ⚠️docked.io这样的一般是官方镜像,多一层目录的就是第三方镜像
-
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(启动容器)
-
- a.run=create+start
- b.nginx镜像名
- c.docker run -it nginx sh加上-it可以交互
8.docker ps (正在运行的容器有哪些)
-
- ⚠️ctrl+p+q 退出容器但是后台还在运行不关闭
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 run”通常是在新创建的容器中所使用的命令。 它适用于在没有其他容器运行的情况下,您想要创建一个容器,并且要启动它,然后在其上运行一个进程;
- ⚠️“docker exec”适用于在现有容器中运行命令的情况。如果您已经拥有了一个正在运行的容器,并希望更改该容器或从中获取某些内容,那么使用“docker exec”命令就非常合适了。例如,如果您使用了 docker-compose,那么您可能会启动多个容器,并且希望能够在创建它们后访问其中的一个或多个容器。
三,docker镜像制作
简单制作办法(不推荐,测试,麻烦)
1.首先pull一个基础镜像出来。
- docker pull centos
2.然后run起来,创建启动一个容器
- docker run -it --name mynginx centos bash
3.配置镜像,安装nginx
- wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
- wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
- yum -y install nginx
4.配置nginx vi /etc/nginx/nginx.conf,
- 添加daemon off;
- nginx -t
5.做好后的容器提交成新镜像
- docker commit -m 'add nginx images' 58a6cc0a2941 mynginx
- docker commit -m 'add nginx images' 58a6cc0a2941 mynginx:v1
6.启动自己做的镜像
- docker run -it --name mynginx qiuhongli/my_nginx:v1 nginx
7.把本地的镜像文件上传到网上https://hub.docker.com
- docker login
- docker images
- docker tag imagesID docker.io/username/容器名
- docker push docker.io/username/容器名
- docker login -u=username -p=password
- docker push username/imagename
⚠️.自己做镜像尽量少安装包,体积越小越好
⚠️.server端挂,所有容器都挂
⚠️.docker kill xxx
⚠️.docker stop xxx
四,docker网络入门
docker run -it -d --name mynginx -P nginx
- -P(大P) :docker会随机映射一个端口到容器内部开放的端口
docker run --name mynginx2413 -d -p 80:80 mynginx:v1 nginx
- -p(小p)宿主机端口:容器nginx的80端口
docker run --name mynginx2413 -d -p 80:80/udp mynginx:v1 nginx
- 可以把默认tcp改为udp
docker run --name mynginx2416 -d -p 127.0.0.1:80:80 mynginx:v1 nginx
- 绑定IP
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
- 启动容器web1
docker run --name web2 --link web1:shop_web -d -p 8888:80 mynginx:v1 nginx
- 启动容器web2和web1关联
docker run -it --rm --net=host nginx
- 把默认bridge网络改成host
docker run -it --rm --net=none nginx
- 把默认bridge网络改成none
三种驱动方式 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 run后面跟-v参数,不过-V后面跟的不再是单独的目录了,它是[host-dir]:[container-dir]:[rw]:[ro]这样格式的,host-dir是一个聚堆路径地址,如果host-dir不存在,则docker会创建一个新的数据卷,如果host-dir存在,但是指向的是一个不存在的目录,则docker也会创建目录,然后使用该目录做数据源
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写好了,需要转换成镜像:
- docker build -t kevin_nginx --rm=true .
- docker run -ti -d --name test_nginx -p 8899:80 kevin_nginx /bin/bash
进入容器,检查容器内的nginx程序是否已启动
- docker exec -ti test_nginx /bin/bash
- ps -ef|grep nginx
编辑好配置之后,记得要重启容器,使得配置生效
docker restart bobo_nginx
需要注意的是:
1)一旦使用-
v
参数创建容器时添加映射关系后,就一定要小心宿主机映射目录下的操作,因为此时两边时实时同步的,别一不小心就删除或修改了数据。
2)修改映射文件后,涉及到服务配置文件的,要记得使用docker restart重启容器,使之生效!
3)一旦容器创建后,启动报错,要记得使用docker logs 查看容器日志
4)在做映射关系前,要先创建一个初始容器,将容器里要映射的文件或目录先docker
cp
拷贝到宿主机的对应目录下,接着删除初始容器,然后再使用
-
v
参数进行带有映射目录关系的容器创建。创建后,就可以操作宿主机映射后的文件了。
1)Docker宿主机必须要有base镜像以供Dockerfile文件使用
2)注意Dockerfile实例文件中的base镜像,这个引用的base镜像一定要是存在的
3)可以切换到不同的目录路径下编写Dockerfile,然后构建,构建的时候直接使用.表示在当前路径下。
镜像构建成功后,可以放到自己的私有仓库里,然后Dockerfile文件可以选择删除。
八,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
- http://192.168.56.11:5000/v2/_catalog
- DOCKER_OPTS="‐‐insecure‐registry xxx.xxx.xxx.xxx:5000" #有可能
- docker私库相当于gitlab
九,docker容器编排
- Compose 是 Docker 容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器,使用Docker Compose不再需要使用shell脚本来启动容器
- Compose 通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。
- docker-compose默认的模板文件是 docker-compose.yml,其中定义的每个服务都必须通过 image 指令指定镜像或 build 指令(需要 Dockerfile)来自动构建。
使用Compose 基本上分为三步:
1.Dockerfile 定义应用的运行环境
2.docker-compose.yml 定义组成应用的各服务
3.docker-compose up 启动整个应用
安装Compose
两种docker-compose安装方式
a.从github上下载docker-compose二进制文件安装
- sudo curl -L https://github.com/docker/compose/releases/download/1.16.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
- sudo chmod +x /usr/local/bin/docker-compose
- docker-compose --version
- docker-compose version 1.16.1, build 1719ceb
b.pip安装
- yum -y install epel-release
- yum -y install python-pip
- pip install docker-compose
- docker-compose version
配置文件详解
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.2、版本
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.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