~7 دقیقه مطالعه • بروزرسانی ۶ دی ۱۴۰۴
1. مقدمه
ماژول node:dns برای نامگذاری دامنهها استفاده میشود. این ماژول میتواند آدرسهای IP را برای نامهای میزبان پیدا کند و درخواستهای DNS را اجرا نماید. در حالی که dns.lookup() از Resolver سیستمعامل استفاده میکند، سایر توابع مستقیماً به سرورهای DNS متصل میشوند.
2. dns.lookup()
dns.lookup() یک نام میزبان را به آدرس IPv4 یا IPv6 تبدیل میکند.
const dns = require('node:dns');
dns.lookup('example.org', (err, address, family) => {
console.log('address: %j family: IPv%s', address, family);
});
- گزینهها شامل
family،hints،allوorderهستند. - وقتی
allبرابر true باشد، نتیجه یک آرایه از آدرسها خواهد بود. - خطاها شامل
ENOTFOUNDدر صورت شکست نامگذاری هستند.
3. درخواستهای DNS
توابع دیگر ماژول درخواستهای واقعی DNS را اجرا میکنند:
dns.resolve4(): دریافت رکوردهای A (IPv4).dns.resolve6(): دریافت رکوردهای AAAA (IPv6).dns.resolveMx(): دریافت رکوردهای Mail Exchange.dns.reverse(): تبدیل آدرس IP به نام میزبان.
dns.resolve4('archive.org', (err, addresses) => {
addresses.forEach((a) => {
dns.reverse(a, (err, hostnames) => {
console.log(`reverse for ${a}: ${JSON.stringify(hostnames)}`);
});
});
});
4. کلاس dns.Resolver
کلاس dns.Resolver امکان ایجاد Resolverهای مستقل با تنظیمات سفارشی را فراهم میکند.
const { Resolver } = require('node:dns');
const resolver = new Resolver();
resolver.setServers(['4.4.4.4']);
resolver.resolve4('example.org', (err, addresses) => {
console.log(addresses);
});
resolver.getServers(): نمایش سرورهای DNS فعلی.resolver.setServers(): تنظیم سرورهای DNS سفارشی.resolver.cancel(): لغو درخواستهای در حال اجرا.resolver.setLocalAddress(): مشخص کردن آدرسهای خروجی IPv4 یا IPv6.
5. dns.getServers()
لیست آدرسهای IP سرورهای DNS فعلی را نمایش میدهد:
console.log(dns.getServers()); // ['8.8.8.8', '2001:4860:4860::8888']
6. مثال با گزینهها
const options = { family: 6, hints: dns.ADDRCONFIG | dns.V4MAPPED };
dns.lookup('example.org', options, (err, address, family) =>
console.log('address: %j family: IPv%s', address, family)
);
نتیجهگیری
ماژول node:dns هم نامگذاری سطح سیستمعامل و هم درخواستهای مستقیم DNS را فراهم میکند. با dns.lookup() میتوان نامها را مشابه سیستمعامل تبدیل کرد، در حالی که توابعی مانند resolve4() و reverse() امکان اجرای درخواستهای مستقیم DNS را میدهند. کلاس dns.Resolver نیز انعطافپذیری بیشتری با تنظیمات سفارشی فراهم میکند و این ماژول را به ابزاری قدرتمند برای برنامههای شبکهای در Node.js تبدیل میسازد.
1. فلگهای getaddrinfo
فلگها را میتوان بهعنوان hints به dns.lookup() پاس داد:
dns.ADDRCONFIG: محدود کردن نوع آدرسها به آدرسهای غیر-loopback موجود در سیستم.dns.V4MAPPED: در صورت نبود IPv6، آدرسهای IPv4 بهصورت IPv6 mapped بازگردانده میشوند.dns.ALL: همراه با V4MAPPED، هم آدرسهای IPv6 و هم IPv4 mapped بازگردانده میشوند.
2. dns.lookupService()
این متد یک آدرس و پورت را به نام میزبان و سرویس تبدیل میکند:
dns.lookupService('127.0.0.1', 22, (err, hostname, service) => {
console.log(hostname, service);
// خروجی: localhost ssh
});
3. dns.resolve()
این متد رکوردهای مختلف DNS را بر اساس نوع رکورد (rrtype) بازمیگرداند:
- A: آدرسهای IPv4 →
dns.resolve4() - AAAA: آدرسهای IPv6 →
dns.resolve6() - CNAME: نامهای canonical →
dns.resolveCname() - MX: رکوردهای Mail Exchange →
dns.resolveMx() - NS: رکوردهای Name Server →
dns.resolveNs() - TXT: رکوردهای متنی →
dns.resolveTxt() - SOA: رکوردهای Start of Authority →
dns.resolveSoa() - SRV: رکوردهای سرویس →
dns.resolveSrv() - TLSA: رکوردهای Certificate Association →
dns.resolveTlsa()
4. مثال resolveAny()
برای دریافت همهٔ رکوردها:
dns.resolveAny('example.com', (err, records) => {
console.log(records);
});
5. dns.reverse()
برای تبدیل آدرس IP به نام میزبان:
dns.reverse('8.8.8.8', (err, hostnames) => {
console.log(hostnames);
});
6. مدیریت ترتیب نتایج
dns.setDefaultResultOrder(order): تنظیم ترتیب پیشفرض (ipv4first، ipv6first، verbatim).dns.getDefaultResultOrder(): دریافت ترتیب پیشفرض فعلی.
7. dnsPromises API
نسخهٔ Promise از متدهای DNS برای استفادهٔ مدرن:
const dnsPromises = require('node:dns').promises;
(async function() {
const result = await dnsPromises.lookup('example.org', { family: 6 });
console.log(result);
})();
dnsPromises.lookup(): مشابهdns.lookup()اما با Promise.dnsPromises.resolve4(): دریافت رکوردهای A.dnsPromises.resolveMx(): دریافت رکوردهای MX.dnsPromises.reverse(): تبدیل IP به نام میزبان.
نتیجهگیری
ماژول node:dns در Node.js امکانات پیشرفتهای برای مدیریت رکوردهای DNS، کنترل ترتیب نتایج، و استفاده از API مبتنی بر Promise فراهم میکند. این قابلیتها توسعهدهندگان را قادر میسازد تا برنامههای شبکهای دقیقتر و انعطافپذیرتری بسازند.
1. dnsPromises.resolve()
این متد یک نام میزبان را به رکوردهای DNS تبدیل میکند. نوع رکورد با پارامتر rrtype مشخص میشود.
- A: آدرسهای IPv4 →
dnsPromises.resolve4() - AAAA: آدرسهای IPv6 →
dnsPromises.resolve6() - ANY: همهٔ رکوردها →
dnsPromises.resolveAny() - CNAME: نامهای canonical →
dnsPromises.resolveCname() - MX: رکوردهای Mail Exchange →
dnsPromises.resolveMx() - NS: رکوردهای Name Server →
dnsPromises.resolveNs() - PTR: رکوردهای Pointer →
dnsPromises.resolvePtr() - SOA: رکوردهای Start of Authority →
dnsPromises.resolveSoa() - SRV: رکوردهای سرویس →
dnsPromises.resolveSrv() - TLSA: رکوردهای Certificate Association →
dnsPromises.resolveTlsa() - TXT: رکوردهای متنی →
dnsPromises.resolveTxt()
در صورت موفقیت، Promise با آرایهای از رکوردها resolve میشود. در صورت خطا، Promise reject شده و خطا شامل err.code خواهد بود.
2. dnsPromises.resolve4()
این متد برای دریافت رکوردهای A (آدرسهای IPv4) استفاده میشود.
hostname: نام میزبان.options.ttl: اگر true باشد، مقدار TTL هر رکورد نیز بازگردانده میشود.
const dnsPromises = require('node:dns').promises;
(async function() {
const addresses = await dnsPromises.resolve4('example.org');
console.log(addresses);
// خروجی: ['74.125.79.104', '74.125.79.105', '74.125.79.106']
})();
اگر گزینهٔ ttl فعال باشد:
const addresses = await dnsPromises.resolve4('example.org', { ttl: true });
console.log(addresses);
// خروجی: [{ address: '74.125.79.104', ttl: 60 }, ...]
3. کاربردها
- دریافت آدرسهای IPv4 و IPv6 برای اتصال شبکه.
- مدیریت رکوردهای MX برای سرورهای ایمیل.
- بررسی رکوردهای TXT برای تنظیمات SPF یا DKIM.
- مدیریت رکوردهای SOA و SRV برای سرویسهای خاص.
نتیجهگیری
متدهای dnsPromises.resolve() و dnsPromises.resolve4() ابزارهای قدرتمندی برای کار با رکوردهای DNS در Node.js هستند. این متدها با استفاده از Promiseها امکان مدیریت مدرن و غیرهمزمان رکوردهای DNS را فراهم میکنند و برای برنامههای شبکهای و امنیتی بسیار کاربردیاند.
1. dnsPromises.resolve6()
این متد رکوردهای AAAA (آدرسهای IPv6) را برای یک hostname بازمیگرداند.
options.ttl: در صورت true بودن، مقدار TTL هر رکورد نیز بازگردانده میشود.
2. dnsPromises.resolveAny()
این متد همهٔ رکوردهای DNS را بازمیگرداند. نتیجه شامل انواع مختلف رکوردها مانند A، AAAA، MX، NS، TXT، SOA و غیره خواهد بود.
3. سایر متدهای resolve
dnsPromises.resolveCaa(): دریافت رکوردهای CA Authorization.dnsPromises.resolveCname(): دریافت رکوردهای Canonical Name.dnsPromises.resolveMx(): دریافت رکوردهای Mail Exchange.dnsPromises.resolveNaptr(): دریافت رکوردهای مبتنی بر Regular Expression.dnsPromises.resolveNs(): دریافت رکوردهای Name Server.dnsPromises.resolvePtr(): دریافت رکوردهای Pointer.dnsPromises.resolveSoa(): دریافت رکوردهای Start of Authority.dnsPromises.resolveSrv(): دریافت رکوردهای سرویس.dnsPromises.resolveTlsa(): دریافت رکوردهای Certificate Association.dnsPromises.resolveTxt(): دریافت رکوردهای متنی.
4. dnsPromises.reverse()
این متد یک آدرس IPv4 یا IPv6 را به نام میزبان تبدیل میکند.
5. مدیریت ترتیب نتایج
dnsPromises.setDefaultResultOrder(order): تنظیم ترتیب پیشفرض (ipv4first، ipv6first، verbatim).dnsPromises.getDefaultResultOrder(): دریافت ترتیب پیشفرض فعلی.
1. dnsPromises.resolve6()
این متد رکوردهای AAAA (آدرسهای IPv6) را برای یک hostname بازمیگرداند.
options.ttl: در صورت true بودن، مقدار TTL هر رکورد نیز بازگردانده میشود.
2. dnsPromises.resolveAny()
این متد همهٔ رکوردهای DNS را برای یک hostname بازمیگرداند. نتیجه شامل انواع مختلف رکوردها مانند A، AAAA، MX، NS، TXT، SOA و غیره خواهد بود.
3. سایر متدهای resolve
dnsPromises.resolveCaa(): رکوردهای CA Authorization.dnsPromises.resolveCname(): رکوردهای Canonical Name.dnsPromises.resolveMx(): رکوردهای Mail Exchange.dnsPromises.resolveNaptr(): رکوردهای مبتنی بر Regular Expression.dnsPromises.resolveNs(): رکوردهای Name Server.dnsPromises.resolvePtr(): رکوردهای Pointer.dnsPromises.resolveSoa(): رکوردهای Start of Authority.dnsPromises.resolveSrv(): رکوردهای سرویس.dnsPromises.resolveTlsa(): رکوردهای Certificate Association.dnsPromises.resolveTxt(): رکوردهای متنی.
4. dnsPromises.reverse()
این متد یک آدرس IPv4 یا IPv6 را به نام میزبان تبدیل میکند.
5. مدیریت ترتیب نتایج
dnsPromises.setDefaultResultOrder(order): تنظیم ترتیب پیشفرض (ipv4first، ipv6first، verbatim).dnsPromises.getDefaultResultOrder(): دریافت ترتیب پیشفرض فعلی.
6. تنظیم سرورهای DNS
با استفاده از dnsPromises.setServers() میتوان سرورهای DNS سفارشی را مشخص کرد:
dnsPromises.setServers([ '8.8.8.8', '[2001:4860:4860::8888]', '8.8.8.8:1053', '[2001:4860:4860::8888]:1053', ]);
نتیجهگیری
ماژول dns.promises مجموعهای کامل از متدهای Promise-based برای کار با رکوردهای DNS در Node.js ارائه میدهد. این متدها امکان مدیریت رکوردهای مختلف، انجام reverse lookup، کنترل ترتیب نتایج و تنظیم سرورهای سفارشی را فراهم میکنند و برای توسعهٔ برنامههای شبکهای مدرن بسیار کاربردیاند.
6. تنظیم سرورهای DNS
با استفاده از dnsPromises.setServers() میتوان سرورهای DNS سفارشی را مشخص کرد:
dnsPromises.setServers([ '8.8.8.8', '[2001:4860:4860::8888]', '8.8.8.8:1053', '[2001:4860:4860::8888]:1053', ]);
نتیجهگیری
ماژول dns.promises مجموعهای کامل از متدهای Promise-based برای کار با رکوردهای DNS در Node.js ارائه میدهد. این متدها امکان مدیریت رکوردهای مختلف، انجام reverse lookup، کنترل ترتیب نتایج و تنظیم سرورهای سفارشی را فراهم میکنند و برای توسعهٔ برنامههای شبکهای مدرن بسیار کاربردیاند.
نوشته و پژوهش شده توسط دکتر شاهین صیامی