Traditional Culture Encyclopedia - Weather inquiry - Troubleshooting of UDP message failure
Troubleshooting of UDP message failure
The program is sent to the local application and the remote application at the same time. Although it is different IP and port, it is the same logic, so the problem of the program itself is less likely. Test whether it is a network problem first:
First, let's look at how this 1472 came from. In the Ethernet environment, the body size of an Ethernet frame is between 46 bytes and 1500 bytes. This time, in the IPV4 environment, the IP header size is 20 bytes, so there are 1480 bytes. The header length of udp protocol is 8 bytes, so the remaining UDP packet length is 1480-8 = 1472 bytes, as shown in the following figure:
The format is as follows:
The above alarm means that the MTU of network cards in our environment is set to 1500 bytes, as shown below:
Because the length of the transmitted UDP message exceeds the safe length of 1472 bytes, it does not mean that it cannot be sent, but because it exceeds the maximum transmission length of the frame, it needs to be packed at the IP layer. Once the network environment is not good, IP packetization will fail, resulting in the loss of UDP packets.
You can also monitor through netstat -su:
Because the MTU is too small, try to modify the maximum MTU at both ends, that is, the minimum MTU of the whole route. We try to increase the MTU at both ends:
After the MTU at both ends is increased, the error will still be reported, so the possible reason is that the MTU set by the intermediate routing device is relatively small. Check it because there is no traceroute command to trace on the host, please try another command:
Similar to traceroute, you can trace the route and print the MTU value after the end.
You can also get a port and test this UDP port.
In the actual environment, because many routes in the middle are invisible, and it is not realistic to change the MTU values of all routes in the middle.
When the MTU is 1500 bytes, if the sent UDP message is larger than the MTU, such as sending 8000 bytes, if the message buffer is sufficient and the message arrival sequence is correct, a complete UDP message can still be received through recvfrom(9000). If the IP fragment is lost and the verification fails, the packet will be discarded. Recvfrom(9000) will be blocked.
In order to prevent the problems caused by the overflow of socket buffer, the buffer of socket is specially increased.
Cat/proc/sys/net/core/rmem _ default and cat /proc/sys/net/core/rmem_max can view the default and maximum values of socket buffers.
You can use echoxxx >/proc/sys/net/core/rmem _ default or add the following configuration by changing the /etc/sysctl.conf file:
Remember, the following command will not take effect until the modification is completed:
But it didn't work this time.
The final solution is to bypass this problem, change the interface directly, and use file collection instead of UDP transmission.
This is an unsuccessful experience, and friends with this experience can leave a message to exchange what caused this problem.
- Previous article:Where can I hike outdoors in Baoding?
- Next article:Gale weather forecast
- Related articles
- Who knows the Spring Festival couplets? Ten members of parliament
- Seek eleven to climb Mount Tai and Fontaine. ...
- Is the flooding of Shenzhen subway station caused by the rainstorm caused by typhoon?
- The climate in Yunnan is more similar to that in Beijing.
- 165438+ 10 Chongqing Jiuzhaigou Travel Guide 65438+Jiuzhaigou Travel Guide in February
- Historical weather in Hefei
- Who is the outstanding athlete in the marathon?
- What's the weather like in Shanghai during the New Year holiday? Get ready to travel.
- A complete collection of 75 practical telephone numbers.
- What are the applications of artificial intelligence in life?