linux c同一个动态库,放到多台机器,其中一台机器段错误core

现象:

linux c编译的一个动态库,放到多台机器,其中一台机器产生core文件,其它机器正常运行。

分析:

由于编译成动态库,系统使用不生成core文件,无法跟踪问题。
一、直接编译动态库,调用出现core的函数

#include <stdio.h>
int main()
{
	sign8256_20();
	return 0;
}

注意编译和执行
将sign.so改成标准三方库名,并放到当前目录,修改LD_LIBRARY_PATH环境变量,执行./a.out

cp ~/dll/sign.so libsign.so
gcc test.c -L./ -lsign
export LD_LIBRARY_PATH=./:$LD_LIBRARY_PATH:
./a.out

二、单独编写dlsym程序,调用出现core的函数,进行测试。程序如下:

#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>
#define FAIL -1
int (*p_func)();
void    *p_handle;
int main()
{
    int     iRetCode;
    char    strFuncName[48+1] = {0};
    char    strFileName[256+1]= {0};
    char    strDllName[256+1] = {0};
    memset(strDllName,0,sizeof(strDllName));
    sprintf(strDllName,"%s/dll/sign.so",getenv("BASE"));
    p_handle = dlopen(strDllName,RTLD_NOW);
    if ( NULL == p_handle )
    {
        printf("error [%s][%d]\n",dlerror(),__LINE__);
        dlclose(p_handle);
        return FAIL;
    }
    sprintf(strFuncName,"sign8256_20");
    p_func = (int (*))dlsym(p_handle,strFuncName);
    if ( NULL == p_func )
    {
        printf("error [%s][%d]\n",dlerror(),__LINE__);
        dlclose(p_handle);
        return FAIL;
    }
    iRetCode = p_func();
    if( iRetCode < 0)
    {
        printf("error [%s][%d]\n",dlerror(),__LINE__);
        dlclose(p_handle);
        return FAIL;
    }
    dlclose(p_handle);
    return 0;
}

两种方式,运行程序,产生core文件。使用gdb跟踪时,发现程序进入这个函数之后,直接coredump。
gdb 使用info locals查看变量的时候发现,出现core文件这个台机器的打印出现了异常。最后变量报这个异常

stSign = <error reading variable stSign (Cannot access memory at address 0x7fffff56c980)>

结论:

确认为进程的默认的栈空间太小,该函数声明的变量超限。
执行ulimit -s 命令,发现系统默认栈空间大小为8192。
扩大系统默认栈空间,两种方案
1、/etc/rc.local 加入
ulimit -s 102400
2、/etc/security/limits.conf 加入
* soft stack 102400

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你在执行Python程序时遇到"Segmentation fault (core dumped)"的错误,这通常是由于程序访问了无效的内存地址导致的。这种错误通常是由于编程错误或者底层的bug引起的。 为了解决这个问题,你可以采取以下步骤: 1. 首先,你可以尝试检查你的代码,看看有没有明显的错误,比如数组越界、空指针引用等。确保你的代码逻辑正确,并且没有潜在的内存访问问题。 2. 如果你确定代码没有明显的问题,你可以尝试使用调试器来定位错误。调试器可以帮助你跟踪代码的执行过程,并找到导致错误的具体位置。你可以使用Python自带的pdb调试器或者其他第三方调试器来进行调试。 3. 另外,你也可以尝试使用不同的Python版本或者更新的来运行你的程序。有时候,这种错误可能是由于底层的bug导致的,更新版本可能会解决问题。 总结来说,当你遇到"Segmentation fault (core dumped)"的错误时,你可以通过检查代码、使用调试器和更新版本等方式来解决问题。希望这些方法能够帮助你找到并修复错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【Q&A】Python代码调试之解决Segmentation fault (core dumped)问题](https://blog.csdn.net/ARPOSPF/article/details/130248065)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值