На что похож запрос DNS?

Это не похоже на проблему тайм-аута. Мое предположение - то, что истинный склеп не обрабатывает поврежденный раздел достаточно корректно. И тем самым создайте проблемы для проводника.

Попытка исключить проблематичные файлы из процесса копии (и использовать robocopy в качестве других предлагает).

32
задан 30 October 2014 в 01:29
4 ответа

Это - необработанный дамп от Wireshark запроса DNS.

Часть DNS запускается с 24 1a:

0000  00 00 00 00 00 00 00 00  00 00 00 00 08 00 45 00   ........ ......E.
0010  00 3c 51 e3 40 00 40 11  ea cb 7f 00 00 01 7f 00   .<Q.@.@. ........
0020  00 01 ec ed 00 35 00 28  fe 3b 24 1a 01 00 00 01   .....5.( .;$.....
0030  00 00 00 00 00 00 03 77  77 77 06 67 6f 6f 67 6c   .......w ww.googl
0040  65 03 63 6f 6d 00 00 01  00 01                     e.com... ..      

И вот разбивка:

Domain Name System (query)
    [Response In: 1852]
    Transaction ID: 0x241a
    Flags: 0x0100 (Standard query)
        0... .... .... .... = Response: Message is a query
        .000 0... .... .... = Opcode: Standard query (0)
        .... ..0. .... .... = Truncated: Message is not truncated
        .... ...1 .... .... = Recursion desired: Do query recursively
        .... .... .0.. .... = Z: reserved (0)
        .... .... ...0 .... = Non-authenticated data OK: Non-authenticated data is unacceptable
    Questions: 1
    Answer RRs: 0
    Authority RRs: 0
    Additional RRs: 0
    Queries
        www.google.com: type A, class IN
            Name: www.google.com
            Type: A (Host address)
            Class: IN (0x0001)

И ответ, снова запускающийся в 24 1a:

0000  00 00 00 00 00 00 00 00  00 00 00 00 08 00 45 00   ........ ......E.
0010  00 7a 00 00 40 00 40 11  3c 71 7f 00 00 01 7f 00   .z..@.@. <q......
0020  00 01 00 35 ec ed 00 66  fe 79 24 1a 81 80 00 01   ...5...f .y$.....
0030  00 03 00 00 00 00 03 77  77 77 06 67 6f 6f 67 6c   .......w ww.googl
0040  65 03 63 6f 6d 00 00 01  00 01 c0 0c 00 05 00 01   e.com... ........
0050  00 05 28 39 00 12 03 77  77 77 01 6c 06 67 6f 6f   ..(9...w ww.l.goo
0060  67 6c 65 03 63 6f 6d 00  c0 2c 00 01 00 01 00 00   gle.com. .,......
0070  00 e3 00 04 42 f9 59 63  c0 2c 00 01 00 01 00 00   ....B.Yc .,......
0080  00 e3 00 04 42 f9 59 68                            ....B.Yh         

Разбивка:

Domain Name System (response)
    [Request In: 1851]
    [Time: 0.000125000 seconds]
    Transaction ID: 0x241a
    Flags: 0x8180 (Standard query response, No error)
        1... .... .... .... = Response: Message is a response
        .000 0... .... .... = Opcode: Standard query (0)
        .... .0.. .... .... = Authoritative: Server is not an authority for domain
        .... ..0. .... .... = Truncated: Message is not truncated
        .... ...1 .... .... = Recursion desired: Do query recursively
        .... .... 1... .... = Recursion available: Server can do recursive queries
        .... .... .0.. .... = Z: reserved (0)
        .... .... ..0. .... = Answer authenticated: Answer/authority portion was not authenticated by the server
        .... .... .... 0000 = Reply code: No error (0)
    Questions: 1
    Answer RRs: 3
    Authority RRs: 0
    Additional RRs: 0
    Queries
        www.google.com: type A, class IN
            Name: www.google.com
            Type: A (Host address)
            Class: IN (0x0001)
    Answers
        www.google.com: type CNAME, class IN, cname www.l.google.com
            Name: www.google.com
            Type: CNAME (Canonical name for an alias)
            Class: IN (0x0001)
            Time to live: 3 days, 21 hours, 52 minutes, 57 seconds
            Data length: 18
            Primary name: www.l.google.com
        www.l.google.com: type A, class IN, addr 66.249.89.99
            Name: www.l.google.com
            Type: A (Host address)
            Class: IN (0x0001)
            Time to live: 3 minutes, 47 seconds
            Data length: 4
            Addr: 66.249.89.99
        www.l.google.com: type A, class IN, addr 66.249.89.104
            Name: www.l.google.com
            Type: A (Host address)
            Class: IN (0x0001)
            Time to live: 3 minutes, 47 seconds
            Data length: 4
            Addr: 66.249.89.104

Править:

Обратите внимание что, если Ваш реальный вопрос, "как я пишу сервер DNS?", затем существует два соответствующих ответа:

Редактирование (2):

Запрос был отправлен с помощью host на поле Linux:

host www.google.com

Если Вы находитесь в Windows, можно использовать nslookup

nslookup www.google.com
40
ответ дан 28 November 2019 в 19:56
  • 1
    Как Вы отправляли запрос для получения этого? –  AMWJ 31 August 2010 в 23:59
  • 2
    @SPRBRN DNS не имеет дело с URL, только доменные имена. –  Håkan Lindqvist 30 October 2014 в 08:55

Формат данных запроса DNS описан в RFC 1035. Я думаю, что немного бессмысленно скопировать текст здесь...

7
ответ дан 28 November 2019 в 19:56

На запросы DNS и ответы лучше всего смотрят использование протокола анализатор - Wireshark является хорошим кросс-платформенным инструментом, который может получить и вскрыть противоречия в запросах и ответах в их различные части. Существует хорошее введение в структуру запросов DNS и Ответов в Firewall.cx здесь.

Запросы DNS содержат вопросы, которые указывают имя (или возможно несколько произвольное текстовое поле) и тип записи - контент ответа будет варьироваться в зависимости от типа. Большинство запросов является простыми прямыми поисками имени сервера, ища IP-адрес в ответ (Тип A), но некоторые будут смотреть для получения дополнительной информации о самих серверах имен (NS Типа), почтовые записи (Тип, MX) и другие сервисы (Вводят SRV, который возвратит имена, порты, веса и приоритеты). Ответы DNS содержат ответы на эти вопросы, возможно больше чем один, если запрос требует, чтобы и были не всегда просто IP-адреса.

Еще одно разъяснение - DNS не разрешает URL - в большинстве сценариев, включающих URL, DNS только используется, чтобы позволить клиентской системе найти IP-адрес части сервера URL, все остальное обрабатывается другими протоколами.

5
ответ дан 28 November 2019 в 19:56

Если можно добраться на машину Linux, можно выполнить вырыть команду для выполнения поиска DNS. Эта утилита выполняет поиск и возвращает точно, чем отвечает сервер имен. Например:

; <<>> DiG 9.6.1-P2 <<>> serverfault.com
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 32383
;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 0

;; QUESTION SECTION:
;serverfault.com.               IN      A

;; ANSWER SECTION:
serverfault.com.        55961   IN      A       69.59.196.211

;; Query time: 21 msec
;; SERVER: 68.87.64.150#53(68.87.64.150)
;; WHEN: Sun Aug 22 09:21:35 2010
;; MSG SIZE  rcvd: 49

Все запускающееся с раздела "HEADER" - то, что возвращается из сервера имен. Я предполагаю, что это - то, что Вы называете текстовым форматом, потому что это не формат действительного пакета, но это - текст, который возвращается.

3
ответ дан 28 November 2019 в 19:56

Теги

Похожие вопросы