gpt4 book ai didi

multithreading - Perl - 多线程脚本打印内存映射和回溯

转载 作者:行者123 更新时间:2023-12-03 13:15:59 25 4
gpt4 key购买 nike

enter image description here当我调用我的多线程 perl 脚本时,在少数情况下,它会抛出一些类似于以下内容的异常。很抱歉我无法共享代码。但如果真的需要,我可以尝试构建一个片段(如果真的需要)。因为我想这应该有一些理论上的答案。

*** glibc detected *** perl: double free or corruption (!prev): 0x00007f775401e9a0 ***
======= Backtrace: =========
/lib64/libc.so.6[0x3d74c75e66]
/lib64/libc.so.6[0x3d74c789b3]
/lib64/libc.so.6[0x3d74c7b880]
/lib64/libc.so.6(realloc+0xe5)[0x3d74c7baf5]
/usr/lib/../lib64/libcrypto.so.10(CRYPTO_realloc+0x5f)[0x7f775907bd8f]
/usr/lib/../lib64/libcrypto.so.10(lh_insert+0xee)[0x7f77590f763e]
/usr/lib/../lib64/libcrypto.so.10(OBJ_NAME_add+0x6b)[0x7f775907f12b]
/usr/lib/../lib64/libcrypto.so.10(EVP_add_cipher+0x27)[0x7f7759102387]
/usr/lib/../lib64/libcrypto.so.10(OpenSSL_add_all_ciphers+0x4b7)[0x7f7759106a07]
/usr/lib/../lib64/libcrypto.so.10(OPENSSL_add_all_algorithms_noconf+0xe)[0x7f775910653e]
/usr/local/lib/libssh2.so.1(libssh2_init+0x39)[0x7f77596800b9]

为什么我会收到这样的错误?

我正在使用 Thread::Queue;使用线程::共享;请让我知道你的看法。

以下是线程库版本信息。
use threads; - installed v2.15 (latest - 2.16)
use Thread::Queue; - installed v3.12 (up to date)
use threads::shared; - installed v1.56 (latest - 1.57)
perl - installed v5.26.1

其他库是::
use YAML::XS 'LoadFile';  - 0.66 up to date
use Net::Netconf::Manager; - 1.02 up to date
use Config::Properties; - 1.80 up to date
use Sys::Syslog; - 0.35 up to date
use DateTime::Format::Strptime; - 1.74 up to date
use DateTime; - 1.44 up to date
use XML::LibXML; - 2.0129 (latest 2.0139)
use Regexp::Common qw/net/; - 2017060201 up to date
use Getopt::Long; - 2.5 up to date

最佳答案

为了给您一个明确的答案,我们需要一些可以运行和排除故障的东西。否则错误是不可重现的。

话虽如此 - 这看起来类似于我之前遇到的某些模块不是线程安全的 - 它们通常会运行良好,然后偶尔会在你的脸上爆炸。

例如。 Crypt::SSLeay回到 2008 年。Net::SSLeay 1.4.2 之前

一般的解决方法是在编译时使用 use 停止加载罪魁祸首。 - 因为所有线程都继承了相同的状态 - 而是在线程内,在运行时使用 require 加载它们和 import .通过这样做,您将它们隔离 - 您的线程将需要稍长的时间才能启动,但无论如何您都不应该在 perl 中发送垃圾邮件。

或者使用线程安全的不同模块。

随着你的更新和截图 - Net::SSH2提到了-这意味着您的其他模块之一正在将其拉入。

然而Net::SSH thread safey表示libssh可能对线程安全有一些限制:

Thread-safe: just don't share handles simultaneously



你没有明确提到使用它,但它看起来像是被另一个模块拉进来的。估计是 Net::Netconf::Manager .

作为第二个进一步的猜测 - 它很可能正在执行“共享句柄”,因为它没有意识到它正在线程中运行。

所以这个模块是我建议在线程中隔离的模块:
require 'Net::NetConf::Manager';
Net::NetConf::Manager -> import;

并在线程内进行实例化。

当您使用工作线程模型时,这应该是最小的开销,并且意味着您没有遇到这个问题。

但更一般地说 - 假设模块是线程安全的是不明智的,除非它们明确表示它们是。主要的“绊脚石”点通常是模块可以假设/暗示任何类型的资源共享,例如网络套接字、文件句柄、数据库连接等。通常在实例化时创建套接字(例如,传递用户名的点/password) 并且有两个线程试图同时驱动一个套接字是一个潜在的竞争条件。

关于multithreading - Perl - 多线程脚本打印内存映射和回溯,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47074511/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com