RFC-952 (가정에서 포인트 1의 마지막 문장) 단일 문자 호스트 이름을 금지하고 (나는 경험이 있었다 이상 칠년 전 일부 서비스는 단일 문자 호스트 이름을 가진 작업을 거부 할 경우 2002 년 여름) 등의 이름이 있었기 때문에 ( 표준을 준수하지는 않지만) 지난 몇 년 동안 여러 단일 문자 호스트 이름을 사용하고 있습니다. 단일 문자 호스트 이름이 이제 유효합니까? (그렇다면 적절한 검증 참조는 무엇입니까?)
편집 (답변에서 일부 정보를 통합하기 위해) : DNS의 다양한 측면이 1035 , 1123 및 2181을 포함한 여러 RFC에 정의되어있는 것 같습니다 . 에서 RFC-2181 (11) :
Note however, that the various applications that make use of DNS data
can have restrictions imposed on what particular values are
acceptable in their environment. For example, that any binary label
can have an MX record does not imply that any binary name can be used
as the host part of an e-mail address.
[ ... ]
See also [RFC1123] section 6.1.3.5.
에서 RFC-1123 섹션 6.1.3.5 :
The DNS defines domain name syntax very generally -- a
string of labels each containing up to 63 8-bit octets,
separated by dots, and with a maximum total of 255
octets. Particular applications of the DNS are
permitted to further constrain the syntax of the domain
names they use, although the DNS deployment has led to
some applications allowing more general names. In
particular, Section 2.1 of this document liberalizes
slightly the syntax of a legal Internet host name that
was defined in RFC-952 [DNS:4].
에서 RFC-1123 2.1 :
The syntax of a legal Internet host name was specified in RFC-952
[DNS:4]. One aspect of host name syntax is hereby changed: the
restriction on the first character is relaxed to allow either a
letter or a digit. Host software MUST support this more liberal
syntax.
마지막으로 RFC-952 에서 처음 참조한대로 :
1. A "name" (Net, Host, Gateway, or Domain name) is a text string up
to 24 characters drawn from the alphabet (A-Z), digits (0-9), minus
sign (-), and period (.). Note that periods are only allowed when
they serve to delimit components of "domain style names". (See
RFC-921, "Domain Name System Implementation Schedule", for
background). No blank or space characters are permitted as part of a
name. No distinction is made between upper and lower case. The first
character must be an alpha character. The last character must not be
a minus sign or period.
[ ... ]
Single character names or nicknames are not allowed.
RFC-952가 단일 문자 호스트 이름을 금지한다고 말한 것은이 체인을 따르는 것입니다.
답변
‘유효한’과 ‘작동하는’사이에는 차이가 있습니다. 호스트 이름이 단일 문자 인 경우 호스트 이름이 유효하지 않은 것으로 간주 될 수 있습니다 (이전 게시물은 견딜 수 없음). 그러나 많은 시스템에서 허용합니다. 하나의 주요 시스템 인 Microsoft의 AD / DNS 시스템은 단일 문자 이름을 허용하는 기존의 이유가 있습니다.
구식 NetBIOS 이름의 길이는 1-15 자입니다. 이 사양은 RFC952와 독립적으로 개발되었으며 lmhosts라는 다른 파일을 기반으로하므로 작동합니다. 문제는 Microsoft가 NetBEUI (실제로 NBF, NetBIOS 프레임 프로토콜)에서 TCP / IP (실제로 NBT)로 이동할 때 발생했으며 TCP / IP 네트워크를 통한 이름 지정 해상도를 허용해야했습니다. MS는 RFC952 호환 호스트의 필요성을 무시하고 WINS 서버에서 NetBIOS 스타일의 해상도를 유지하기로 결정했습니다.
그런 다음 Active Directory와 해당 DNS 종속성이 나타났습니다. 동적 DNS가 규칙이므로 클라이언트는 DNS 도메인에 ComputerName (처음 15 자 중 NetBIOS 이름 임)도 등록해야합니다. MS는 단일 문자 NetBIOS 이름을 DNS에 등록 할 수 있으므로 RFC952와 충돌합니다. 그들은 WINS 시절에 항상 어떻게 작동 했었는지 모방했기 때문에이를 허용하기 위해 시스템을 코딩하기로 결정했습니다.
BIND DNS는 단일 문자 호스트 이름도 허용합니다. 그러나 RFC2181은 애플리케이션이 더 이상 DNS가 아닌 자신의 데이터를 조사해야한다고 지적했다. 단일 문자 호스트 이름만으로도 사용할 수있는 많은 장치 및 소프트웨어와 RFC952를 준수하지 않는 몇몇 특이 치가 있습니다.
답변
루트 이름 서버는 모두 단일 문자 호스트 (a.root-servers.net)이며 DNS 사양은 특정 예외를 생성하지 않기 때문에 이것이 유효하다고 생각할 것입니다. 문제의 RFC는 DNS가 아닌 호스트 파일 형식을위한 것입니다. DNS는 이후 RFC에서 정의되었습니다 ( RFC 1035에서 시작). RFC 1123 (1989)은이를 명확하게 설명합니다.
The syntax of a legal Internet host name was specified in RFC-952 [DNS:4]. One aspect of host name syntax is hereby changed: the restriction on the first character is relaxed to allow either a letter or a digit. Host software MUST support this more liberal syntax.
따라서 단일 문자 호스트 이름은 DNS 기반 시스템에서 유효하며 스팸이 발명되기 전부터 사용되었습니다. RFC를 준수하지 않고 조롱 할 수있는 시스템. DNS를 전혀 사용하지 않고 호스트 파일 만 사용하지 않는 한, 동정이 더 나은 선택입니다.
답변
호스트 이름이 RFC 작성에 대해 생각하기 전에 주변에 있었기 때문에 단일 문자 호스트 이름이 갑자기 “불법”이 된 이유를 알 수 없습니다. 그 특정 RFC가 언급되었을 때 나를 잃었습니다.
이 RFC는 공식 사양입니다
RFC는 표준이 아니기 때문입니다. 근처에도 안.
전술 한 내용에도 불구하고, 해당 RFC는 비교적 작은 그룹, 즉 국방부 (아마도 미국)에 적용하기 위해 만들어 졌다는 점에 유의해야합니다.
답변
DNS는 대부분의 사람들이 네트워크 나 인터넷에서 사용할 것이므로 현재 호스트 이름은 DNS 사양에 더 의존적이라고 생각합니다. 3 개의 RFC (1034- 개념, 1035- 구현 및 2181-DNS에 대한 설명)가 떠 오릅니다.
RFC 1034의 섹션 3 에서는 다음과 같이 말합니다.
도메인 네임 스페이스는 트리 구조입니다. 트리의 각 노드와 리프는 리소스 세트 (비어있을 수 있음)에 해당합니다. 도메인 시스템은 내부 노드와 잎의 사용을 구분하지 않으며이 메모는 “노드”라는 용어를 사용하여 둘 다를 나타냅니다.
각 노드에는 길이가 0-63 옥텟 인 레이블이 있습니다. 형제가 아닌 노드에 동일한 레이블을 사용할 수 있지만 형제 노드에는 동일한 레이블이 없을 수 있습니다. 하나의 레이블이 예약되어 있으며 이는 루트에 사용되는 널 (즉, 길이가 0) 레이블입니다.
그리고에서 제 11 RFC 2181의 우리는 주소의 각 노드 이름에 대한 설명이있다 :
DNS 자체는
리소스 레코드를 식별하는 데 사용할 수있는 특정 레이블에 하나의 제한 사항 만 적용 합니다. 한 가지 제한
은 레이블의 길이와 이름과 관련이 있습니다. 하나의 레이블 길이는 1에서 63 옥텟으로 제한됩니다. 전체 도메인 이름은 255 옥텟 (구분 기호 포함)으로 제한됩니다
따라서 DNS 사양에 따라 a.domain.tld를 가질 수 있습니다.
답변
결정한 바와 같이, RFC 1123은이 길이 문제에 대해 완전히 명확하지 않습니다.
섹션 2.1은 다음과 같이 말합니다.
호스트 소프트웨어는 최대 63 자의 호스트 이름을 처리해야하며 최대 255 자의 호스트 이름을 처리해야합니다.
이 텍스트는 RFC 952의 텍스트를 효과적으로 대체 하기 때문에 255 자까지의 길이가 합법적 임을 암시해야 합니다 .
불행히도 1989 년에 인터넷 초안은 그들이 지금 얻는 엄청나게 엄밀한 검토를 얻지 못했기 때문에 모호함은 단순히 발견되지 않았습니다.