docker部分常见配置

对于centos 7系统而言
1.修改docker镜像存放位置
须要修改/usr/lib/systemd/system/docker.service文件中为
ExecStart = '.... --graph /path/to/dir'   添加 --grahp /path/to/dir
注意:/path/to/dir目录是不存在的,  权限为  drwx-----x
须要重启docker
systemctl restart docker
不建议本身建立,可经过建立软链接的方式linux

自动化实现修改:
sed -ie 's@ExecStart=/usr/bin/docker-current daemon@ExecStart=/usr/bin/docker-current daemon --graph /data/docker@' /usr/lib/systemd/system/docker.servicegit

2.修改docker以监听端口的方式启动
须要修改/usr/lib/systemd/system/docker.service文件中
ExecStart 中的内容
ExecStart='... -H tcp://0.0.0.0:2375'
修改后须要重启docker
systemctl restart dockergithub

自动化实现修改:
sed -ie 's@ExecStart=/usr/bin/docker-current daemon@ExecStart=/usr/bin/docker-current daemon -H tcp://0.0.0.0:2375@' /usr/lib/systemd/system/docker.servicedocker


3.centos7宿主机上创建Docker桥接物理网络过程
须要安装bridge-utils包
宿主机网卡信息:
name:ens0
IP:192.168.184.99
GATEWAY:192.168.184.2
DNS:192.168.184.2vim

1. 中止docker服务
~#:service docker stopcentos

2.删除docker0网卡
~#:ip link set dev docker0 down
~#:brctl delbr docker0bash

3.新建桥接物理网络虚拟网卡br0
~#:brctl addbr br0
~#:ip link set dev br0 up
~#:ip addr add 192.168.184.100/24 dev br0 #为br0分配物理网络中的ip地址
~#:ip addr del 192.168.184.99/24 dev ens0 #将宿主机网卡的IP清空
~#:brctl addif br0 ens0 #将宿主机网卡挂到br0上
~#:ip route del default #删除原路由
~#:ip route add default via 192.168.184.2 dev br0 #为br0设置路由网络

4.设置docker服务启动参数
这里要注意的是,不一样的linux操做系统docker的配置文件所在不一样
centos 在/etc/sysconfig/docker
其余操做系统请前往下面的网址
https://docs.docker.com/installation/#installationtcp

~#:vim /etc/sysconfig/docker #在OPTIONS='--selinux-enabled'这行中修改成OPTIONS='--selinux-enabled -b=br0'即让docker服务启动时使用br0网卡进行桥接centos7

5.启动docker服务
~#:service docker start

6.安装pipework
~#:git clone https://github.com/jpetazzo/pipework
~#:cp ~/pipework/pipework /usr/local/bin/

7.启动一个手动设置网络的容器
这里最好不要让docker自动获取ip,下次启动会有变化并且自动获取的ip可能会和物理网段中的ip冲突
~#:docker run -itd --net=none --name=test centos7 /bin/bash

9.为test容器设置一个与桥接物理网络同地址段的ip@网关
~#:pipework br0 test 192.168.184.11/24@192.168.184.2

10.进入容器查看ip ~#:docker attach test

相关文章
相关标签/搜索