目前我这里docker主要使用1.5版本,用途是给研发、运维做测试环境,给游戏与平台业务做生产应用,昨天接到某游戏研发反馈,2个不同宿主机进行数据同步的时候,出现以下错误
orrupted MAC on input. Disconnecting: Packet corrupt lost connection
经过谷歌搜索发现问题原因是
"Corrupted MAC on input" This situation happens when the packet is decrypted, the length field is checked, the MAC is computed over the decrypted data and then checked against the MAC field from the SSH packet (see the picture above). If those two MACs don't match we print the "bad mac" error message. Possible reasons for "Corrupted MAC on input" If you see those messages instead of the "Bad packet length" one you can safely assume that the encryption/decryption works fine. If it wasn't then the packet length check could hardly pass a few times in a row - assuming we have seen the message a couple of times at least. That means that we have a data corruption somewhere. There are many situations this could happen. It could be a mulfunctioning: firewall, or NAT, or NIC device driver, or NIC itself, or switch/router along the way, or ...something else that corrupted the data in between the two SSH parties Again, it could also be the SSH implementation itself but as with the "bad packet length" problem that's usually not the case. Note that all those corruptions assume that the TCP packet passes the checksum test but that can easily happen. The checksum is basically a sum of all 16 bit words in the TCP frame; see RFC 793 (Transmission Control Protocol) for the details.
具体网页地址是https://blogs.oracle.com/janp/entry/ssh_messages_code_bad_packet
我容器跨主机互通是使用ovs+vxlan,为了测试是否真为此问题,我使用下面方法进行测试。
1、测试环境
容器名 内网IP 宿主机 test_mac 172.16.2.114 A test_mac_2 172.16.2.115 B test_mac_3 172.16.2.116 A
在宿主机A的容器test_mac里生成3G测试文件
09:56:16 # dd if=/dev/zero of=/tmp/test.tgz bs=1G count=3 3+0 records in 3+0 records out 3221225472 bytes (3.2 GB) copied, 5.21114 s, 618 MB/s
2、测试另外宿主机B的跨主机容器数据同步情况
root@41255dbf85b4:/tmp 09:56:21 # scp -P 22 172.16.2.114:/tmp/test.tgz . root@172.16.2.114's password: test.tgz 3% 99MB 50.6MB/s 00:58 ETA Corrupted MAC on input. Disconnecting: Packet corrupt lost connection
可以看到出现了问题。
3、测试通宿主机容器数据同步情况
09:59:50 # scp -P 22 172.16.2.114:/tmp/test.tgz . root@172.16.2.114's password: test.tgz 100% 3072MB 80.8MB/s 00:38 root@5805f5017f89:/tmp
可以看到正常同步。
4、解决跨宿主机容器数据同步方法
先在宿主机B里获取容器test_mac_2的pid
[root@ip-10-10-125-10 ~]# docker inspect test_mac_2|grep -i pid "PidMode": "", "Pid": 29416,
可以看到pid是29416
然后使用nsenter来设置容器的内网网卡eth1关闭校验和
nsenter --target 29416 --mount --uts --ipc --net --pid -- /bin/bash -c "ethtool -k eth1"
使用nsenter是因为此方法可以直接拥有最高权限来修改,如果直接在容器里输入会有下面错误
10:12:52 # ethtool -K eth0 tx off rx off Cannot get device feature names: No such device root@41255dbf85b4:/
下面是解决前eth1网卡信息
[root@ip-10-10-125-10 ~]# nsenter --target 29416 --mount --uts --ipc --net --pid -- /bin/bash -c "ethtool -k eth1" Features for eth1: rx-checksumming: on tx-checksumming: on tx-checksum-ipv4: off [fixed] tx-checksum-ip-generic: on tx-checksum-ipv6: off [fixed] tx-checksum-fcoe-crc: off [fixed] tx-checksum-sctp: off [fixed] scatter-gather: on tx-scatter-gather: on tx-scatter-gather-fraglist: on tcp-segmentation-offload: on tx-tcp-segmentation: on tx-tcp-ecn-segmentation: on tx-tcp6-segmentation: on udp-fragmentation-offload: on generic-segmentation-offload: on generic-receive-offload: on large-receive-offload: off [fixed] rx-vlan-offload: on tx-vlan-offload: on ntuple-filters: off [fixed] receive-hashing: off [fixed] highdma: on rx-vlan-filter: off [fixed] vlan-challenged: off [fixed] tx-lockless: on [fixed] netns-local: off [fixed] tx-gso-robust: off [fixed] tx-fcoe-segmentation: off [fixed] tx-gre-segmentation: on tx-ipip-segmentation: on tx-sit-segmentation: on tx-udp_tnl-segmentation: on tx-mpls-segmentation: off [fixed] fcoe-mtu: off [fixed] tx-nocache-copy: on loopback: off [fixed] rx-fcs: off [fixed] rx-all: off [fixed] tx-vlan-stag-hw-insert: on rx-vlan-stag-hw-parse: on rx-vlan-stag-filter: off [fixed] busy-poll: off [fixed]
开始运行命令关闭校验和
[root@ip-10-10-125-10 ~]# nsenter --target 29416 --mount --uts --ipc --net --pid -- /bin/bash -c "ethtool -K eth1 tx off rx off " Actual changes: rx-checksumming: off tx-checksumming: off tx-checksum-ip-generic: off tcp-segmentation-offload: off tx-tcp-segmentation: off [requested on] tx-tcp-ecn-segmentation: off [requested on] tx-tcp6-segmentation: off [requested on] udp-fragmentation-offload: off [requested on]
然后在查看一下eth1网卡信息
Features for eth1: rx-checksumming: off tx-checksumming: off tx-checksum-ipv4: off [fixed] tx-checksum-ip-generic: off tx-checksum-ipv6: off [fixed] tx-checksum-fcoe-crc: off [fixed] tx-checksum-sctp: off [fixed] scatter-gather: on tx-scatter-gather: on tx-scatter-gather-fraglist: on tcp-segmentation-offload: off tx-tcp-segmentation: off [requested on] tx-tcp-ecn-segmentation: off [requested on] tx-tcp6-segmentation: off [requested on] udp-fragmentation-offload: off [requested on] generic-segmentation-offload: on generic-receive-offload: on large-receive-offload: off [fixed] rx-vlan-offload: on tx-vlan-offload: on ntuple-filters: off [fixed] receive-hashing: off [fixed] highdma: on rx-vlan-filter: off [fixed] vlan-challenged: off [fixed] tx-lockless: on [fixed] netns-local: off [fixed] tx-gso-robust: off [fixed] tx-fcoe-segmentation: off [fixed] tx-gre-segmentation: on tx-ipip-segmentation: on tx-sit-segmentation: on tx-udp_tnl-segmentation: on tx-mpls-segmentation: off [fixed] fcoe-mtu: off [fixed] tx-nocache-copy: on loopback: off [fixed] rx-fcs: off [fixed] rx-all: off [fixed] tx-vlan-stag-hw-insert: on rx-vlan-stag-hw-parse: on rx-vlan-stag-filter: off [fixed] busy-poll: off [fixed]
可以很明显看到rx-checksumming与tx-checksumming都从on变为off了。
然后在宿主机B里使用test_mac_2进行数据同步宿主机A的test_mac数据
10:16:09 # scp -P 22 172.16.2.114:/tmp/test.tgz . root@172.16.2.114's password: test.tgz 100% 3072MB 46.6MB/s 01:06 root@41255dbf85b4:/
可以看到数据传输正常。
本文转自 reinxu 51CTO博客,原文链接:http://blog.51cto.com/dl528888/1655631,如需转载请自行联系原作者