Как пользователи в локальной сети однозначно идентифицируются внешним объектом

Как пользователи в локальной сети однозначно идентифицируются внешним объектом

Рассмотрим небольшую локальную сеть. Когда каждый пользователь проверяет публичный IP-адрес (например, используя whatismyipaddress), все пользователи имеют один и тот же публичный IP-адрес. Однако ipconfig показывает разный частный IP-адрес для каждого пользователя. Допустим, два пользователя получают доступ к gmail. Как сервер gmail идентифицирует обоих пользователей, если у них одинаковый публичный IP-адрес? Пакеты данных от обоих пользователей будут иметь целевой и исходный IP-адреса. Для обоих пользователей исходный IP-адрес в их пакете данных для gmail будет одинаковым. Выполняется ли идентификация путем добавления разных номеров портов к IP-адресу каждого пользователя.

решение1

Вы сами ответили на свой вопрос :)

Каждый сеанс TCP на сервере GMail начинается с другого исходного порта на вашей стороне, поэтому обе стороны знают, какому соединению (или потоку) принадлежит каждый пакет. Отслеживание этой информации является обязанностью реализации NAT. В случае GMail каждый пользователь, скорее всего, также подключается к другому серверу на стороне Google, поскольку их так много.

GMail отслеживает, какому «пользователю» принадлежит каждое соединение/поток, на основе файлов cookie и т. д. в HTTP-трафике.

Связанный контент