찾다
운영 및 유지보수리눅스 운영 및 유지 관리리눅스 코어는 무엇을 의미합니까?

Linux에서 Core는 메모리를 의미합니다. 프로그램이 실행되는 동안 예외가 감지되고 프로그램이 비정상적으로 종료되면 시스템은 프로그램의 현재 메모리 상태를 코어 덤프(core dumped)라고 하는 코어 파일에 저장합니다. 이 파일은 운영 체제가 예외를 감지할 때 정보 덤프이기도 합니다. 현재 프로세스에서는 신호를 사용하여 해당 오류 정보를 대상 프로세스에 알립니다. 일반적인 신호에는 SIGSEGV, SIGBUS 등이 포함됩니다. 기본적으로 프로세스는 해당 신호를 수신할 때 해당 처리 메커니즘을 갖습니다.

리눅스 코어는 무엇을 의미합니까?

이 튜토리얼의 운영 환경: linux7.3 시스템, Dell G3 컴퓨터.

Linux에서 개발할 때 프로그래머들이 내 프로그램의 핵심이 떨어졌다는 말을 자주 듣습니다. 이러한 문제는 일반적으로 범위를 벗어난 메모리 액세스, 널 포인터 사용, 스택 오버플로 등과 같은 낮은 수준의 버그로 인해 발생합니다. . 프로그램이 실행 중 비정상적으로 종료되거나 종료되는 경우 이러한 조건이 충족되면 코어 파일이 생성됩니다.

코어덤은 왜 생기는 걸까요

코어는 메모리를 뜻하는 단어로 오래전부터 메모리를 만드는데 사용되는 재료로, 지금까지 프로그램 실행 중 이상이 감지되었을 때 사용하던 단어입니다. 프로그램이 비정상적으로 종료되면 시스템은 정보 덤프라고도 알려진 코어 파일에 프로그램의 현재 메모리 상태를 저장합니다. 신호를 통한 해당 오류 정보. 일반적인 신호에는 SIGSEGV, SIGBUS 등이 포함됩니다. 기본적으로 프로세스는 해당 신호를 수신할 때 해당 처리 메커니즘을 갖습니다.

리눅스를 예로 들면, 빨간색 상자는 공통 신호로 표시됩니다.

리눅스 코어는 무엇을 의미합니까?

이전에 프로세스의 메모리 레이아웃을 이해하는 것이 가장 좋습니다. Unix와 Linux 시스템은 약간 다릅니다. 커널 공간은 Linux보다 작습니다. 특히 커널과 사용자 프로세스는 별도의 주소 공간 모드를 채택합니다. 예를 들어 Linux는

리눅스 코어는 무엇을 의미합니까?

코어 덤프 파일 위치

우리는 Linux 시스템에서 프로세스가 충돌하면 시스템 커널이 프로세스 충돌 정보를 캡처한 다음 프로세스의 코어 덤프 정보를 파일에 기록한다는 것을 알고 있습니다. 핵심. 저장 위치는 해당 실행 프로그램과 동일한 디렉터리에 있습니다. 파일 이름은 core입니다.

리눅스 코어는 무엇을 의미합니까?

Core_pattern 형식:

%p 전송 덤프된 프로세스의 PID
%u(숫자) 덤프된 프로세스의 실제 UID
%G(숫자) 덤프된 프로세스의 실제 GID
%s 덤프를 유발한 신호 수
%t 덤프 시간, 다음과 같이 표현됩니다. 1970년부터 월 1일 이후의 초 수 00:00:00 +0000(UTC)
%H 호스트 이름(uname(2)에서 반환된 노드 이름과 동일)
%e 실행 파일 이름(경로 접두어 없음)
%E 예 경로 이름 슬래시('/')가 느낌표('!')로 대체된 실행 파일입니다.
%C 충돌 프로세스에 대한 코어 파일 크기 소프트 리소스 제한(Linux 2.6.24부터)

다음 프로그램을 사용하여 /proc/sys/kernel/core_pattern 파일에서 파이프 구문 사용법을 보여줄 수 있습니다.

#include <sys/stat.h>
#include <fcntl.h>
#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

#define BUF_SIZE 1024

int main(int argc, char *argv[])
{
    int tot, j;
    ssize_t nread;
    char buf[BUF_SIZE];
    FILE *fp;
    char cwd[PATH_MAX];

   /* 属性的当前工作目录崩溃的过程*/

    snprintf(cwd, PATH_MAX, "/proc/%s/cwd", argv[1]);
    chdir(cwd);

   /* 将输出写到该目录下的文件"core.info" */

    fp = fopen("core.info", "w+");
	if (fp == NULL)
	{
		exit(EXIT_FAILURE);
	}


   fprintf(fp, "argc=%d\n", argc);
    for (j = 0; j < argc; j++)
	{
        fprintf(fp, "argc[%d]=<%s>\n", j, argv[j]);
	}

   /* 计算标准输入(核心转储)中的字节数*/

    tot = 0;
    while ((nread = read(STDIN_FILENO, buf, BUF_SIZE)) > 0)
	{
        tot += nread;
	}
	
    fprintf(fp, "Total bytes in core dump: %d\n", tot);

   return 0;
}

注意一下:  这里是指在进程当前工作目录的下创建。通常与程序在相同的路径下。但如果程序中调用了chdir函数,则有可能改变了当前工作目录。这时core文件创建在chdir指定的路径下。有好多程序崩溃了,我们却找不到core文件放在什么位置。和chdir函数就有关系。当然程序崩溃了不一定都产生  core文件。

下面通过的命令可以更改coredump文件的存储位置,如下:

echo “|$PWD/core_pattern_pipe_test %p UID=%u GID=%g sig=%s” > 
/proc/sys/kernel/core_pattern

cat /proc/sys/kernel/core_pattern 查看路径已经变为如下:

리눅스 코어는 무엇을 의미합니까?

下面带大家配置永久的core。只要出现内存访问越界、使用空指针、堆栈溢出等情况,都可以在这个目录下查看。

配置 core

1、首先在根目录下建立一个储存coredump文件的文件夹,命令如下:

mkdir /corefile

2、设置产生coredump文件的大小,命令如下:

ulimit -c unlimited

3、 执行以下两条命令:

echo “1” > /proc/sys/kernel/core_uses_pid       //将1写入到该文件里
echo “/corefile/core-%e-%p-%t” > /proc/sys/kernel/core_pattern

将coredump产生的格式制定好写入core_pattern文件,这样当coredump产生时会直接以这种格式存入到根目录下的文件夹corefile中。

4、修改配置文件/etc/profile

vim /etc/profile

添加 ulimit -S -c unlimited > /dev/null 2>&1

리눅스 코어는 무엇을 의미합니까?

执行命令生效该文件

리눅스 코어는 무엇을 의미합니까?

5、 在配置文件/etc/rc.local中最后面添加信息(机器重启时会自动加载该命令):添加命令:

rm -rf /corefile/*

机器重启时清空该文件夹,由于产生的coredump文件很大,若不清空的话时间长了会将硬盘占满;

再执行以下两条命令:

echo “1” > /proc/sys/kernel/core_uses_pid
echo “/corefile/core-%e-%p-%t” > /proc/sys/kernel/core_pattern

测试
下面写个例子测试一下是否配置好了corefile文件

#include int main(int argc, char *argv[]){ int *p = NULL; *p = 3; return 0; }

编译运行,注意这里需要-g选项编译。

리눅스 코어는 무엇을 의미합니까?

进入前面创建的corefile文件夹:

리눅스 코어는 무엇을 의미합니까?

出现core文件表示完成coredump配置。可以用通过readelf命令进行判断是否是core文件:

리눅스 코어는 무엇을 의미합니까?

gdb를 실행하여 코어 파일을 읽습니다. 명령은 "gdb 프로그램이 코어 덤프 파일에 해당합니다"입니다. 이때 gdb 프롬프트 "(gdb)"를 입력합니다.

리눅스 코어는 무엇을 의미합니까?

빨간 박스 스크린샷을 보시면 아시겠지만 11번 신호로 인해 프로그램이 종료됩니다.

아래 bt(역추적) 명령(또는 위치)을 통해 함수의 호출 스택을 볼 수 있습니다.

리눅스 코어는 무엇을 의미합니까?

즉, 프로그램이 test.cpp의 6번째 줄까지 실행될 때 세그폴트 발생합니다. 그 이유는 널 포인터를 가리키기 때문입니다.

요약

프로그램 코어 덤프에는 여러 가지 이유가 있습니다. 주로 메모리 액세스 범위를 벗어남, 스레드에 안전하지 않은 함수 사용, 널 포인터 사용, 스택 오버플로 등이 있습니다.

여기서 말하고 싶은 점은 gdb로 코어 덤프를 디버깅할 때 대부분의 경우 코어 파일에서 코어에 대한 직관적인 이유만 찾을 수 있다는 것입니다. 그러나 더 근본적인 이유는 일반적으로 코드와 결합되어야 합니다. 이를 추론하기 위해 당시 프로세스의 실행 컨텍스트를 분석합니다. 문제는 프로그램 코드에 있습니다.

관련 추천: "Linux 비디오 튜토리얼"

위 내용은 리눅스 코어는 무엇을 의미합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Linux : 필수 명령 및 운영Linux : 필수 명령 및 운영Apr 24, 2025 am 12:20 AM

Linux의 필수 명령에는 다음이 포함됩니다. 1.LS : 목록 디렉토리 내용; 2.CD : 작업 디렉토리 변경; 3.mkdir : 새 디렉토리 생성; 4.RM : 파일 또는 디렉토리 삭제; 5.CP : 파일 또는 디렉토리 복사; 6.mv : 파일 또는 디렉토리를 이동하거나 바꾸십시오. 이러한 명령은 사용자가 커널과 상호 작용하여 파일 및 시스템을 효율적으로 관리하는 데 도움이됩니다.

Linux 작업 : 파일, 디렉토리 및 권한 관리Linux 작업 : 파일, 디렉토리 및 권한 관리Apr 23, 2025 am 12:19 AM

Linux에서 파일 및 디렉토리 관리는 LS, CD, MKDIR, RM, CP, MV 명령을 사용하며 권한 관리는 CHMOD, Chown 및 CHGRP 명령을 사용합니다. 1. 파일 및 디렉토리 관리 명령 LS-L 목록 상세 정보와 같은 MKDIR-P는 디렉토리를 재귀 적으로 생성합니다. 2. CHMOD755FILE SET 파일 권한 설정, ChownUserFile 변경 파일 소유자 및 CHGRPGROUPFILE와 같은 허가 관리 명령은 파일 그룹을 변경합니다. 이러한 명령은 파일 시스템 구조 및 사용자 및 그룹 시스템을 기반으로하며 시스템 호출 및 메타 데이터를 통해 작동 및 제어합니다.

Linux의 유지 관리 모드 란 무엇입니까? 설명했다Linux의 유지 관리 모드 란 무엇입니까? 설명했다Apr 22, 2025 am 12:06 AM

MaintenanceModeInlinlinlinuxisspecialbootenvernmentforcriticalsystemmaintenancetasks.itallowsAdministratorStorformtaskSlikeresettingpasswords, Repairingfilesystems, Andrecoveringfrombootfailuresinaminimalenvernment.toentermaintingancemode, intermainteancemode

Linux : 기본 부분에 대한 깊은 다이빙Linux : 기본 부분에 대한 깊은 다이빙Apr 21, 2025 am 12:03 AM

Linux의 핵심 구성 요소에는 커널, 파일 시스템, 쉘, 사용자 및 커널 공간, 장치 드라이버 및 성능 최적화 및 모범 사례가 포함됩니다. 1) 커널은 하드웨어, 메모리 및 프로세스를 관리하는 시스템의 핵심입니다. 2) 파일 시스템은 데이터를 구성하고 Ext4, BTRF 및 XFS와 같은 여러 유형을 지원합니다. 3) Shell은 사용자가 시스템과 상호 작용하고 스크립팅을 지원하는 명령 센터입니다. 4) 시스템 안정성을 보장하기 위해 사용자 공간을 커널 공간과 별도로 분리하십시오. 5) 장치 드라이버는 하드웨어를 운영 체제에 연결합니다. 6) 성능 최적화에는 튜닝 시스템 구성 및 다음 모범 사례가 포함됩니다.

Linux Architecture : 5 개의 기본 구성 요소를 공개합니다Linux Architecture : 5 개의 기본 구성 요소를 공개합니다Apr 20, 2025 am 12:04 AM

Linux 시스템의 5 가지 기본 구성 요소는 다음과 같습니다. 1. Kernel, 2. System Library, 3. System Utilities, 4. 그래픽 사용자 인터페이스, 5. 응용 프로그램. 커널은 하드웨어 리소스를 관리하고 시스템 라이브러리는 사전 컴파일 된 기능을 제공하며 시스템 유틸리티는 시스템 관리에 사용되며 GUI는 시각적 상호 작용을 제공하며 응용 프로그램은 이러한 구성 요소를 사용하여 기능을 구현합니다.

Linux 작업 : 유지 보수 모드 사용Linux 작업 : 유지 보수 모드 사용Apr 19, 2025 am 12:08 AM

Linux 유지 관리 모드는 Grub 메뉴를 통해 입력 할 수 있습니다. 특정 단계는 다음과 같습니다. 1) Grub 메뉴에서 커널을 선택하고 'e'를 눌러 편집, 2) 'Linux'라인 끝에 '단일'또는 '1'추가, 3) Ctrl X를 눌러 시작합니다. 유지 보수 모드는 시스템 수리, 비밀번호 재설정 및 시스템 업그레이드와 같은 작업을위한 안전한 환경을 제공합니다.

Linux : 복구 모드에 들어가는 방법 (및 유지 보수)Linux : 복구 모드에 들어가는 방법 (및 유지 보수)Apr 18, 2025 am 12:05 AM

Linux 복구 모드를 입력하는 단계는 다음과 같습니다. 1. 시스템을 다시 시작하고 특정 키를 눌러 Grub 메뉴를 입력하십시오. 2. (복구 계)로 옵션을 선택하십시오. 3. FSCK 또는 루트와 같은 복구 모드 메뉴에서 작업을 선택하십시오. 복구 모드를 사용하면 단일 사용자 모드에서 시스템을 시작하고 파일 시스템 검사 및 수리를 수행하고 구성 파일 편집 및 기타 작업을 수행하여 시스템 문제를 해결할 수 있습니다.

Linux의 필수 구성 요소 : 초보자를위한 설명Linux의 필수 구성 요소 : 초보자를위한 설명Apr 17, 2025 am 12:08 AM

Linux의 핵심 구성 요소에는 커널, 파일 시스템, 쉘 및 공통 도구가 포함됩니다. 1. 커널은 하드웨어 리소스를 관리하고 기본 서비스를 제공합니다. 2. 파일 시스템은 데이터를 구성하고 저장합니다. 3. Shell은 사용자가 시스템과 상호 작용할 수있는 인터페이스입니다. 4. 일반적인 도구는 일상적인 작업을 완료하는 데 도움이됩니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.