Docker数据及网络管理

一、数据管理

1. 挂载本地的目录到容器里

[[email protected] ~]# docker run -tid -v /data/:/data centos bash

0f1093aadf6ec85224520a303f92282d12443ecf0305bbf15eb2f3526fd55212

[[email protected] ~]# docker exec -it 0f10 bash

[[email protected] /]# df -h

Filesystem                                                                                          Size  Used Avail Use% Mounted on

/dev/mapper/docker-253:0-34406889-

tmpfs                                                                                               490M     0  490M   0% /sys/fs/cgroup

/dev/mapper/centos-root                                                                              18G  4.8G   13G  28% /data

-v 用来指定挂载目录:前面的/data/为本地目录:后面的/data/为容器里的目录

2. 挂载数据卷

其实我们挂载目录的时候可以指定容器name如果不指定就随机定义了。比如上面我们没有指定它就生成了一个名字为loving_kowalevski这个名字可以使用命令 docker ps  看最右侧一列

docker run -itd --volumes-from loving_kowalevski aming/centos bash

这样我们使用szk/centos镜像创建了新的容器并且使用了 loving_kowalevski  容器的数据卷

自定义容器name

docker run -itd -v /data/:/mnt --name datavol aming/centos bash

3. 定义数据卷容器

有时候我们需要多个容器之间相互共享数据类似于linux里面的NFS所以就可以搭建一个专门的数据卷容器然后其他容器直接挂载该数据卷。

首先建立数据卷容器

docker run -itd -v /data/ --name insane_hopper centos  bash

#注意这里的/data/是容器的/data目录并非本地的/data/目录如果想使用已经运行的容器则通过docker ps 查看 容器最后一行 名称使用--volumes-from指定然后让其他容器挂载该数据卷

[[email protected] ~]# docker run -itd  --volumes-from   insane_hopper  centos  bash

9c296da6550be50bbe90cce23bbebf1590245c114d572dea1ec4f9441f70dd07

[[email protected] ~]#  docker run -itd  --volumes-from   insane_hopper --name web2  centos  bash  #还可以继续创建

88e24c0d19efb8c152271b0c07e3f262fbb6d03252b72b2fbc3433c30930f6eb

[[email protected] ~]# docker exec -it 88e2 bash

[[email protected] /]# ls /data/

szk.txt

4. 数据卷的备份与恢复

1备份

[[email protected] ~]# mkdir /vol_data_backup

[[email protected] ~]# docker run -itd --volumes-from insane_hopper -v /vol_data_backup/:/backup centos bash

ad6c5945f7509cf952f29be51733eddbdd588295c820f01e000b3346ce8b2779

[[email protected] ~]# docker exec -it ad6c bash

[[email protected] /]# ls /backup/

[[email protected] /]# tar cvf /backup/data.tar /data

[[email protected] ~]# ls /vol_data_backup/

data.tar

说明首先我们需要使用insane_hopper数据卷新开一个容器同时我们还需要把本地的/vol_data_backup/目录挂载到该容器的/backup下这样在容器中/backup目录里面新建的文件我们就可以直接在/vol_data_backup/目录中看到了。 然后再把/data/目录下面的文件打包到成data.tar文件放到/backup目录下面。

2恢复

思路 先新建一个数据卷容器再建一个新的容器并挂载该数据卷容器然后再把tar包解包。

新建数据卷容器docker run -itd -v /data/ --name data centos bash

挂载数据卷新建容器并解包docker run --volumes-from testvol2  -v /vol_data_backup/:/backup centos tar xvf /backup/data.tar

二、网络管理

四种网络模式

  • host模式使用docker run时使用--net=host指定docker使用的网络实际上和宿主机一样在容器内看到的网卡ip是宿主机上的ip
  • container模式使用--net=container:container_id/container_name多个容器使用共同的网络看到的ip是一样的
  • none模式使用--net=none指定这种模式下不会配置任何网络
  • bridge模式使用--net=bridge指定默认模式不用指定默认就是这种网络模式。这种模式会为每个容器分配一个独立的Network Namespace。类似于vmware的nat网络模式。同一个宿主机上的所有容器会在同一个网段下相互之间是可以通信的。

外部网络访问容器

首先使用centos镜像新建一个容器然后在该容器中安装httpd服务并启动

[[email protected] vol_data_backup]# docker commit -m "centos_with_httpd" -a "szk" 8d5192bdf660 centos_with_httpd

216d5f8f0c57f49c311e7b7a07c2767b14a1bd78cf3a11c7f923bea9df6a7b57

[[email protected] vol_data_backup]# docker images

REPOSITORY           TAG                 IMAGE ID            CREATED             VIRTUAL SIZE

centos_with_httpd    latest              216d5f8f0c57        11 seconds ago      337.7 MB

再把该容器导成一个新的镜像centos-httpd)然后再使用新镜像创建容器并指定端口映射

docker run -itd -p 5123:80 centos-httpd bash  //-p 可以指定端口映射本例中将容器的80端口映射为本地的5123端口

[[email protected] vol_data_backup]# docker run -itd -p 8080:80 centos_with_httpd:latest

1cf3b634f537d6f2bfc8b17461e92dfa0f7370b91607f125f58cdbf2e545314b

[[email protected] vol_data_backup]# docker exec -it 1cf3 bash

[[email protected] /]# /usr/sbin/httpd

[[email protected] /]# vi /var/www/html/1.html

[[email protected] ~]# netstat -ntlup | grep 8080

tcp6       0      0 :::8080                 :::*                    LISTEN      4069/docker-proxy

[[email protected] ~]# curl localhost:8080/1.html

szk

docker exec -it container_id  bash

启动httpd httpd -k start

编辑1.html vi /var/www/html/1.html 随便写点东西

退出该容器exit

测试 curl 127.0.0.1:5123/1.html

-p后面也支持IP:port:ip:port 的格式比如

-p 127.0.0.1:8080:80

也可以不写本地的端口只写ip这样会随意分配一个端口

-p 127.0.0.1::80

容器互联

下载一个mysql镜像

docker pull mysql

新建一个容器命名为db

docker run -it -d -p 13306:3306 --name db mysql bash

在新建一个web容器并和db互联

docker run -it -d -p 12308:80 --name web --link db:db centos-httpd bash

配置桥接网络centos7)

为了使本地网络中的机器和Docker容器更方便的通信我们经常会有将Docker容器配置到和主机同一网段的需求。这个需求其实很容易实现我们只要将Docker容器和宿主机的网卡桥接起来再给Docker容器配上IP就可以了。

安装pipworkgit clone https://github.com/jpetazzo/pipework

cp ~/pipework/pipework /usr/local/bin/

开启一个容器 docker run -itd --net=none --name aming123 centos  /bin/bash

pipework br0  aming123 172.7.15.201/[email protected]  #201为容器的[email protected]后面的ip为宿主机ip

brctl addif br0 eth0  #eth0为宿主机网卡这一步为把br0和eth0桥接起来

ip addr add 172.7.15.107/24 br0 #把107的ip绑定在br0上

docker exec -it aming123 /bin/bash #进去后ifconfig查看就可以看到新添加的ip

centos6:

cd /etc/sysconfig/network-scripts/; cp ifcfg-eth0  ifcfg-br0

vi ifcfg-eth0 //增加BRIDGE=br0删除IPADDR,NETMASK,GATEWAY,DNS1

vi ifcfg-br0//修改DEVICE为br0,Type为Bridge,把eth0的网络设置设置到这里来

service network restart

安装pipwork:  git clone https://github.com/jpetazzo/pipework

cp ~/pipework/pipework /usr/local/bin/

开启一个容器: docker run -itd --net=none --name aming123 centos  /bin/bash

rpm -Uvh rpm -Uvh https://repos.fedorapeople.org/openstack/EOL/openstack-grizzly/epel-6/iproute-2.6.32-130.el6ost.netns.2.x86_64.rpm #不安会报错Object "netns" is unknown, try "ip help"

pipework br0  aming123 172.7.15.201/24

docker exec -it aming123 /bin/bash #进去后ifconfig查看就可以看到新添加的ip

时间: 2024-10-08 11:13:45

Docker数据及网络管理的相关文章

Docker学习笔记之docker数据卷

Docker数据卷数据卷是经过特殊设计的目录,可用绕过联合文件系统(UFS),为一个或多个容器提供访问 数据卷的特点:数据卷在容器启动时初始化,如果容器使用的镜像在挂载点包含了数据,这些数据会拷贝到新初始化的数据卷中数据卷可以在容器之间共享和重用可以对数据卷里的内容直接进行修改数据卷的变化不会影响镜像的更新卷会一直存在,即使挂载数据卷的容器已经被删除 为容器添加数据卷:docker run -v ~/container_data:/data -it centos /bin/bash:contai

解决docker数据文件过大导致根磁盘满的问题

背景: 最近在线上使用的docker主机发现根目录容量快满了,一番查找,发现是docker的data文件过大了.     我们知道docker数据默认是存放在/var/lib/docker下的,我们可以在启动时用-g --graph=""参数,把数据目录更改到其他容量大的地方去.但是对于在使用中的docker来说,直接修改这个目录路径,会导致镜像和容器都丢失了,所以修改参数这个方法适用于初始化docker的时候使用. 对于又想解决根分区容量满,又不想更改数据存储路径的我来说,我不想更改

docker数据拷贝

docker数据拷贝的方式有很多种,下面介绍几种数据拷贝的方式:此处只是介绍几种简易的方式,更多方式可以google下. 从容器中向主机拷贝数据 docker cp <containerId>:/file/path/within/container /host/path/target docker cp 8e7e5f4574f4:/root/test.txt ./test.txt 从主机向容器中拷贝数据 docker cp /host/path/target <containerId&g

Docker 数据卷,数据卷容器详细介绍

Docker 数据卷,数据卷容器详细介绍 引子 有些时候,我们的服务运行时必不可少的会产生一些日志,或是我们需要把容器内的数据进行备份,甚至多个容器之间进行数据共享,这必然涉及容器的数据管理操作. 容器中管理数据主要有两种方式: 数据卷数据卷容器 数据卷是一个可供容器使用的特殊目录,它绕过文件系统,可以提供很多有用的特性: - 数据卷可以在容器之间共享和重用 - 对数据卷的修改会立马生效 - 对数据卷的更新,不会影响镜像 - 卷会一直存在,直到没有容器使用 #(类似linux下的挂载(mount

docker数据卷备份恢复以及配置桥接网络

笔记内容:docker数据卷备份恢复以及网络相关笔记日期:2018-02-06 25.9 数据卷备份恢复 25.10 docker网络模式 25.11 opration not permitted错误 25.12 配置桥接网络 25.9 数据卷备份恢复 备份: 如果数据卷容器的共享目录已经挂载到了本地宿主机的磁盘上,那么就无需进行数据卷备份.没有进行挂载到本地,而是作为共享目录的数据卷容器,就得定期将数据卷进行一个备份,不然如果数据卷被删除的话,数据也会丢失. 假设数据卷容器共享的目录是data

4.docker数据卷管理

生产过程中使用docker往往需要对数据进行持久化,或者需要在多个容器之间进行数据共享,因此就需要数据卷来做数据持久化 *数据卷:容器内数据直接映射到本地主机环境 数据卷的特性: 1)可以在容器之间共享和重用,容器间传递数据变得高效方便 2)对数据卷内数据的修改会立马生效,无论是容器内操作还是本地操作 3)对数据卷的更新不会影响镜像,解耦了应用和数据 4)卷会一直存在,直到没有容器使用,可以安全地卸载它 创建数据卷 docker run -it --name web -v ~/webapp:/w

docker数据卷应用场景

docker数据卷应用场景 在多个容器之间共享数据,多个容器可以同时以只读或者读写的方式挂载统一个数据卷,从而共享数据卷中的数据 当宿主机不能保证一定存在某一个目录或一些固定的文件路径时,使用数据卷可以规避这种限制带来的问题 当想把容器中的数据存储在宿主机之外的地方时,比如远程主机上和云存储上 当你需要把容器数据在不同宿主机之间备份.恢复或迁移时,数据卷是很好的选择 数据覆盖问题 如果挂载一个空的数据卷到容器中的一个非空目录中,那么这个目录下的文件会被复制到数据卷中 如果挂载一个非空的数据卷到容

Docker 数据卷与容器互联(3)

title: Docker 数据卷与容器互联(3) date: 2018-12-15 14:50:42 tags: Docker categories: Docker copyright: true --- Docker是基于Go语言实现的开源容器项目,Docker让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不会有任何接口,Docker诞生于2013年年初,最初发起者是dotCloud公司.

你必须知道的Docker数据卷(Volume)

本篇已加入<.NET Core on K8S学习实践系列文章索引>,可以点击查看更多容器化技术相关系列文章. 一.将Docker数据挂载到容器 在Docker中,要想实现数据的持久化(所谓Docker的数据持久化即数据不随着Container的结束而结束),需要将数据从宿主机挂载到容器中.目前Docker提供了三种不同的方式将数据从宿主机挂载到容器中: (1)volumes:Docker管理宿主机文件系统的一部分,默认位于 /var/lib/docker/volumes 目录中:(最常用的方式