JS在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
测试基础函数 发布于:2024-11-13 14:26 批量导入文档到数据库0.0.6-笔记本版 发布于:2024-11-13 09:07 js quirks 发布于:2024-11-11 10:28 思源实现可手动修改数据库主键引用块的标题 发布于:2024-11-11 12:18 解析markdown ul 发布于:2024-11-08 23:33 臭豆腐大范甘迪方便v更大发吧 发布于:2024-11-08 11:38 测试有限状态机代码 发布于:2024-11-08 11:37 校验身份证格式 发布于:2024-11-08 01:14 这是一个项目 发布于:2024-11-03 14:29 群艺馆js 发布于:2024-11-02 19:24 ## Temu 面单打印 发布于:2024-11-08 10:16 获取数组的维度 发布于:2024-10-31 15:18 cascader tree 结构 发布于:2024-11-06 11:52 经纬度 度分秒转度 发布于:2024-11-06 08:33 验证坐标系问题 发布于:2024-11-06 08:40 加密 作业 demo 发布于:2024-11-11 15:20 数组不常用方法 发布于:2024-10-29 13:12 测试一段加密算法,需要每次对明文进行加密处理 发布于:2024-10-28 16:24 防抖节流函数 发布于:2024-10-21 20:14 TonScan-Str-Bytes 发布于:2024-10-21 17:01 UE Logger 发布于:2024-10-18 10:23 导航业务数组处理 发布于:2024-10-18 10:39 promise测试 发布于:2024-10-17 16:21 获取当前时间戳 发布于:2024-10-29 11:20 拓扑排序示例 发布于:2024-10-11 14:49 again-wyex 发布于:2024-10-12 11:12 json排序 发布于:2024-10-10 17:32 链滴自动签到支持二次验证版 发布于:2024-10-10 14:16 call实现 发布于:2024-10-09 17:31 随便写的,只是随便写的 发布于:2024-10-10 10:49 思源代码块超出指定高度折叠 发布于:2024-10-04 14:09 思源鼠标移入大纲自动展开子标题 发布于:2024-09-25 02:49 思源建文档的时候自动设置为自定义的某个图标 发布于:2024-09-22 06:35 异步任务线程池 发布于:2024-09-21 16:42 JS的各种锻炼 发布于:2024-09-13 16:53 思源同步感知脚本 发布于:2024-09-16 11:42 在线测试各种脚本! 发布于:2024-09-12 14:37 思源编辑器增加标尺 发布于:2024-09-11 16:21 思源查询不在数据库中的文档2 发布于:2024-09-07 16:32 思源简单锁定笔记 发布于:2024-09-07 23:38 项目热度榜单 发布于:2024-09-06 15:20 修改z坐标 发布于:2024-09-06 15:23 带千分符的大小比较 发布于:2024-09-06 13:05 altG临时 发布于:2024-09-09 18:08 批量导入文档到数据库0.0.6版 发布于:2024-11-08 22:42 最长合法表达式 发布于:2024-09-04 21:55 API集群负载统计 发布于:2024-09-04 19:04 英文输入法 字符串 发布于:2024-09-04 15:05 RMS 变量 发布于:2024-09-04 14:44 最少停车数/停车场车辆统计 发布于:2024-09-04 15:02 [更多]
显示目录

DNS



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

DNS

稳定性: 3 - 稳定

本节将介绍Node.js的DNS模块,你可以通过调用require('dns')来访问DNS模块。

DNS模块包含的函数属于2个不同的分类:

1)使用系统底层的特性,完成名字解析,这个过程不需要网络通讯,这个分类仅有一个函数:dns.lookup开发者在同一个系统里名字解析都是用 dns.lookup

下面的例子解析了www.google.com

var dns = require('dns');

dns.lookup('www.google.com', function onLookup(err, addresses, family) {
  console.log('addresses:', addresses);
});

2)连接到DNS服务器进行名字解析,始终使用网络来进行域名查询。这个分类包含除了dns.lookup外的所有函数。这些函数不会和dns.lookup使用同一套配置文件。如果你不想使用系统底层的特性来进行名字解析,而想进行DNS查询的话,可以使用这个分类的函数。

下面的例子,解析了'www.google.com',并反向解析返回的IP地址:

var dns = require('dns');

dns.resolve4('www.google.com', function (err, addresses) {
  if (err) throw err;

  console.log('addresses: ' + JSON.stringify(addresses));

  addresses.forEach(function (a) {
    dns.reverse(a, function (err, hostnames) {
      if (err) {
        throw err;
      }

      console.log('reverse for ' + a + ': ' + JSON.stringify(hostnames));
    });
  });
});

更多细节参考Implementation considerations section

dns.lookup(hostname[, options], callback)

将域名(比如'google.com')解析为第一条找到的记录A (IPV4)或AAAA(IPV6)。参数options可以是一个对象或整数。如果没有提供options,IP v4和 v6地址都可以。如果options是整数,则必须是46

options参数可能是包含familyhints两个属性的对象。这两个属性都是可选的。如果提供了family,则必须是46,否则,IP v4和v6地址都可以。如果提供了hints,可以是一个或者多个getaddrinfo标志,若不提供,没有标志会传给getaddrinfo。多个标志位可以通过或运算来整合。以下的例子展示如何使用options

{
  family: 4,
  hints: dns.ADDRCONFIG | dns.V4MAPPED
}

参见supported getaddrinfo flags 查看更多的标志位。

回调函数包含参数 (err, address, family)address参数表示IP v4或v6地址。family参数是4或6,表示address家族(不一定是之前传入lookup的值)。

出错时,参数errError对象,err.code是错误代码。请记住,err.code等于'ENOENT',不仅可能是因为域名不存在,还有可能是是其他原因,比如没有可用文件描述符。

dns.lookup不必和DNS协议有关系。它使用了操作系统的特性,能将名字和地址关联。

实现这些东西也许很简单,但是对于 Node.js 程序来说都重要,所以在使用前请花点时间阅读Implementation considerations section

dns.lookupService(address, port, callback)

使用getnameinfo解析传入的地址和端口为域名和服务。

这个回调函数的参数是(err, hostname, service)hostnameservice都是字符串 (比如'localhost''http')。

出错时,参数errError对象,err.code是错误代码。

dns.resolve(hostname[, rrtype], callback)

将一个域名(如'google.com')解析为一个rrtype指定记录类型的数组。

有效的rrtypes值为:

  • 'A' (IPV4地址,默认)
  • 'AAAA' (IPV6地址)
  • 'MX' (邮件交换记录)
  • 'TXT' (text记录)
  • 'SRV' (SRV记录)
  • 'PTR' (用来反向IP查找)
  • 'NS' (域名服务器记录)
  • 'CNAME' (别名记录)
  • 'SOA' (授权记录的初始值)

回调参数为(err, addresses). 其中addresses中每一项的类型都取决于记录类型,详见下文对应的查找方法。

出错时,参数errError 对象,err.code是错误代码。

dns.resolve4(hostname, callback)

dns.resolve()类似,仅能查询IPv4 (A记录)。addressesIPv4地址数组 (比如,['74.125.79.104', '74.125.79.105', '74.125.79.106'])。

dns.resolve6(hostname, callback)

dns.resolve4()类似,仅能查询 IPv4(AAAA查询)。

dns.resolveMx(hostname, callback)

dns.resolve()类似,仅能查询邮件交换(MX记录)。

addresses是MX记录数组,每一个包含优先级和交换属性(比如,[{'priority': 10, 'exchange': 'mx.example.com'},...])。

dns.resolveTxt(hostname, callback)

dns.resolve()类似,仅能进行文本查询 (TXT记录)。addresses是2-d文本记录数组。(比如,[ ['v=spf1 ip4:0.0.0.0 ', '~all' ] ])。每个子数组包含一条记录的TXT块。根据使用情况可以连接在一起,也可单独使用。

dns.resolveSrv(hostname, callback)

dns.resolve()类似,仅能进行服务记录查询 (SRV记录)。addresseshostname可用的SRV记录数组。SRV记录属性有优先级(priority),权重(weight), 端口(port), 和名字(name) (比如,[{'priority': 10, 'weight': 5, 'port': 21223, 'name': 'service.example.com'}, ...])。

dns.resolveSoa(hostname, callback)

dns.resolve()类似,仅能查询权威记录(SOA记录)。

addresses是包含以下结构的对象:

{
  nsname: 'ns.example.com',
  hostmaster: 'root.example.com',
  serial: 2013101809,
  refresh: 10000,
  retry: 2400,
  expire: 604800,
  minttl: 3600
}

dns.resolveNs(hostname, callback)

dns.resolve()类似,仅能进行域名服务器记录查询(NS记录)。addresses是域名服务器记录数组(hostname可以使用) (比如,['ns1.example.com', 'ns2.example.com'])。

dns.resolveCname(hostname, callback)

dns.resolve()类似,仅能进行别名记录查询 (CNAME记录)。addresses是对hostname可用的别名记录数组 (比如,['bar.example.com'])。

dns.reverse(ip, callback)

反向解析IP地址,返回指向该IP地址的域名数组。

回调函数参数(err, hostnames)

出错时,参数errError对象,err.code是错误代码。

dns.getServers()

返回一个用于当前解析的IP地址的数组的字符串。

dns.setServers(servers)

指定一组IP地址作为解析服务器。

如果你给地址指定了端口,端口会被忽略,因为底层库不支持。

传入无效参数,会抛出以下错误:

Error codes

每个DNS查询都可能返回以下错误:

  • dns.NODATA: DNS服务器返回无数据应答。
  • dns.FORMERR: DNS服务器声称查询格式错误。
  • dns.SERVFAIL: DNS服务器返回一般失败。
  • dns.NOTFOUND: 没有找到域名。
  • dns.NOTIMP: DNS服务器未实现请求的操作。
  • dns.REFUSED: DNS服务器拒绝查询。
  • dns.BADQUERY: DNS查询格式错误。
  • dns.BADNAME: 域名格式错误。
  • dns.BADFAMILY: 地址协议不支持。
  • dns.BADRESP: DNS回复格式错误。
  • dns.CONNREFUSED: 无法连接到DNS服务器。
  • dns.TIMEOUT: 连接DNS服务器超时。
  • dns.EOF: 文件末端。
  • dns.FILE: 读文件错误。
  • dns.NOMEM: 内存溢出。
  • dns.DESTRUCTION: 通道被摧毁。
  • dns.BADSTR: 字符串格式错误。
  • dns.BADFLAGS: 非法标识符。
  • dns.NONAME: 所给主机不是数字。
  • dns.BADHINTS: 非法HINTS标识符。
  • dns.NOTINITIALIZED: c c-ares库尚未初始化。
  • dns.LOADIPHLPAPI: 加载iphlpapi.dll出错。
  • dns.ADDRGETNETWORKPARAMS: 无法找到GetNetworkParams函数。
  • dns.CANCELLED: 取消DNS查询。

支持的 getaddrinfo 标志

以下内容可作为hints标志传给dns.lookup

  • dns.ADDRCONFIG: 返回当前系统支持的地址类型。例如,如果当前系统至少配置了一个IPv4地址,则返回IPv4地址。
  • dns.V4MAPPED: 如果指定了IPv6家族, 但是没有找到IPv6地址,将返回IPv4映射的IPv6地址。

Implementation considerations

虽然dns.lookupdns.resolve*/dns.reverse函数都能实现网络名和网络地址的关联,但是他们的行为不太一样。这些不同点虽然很巧妙,但是会对Node.js程序产生显著的影响。

dns.lookup

dns.lookup和绝大多数程序一样使用了相同的系统特性。例如,dns.lookupping命令用相同的方法解析了一个指定的名字。多数类似POSIX的系统,dns.lookup函数可以通过改变nsswitch.conf(5)和/或resolv.conf(5)的设置调整。如果改变这些文件将会影响系统里的其他应用。

虽然,JavaScript调用是异步的,它的实现是同步的调用libuv线程池里的getaddrinfo(3)。因为libuv线程池固定大小,所以如果调用getaddrinfo(3) 的时间太长,会使的池里的其他操作(比如文件操作)性能降低。为了降低这个风险,可以通过增加'UV_THREADPOOL_SIZE'的值,让它超过4,来调整libuv线程池大小,更多信息参见[the official libuvdocumentation](http://docs.libuv.org/en/latest/threadpool.html)。

dns.resolve, functions starting with dns.resolve and dns.reverse

这些函数的实现和dns.lookup不大相同。他们不会用到getaddrinfo(3),而是始终进行网络查询。这些操作都是异步的,和libuv线程池无关。

因此,这些操作对于其他线程不会产生负面影响,这和dns.lookup不同。

它们不会用到dns.lookup的配置文件(例如 ,/etc/hosts_)。

由JSRUN为你提供的JS在线运行、在线编译工具
        JSRUN提供的JS 在线运行,JS 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout