非常教程

Ruby 2.4参考手册

Resolv

Resolv::DNS

Parent:Object

Resolv :: DNS是一个DNS存根解析器。

从以下地点获取信息:

  • STD0013
  • RFC 1035
  • etc.

常量

端口

默认DNS端口

UDPSize

默认DNS UDP数据包大小

公共类方法

new(config_info=nil) Show source

创建一个新的DNS解析器。

config_info 可以为:

Uses /etc/resolv.conf.

字符串

使用/etc/resolv.conf格式的文件路径。

Hash

必须包含:nameserver,:search和:ndots键。

:nameserver_port可用于指定名称服务器地址的端口号。

nameserver的值应该是地址字符串或地址字符串数组。

  • :nameserver => '8.8.8.8'
  • :nameserver => '8.8.8.8', '8.8.4.4'

nameserver_port的值应该是一对名称服务器地址和端口号的数组。

:nameserver_port => ['8.8.8.8', 53, '8.8.4.4', 53]Example:Resolv::DNS.new(:nameserver => ['210.251.121.21'],
                :search => ['ruby-lang.org'],
                :ndots => 1)# File lib/resolv.rb, line 333
def initialize(config_info=nil)
  @mutex = Thread::Mutex.new
  @config = Config.new(config_info)
  @initialized = nil
end open(*args) { |dns| ... } 

显示源创建一个新的DNS解析器。 有关详细信息,请参阅:: new。如果已提供,请将创建的DNS解析器解析为块,否则返回该解析器。

# File lib/resolv.rb, line 298
def self.open(*args)
  dns = new(*args)
  return dns unless block_given?
  begin
    yield dns
  ensure
    dns.close
  end
endPublic Instance Methods close() Show source Closes the DNS resolver.# File lib/resolv.rb, line 367
def close
  @mutex.synchronize {
    if @initialized
      @initialized = false
    end
  }
end each_address(name) { |address| ... } Show source Iterates over all IP addresses for name retrieved from the DNS resolver.name can be a Resolv::DNS::Name or a String. Retrieved addresses will be a Resolv::IPv4 or Resolv::IPv6# File lib/resolv.rb, line 405
def each_address(name)
  each_resource(name, Resource::IN::A) {|resource| yield resource.address}
  if use_ipv6?
    each_resource(name, Resource::IN::AAAA) {|resource| yield resource.address}
  end
end each_name(address) { |name| ... } Show source Iterates over all hostnames for address retrieved from the DNS resolver.address must be a Resolv::IPv4, Resolv::IPv6 or a String. Retrieved names will be Resolv::DNS::Name instances.# File lib/resolv.rb, line 452
def each_name(address)
  case address
  when Name
    ptr = address
  when IPv4::Regex
    ptr = IPv4.create(address).to_name
  when IPv6::Regex
    ptr = IPv6.create(address).to_name
  else
    raise ResolvError.new("cannot interpret as address: #{address}")
  end
  each_resource(ptr, Resource::IN::PTR) {|resource| yield resource.name}
end each_resource(name, typeclass, &proc) Show source Iterates over all typeclass DNS resources for name. See getresource for argument details.# File lib/resolv.rb, line 508
def each_resource(name, typeclass, &proc)
  fetch_resource(name, typeclass) {|reply, reply_name|
    extract_resources(reply, reply_name, typeclass, &proc)
  }
end fetch_resource(name, typeclass) { |reply, reply_name| ... } Show source # File lib/resolv.rb, line 514
def fetch_resource(name, typeclass)
  lazy_initialize
  requester = make_udp_requester
  senders = {}
  begin
    @config.resolv(name) {|candidate, tout, nameserver, port|
      msg = Message.new
      msg.rd = 1
      msg.add_question(candidate, typeclass)
      unless sender = senders[[candidate, nameserver, port]]
        sender = requester.sender(msg, candidate, nameserver, port)
        next if !sender
        senders[[candidate, nameserver, port]] = sender
      end
      reply, reply_name = requester.request(sender, tout)
      case reply.rcode
      when RCode::NoError
        if reply.tc == 1 and not Requester::TCP === requester
          requester.close
          # Retry via TCP:
          requester = make_tcp_requester(nameserver, port)
          senders = {}
          # This will use TCP for all remaining candidates (assuming the
          # current candidate does not already respond successfully via
          # TCP).  This makes sense because we already know the full
          # response will not fit in an untruncated UDP packet.
          redo
        else
          yield(reply, reply_name)
        end
        return
      when RCode::NXDomain
        raise Config::NXDomain.new(reply_name.to_s)
      else
        raise Config::OtherResolvError.new(reply_name.to_s)
      end
    }
  ensure
    requester.close
  end
end getaddress(name) Show source Gets the IP address of name from the DNS resolver.name can be a Resolv::DNS::Name or a String. Retrieved address will be a Resolv::IPv4 or Resolv::IPv6# File lib/resolv.rb, line 381
def getaddress(name)
  each_address(name) {|address| return address}
  raise ResolvError.new("DNS result has no information for #{name}")
end getaddresses(name) Show source Gets all IP addresses for name from the DNS resolver.name can be a Resolv::DNS::Name or a String. Retrieved addresses will be a Resolv::IPv4 or Resolv::IPv6# File lib/resolv.rb, line 392
def getaddresses(name)
  ret = []
  each_address(name) {|address| ret << address}
  return ret
end getname(address) Show source Gets the hostname for address from the DNS resolver.address must be a Resolv::IPv4, Resolv::IPv6 or a String. Retrieved name will be a Resolv::DNS::Name.# File lib/resolv.rb, line 428
def getname(address)
  each_name(address) {|name| return name}
  raise ResolvError.new("DNS result has no information for #{address}")
end getnames(address) Show source Gets all hostnames for address from the DNS resolver.address must be a Resolv::IPv4, Resolv::IPv6 or a String. Retrieved names will be Resolv::DNS::Name instances.# File lib/resolv.rb, line 439
def getnames(address)
  ret = []
  each_name(address) {|name| ret << name}
  return ret
end getresource(name, typeclass) 

显示源查找name.name的类型类DNS资源必须是Resolv :: DNS :: Name或String.typeclass应该是以下之一:

  • Resolv::DNS::Resource::IN::A
  • Resolv::DNS::Resource::IN::AAAA
  • Resolv::DNS::Resource::IN::ANY
  • Resolv::DNS::Resource::IN::CNAME
  • Resolv::DNS::Resource::IN::HINFO
  • Resolv::DNS::Resource::IN::MINFO
  • Resolv::DNS::Resource::IN::MX
  • Resolv::DNS::Resource::IN::NS
  • Resolv::DNS::Resource::IN::PTR
  • Resolv::DNS::Resource::IN::SOA
  • Resolv::DNS::Resource::IN::TXT
  • Resolv::DNS::Resource::IN::WKS

返回的资源表示为Resolv :: DNS :: Resource实例,即Resolv :: DNS :: Resource :: IN :: A。

# File lib/resolv.rb, line 489
def getresource(name, typeclass)
  each_resource(name, typeclass) {|resource| return resource}
  raise ResolvError.new("DNS result has no information for #{name}")
end

getresources(name, typeclass) Show source

查找所有typeclassDNS资源name。有关参数详情,请参阅getresource。

# File lib/resolv.rb, line 498
def getresources(name, typeclass)
  ret = []
  each_resource(name, typeclass) {|resource| ret << resource}
  return ret
end

timeouts=(values) Show source

设置解析器超时。 这可能是一个单一的正数或表示超时秒数的正数的数组。 如果指定了数组,则DNS请求将重试并等待数组中的每个连续时间间隔,直到收到成功的响应。 指定nil将恢复为默认超时:

5, second = 5 * 2 / nameserver_count, 2 * second, 4 * second

例:

dns.timeouts = 3
# File lib/resolv.rb, line 350
def timeouts=(values)
  @config.timeouts = values
end
Ruby 2.4

Ruby 是一种面向对象、命令式、函数式、动态的通用编程语言,是世界上最优美而巧妙的语言。

主页 https://www.ruby-lang.org/
源码 https://github.com/ruby/ruby
版本 2.4
发布版本 2.4.1

Ruby 2.4目录

1.缩略 | Abbrev
2.ARGF
3.数组 | Array
4.Base64
5.基本对象 | BasicObject
6.基准测试 | Benchmark
7.BigDecimal
8.绑定 | Binding
9.CGI
10.类 | Class
11.比较 | Comparable
12.负责 | Complex
13.计算续体 | Continuation
14.覆盖 | Coverage
15.CSV
16.日期 | Date
17.日期时间 | DateTime
18.DBM
19.代理 | Delegator
20.摘要 | Digest
21.Dir
22.DRb
23.编码 | Encoding
24.枚举 | Enumerable
25.枚举 | Enumerator
26.ENV
27.ERB
28.错误 | Errors
29.Etc
30.期望值 | Exception
31.错误类 | FalseClass
32.Fiber
33.Fiddle
34.文件 | File
35.文件实用程序 | FileUtils
36.查找 | Find
37.浮点 | Float
38.Forwardable
39.GC
40.GDBM
41.GetoptLong
42.Hash
43.Integer
44.IO
45.IPAddr
46.JSON
47.Kernel
48.语言 | 3Language
49.记录 | Logger
50.编排 | Marshal
51.MatchData
52.数学 | Math
53.矩阵 | Matrix
54.方法 | Method
55.模型 | Module
56.监控 | Monitor
57. 互斥 | Mutex
58.Net
59.Net::FTP
60.Net::HTTP
61.Net::IMAP
62.Net::SMTP
63.NilClass
64.数字 | Numeric
65.对象 | Object
66.ObjectSpace
67.Observable
68.Open3
69.OpenSSL
70.OpenStruct
71.OpenURI
72.OptionParser
73.路径名 | Pathname
74.完整输出 | PrettyPrint
75.Prime
76.Proc
77.过程 | Process
78.PStore
79.PTY
80.队列 | Queue
81.随机 | Random
82.范围 | Range
83.合理的 | Rational
84.Readline
85.Regexp
86.Resolv
87.Ripper
88.RubyVM
89.Scanf
90.SDBM
91.SecureRandom
92.Set
93.Shell
94.信号 | Signal
95.Singleton
96.套接字 | Socket
97.字符串 | String
98.StringIO
99.StringScanner
100.结构 | Struct