docker数据卷 (难点)

容器数据卷
1.解决容器间数据共享的问题
2.卷技术 就是将容器内的目录挂载到linux目录上

  在docker run 上加入-主机内的目录:容器目录

处理数据的持久化

docker run -d -p 3306:3306 -v /home/mysql/conf:/etc/mysql.conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7

远程配置mysql报错 问题解决方案 删除mysql镜像 重新安装 将安装目录在home下

查询挂载 是否否成功

docker inspect 容器id

[
    {
        "Id": "8fb071e82d6c6ba8113866c5c01f2ca3642dcef20c11b367cdafa1d6b598a567",
        "Created": "2020-09-13T19:00:24.989522406Z",
        "Path": "docker-entrypoint.sh",
        "Args": [
            "mysqld"
        ],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 16108,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2020-09-13T19:00:25.48613544Z",
            "FinishedAt": "0001-01-01T00:00:00Z"
        },
        "Image": "sha256:ef08065b0a302111b56966aa92c89fa0bacdfc537741cbca88a15b10f14332ca",
        "ResolvConfPath": "/var/lib/docker/containers/8fb071e82d6c6ba8113866c5c01f2ca3642dcef20c11b367cdafa1d6b598a567/resolv.conf",
        "HostnamePath": "/var/lib/docker/containers/8fb071e82d6c6ba8113866c5c01f2ca3642dcef20c11b367cdafa1d6b598a567/hostname",
        "HostsPath": "/var/lib/docker/containers/8fb071e82d6c6ba8113866c5c01f2ca3642dcef20c11b367cdafa1d6b598a567/hosts",
        "LogPath": "/var/lib/docker/containers/8fb071e82d6c6ba8113866c5c01f2ca3642dcef20c11b367cdafa1d6b598a567/8fb071e82d6c6ba8113866c5c01f2ca3642dcef20c11b367cdafa1d6b598a567-json.log",
        "Name": "/mysql01",
        "RestartCount": 0,
        "Driver": "overlay2",
        "Platform": "linux",
        "MountLabel": "",
        "ProcessLabel": "",
        "AppArmorProfile": "",
        "ExecIDs": null,
        "HostConfig": {
            "Binds": [
                "/home/mysql/conf:/etc/mysql.conf.d",
                "/home/musql/data:/var/lib/mysql"
            ],
            "ContainerIDFile": "",
            "LogConfig": {
                "Type": "json-file",
                "Config": {}
            },
            "NetworkMode": "default",
            "PortBindings": {
                "3306/tcp": [
                    {
                        "HostIp": "",
                        "HostPort": "3306"
                    }
                ]
            },
            "RestartPolicy": {
                "Name": "no",
                "MaximumRetryCount": 0
            },
            "AutoRemove": false,
            "VolumeDriver": "",
            "VolumesFrom": null,
            "CapAdd": null,
            "CapDrop": null,
            "Capabilities": null,
            "Dns": [],
            "DnsOptions": [],
            "DnsSearch": [],
            "ExtraHosts": null,
            "GroupAdd": null,
            "IpcMode": "private",
            "Cgroup": "",
            "Links": null,
            "OomScoreAdj": 0,
            "PidMode": "",
            "Privileged": false,
            "PublishAllPorts": false,
            "ReadonlyRootfs": false,
            "SecurityOpt": null,
            "UTSMode": "",
            "UsernsMode": "",
            "ShmSize": 67108864,
            "Runtime": "runc",
            "ConsoleSize": [
                0,
                0
            ],
            "Isolation": "",
            "CpuShares": 0,
            "Memory": 0,
            "NanoCpus": 0,
            "CgroupParent": "",
            "BlkioWeight": 0,
            "BlkioWeightDevice": [],
            "BlkioDeviceReadBps": null,
            "BlkioDeviceWriteBps": null,
            "BlkioDeviceReadIOps": null,
            "BlkioDeviceWriteIOps": null,
            "CpuPeriod": 0,
            "CpuQuota": 0,
            "CpuRealtimePeriod": 0,
            "CpuRealtimeRuntime": 0,
            "CpusetCpus": "",
            "CpusetMems": "",
            "Devices": [],
            "DeviceCgroupRules": null,
            "DeviceRequests": null,
            "KernelMemory": 0,
            "KernelMemoryTCP": 0,
            "MemoryReservation": 0,
            "MemorySwap": 0,
            "MemorySwappiness": null,
            "OomKillDisable": false,
            "PidsLimit": null,
            "Ulimits": null,
            "CpuCount": 0,
            "CpuPercent": 0,
            "IOMaximumIOps": 0,
            "IOMaximumBandwidth": 0,
            "MaskedPaths": [
                "/proc/asound",
                "/proc/acpi",
                "/proc/kcore",
                "/proc/keys",
                "/proc/latency_stats",
                "/proc/timer_list",
                "/proc/timer_stats",
                "/proc/sched_debug",
                "/proc/scsi",
                "/sys/firmware"
            ],
            "ReadonlyPaths": [
                "/proc/bus",
                "/proc/fs",
                "/proc/irq",
                "/proc/sys",
                "/proc/sysrq-trigger"
            ]
        },
        "GraphDriver": {
            "Data": {
                "LowerDir": "/var/lib/docker/overlay2/8b2b5b5190038c90be8985ff303717194ad3edc11700b6e043defa7bcc0148d9-init/diff:/var/lib/docker/overlay2/cc1f32ae84df65842d71b549ebd9144cf6df4dfb8a34f73ce93131915ea97feb/diff:/var/lib/docker/overlay2/f3b7c72f450e2960cd65f67fd8923974a1286030097b0156f415c098a78ad6b1/diff:/var/lib/docker/overlay2/1d5608415c1c3e73f0683e06c42d03563e1cacf3b135d3a0206c791e403b9480/diff:/var/lib/docker/overlay2/2de28428375798cc083dbc7d7420c213628f7f983459f7f11c352f2191805a19/diff:/var/lib/docker/overlay2/d4ceb94e0120850ffd69477b997c0ca9f262a2ce8d42277f09021affaaa7fede/diff:/var/lib/docker/overlay2/1c066e6e0d856ac700daccce8cff8a50905a1f3ba0abeba6ed65d32e8a8c0849/diff:/var/lib/docker/overlay2/4b07232e34638f4961a720a7d5e2ad0ce01d2abf018b5a403b5cd0ca116ce605/diff:/var/lib/docker/overlay2/f0b7120e702f0559c23ad2bc421dff5d83fd6cb7379a8b7f4ba8da7411f7cc21/diff:/var/lib/docker/overlay2/b5872cf4280467fb02b098c5a48bc3c98145f3fba75dcb729f38385c4310c43d/diff:/var/lib/docker/overlay2/b454e482b451a4521e6e341c672be21b601f34c1be925629041b974d2fc51222/diff:/var/lib/docker/overlay2/b8a4299a3c7f91b15c6bba3519ee675ac209db90767f550b71c1c024809dba24/diff",
                "MergedDir": "/var/lib/docker/overlay2/8b2b5b5190038c90be8985ff303717194ad3edc11700b6e043defa7bcc0148d9/merged",
                "UpperDir": "/var/lib/docker/overlay2/8b2b5b5190038c90be8985ff303717194ad3edc11700b6e043defa7bcc0148d9/diff",
                "WorkDir": "/var/lib/docker/overlay2/8b2b5b5190038c90be8985ff303717194ad3edc11700b6e043defa7bcc0148d9/work"
            },
            "Name": "overlay2"
        },
        "Mounts": [
            {
                "Type": "bind",
                "Source": "/home/mysql/conf"//主机目录
                "Destination": "/etc/mysql.conf.d",//容器目录
                "Mode": "",
                "RW": true,
                "Propagation": "rprivate"
            },
            {
                "Type": "bind",
                "Source": "/home/musql/data",
                "Destination": "/var/lib/mysql",
                "Mode": "",
                "RW": true,
                "Propagation": "rprivate"
            }
        ],
        "Config": {
            "Hostname": "8fb071e82d6c",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "ExposedPorts": {
                "3306/tcp": {},
                "33060/tcp": {}
            },
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
                "MYSQL_ROOT_PASSWORD=123456",
                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
                "GOSU_VERSION=1.12",
                "MYSQL_MAJOR=5.7",
                "MYSQL_VERSION=5.7.31-1debian10"
            ],
            "Cmd": [
                "mysqld"
            ],
            "Image": "mysql:5.7",
            "Volumes": {
                "/var/lib/mysql": {}
            },
            "WorkingDir": "",
            "Entrypoint": [
                "docker-entrypoint.sh"
            ],
            "OnBuild": null,
            "Labels": {}
        },
        "NetworkSettings": {
            "Bridge": "",
            "SandboxID": "0305171997d589cc4d5e7870f84db8bdcc74b64536c043340a211a3c170167bf",
            "HairpinMode": false,
            "LinkLocalIPv6Address": "",
            "LinkLocalIPv6PrefixLen": 0,
            "Ports": {
                "3306/tcp": [
                    {
                        "HostIp": "0.0.0.0",
                        "HostPort": "3306"
                    }
                ],
                "33060/tcp": null
            },
            "SandboxKey": "/var/run/docker/netns/0305171997d5",
            "SecondaryIPAddresses": null,
            "SecondaryIPv6Addresses": null,
            "EndpointID": "fbb6e7509b9a9b48a5230d87c303f6f2e59d1df0face209d98e3e0156ac4abcb",
            "Gateway": "172.17.0.1",
            "GlobalIPv6Address": "",
            "GlobalIPv6PrefixLen": 0,
            "IPAddress": "172.17.0.2",
            "IPPrefixLen": 16,
            "IPv6Gateway": "",
            "MacAddress": "02:42:ac:11:00:02",
            "Networks": {
                "bridge": {
                    "IPAMConfig": null,
                    "Links": null,
                    "Aliases": null,
                    "NetworkID": "1513f2913519d5295ef3ef102330226ebf2b4c6c90934429ad5dfea547831610",
                    "EndpointID": "fbb6e7509b9a9b48a5230d87c303f6f2e59d1df0face209d98e3e0156ac4abcb",
                    "Gateway": "172.17.0.1",
                    "IPAddress": "172.17.0.2",
                    "IPPrefixLen": 16,
                    "IPv6Gateway": "",
                    "GlobalIPv6Address": "",
                    "GlobalIPv6PrefixLen": 0,
                    "MacAddress": "02:42:ac:11:00:02",
                    "DriverOpts": null
                }
            }
        }
    }
]

具名挂载 和匿名挂载 和 指定路径挂载

具名挂载和匿名挂载的区别

1.在所有的 docker中匿名挂载 全部在/var/lib/docker 中

2.具名挂载就是指定主目录位置的挂载 就是卷名:容器类路径

3.指定路径挂载 宿主机路径:容器内路径

4.在挂载时:选择属性:ro 或者 :rw ro代表意思 readonley (只读 或者只能在宿主机中操作):rw readwrite(可写)

实现多个mysql数据共享

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql03 mysql:5.7 --volumes-form mysql01 mysql:5.7

将这个mysql服务与上一个mysql共享

volumes 挂载

--volumes-form 挂载地址name 

dockerfile技术

dockerfile的核心就是用来构建docker的镜像的
构建步骤
1.创建一个docker文件
2.docker bliud 构成镜像
3.docker run运行镜像
4.docker push 发布镜像

dockerfile基础知识

1.关键字要大写
2.指令是从上到下执行的
3.# 表示注释
3.dockerfile每一层都表示提交 执行镜像
4.dockerimages 通过dockerfiles生成镜像
5.docker 容器就是镜像运行起来提供服务的

docker基础命令
在这里插入图片描述
追加指令
1.CMD 可以被替代 只有最后一个会被执行
2.NETRYPONT指定这个容器启动是时执行的命令 可以追加
3.ONBUILD 当构建一个被继承的dockerfile文件运行下时会被启用
4.COPY将文件拷贝到镜像中
5.ENV 构建的时候设置环境变量

构建一个简单的 dockerfile文件

第一步
vim dockerfile文件

FROM centos
MAINTAINER mao<1983598699@qq.com>

ENV MyPATH /usr/local
WORKDIR $MyPATH 
RUN yum -y install vim 
RUN yum -y install net-tools

EXPOSE 80

CMD echo $MyPATH 
CMD echo "---end----"
CMD /bin/bash

第二步

docker build -f mydockerfile -t mycentos:1.0 .

详解

1.build -f 创建镜像执行的文件
2.-t 自定义镜像的命名
3. 后面加入 "." 是指定当前目录

第三步测试运行
docker run -it 3a36679e9ca3

结果: vim 和 ifconfig命令都添加进去了
构建服务完成

docker history 镜像id//查询当前版本变更情况

CMD 和 NETRYPONT区别

1.cmd 不能直接追加 要写命令
2.NETRYPONT能进行拼接追加


实战练习

dockerfile 添加tomcat
问题分解 tomcat需要依赖java 所以需要jdk的压缩包 和tomcat的压缩包

1.下载 tomcat 和jdk压缩包
tomcat下载:wget https://archive.apache.org/dist/tomcat/tomcat-8/v8.0.23/bin/apache-tomcat-8.0.23.tar.gz
jdk下载:wget http://download.oracle.com/otn-pub/java/jdk/8u171-b11/512cd62ec5174c3487ac17c61aaa89e8/jdk-8u171-linux-x64.tar.gz

2.编写测试Dockerfile

FROM centos
MAINTAINER mao<1983598699@.com>
COPY readem.text /url/local/readem.text
ADD jdk-8u171-linux-x64.tar.gz /usr/local
ADD apache-tomcat-8.0.23.tar.gz /usr/local
RUN yum -y install vim
ENV MYPATH /usr/local
WORKDIR $MYPATH
ENV JAVA_HOME /usr/local/jdk1.8.0_171/
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-8.0.23
ENV CATALINA_BASH  /usr/local/apache-tomcat-8.0.23
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
EXPOSE 8080
CMD /usr/local/apache-tomcat-8.0.23/bin/startup.sh && tail -F /usr/local/usr/local/apache-tomcat-8.0.23/bin/logs/catalina.out

3.执行build

docker build -t diy/tomcat .

4.运行自定义的tomcat

docker run -d -p 9090:8080 --name mytomcat -v /home/tomcat/test:/url/local/apache-tomcat-8.0.23/webapps/test -v /home/tomcat/tomcatlog:/url/local/apache-tomcat-8.0.23/logs diy/tomcat

5.启动curl localhost:9090
报错
curl: (56) Recv failure: Connection reset by peer//更换tomcat和jdk压缩吧 和 修改服务端口号 开启端口号都无法解决
tmd

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值