How do the communication protocols TCP and UDP (QUIC) differ?

How do the communication protocols TCP and UDP (QUIC) differ?

General

Two protocols are available for communication between the timeSensor LEGAL 365 Client App and the database (backend):
  • TCP
  • UDP (QUIC)
This article explains the advantages and disadvantages of the two protocols.

Difference TCP vs. UDP (QUIC)

  • TCP guarantees a reliable, ordered data transmission. If packets are lost, they are resent. However, as soon as the connection is interrupted (e.g. due to timeout or routing problem), TCP immediately detects this and terminates the connection.

  • UDP (QUIC) on the other hand is connectionless and tolerant of packet loss. The 4D database (or QUIC as a transport layer) tries to keep data streams running despite disruptions. This makes the system more robust against short network problems, but there is no 100% guarantee that all data packets arrive in the correct order or completely.

If, during a major network disruption under UDP

  • individual UDP packets are lost,

  • or packets arrive late or in the wrong order,
    the state of client-server synchronization can become inconsistent.

Example:

  • The client requests record ID 123 .

  • The response packet is received partially or late.

  • QUIC tries to reconstruct, but parts of the stream are inconsistent.

  • The client receives data that looks formally correct (because it can be decoded), but no longer matches the expected request.

This can lead to the following behavior:

Click on record A → display of a different record.

The client "believes" it is synchronized with the server, but it is no longer.

Source of disruption Anti-Virus Software

Antivirus software can massively interfere with network traffic in terminal server or remote desktop environments and massively interfere with network traffic, and this particularly affects UDP/QUIC connections.

How antivirus software interferes with communication

Many modern AV products (e.g. BitDefender, Kaspersky, ESET, Sophos, etc.) include network protection modulesthat:

  • intercept and inspect all network traffic, intercept and inspect,

  • possibly break and re-encrypt TLS/SSL connections,,

  • apply heuristics or "intrusion detection" apply,

  • and discard "abnormal" UDP packets if they do not fit the expected scheme.

This happens deep in the Windows network stack, often via:

  • NDIS drivers,

  • LSPs (Layered Service Provider),

  • or WFP filters (Windows Filtering Platform).

These hooks are located below the application layer, also below 4D.
This means: 4D does not notice that packets have been blocked, delayed, or altered.

Why this is especially problematic with UDP/QUIC

UDP/QUIC is stateless and and time-critical..
If packets are delayed, blocked, or "re-sequenced":

  • the expected packet sequence is no longer correct,

  • internal streams of QUIC break asynchronously,

  • or certain sequence numbers "are missing."

This also leads to the phenomenon described above, where the client app continues to respond but delivers incorrect records or illogical search results.

TCP would be less susceptible here because TCP would detect and terminate a faulty transmission – UDP/QUIC, on the other hand, tries to "sneak through," and 4D continues to work with inconsistent data.

Why terminal servers are particularly affected

In terminal server environments, the following run:

  • many simultaneous 4D client instances,

  • over the same network interface,

  • often through the same AV monitoring layer.

This causes:

  • high latencies (because the AV driver checks every stream),

  • sporadic packet losses or blockages,,

  • and sometimes memory leaks or deadlocks in the filter drivers.

Especially with "security suites" that analyze network traffic in real time or activate "protection against suspicious connections," these phenomena occur.

Conclusion

Various causes can lead to packets not being received or being received late by the client app. When using the TCP protocol, the 4D database reacts immediately by losing the connection in case of an error. This is consistent but can be unpleasant.

When using the UDP protocol, the 4D database is more tolerant and tries to keep the data streams running. However, situations can arise where the client and server are no longer synchronized without a formal error occurring. The problem then becomes noticeable, for example, when double-clicking on a record opens a different record. In such a case, the client app must be restarted.



    • Related Articles

    • How does font management differ between 4D Write and 4D Write Pro

      Background When 4D Write was developed 30 years ago, the font style (bold/italic) was created by moving pixels. An algorithm converted each character of the font into a bold or italic character if necessary by pixelated or slightly distorting the ...
    • Which ports must not be blocked by the firewall?

      This article has been machine translated. If you find any errors, we would be grateful if you could report them to translation@timesensor.com. Various tasks in timeSensor LEGAL need access to internet resources to run correctly. Therefore, you must ...
    • How do I track down crashes on the server?

      This article has been machine translated. If you find any errors, we would be grateful if you could report them to translation@timesensor.com. If you observe repeated crashes on your server, you must get to the bottom of the causes promptly. Every ...
    • Is It Possible to Directly Drag & Drop from the Volume of a Server?

      Server volumes may be connected to the file system with different protocols (AFP, SMB, FTP, etc.). Whether or not it is possible to drag & drop files located on the server volume directly into timeSensor LEGAL will depend on this protocol. Under Mac ...
    • What is the difference between the mail window and the communicator?

      There are two ways of archiving emails in timeSensor LEGAL Classic : the mail window and the communicator module. The table below shows the differences between the Mail window and the Communicator module : Characteristic mail window communicator ...