0

0

Python多进程加速:高效批量查询域名可用性

心靈之曲

心靈之曲

发布时间:2025-10-24 12:07:15

|

301人浏览过

|

来源于php中文网

原创

Python多进程加速:高效批量查询域名可用性

本教程将详细介绍如何利用python的multiprocessing模块,结合python-whois库,实现对大量域名进行高效并行可用性查询。通过并行化处理,可以显著提高查询速度,解决传统顺序查询效率低下的问题,并提供完整的示例代码和性能优化建议。

在处理数万甚至更多域名列表的可用性查询时,传统的顺序whois查询方法效率极低,可能耗费数天甚至更长时间。python-whois库虽然提供了方便的接口,但其本质是进行网络请求,单个请求的延迟累积起来会成为瓶颈。为了克服这一挑战,我们可以利用Python的multiprocessing模块,将查询任务并行化,从而显著提升处理速度。

1. 环境准备

在开始之前,请确保您的Python环境中安装了以下库:

  • python-whois: 用于查询域名WHOIS信息。
  • pandas: 用于处理和展示查询结果。
  • tqdm: 提供美观的进度条,方便跟踪任务执行。

您可以使用pip进行安装:

pip install python-whois pandas tqdm

2. 核心查询逻辑:check_domain 函数

首先,我们需要一个函数来处理单个域名的查询。这个函数将负责调用whois库,并处理可能出现的异常。为了使并行执行时的控制台输出更加整洁,我们还会引入一个技巧来暂时禁用whois库可能产生的标准输出。

立即学习Python免费学习笔记(深入)”;

import os
import sys
from whois import whois

# 用于禁用whois库的内部打印输出,避免干扰tqdm进度条
def blockPrint():
    sys.stdout = open(os.devnull, "w")

# 恢复标准输出
def enablePrint():
    sys.stdout = sys.__stdout__

def check_domain(domain):
    """
    检查单个域名的WHOIS信息并判断其可用性。
    :param domain: 待查询的域名字符串。
    :return: (domain, status),其中status为None表示可用,否则表示已注册。
    """
    try:
        blockPrint()  # 禁用打印
        result = whois(domain)
    except Exception:
        # 捕获所有异常,确保即使whois查询失败也能返回结果
        return domain, None
    finally:
        enablePrint()  # 恢复打印

    # whois库返回的status字段通常在域名已注册时包含信息,
    # 否则可能为None或空列表。这里我们简化判断逻辑。
    # 如果result.status为None或空列表,则认为域名可用。
    return domain, result.status

在check_domain函数中,我们使用了blockPrint和enablePrint来控制whois库的输出。这是因为python-whois在执行过程中可能会打印一些调试信息或错误,这会与tqdm的进度条混淆,影响用户体验。通过将sys.stdout重定向到os.devnull(空设备),我们可以有效地抑制这些输出。

3. 利用multiprocessing实现并行查询

有了单个域名的查询函数后,我们就可以利用multiprocessing.Pool来创建多个进程,并行地执行这些查询任务。Pool提供了一种便捷的方式来管理一组工作进程,并将任务分发给它们。

import pandas as pd
from multiprocessing import Pool
from tqdm import tqdm

if __name__ == "__main__":
    # 示例域名列表,实际应用中替换为您的50k域名列表
    domains = [
        "google.com",
        "yahoo.com",
        "facebook.com",
        "xxxnonexistentzzz.domain",
        "example.com",
        "nonexistentdomain123.xyz",
        "python.org",
        "github.com",
        "stackoverflow.com",
        "openai.com"
    ] * 100 # 放大列表以模拟大量查询

    results = []
    # 使用Pool创建进程池,processes参数控制并行进程数
    # 通常设置为CPU核心数或根据网络I/O瓶颈调整
    with Pool(processes=16) as pool:  
        # imap_unordered用于异步获取结果,结果顺序不保证,但可以立即处理已完成的任务
        # tqdm用于显示进度条
        for domain, status in tqdm(
            pool.imap_unordered(check_domain, domains), total=len(domains)
        ):
            # 将结果添加到列表中。not bool(status)是判断域名是否可用的关键:
            # 如果status为None或空列表(表示域名可用),则not bool(status)为True。
            # 如果status有值(表示域名已注册),则not bool(status)为False。
            results.append((domain, not bool(status)))

    # 将结果转换为DataFrame并去重,方便查看和分析
    df = pd.DataFrame(results, columns=["domain", "is_free"])
    print("\n查询结果:")
    print(df.drop_duplicates().sort_values(by='is_free', ascending=False))

代码解析:

佳蓝在线销售系统(创业版) 佳蓝在线销售
佳蓝在线销售系统(创业版) 佳蓝在线销售

1、对ASP内核代码进行DLL封装,从而大大提高了用户的访问速度和安全性;2、采用后台生成HTML网页的格式,使程序访问速度得到进一步的提升;3、用户可发展下级会员并在下级购买商品时获得差额利润;4、全新模板选择功能;5、后台增加磁盘绑定功能;6、后台增加库存查询功能;7、后台增加财务统计功能;8、后台面值类型批量设定;9、后台财务曲线报表显示;10、完善订单功能;11、对所有传输的字符串进行安全

下载
  • if __name__ == "__main__":: 这是Python多进程编程的惯例,确保在Windows系统上脚本能够正确运行,并防止子进程无限递归地创建新进程。
  • Pool(processes=16): 创建一个包含16个工作进程的进程池。这个数字可以根据您的CPU核心数和网络带宽进行调整。whois查询主要是I/O密集型任务(等待网络响应),因此可以适当增加进程数,但过多的进程也可能导致资源竞争和效率下降。
  • pool.imap_unordered(check_domain, domains): 这是Pool对象的一个方法,它将domains列表中的每个元素作为参数,依次调用check_domain函数。imap_unordered的特点是,一旦某个任务完成,其结果就会立即返回,而无需等待所有之前的任务完成,这对于进度条的实时更新非常有利。
  • tqdm(...): tqdm包装了imap_unordered的迭代器,自动显示一个动态的进度条,让您了解任务的执行情况。
  • results.append((domain, not bool(status))): whois库在域名可用时,result.status通常是None或一个空列表。not bool(None)和not bool([])都为True,这正是我们判断域名是否可用的逻辑。
  • pd.DataFrame(...)和df.drop_duplicates(): 将查询结果组织成一个Pandas DataFrame,并移除重复的域名条目,使最终输出更清晰。sort_values则用于将可用的域名排在前面。

4. 性能与注意事项

性能表现: 通过上述多进程并行化的方法,查询速度可以得到显著提升。例如,在测试环境中,处理数百个域名可能只需几秒钟,相当于每秒查询数十个域名。对于50k的域名列表,这将把查询时间从数天缩短到数小时甚至更短,具体取决于您的网络带宽和选择的进程数。

注意事项:

  1. 进程数选择 (processes):

    • whois查询是I/O密集型任务(等待网络响应),而不是CPU密集型。因此,processes的值可以适当高于CPU核心数,以弥补网络延迟。
    • 然而,过多的进程可能会导致:
      • 系统资源(内存、文件句柄)耗尽。
      • whois服务器对您的IP地址进行速率限制或临时封禁。
    • 建议从CPU核心数开始尝试,然后逐步增加,观察性能和稳定性。
  2. 速率限制与IP封禁:

    • 频繁且大量的whois查询可能会被whois服务器视为恶意行为,导致您的IP地址被暂时或永久封禁。
    • 如果遇到此类问题,可以考虑:
      • 在check_domain函数内部添加time.sleep(seconds)来引入随机延迟。
      • 使用代理IP池进行查询。
      • 分散查询时间,避免短时间内集中爆发大量请求。
  3. 域名价格查询:

    • 原始问题中提到了域名价格查询。whois协议和库主要用于查询域名的注册信息(如注册人、注册商、过期日期等)和可用性,它不提供域名的销售价格。
    • 域名的价格通常由域名注册商设定,并随时间、促销活动和TLD(顶级域名)而变化。要获取价格,您需要与特定的域名注册商(如GoDaddy, Namecheap等)的API集成,或使用其批量查询工具(如果提供)。
  4. 错误处理:

    • whois查询可能会因为网络问题、域名格式错误、WHOIS服务器无响应等原因而失败。
    • 示例代码中的try-except块捕获了所有异常,并返回None作为状态,确保程序不会崩溃。在实际应用中,您可能需要更精细的错误处理,例如记录失败的域名及其错误信息,以便后续分析。

总结

通过结合Python的multiprocessing模块和python-whois库,我们可以有效地解决批量域名可用性查询的性能瓶颈。并行化处理将原本耗时漫长的任务转化为可在合理时间内完成的操作。然而,在进行大规模查询时,务必注意whois服务器的速率限制,并合理配置进程数,以确保查询的稳定性和可靠性。对于域名价格查询,需要明确whois工具的局限性,并寻求注册商提供的专用API或服务。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

772

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

679

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1365

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

570

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

730

2023.08.11

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 14.1万人学习

Django 教程
Django 教程

共28课时 | 3.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号