Подпишите кто является клиентом а кто сервером
Перейти к содержимому

Подпишите кто является клиентом а кто сервером

  • автор:

Передача данных между клиентом и сервером

Для создания производительных приложений недостаточно научиться работать с клиентскими компонентами и SQL. Нужно еще понимать процессы, происходящие между клиентом и сервером при выполнении запросов.

Давайте рассмотрим взаимодействие на конкретном примере. В качестве клиента у нас выступает приложение и gds32.dll (fbclient.dll), поскольку все высокоуровневые вызовы компонент доступа к БД все равно превращаются в вызовы gds32.dll). Тип соединения (локальный, сетевой tcp или netbeui) не имеет значения.

Также опускаем все подробности по установке соединения и вызовам всяческих сервисных или информационных функций. Основная деятельность между клиентом и сервером – это обработка запросов SQL. На картинке изображена последовательность действий между клиентом и сервером при выполнении любого запроса. Пусть это будет

SELECT * FROM TEST

  1. Независимо от того, один вызов клиентской библиотеки выполняет запрос, или несколько, gds32.dll всегда начинает с Prepare. Prepare означает отправку запроса на сервер. При этом сервер
  • проверяет синтаксическую корректность запроса
  • проверяет наличие всех объектов, указанных в запросе, и права доступа к ним.
  • формирует список возвращаемых столбцов и параметров (если таковые есть)
  • передает клиенту результат prepare (ok, error), и списки столбцов и параметров (если есть)

после выполнения prepare от сервера можно получить план запроса – для примера см. код IBX.

  1. Раз запрос корректен, и вся информация для получения данных, возвращаемых запросом, получена от сервера, запрос можно выполнить. Вызывается Execute. Собственно, только в этот момент сервер начинает выполнять запрос.

На данном этапе, пока запрос не выполнится целиком, клиент не получит никакого сообщения. Под «выполнением» запроса означает готовность сервера к выдаче первой записи, возвращаемой запросом, или успешного/неуспешного выполнения запроса (например выполнение операторов ddl или процедур, не возвращающих результат, а также update, insert, delete).
Время выполнения запроса зависит от метода его обработки на сервере. Если это прямое считывание данных с диска (в натуральном порядке или по индексу), то ответ сервера на Execute придет быстро. Если это группировка или сортировка без использования индекса, то чем больше обрабатывается данных, тем дольше будет выполняться запрос.

  1. Запрос выполнен, и теперь клиент может начать получать записи (если они есть). Для этого клиент вызывает функцию Fetch. С точки зрения клиента (и приложения) Fetch – это получение одной записи. Но сервер всегда (кроме select for update) передает клиенту целый пакет записей. Поэтому первый Fetch приводит к получению пакета записей, а очередные Fetch – к выборке из полученного пакета (фактически буфера) до тех пор, пока записи в пакете не кончатся.
  2. Если в момент очередного Fetch клиент вместо данных записи получает EOF (End Of File), то значит на сервере данные кончились, и запрос можно закрыть.
  1. С момента выдачи серверу Execute до получения от сервера ответа (о готовности выдавать результат) клиент как бы «повисает», а сервер продолжает выполнять запрос «до упора». Если в этот момент принудительно «снять» клиентское приложение, сервер все равно проверит существование клиентского соединения только когда закончит выполнять запрос, т. е. соберется передавать результат клиенту. Существуют только две версии серверов, в которых запрос в этот момент можно отменить:
  • IB 6.5, при помощи вызова IB API (в отдельном thread). Подробнее обратитесь к APIGuide.pdf от IB 6.5/7.0
  • IB 7.x, при помощи временных системных таблиц (в отдельном коннекте). Подробнее см. OpGuide.pdf от IB 7.x
  1. На пути данных от сервера к клиенту может возникнуть тройная буферизация:
  • данные запросов, сортируемые на диске, формируются в момент Execute и удерживаются сервером до тех пор, пока клиент не выберет последнюю запись. Т. е. это своеобразный «кэш запроса на сервере», причем кэш, индивидуальный для каждого запроса, содержащего в плане слово SORT.
  • Клиент, запрашивая данные «поштучно», все равно получает от сервера «пакеты записей», т. е. буфер присутствует в gds32.dll
  • Клиентские компоненты (BDE, FIBPlus, IBX. ) так или иначе тоже буферизируют принимаемые данные. Особенно это относится к компонентам dbExpress, где обеспечить навигацию по записям можно только буферизировав их (целиком все записи) при помощи ClientDataSet.

Не буферизируют записи такие компоненты, как IBX.IBSQL и FIBPlus.pFIBQuery.

  • Сортировка большого количества записей приводит к длительному выполнению запроса на сервере (методы ускорения этого есть во всех последних версиях IB, FB и YA) и к неспособности клиента в это время выполнять другие действия (в этом коннекте. О параллельной работе в разных коннектах см. FAQ).
  • Многочисленная буферизация приводит к тому, что данные становятся «неактуальными» задолго до того, как клиент их начнет просматривать. Собственно, здесь нет никаких проблем с точки зрения целостности данных в транзакции.

Другие статьи на эту же тему

  • Обновление клиентских наборов данных
  • Как работает BDE (TTable и TQuery)?
  • IBX (IBDataSet)
  • Все о ClientDataSet

Copyright iBase.ru © 2002-2024

HTTP-запросы: структура, методы, строка статуса и коды состояния

Рассказываем, как веб- и мобильные приложения взаимодействуют с глобальной сетью через HTTP-протокол.

Изображение записи

Большинство используемых нами веб- и мобильных приложений постоянно взаимодействуют с глобальной сетью. Почти все подобные коммуникации совершаются с помощью запросов по протоколу HTTP. Рассказываем о них подробнее.

Базово о протоколе HTTP

HTTP (HyperText Transfer Protocol, дословно — «протокол передачи гипертекста») представляет собой протокол прикладного уровня, используемый для доступа к ресурсам Всемирной Паутины. Под термином гипертекст следует понимать текст, в понятном для человека представлении, при этом содержащий ссылки на другие ресурсы.

Данный протокол описывается спецификацией RFC 2616. На сегодняшний день наиболее распространенной версией протокола является версия HTTP/2, однако нередко все еще можно встретить более раннюю версию HTTP/1.1.

В обмене информацией по HTTP-протоколу принимают участие клиент и сервер. Происходит это по следующей схеме:

  1. Клиент запрашивает у сервера некоторый ресурс.
  2. Сервер обрабатывает запрос и возвращает клиенту ресурс, который был запрошен.

Схема коммуникации устройств по HTTP-протоколу.

По умолчанию для коммуникации по HTTP используется порт 80, хотя вместо него может быть выбран и любой другой порт. Многое зависит от конфигурации конкретного веб-сервера.

HTTP-сообщения: запросы и ответы

Данные между клиентом и сервером в рамках работы протокола передаются с помощью HTTP-сообщений. Они бывают двух видов:

  • Запросы (HTTP Requests) — сообщения, которые отправляются клиентом на сервер, чтобы вызвать выполнение некоторых действий. Зачастую для получения доступа к определенному ресурсу. Основой запроса является HTTP-заголовок.
  • Ответы (HTTP Responses) — сообщения, которые сервер отправляет в ответ на клиентский запрос.

Само по себе сообщение представляет собой информацию в текстовом виде, записанную в несколько строчек.

В целом, как запросы HTTP, так и ответы имеют следующую структуру:

  1. Стартовая строка (start line) — используется для описания версии используемого протокола и другой информации — вроде запрашиваемого ресурса или кода ответа. Как можно понять из названия, ее содержимое занимает ровно одну строчку.
  2. HTTP-заголовки (HTTP Headers) — несколько строчек текста в определенном формате, которые либо уточняют запрос, либо описывают содержимое тела сообщения.
  3. Пустая строка, которая сообщает, что все метаданные для конкретного запроса или ответа были отправлены.
  4. Опциональное тело сообщения, которое содержит данные, связанные с запросом, либо документ (например HTML-страницу), передаваемый в ответе.

Рассмотрим атрибуты HTTP-запроса подробнее.

Стартовая строка

Стартовая строка HTTP-запроса состоит из трех элементов:

  1. Метод HTTP-запроса (method, реже используется термин verb). Обычно это короткое слово на английском, которое указывает, что конкретно нужно сделать с запрашиваемым ресурсом. Например, метод GET сообщает серверу, что пользователь хочет получить некоторые данные, а POST — что некоторые данные должны быть помещены на сервер.
  2. Цель запроса. Представлена указателем ресурса URL, который состоит из протокола, доменного имени (или IP-адреса), пути к конкретному ресурсу на сервере. Дополнительно может содержать указание порта, несколько параметров HTTP-запроса и еще ряд опциональных элементов.
  3. Версия используемого протокола (либо HTTP/1.1, либо HTTP/2), которая определяет структуру следующих за стартовой строкой данных.

В примере ниже стартовая строка указывает, что в качестве метода используется GET, обращение будет произведено к ресурсу /index.html, по версии протокола HTTP/1.1:

Основные структурные элементы URL.

Разберемся с каждым из названных элементов подробнее.

Методы

Методы позволяют указать конкретное действие, которое мы хотим, чтобы сервер выполнил, получив наш запрос. Так, некоторые методы позволяют браузеру (который в большинстве случаев является источником запросов от клиента) отправлять дополнительную информацию в теле запроса — например, заполненную форму или документ.

Ниже приведены наиболее используемые методы и их описание:

Методы запроса.

Разберемся с каждым из названных элементов подробнее.

Метод Описание
GET Позволяет запросить некоторый конкретный ресурс. Дополнительные данные могут быть переданы через строку запроса (Query String) в составе URL (например ?param=value).О составляющих URL мы поговорим чуть позже.
POST Позволяет отправить данные на сервер. Поддерживает отправку различных типов файлов, среди которых текст, PDF-документы и другие типы данных в двоичном виде. Обычно метод POST используется при отправке информации (например, заполненной формы логина) и загрузке данных на веб-сайт, таких как изображения и документы.
HEAD Здесь придется забежать немного вперед и сказать, что обычно сервер в ответ на запрос возвращает заголовок и тело, в котором содержится запрашиваемый ресурс. Данный метод при использовании его в запросе позволит получить только заголовки, которые сервер бы вернул при получении GET-запроса к тому же ресурсу. Запрос с использованием данного метода обычно производится для того, чтобы узнать размер запрашиваемого ресурса перед его загрузкой.
PUT Используется для создания (размещения) новых ресурсов на сервере. Если на сервере данный метод разрешен без надлежащего контроля, то это может привести к серьезным проблемам безопасности.
DELETE Позволяет удалить существующие ресурсы на сервере. Если использование данного метода настроено некорректно, то это может привести к атаке типа «Отказ в обслуживании» (Denial of Service, DoS) из-за удаления критически важных файлов сервера.
OPTIONS Позволяет запросить информацию о сервере, в том числе информацию о допускаемых к использованию на сервере HTTP-методов.
PATCH Позволяет внести частичные изменения в указанный ресурс по указанному расположению.

URL

Получение доступа к ресурсам по HTTP-протоколу осуществляется с помощью указателя URL (Uniform Resource Locator). URL представляет собой строку, которая позволяет указать запрашиваемый ресурс и еще ряд параметров.

Использование URL неразрывно связано с другими элементами протокола, поэтому далее мы рассмотрим его основные компоненты и строение:

Поле Scheme используется для указания используемого протокола, всегда сопровождается двоеточием и двумя косыми чертами (://).

Host указывает местоположение ресурса, в нем может быть как доменное имя, так и IP-адрес.

Port, как можно догадаться, позволяет указать номер порта, по которому следует обратиться к серверу. Оно начинается с двоеточия (:), за которым следует номер порта. При отсутствии данного элемента номер порта будет выбран по умолчанию в соответствии с указанным значением Scheme (например, для http:// это будет порт 80).

Далее следует поле Path. Оно указывает на ресурс, к которому производится обращение. Если данное поле не указано, то сервер в большинстве случаев вернет указатель по умолчанию (например index.html).

Поле Query String начинается со знака вопроса (?), за которым следует пара «параметр-значение», между которыми расположен символ равно (=). В поле Query String могут быть переданы несколько параметров с помощью символа амперсанд (&) в качестве разделителя.

Не все компоненты необходимы для доступа к ресурсу. Обязательно следует указать только поля Scheme и Host.

Версии HTTP

Раз уж мы упомянули версию протокола как элемента стартовой строки, то стоит сказать об основных отличиях версий HTTP/1.X от HTTP/2.X.

Последняя стабильная, наиболее стандартизированная версия протокола первого поколения (версия HTTP/1.1) вышла в далеком 1997 году. Годы шли, веб-страницы становились сложнее, некоторые из них даже стали приложениями в том виде, в котором мы понимаем их сейчас. Кроме того, объем медиафайлов и скриптов, которые добавляли интерактивность страницам, рос. Это, в свою очередь, создавало перегрузки в работе протокола версии HTTP/1.1.

Стало очевидно, что у HTTP/1.1 есть ряд значительных недостатков:

  • Заголовки, в отличие от тела сообщения, передавались в несжатом виде.
  • Часто большая часть заголовков в сообщениях совпадала, но они продолжали передаваться по сети.
  • Отсутствовала возможность так называемого мультиплексирования — механизма, позволяющего объединить несколько соединений в один поток данных. Приходилось открывать несколько соединений на сервере для обработки входящих запросов.

С выходом HTTP/2 было предложено следующее решение: HTTP/1.X-сообщения разбивались на так называемые фреймы, которые встраивались в поток данных.

Фреймы данных (тела сообщения) отделялись от фреймов заголовка, что позволило применять сжатие. Вместе с появлением потоков появился и ранее описанный механизм мультиплексирования — теперь можно было обойтись одним соединением для нескольких потоков.

Единственное о чем стоит сказать в завершение темы: HTTP/2 перестал быть текстовым протоколом, а стал работать с «сырой» двоичной формой данных. Это ограничивает чтение и создание HTTP-сообщений «вручную». Однако такова цена за возможность реализации более совершенной оптимизации и повышения производительности.

Заголовки

HTTP-заголовок представляет собой строку формата «Имя-Заголовок:Значение», с двоеточием(:) в качестве разделителя. Название заголовка не учитывает регистр, то есть между Host и host, с точки зрения HTTP, нет никакой разницы. Однако в названиях заголовков принято начинать каждое новое слово с заглавной буквы. Структура значения зависит от конкретного заголовка. Несмотря на то, что заголовок вместе со значениями может быть достаточно длинным, занимает он всего одну строчку.

В запросах может передаваться большое число различных заголовков, но все их можно разделить на три категории:

  1. Общего назначения, которые применяются ко всему сообщению целиком.
  2. Заголовки запроса уточняют некоторую информацию о запросе, сообщая дополнительный контекст или ограничивая его некоторыми логическими условиями.
  3. Заголовки представления, которые описывают формат данных сообщения и используемую кодировку. Добавляются к запросу только в тех случаях, когда с ним передается некоторое тело.

Ниже можно видеть пример заголовков в запросе:

Самые частые заголовки запроса
Заголовок Описание
Host Используется для указания того, с какого конкретно хоста запрашивается ресурс. В качестве возможных значений могут использоваться как доменные имена, так и IP-адреса. На одном HTTP-сервере может быть размещено несколько различных веб-сайтов. Для обращения к какому-то конкретному требуется данный заголовок.
User-Agent Заголовок используется для описания клиента, который запрашивает ресурс. Он содержит достаточно много информации о пользовательском окружении. Например, может указать, какой браузер используется в качестве клиента, его версию, а также операционную систему, на которой этот клиент работает.
Refer Используется для указания того, откуда поступил текущий запрос. Например, если вы решите перейти по какой-нибудь ссылке в этой статье, то вероятнее всего к запросу будет добавлен заголовок Refer: https://selectel.ru
Accept Позволяет указать, какой тип медиафайлов принимает клиент. В данном заголовке могут быть указаны несколько типов, перечисленные через запятую (‘ , ‘). А для указания того, что клиент принимает любые типы, используется следующая последовательность — */*.
Cookie Данный заголовок может содержать в себе одну или несколько пар «Куки-Значение» в формате cookie=value. Куки представляют собой небольшие фрагменты данных, которые хранятся как на стороне клиента, так и на сервере, и выступают в качестве идентификатора. Куки передаются вместе с запросом для поддержания доступа клиента к ресурсу. Помимо этого, куки могут использоваться и для других целей, таких как хранение пользовательских предпочтений на сайте и отслеживание клиентской сессии. Несколько кук в одном заголовке могут быть перечислены с помощью символа точка с запятой (‘ ; ‘), который используется как разделитель.
Authorization Используется в качестве еще одного метода идентификации клиента на сервере. После успешной идентификации сервер возвращает токен, уникальный для каждого конкретного клиента. В отличие от куки, данный токен хранится исключительно на стороне клиента и отправляется клиентом только по запросу сервера. Существует несколько типов аутентификации, конкретный метод определяется тем веб-сервером или веб-приложением, к которому клиент обращается за ресурсом.

Тело запроса

Завершающая часть HTTP-запроса — это его тело. Не у каждого HTTP-метода предполагается наличие тела. Так, например, методам вроде GET, HEAD, DELETE, OPTIONS обычно не требуется тело. Некоторые виды запросов могут отправлять данные на сервер в теле запроса: самый распространенный из таких методов — POST.

Ответы HTTP

HTTP-ответ является сообщением, которое сервер отправляет клиенту в ответ на его запрос. Его структура равна структуре HTTP-запроса: стартовая строка, заголовки и тело.

Строка статуса (Status line)

Стартовая строка HTTP-ответа называется строкой статуса (status line). На ней располагаются следующие элементы:

  1. Уже известная нам по стартовой строке запроса версия протокола (HTTP/2 или HTTP/1.1).
  2. Код состояния, который указывает, насколько успешно завершилась обработка запроса.
  3. Пояснение — короткое текстовое описание к коду состояния. Используется исключительно для того, чтобы упростить понимание и восприятие человека при просмотре ответа.

Строка состояния ответа.

Коды состояния и текст статуса

Коды состояния HTTP используются для того, чтобы сообщить клиенту статус их запроса. HTTP-сервер может вернуть код, принадлежащий одной из пяти категорий кодов состояния:

Категория Описание
1xx Коды из данной категории носят исключительно информативный характер и никак не влияют на обработку запроса.
2xx Коды состояния из этой категории возвращаются в случае успешной обработки клиентского запроса.
3xx Эта категория содержит коды, которые возвращаются, если серверу нужно перенаправить клиента.
4xx Коды данной категории означают, что на стороне клиента был отправлен некорректный запрос. Например, клиент в запросе указал не поддерживаемый метод или обратился к ресурсу, к которому у него нет доступа.
5xx Ответ с кодами из этой категории приходит, если на стороне сервера возникла ошибка.

Полный список кодов состояния доступен в спецификации к протоколу, ниже приведены только самые распространенные коды ответов:

Категория Описание
200 OK Возвращается в случае успешной обработки запроса, при этом тело ответа обычно содержит запрошенный ресурс.
302 Found Перенаправляет клиента на другой URL. Например, данный код может прийти, если клиент успешно прошел процедуру аутентификации и теперь может перейти на страницу своей учетной записи.
400 Bad Request Данный код можно увидеть, если запрос был сформирован с ошибками. Например, в нем отсутствовали символы завершения строки.
403 Forbidden Означает, что клиент не обладает достаточными правами доступа к запрошенному ресурсу. Также данный код можно встретить, если сервер обнаружил вредоносные данные, отправленные клиентом в запросе.
404 Not Found Каждый из нас, так или иначе, сталкивался с этим кодом ошибки. Данный код можно увидеть, если запросить у сервера ресурс, которого не существует на сервере.
500 Internal Error Данный код возвращается сервером, когда он не может по определенным причинам обработать запрос.

Помимо основных кодов состояния, описанных в стандарте, существуют и коды состояния, которые объявляются крупными сетевыми провайдерами и серверными платформами. Так, коды состояния, используемые Selectel, можно посмотреть здесь.

Заголовки ответа

Response Headers, или заголовки ответа, используются для того, чтобы уточнить ответ, и никак не влияют на содержимое тела. Они существуют в том же формате, что и остальные заголовки, а именно «Имя-Значение» с двоеточием (:) в качестве разделителя.

Ниже приведены наиболее часто встречаемые в ответах заголовки:

Категория Пример Описание
Server Server: ngnix Содержит информацию о сервере, который обработал запрос.
Set-Cookie Set-Cookie:PHPSSID=bf42938f Содержит куки, требуемые для идентификации клиента. Браузер парсит куки и сохраняет их в своем хранилище для дальнейших запросов.
WWW-Authenticate WWW-Authenticate: BASIC realm=»localhost» Уведомляет клиента о типе аутентификации, который необходим для доступа к запрашиваемому ресурсу.

Тело ответа

Последней частью ответа является его тело. Несмотря на то, что у большинства ответов тело присутствует, оно не является обязательным. Например, у кодов «201 Created» или «204 No Content» тело отсутствует, так как достаточную информацию для ответа на запрос они передают в заголовке.

Безопасность HTTP-запросов, или что такое HTTPs

HTTP является расширяемым протоколом, который предоставляет огромное количество возможностей, а также поддерживает передачу всевозможных типов файлов. Однако, вне зависимости от версии, у него есть один существенный недостаток, который можно заметить если перехватить отправленный HTTP-запрос:

Данные http-запроса передаются в открытом виде.

Да, все верно: данные передаются в открытом виде. HTTP сам по себе не предоставляет никаких средств шифрования.

Но как же тогда работают различные банковские приложения, интернет-магазины, сервисы оплаты услуг и прочие приложения, в которых циркулирует чувствительная информация пользователей?

Время рассказать про HTTPs!

HTTPs (HyperText Transfer Protocol, secure) является расширением HTTP-протокола, который позволяет шифровать отправляемые данные, перед тем как они попадут на транспортный уровень. Данный протокол по умолчанию использует порт 443.

Теперь если мы перехватим не HTTP , а HTTPs-запрос, то не увидим здесь ничего интересного:

Шифрование данных в https.

Данные передаются в едином зашифрованном потоке, что делает невозможным получение учетных данных пользователей и прочей критической информации средствами обычного перехвата.

Если хотите подробнее узнать о деталях работы протокола, читайте статью в нашем блоге →

Как отправить HTTP-запрос и прочитать его ответ

Теория это, конечно, отлично, но ничего так хорошо не закрепляет материал, как практика

Мы рассмотрим несколько способов, как написать HTTP-запрос в браузер, послать HTTP-запрос на сервер и получить ответ:

  1. Инструменты разработчика в браузере.
  2. Утилита cURL.

Инструменты разработчика

Основной программой на наших устройствах, которая работает с HTTP-протоколом, в большинстве случаев является браузер. Помимо обычных пользователей, с браузерами часто работают и разработчики веб-приложений. Именно их инструментами мы воспользуемся для работы с запросами и ответами.

По нажатию комбинации клавиш [Ctrl+Shift+I] или просто [F12] в подавляющем большинстве современных браузеров у нас откроется окно инструментов разработчика, которая представляет собой панель с несколькими вкладками. Нужная нам вкладка обычно называется Network. Перейдем в нее, а в адресной строке введем URL того сайта, на который хотим попасть. В качестве примера воспользуемся сайтом блога Selectel — https://selectel.ru/blog/.

После нажатия Enter сайт начнет загружаться, а открытая вкладка Network — заполняться различными элементами, начиная все больше напоминать приборную панель самолета.

Вкладка network.

Не спешите пугаться. Это всего лишь список ресурсов, которые нужны для правильного отображения и работы сайта.

Нажав на любой из них, мы можем увидеть детали обработки отправленного запроса:

Детали обработки запроса.

В данном запросе, например:

  • URL, к которому было совершено обращение — https://selectel.ru/blog,
  • Метод, который был использован в запросе — GET,
  • И в качестве кода возврата сервер вернул нам страницу с кодом статуса — 200 OK

Утилита cURL

Следующий инструмент, с помощью которого мы сможем послать запрос на тот или иной сервер, это утилита cURL.

cURL (client URL) является небольшой утилитой командной строки, которая позволяет работать с HTTP и рядом других протоколов.

Для отправки запроса и получения ответа мы можем воспользоваться флагом -v и указанием URL того ресурса, который мы хотим получить. «Схему» HTTP-запроса можно увидеть на скрине ниже:

Схема запроса.

После запуска утилита выполняет:

  • подключение к серверу,
  • самостоятельно разрешает все вопросы, необходимые для отправки запроса по HTTPs,
  • отправляет запрос, содержимое которого мы можем видеть благодаря флагу -v,
  • принимая ответ от сервера, отображает его в командной строке «как-есть».

Помимо этого, у данной утилиты есть огромное количество опций, которые предоставляют возможности по детальной настройке отправляемых запросов. Все эти возможности и делают ее такой популярной у веб-разработчиков и других специалистов, которым приходится работать с протоколом HTTP.

Заключение

HTTP представляет собой расширяемый протокол прикладного уровня, на котором работает весь веб-сегмент интернета. В данной статье мы рассмотрели принцип его работы, структуру, «компоненты» HTTP-запросов. Коснулись вопросов отличия версий протокола, HTTPs — его расширения, добавляющего шифрование. Разобрали устройство запроса, поняли, как можно отправить HTTP-запрос и получить ответ от сервера.

Технология клиент-сервер: что это такое?

banner

Технология клиент-сервер — это сетевая архитектура, в которой процессы обмена данными или файлами распределена между так называемыми поставщиками и заказчиками. Сам по себе принцип очень простой, и с ним мы сталкиваемся практически каждый раз, когда работаем за компьютерным или мобильным устройством. Но понимание более детальных принципов построения связи между клиентов и сервером важно не только системным администраторам и IT-специалистам, но и простым пользователям. А при использовании серверного оборудования и СКУД эта технология является базовой.

В технологии клиент-сервер есть два главных действующих лица:

  • клиент — компьютерное или мобильное устройство при управлении пользователем, которое отправляет запрос или команду серверу (например, ввод поискового запроса в Google тоже относится к этому процессу);
  • сервер — аппаратный или облачный сервер, который принимает запрос и выполняет его (обработка данных на сайтах, приложениях и в сервисах происходит через веб-узлы).

Отсюда и возникло название “клиент-сервер”. Его стали применять еще в начале развития эпохи интернета. Но в современных реалиях стоит добавить и третий элемент — сеть, через которую осуществляется передача данных.

Если бы не существовало архитектуры “клиент-сервер”, то работать в интернете было бы очень сложно. Дело в том, что все запросы конкретный сервер обрабатывает не одновременно, а в приоритетной очередности. Как и любой компьютерный процессор. Например, через мессенджер Telegram одновременно отправляют сообщение 10 000 пользователей. Сервера в data-центре компании Telegram получают этот запрос (от клиентов) и выполняют его в порядке очередности с молниеносной скоростью (основную функцию обработки выполняют процессоры серверного оборудования). Но если одновременно будет отправляться не 10 000, а, например, 100 000 или более сообщений, то может возникнуть задержка в обработке из-за нехватки вычислительных мощностей. Чье-то сообщение в очереди отправляется быстрее, а чье-то на доли миллисекунд или секунд дольше. Зависит от приоритетности.

При отсутствии сетевой архитектуры “клиент-сервер” все запросы выполнялись бы на серверном оборудовании одновременно и в хаотичном порядке. Это делало бы обработку данных во много раз дольше, не считая и других недостатков.

Помимо этого, архитектура “клиент-сервер” означает ещё и способ доставки пользователю данных какого-либо приложения. Благодаря данной архитектуре появился способ обеспечения безопасности при работе с приложениями. Есть возможность отследить сессии клиента, и на сессионном уровне (пятый уровень эталонной модели OSI) обеспечить контроль над клиентами. Это повышает и безопасность и устойчивость, что очень важно в высоко нагруженных IT-системах.

Серверами в этой сетевой архитектуре могут быть серверы http, облачные СХД, веб-серверы и тому подобное. Быстрый обмен информацией при запросе осуществляется при помощи так называемых сетевых протоколов. В них содержится информация о том, какие сведения нужно предоставить по запросу или какую задачу выполнить. Ответ от сервера поступает мгновенно в виде html-документа. Это может быть любая страница веб-сайта или веб-сервиса.

Архитектура в этой технологии делится на два вида:

  1. Двухзвенная — в системе задействуется всего два устройства: клиент (любое программное обеспечение, браузер) и сервер. Пользователем отправляется запрос, который обрабатывается, и на него затем приходит ответ в виде какого-либо действия или оповещения.
  2. Многоуровневая — в системе задействуется несколько устройств, как в современной архитектуре СУБД. Задачи от клиента перераспределяются между несколькими устройствами.

Чаще всего используется именно многоуровневая система клиент-сервер, где функции приема, обработки и хранения данных перераспределены между несколькими отдельными серверами. Это надежнее, так как в несколько раз повышается стойкость к сбоям. А еще многоуровневая архитектура этого типа легче масштабируется без необходимости замены ПО (достаточно расширить аппаратную часть).

Интернет-сеть LAN построена по такому же принципу (Client/Server network). В ней сетевые устройства управляются одним или несколькими серверами. При этом клиенты могут обращаться с запросом к сетевым ресурсам только через серверы (например, через дата-центры провайдеров). Протокол HTTP (HyperText Transfer Protocol — протокол передачи гипертекста) и HTTPS тоже работают на технологии “клиент-сервер”.

Понимание основ этой технологии позволяет разобраться в том, как работает современное серверное оборудование, и для чего оно вообще необходимо. Современная серверная архитектура позволяет перераспределить запросы от пользователей любых сайтов и веб-сервисов, обработать их и быстро исполнить. Внедрение правильной технологии клиент-сервер важно для любого IT-бизнеса, а также для организации систем СКУД в компаниях.

Приложения «сервер-сервер»

Приложения «сервер-сервер» отличаются тем, что у них нет пользовательского интерфейса. Обычно они загружают данные из серверной части, например продукты для каталога.

Если ваше приложение обменивается данными напрямую с нашими API и в нем нет пользовательского интерфейса, ознакомьтесь с этим руководством. Из него вы узнаете, какие основные настройки приложения следует установить и как пройти проверку.

Основные настройки

Screenshot of Settings ></p>
<p>Basic in left-hand menu and Basic panel displayed.» /></p>
<h4>Значок приложения</h4>
<p>Если вы разрабатываете приложение по заказу клиента, укажите логотип заказчика или значок приложения, используемый клиентом. Во всех остальных случаях вы можете использовать логотип своей компании или собственный значок приложения.</p>
<p>Узнать больше о значках приложений можно здесь.</p>
<h4>Использование для бизнеса</h4>
<p>Если вы разрабатываете приложение, с помощью которого собираетесь просматривать свои данные на Facebook, или создаете его для клиента, который будет просматривать в нем собственные данные на Facebook, выберите <strong>Я или моя компания</strong>.</p>
<p>Если вы разрабатываете приложение, с помощью которого другие компании будут просматривать свои данные на Facebook, выберите <strong>Клиенты</strong>.</p>
<h4>Рабочий режим</h4>
<p>Если у вашего приложения нет пользовательского интерфейса и оно недоступно обычным пользователям, при переключении в рабочий режим оно начнет взаимодействовать с нашими API с использованием реальных данных, а не тех, которые генерируют администраторы, разработчики и тестировщики.</p>
<p>Рекомендуем переводить приложение в рабочий режим только после прохождения проверки приложения.</p>
<h4>Политика конфиденциальности</h4>
<p>Это политика конфиденциальности, действующая для пользователей приложения. Допустим, что вы разрабатываете собственное приложение, но им будут пользоваться другие компании. Прежде чем работать с приложением, они должны будут изучить вашу политику конфиденциальности, поэтому не забудьте указать ссылку на нее.</p>
<h4>Платформа</h4>
<p>Это платформа, на которой пользователи будут взаимодействовать с вашим приложением. Поскольку у приложения нет интерфейса, а пользователи взаимодействуют с ним не напрямую, выберите здесь параметр «Сайт» и укажите URL сайта своей компании.</p>
<h3>Проверка приложения</h3>
<p>Для приложений «сервер-сервер» актуально большинство стандартных этапов проверки. Если какой-то этап вам непонятен, вы можете воспользоваться инструкциями, когда будете указывать, как именно ваше приложение использует разрешения и функции, запрос на которые вы отправляете. Также можно ознакомиться с примером заявки на проверку, где поэтапно описан процесс проверки для вымышленного приложения «сервер-сервер».</p>
<h4>Дополнительная информация</h4>
<p>Если вас попросят описать, как вы будете использовать ту или иную функцию или разрешение, объясните, как будут использоваться данные, предоставленные соответствующей функцией или разрешением.</p>
<p><img decoding=

Если вы уже использовали в работе инструменты Facebook, например рекламный аккаунт, укажите и это.

Платформа

Установите значение Сайт.

Тестирование

Тестирование таких приложений — сложная задача, поэтому опишите, как будут использоваться данные, предоставляемые функцией или разрешением. Если вы уже рассказывали об этом, можно скопировать сюда имеющееся описание.

Подтверждение компании

Если вам необходимо пройти подтверждение компании, и приложение будет принадлежать вашей компании, укажите сведения о ней, следуя инструкциям. Если вы разрабатываете приложение по заказу клиента, которому оно будет принадлежать, укажите информацию о компании-заказчике.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *