无core文件使用符号剥离进行崩溃地址查询

本文介绍了如何在Linux平台上使用工具链对编译后的库进行符号剥离,处理debug信息,同时提供了生成core文件和使用GDB的方法,以及bash环境变量设置的详细过程。
摘要由CSDN通过智能技术生成

直接上代码把,主要是debug信息不能对外输出,采用对应工具链的工具进行符号剥离

剥离

set +x
    STRIP_BIN="nostrip"
    OBJCOPY_BIN="nocopy"
    case "${BUILD_TYPE}" in 
        "linux-x86_64")
        STRIP_BIN="/usr/bin/strip"
        OBJCOPY_BIN="/usr/bin/objcopy"
        echo "strip_symbols for linux-x86_64"
        ;;
        *)
        echo "Other Platform, Not Strip"
        ;;
    esac

for file_so in ${Thirdlib}/*.so*
    do 
        temp_file=`basename $file_so` 
        if [ "${OBJCOPY_BIN}" != "nocopy" ]
        then
            echo "backup ${temp_file} debug info" 
            ${OBJCOPY_BIN} --only-keep-debug ${Thirdlib}/${temp_file} ${Debug_info}/${temp_file}.debug
        fi     
        if [ -h "${Thirdlib}/${temp_file}" ]
        then
            echo "${Thirdlib}/${temp_file} is soft link, skip strip"
        else
            if [ "${STRIP_BIN}" != "nostrip" ]
            then
                ${STRIP_BIN} ${Thirdlib}/${temp_file}
                echo "${temp_file} is stripped" 
            fi
        fi
    done

STRIP_BIN和OBJCOPY_BIN要确认自己使用的平台工具链的路径,这样就可以对-g编译的库进行剥离了

符号使用

/usr/bin/objcopy  --add-gnu-debuglink=./lib*.so.debug ./lib*.so

还原so符号
gdb进入
在这里插入图片描述
就可以看崩溃在哪一行了,这个方法主要使用某些平台由于限制无法生成core文件的情况

生成core方法

使用sysctl kernel.core_pattern查看当前,我的是已经改好的
在这里插入图片描述
修改在后面加上=如下
在这里插入图片描述

之后使用ulimit -a查看core文件大小
在这里插入图片描述

如果是0通过ulimit -c unlimited修改
在这里插入图片描述
这样每次都必须修改可以写入用户的环境变量文件,比如我的,我个人安装的zsh可以参考我之前的文章在这里插入图片描述
在最后加上ulimit -c unlimited

在这里插入图片描述
这样另起终端,就不需要再次执行ulimit -c unlimited,系统会自动加载

如果使用的默认bash,可以用同样的方式修改vi ~/.bashrc

环境变量介绍

直接粘贴从课本看的吧

前言: /etc/profile:此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.并从/etc/profile.d目录的配置文件中搜集shell的设置.所以如果你有对/etc/profile有修改的话必须得重启你的修改才会生效,此修改对每个用户都生效。可以通过命令source /etc/profile立即生效

etc/bashrc或
 /etc/bash.bashrc:为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取.如果你想对所有的使用bash的用户修改某个配置并在以后打开的bash都生效的话可以修改这个文件,
 修改这个文件不用重启,重新打开一个bash即可生效

 ~/.bash_profile或~/.profile :每个用户都可使用该文件输入专用于当前用户使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,他设置一些环境变量,执行用户的.bashrc文件.


 此文件类似于/etc/profile,也是需要需要重启才会生效,/etc/profile对所有用户生效~/.bash_profile只对当前用户生效。


 ~/.bashrc:该文件包含专用于你的bash shell的bash信息,当登录时以及每次打开新的shell时,该文件被读取.(每个用户都有一个.bashrc文件,在用户目录下)。此文件类似于/etc/bashrc 或  /etc/bash.bashrc,不需要重启生效,重新打开一个bash即可生效. 

  /etc/bashrc 或  /etc/bash.bashrc对所有用户新打开的bash都生效,但~/.bashrc只对当前用户新打开的bash生效。

etc/profile中设定的变量(全局)的可以作用于任何用户,而
 ~/.bashrc等中设定的变量(局部)只能继承/etc/profile中的变量,他们是"父子"关系.

要识别一个shell是否为login shell,只需在该shell下执行echo $0:

如果输出的东西带有前缀 - 则为login shell 。

当bash以login shell启动时,它会执行/etc/profile中的命令,然后/etc/profile调用/etc/profile.d目录下的所有脚本;然后执行~/.profile,~/.profile调用~/.bashrc,最后~/.bashrc调用/etc/bash.bashrc。
还以Bash为例,当以非login方式启动时,它会调用~/.bashrc,随后~/.bashrc中调用/etc/bashrc,最后/etc/bashrc调用所有/etc/profile.d目录下的脚本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值