Как это возможно?
NodeX# ping ftp.company.com
PING ftp.company.com (xx.yy.8.11) 56(84) bytes of data.
64 bytes from ftp.company.com (xx.yy.8.11): icmp_seq=1 ttl=127 time=0.657 ms
...
^C
NodeX# /usr/bin/myftp.py -fftp.company.com -uuser -ppasssword
Transferring myftp.tgz to ftp.company.com:Incoming/
*** ftp login failed: [Errno -5] No address associated with hostname
Operation failed, exit code=3
Принимая во внимание, что если я делаю это, это работает:
NodeX# /usr/bin/myftp.py -fxx.yy.8.11 -uuser -ppassword
Transferring myftp.tgz to ftp.company.com:Incoming/
Operation completed successfully
Также, если я создаю запись в /etc /hosts, то она работает с использованием имени. Что дает?
Dig показывает:
NodeX# dig ftp.company.com ANY
; <<>> DiG 9.5.0-P2 <<>> ftp.company.com ANY
;; global options: printcmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 21125
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 0
;; QUESTION SECTION:
;ftp.company.com. IN ANY
;; ANSWER SECTION:
ftp.company.com. 28800 IN A xx.yy.8.11
;; Query time: 1 msec
;; SERVER: xx.zz.8.34#53(xx.zz.8.34)
;; WHEN: Thu Oct 11 14:53:00 2012
;; MSG SIZE rcvd: 63
resolv.conf показывает 2 сервера имен, а dig @each возвращает IP.
Код Python 2.6 выглядит так:
try:
print("Preparing ftplib.FTP for " + ftpHost)
ftp = ftplib.FTP()
except Exception, e:
print("*** ftp prep failed: %s" % e.__str__())
return 3
end
try:
print("Connecting to '" + ftpHost + "'")
ftp.connect(ftpHost, ftpPort)
except Exception, e:
print("*** ftp connection failed: %s" % e.__str__())
return 4
end
Выход:
Preparing ftplib.FTP for ftp.company.com
Connecting to 'ftp.company.com'
*** ftp connection failed: [Errno -5] No address associated with hostname
Operation failed, exit code=4
в то время как:
Node2414332# ping ftp.company.com
PING ftp.company.com (xx.yy.8.11) 56(84) bytes of data.
64 bytes from ftp.company.com (xx.yy.8.11): icmp_seq=1 ttl=127 time=0.804 ms
РЕШИТЬ:
Хотя createconnection() нашего python завершается неудачно в getaddrinfo(), когда ему присваивается имя хоста (см. Ниже), он работает с адресом. Удобно, что gethostbyname () работает, и у нас есть простое исправление: createconnection(gethostbyname (hostname)). Weerd.