二、若程序调用了seteuid()/setegid()改变了进程的有效用户或组,则在默认情况下系统不会为这些进程生成Core dump。很多服务程序都会调用seteuid(),如MySQL,不论你用什么用户运行mysqld_safe启动MySQL,mysqld进行的有效用户始终是msyql用户。如果你当初是以用户A运行了某个程序,但在ps里看到的这个程序的用户却是B的话,那么这些进程就是调用了seteuid了。为了能够让这些进程生成Coredump,需要(echo "1" >/proc/sys/kernel/suid_dumpable)。
三、这个一般都知道,就是要设置足够大的Core文件大小限制了。程序崩溃时生成的Core文件大小租液即为程序运行时占用的内存大小。但程序崩溃时的行为不可按平常时的行为来估计,比如缓冲区溢出等错误可能导致堆栈被破坏,因此经常会出现某个变量的值被修改成乱七八糟的,然消纤后程序用这个大小去申请内存就可能导致程序比平常时多占用很多内存。因此无论程序拿型仿正常运行时占用的内存多么少,要保证生成Core文件还是将大小限制设为unlimited为好。
4
四、在/etc/profile中添加:ulimit -c unlimited >/dev/null 2?&1
五、一般在 CLI 上启动的程序,如果设置:ulimit -c unlimited
就可以在程序以外终止时生成 core dump 文件。但是对于 daemon 方式运行的程序,其与 CLI 启动的程序的主要区别是进程的运行环境,其中就包括
cwd(current working directory)。如果以相对路径方式定义 core 文件的格式,比如定义 /proc/sys/kernel/core_pattern 为:
core-%e-%p-%t
则一般来说,daemon 文件的 cwd 就是/,你可以通过/proc/<your_program_pid>/cwd来查看,一般都是连接到/目录。而如果用户对这个目录没有写权限,那么就不会生成 core dump 文件了。
最直接的解决的方法,是修改/proc/sys/kernel/core_pattern为绝对路径:/data/coredump/core-%e-%p-%t
并且保证这样就基本 OK 了。
修改/proc/sys/kernel/core_pattern文件中的 core dump 文件格式为绝对路径,比如:
/data/coredump/core-%e-%p-%t
演示机型:小米11 系统版本:MIUI12
1、哪颤点击打开手机界面中的设置按钮。
2、在设禅缓败置栏目下点击应用设置按钮。
3、然后点击打开授权管理。
4、点击打开按钮应用权限管贺颤理。
5、选择要开通权限的应用软件点击打开。
6、点击权限后边的问号并点击允许按钮。
7、权限后边显示了绿色的对号即表明权限打开。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)