Linux에서는 ls를 실행하면 읽기 및 exec 시스템 호출이 발생합니다. 쉘 명령을 실행하면 fork 및 exec가 호출되지만 strace를 사용하여 ls로 인한 시스템 호출을 확인하면 ls 명령이 파일을 나열하지 않습니다. 디렉토리에 있으므로 read가 호출됩니다.
이 튜토리얼의 운영 환경: linux7.3 시스템, Dell G3 컴퓨터.
Linux에서 ls를 실행하면 어떤 시스템 호출이 발생할까요
답은 읽기 및 실행 시리즈입니다
셸 명령 실행 메커니즘은 fork+exec이고, fork는 복제, execve는 변환입니다. ls 명령은 디렉터리의 파일을 나열하므로 read도 호출됩니다.
fork 및 exec 명령을 통해 Linux 커널에 대한 쉘 액세스가 가능합니다. 동일한 스레드에서 생성할 수 있습니다.
strace를 사용하여 ls로 인한 시스템 호출을 확인하세요. 포크가 없는 것은 사실이지만 어떤 쉘 명령을 실행하면 포크가 호출되기 때문입니다
execve의 변형은 새로운 프로세스를 생성하고 교체하는 것입니다. 새 프로세스로 원래 프로세스를 삭제합니다.
먼저 시스템 호출이 무엇인지 논의해 볼까요?
사용자는 UNIX/Linux에서 직접 제공하는 소수의 기능을 이용하여 파일 및 장치에 접근하고 제어할 수 있습니다. 이러한 기능이 시스템 호출
[1]입니다. 系统调用
[1]。
使用strace ls
命令我们可以查看ls命令使用到的系统调用[2],其中一部分输出内容如下:
open(".", O_RDONLY|O_NONBLOCK|O_LARGEFILE|O_DIRECTORY|O_CLOEXEC) = 3 getdents64(3, /* 68 entries */, 32768) = 2240 getdents64(3, /* 0 entries */, 32768) = 0 close(3) = 0
open系统调用打开当前目录文件,返回获得的文件描述符。可以看到该文件使用O_RDONLY标志打开。
只要该文件是用O_RDONLY或O_RDWR标志打开的,就可以用read()
系统调用从该文件中读取字节[3]。
所以ls
要用到read
系统调用。除此之外,任何shell命令都会创建进程,都会用到exec系统调用。
回过头来梳理一下我们对于这些概念可能产生的疑惑:
- 包括ls在内,一个程序是如何运行的?
- open系统调用打开当前目录文件,返回获得的文件描述符。那什么是文件描述符?
1 进程是如何运行的
每个运行中的程序被称为进程[1]
Unix将进程创建与加载一个新进程映象分离。这样的好处是有更多的余地对两种操作进行管理。当我们创建了一个进程之后,通常将子进程替换成新的进程映象。所以任何shell命令都会创建进程,都会用到exec系统调用。
例如:在shell命令行执行ps命令,实际上是shell进程调用fork复制一个新的子进程,在利用exec系统调用将新产生的子进程完全替换成ps进程。
用exec函数可以把当前进程替换为一个新进程,且新进程与原进程有相同的PID。exec名下是由多个关联函数组成的一个完整系列[4]
调用fork创建新进程后,父进程与子进程几乎一模一样[1,p398]。
fork是一个UNIX术语,当fork一个进程(一个运行中的程序)时,基本上是复制了它,并且fork后的两个进程都从当前执行点继续运行,并且每个进程都有自己的内存副本。
原进程是父进程,新进程是子进程。可以通过fork()
strace ls
명령을 사용하면 ls 명령[2]에서 사용되는 시스템 호출을 볼 수 있습니다. 출력의 일부는 다음과 같습니다.
#include<unistd.h> #include<stdio.h> #define LEN 10 int main() { pid_t id=getpid(); printf("Main pid: %d \n",id); int i; pid_t res=fork(); if(res==0) { for(i =0;i<len pid_t printf else main res the><strong>open 시스템 호출은 현재 파일을 엽니다. 디렉토리를 검색하고 얻은 파일 설명자를 반환합니다. O_RDONLY 플래그로 파일이 열리는 것을 볼 수 있습니다. </strong>파일이 O_RDONLY 또는 O_RDWR 플래그로 열려 있는 한 <code>read()</code> 시스템 호출[3]을 사용하여 파일에서 바이트를 읽을 수 있습니다. <p></p>그래서 <code>ls</code>는 <code>read</code> 시스템 호출을 사용해야 합니다. 또한 프로세스를 생성하는 모든 쉘 명령은 exec 시스템 호출을 사용합니다. <p></p>다시 돌아가 이러한 개념에 대해 우리가 가질 수 있는 의심을 정리해 보겠습니다. <p></p> <ol> <li>ls를 포함하여 프로그램은 어떻게 실행됩니까? </li> <li>open 시스템 호출은 현재 디렉터리에서 파일을 열고 얻은 파일 설명자를 반환합니다. 그렇다면 파일 설명자는 무엇입니까? </li> </ol>1 프로세스 실행 방법<p></p>실행 중인 각 프로그램을 프로세스라고 합니다. [1]<h2></h2>Unix는 프로세스 생성과 새 프로세스 이미지 로드를 분리합니다. 이것의 장점은 두 작업을 모두 관리할 수 있는 여지가 더 많다는 것입니다. 프로세스를 생성한 후 일반적으로 하위 프로세스를 새 프로세스 이미지로 바꿉니다. 따라서 모든 쉘 명령은 프로세스를 생성하고 exec 시스템 호출을 사용합니다. <p> 예를 들어 쉘 명령줄에서 ps 명령을 실행하면 쉘 프로세스는 실제로 새로운 하위 프로세스를 복사하기 위해 포크를 호출한 다음 exec 시스템 호출을 사용하여 새로 생성된 하위 프로세스를 ps 프로세스로 완전히 대체합니다. </p>🎜exec 기능을 사용하여 현재 프로세스를 새 프로세스로 교체하면 새 프로세스는 원래 프로세스와 동일한 PID를 갖습니다. exec라는 이름 아래에는 여러 관련 함수로 구성된 완전한 시리즈가 있습니다[4]🎜🎜fork를 호출하여 새 프로세스를 생성한 후 상위 프로세스와 하위 프로세스는 거의 동일합니다[1, p398]. 🎜🎜fork는 UNIX 용어로 프로세스(실행 중인 프로그램)가 Fork되면 기본적으로 복사되며, Fork 이후의 두 프로세스는 모두 현재 실행 지점부터 계속 실행되며 각 프로세스는 고유한 메모리 복사본을 갖습니다. 🎜🎜원래 프로세스는 상위 프로세스이고 새 프로세스는 하위 프로세스입니다. <code>fork()</code>의 반환 값으로 구별할 수 있습니다. 🎜🎜🎜부모 프로세스의 포크 호출은 새 자식 프로세스의 pid(프로세스 ID)를 반환하고, 자식 프로세스의 포크 호출은 0🎜🎜🎜을 반환합니다. 예: 🎜<pre class="brush:php;toolbar:false">#include<string.h> #include <errno.h> #include <stdio.h> #include <stdlib.h> #include<unistd.h> char command[256]; void main() { int rtn; /*子进程的返回数值*/ while(1) { /* 从终端读取要执行的命令 */ printf( ">" ); fgets( command, 256, stdin ); command[strlen(command)-1] = 0; if ( fork() == 0 ) {/* 子进程执行此命令 */ execlp( command, NULL ); /* 如果exec函数返回,表明没有正常执行命令,打印错误信息*/ perror( command ); exit( errno ); } else {/* 父进程, 等待子进程结束,并打印子进程的返回值 */ pid_t sonid=wait ( &rtn ); printf(" child pid: %d\n",sonid); printf( " child process return %d\n", rtn ); } } } /*output:错误命令、需要参数命令、正确命令 >aa aa: No such file or directory child pid: 11230 child process return 512 >echo A NULL argv[0] was passed through an exec system call. child pid: 11231 child process return 134 >ps child pid: 11247 child process return 139 */</unistd.h></stdlib.h></stdio.h></errno.h></string.h>🎜프로그램이 다른 프로세스를 시작하도록 하려면 프로그램을 계속 실행하려면 어떻게 해야 합니까? 이는 fork와 exec의 사용을 결합하는 것입니다. [6][1, p397]🎜🎜예([6]에서 수정됨): 🎜
#include<unistd.h> ssize_t read(int filedes, void *buf, size_t nbytes);</unistd.h>🎜Fork를 먼저 사용한 다음 하위 프로세스가 exec의 도움으로 프로그램 명령을 호출합니다. . 오류 명령, 매개변수가 필요한 명령, 매개변수가 필요하지 않은 명령에 대한 해당 출력을 제공합니다. 🎜🎜2 파일 디스크립터(fd) 🎜🎜모든 장치는 파일로 간주될 수 있습니다. 🎜
对内核而言,所有打开的文件都通过文件描述符引用[7]。文件描述符是非负整数,范围是[0,OPEN_MAX -1]。现在OPEN_MAX 一般为64
但是[7]又说对于FreeBSD 8.0,Linux 3.2.0 ,Mac OS X 10.6.8等, fd变化范围几乎无限,只受到存储器数量、int字长以及系统管理员所配置的软限制和硬限制的约束。。。why?
当open或者create一个新文件时,内核向进程返回一个文件描述符。
当读、写一个文件时,使用open或create返回的文件描述符标识该文件,将其作为参数传送给read / write
按照惯例,fd为0 / 1 / 2分别关联STDIN_FILENO / STDOUT_FILENO / STDERR_FILENO。这些常量也定义在unistd.h
.
3 系统调用包含在哪些头文件中呢?
包括exec、fork、read、write在内,许多系统调用包含在unistd.h
头文件中
POSIX,Portable Operating System Interface。是UNIX系统的一个设计标准,很多类UNIX系统也在支持兼容这个标准,如Linux。unistd.h
是POSIX标准定义的unix类系统定义符号常量的头文件,包含了许多UNIX系统服务的函数原型[5]。在该头文件,用于访问设备驱动程序的底层函数(系统调用)有这五个:open/close/read/write/ioctl
[1]。
4 文件I/O
[7]中提到大多数文件I/O用到的5个函数为:open/read/write/lseek/close
4.1 函数read
调用read函数从打开文件中读数据。
#include<unistd.h> ssize_t read(int filedes, void *buf, size_t nbytes);</unistd.h>
返回值:
成功,读出的字节数;
失败,-1;
遇到文件尾,0
有多种情况可使实际读到的字节数少于要求读的字节数:
- 读普通文件时,在读到要求字节数之前已经到达了文件尾端。
例如,若在到达文件尾端之前还有30个字节,而要求读100个字节,则read返回30,下一次再调用read时,它将回0。
当从终端设备读时,通常一次最多读一行
当从网络读时,网络中的缓冲机构可能造成返回值小于所要求读的字节数。
当从管道或FIFO读时,如若管道包含的字节少于所需的数量,那么read将只返回实际可用的字节数。
当从某些面向记录的设备(例如磁盘)读时,一次最多返回一个记录。
当某一信号造成中断,而已经读了部分数据量时。读操作从文件的当前偏移量出开始,在成功返回之前,该偏移量将增加实际独到的字节数
read的经典原型定义则是:
int read(int fd, char*buf, unsigned nbytes);
相关推荐:《Linux视频教程》
위 내용은 Linux에서 ls를 실행하면 어떤 시스템 호출이 발생합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Linux 유지 관리 모드 사용 타이밍 및 이유 : 1) 시스템이 시작될 때 2) 주요 시스템 업데이트 또는 업그레이드를 수행 할 때 3) 파일 시스템 유지 관리를 수행 할 때. 유지 보수 모드는 안전하고 제어 된 환경을 제공하여 운영 안전 및 효율성을 보장하고 사용자에게 미치는 영향을 줄이며 시스템 보안을 향상시킵니다.

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

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

MaintenanceModeInlinlinlinuxisspecialbootenvernmentforcriticalsystemmaintenancetasks.itallowsAdministratorStorformtaskSlikeresettingpasswords, Repairingfilesystems, Andrecoveringfrombootfailuresinaminimalenvernment.toentermaintingancemode, intermainteancemode

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

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
