찾다
시스템 튜토리얼리눅스운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요

운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요

Feb 13, 2024 pm 09:15 PM
linux리눅스 튜토리얼리눅스 시스템리눅스 명령쉘 스크립트네트워크 카드 드라이버임베디드리눅스리눅스 시작하기리눅스 학습

고급 프로그래머든 초보자든, Windows 사용자든 macOS 사용자든, 컴퓨터 운영 체제에 대해 어느 정도 이해하고 있다면 Linux라는 이름이 분명 익숙할 것입니다. 그러나 Linux 운영 체제의 표면만 긁을 수도 있습니다. 실제로 각각 고유한 기능과 응용 프로그램 시나리오를 갖춘 Linux 배포판이 많이 있습니다. 아래에서는 몇 가지 일반적인 Linux 배포판을 소개하고 운영 체제에 대한 전통적인 이해를 뒤집는 데 도움을 줄 것입니다.

여러 장치가 네트워크를 통해 서로 통신할 수 있도록 하고, 네트워크 상호 연결 시 다양한 장치의 호환성 문제를 해결하기 위해 국제 표준화 기구에서는 개방형 시스템 상호 연결 참조 모델을 공식화했으며, 이는 OSI 네트워크 모델이기도 합니다. 이 모델은 주로 애플리케이션 계층, 프리젠테이션 계층, 세션 계층, 전송 계층, 네트워크 계층, 데이터 링크 계층 및 물리 계층의 7개 계층으로 구성됩니다.

운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요
각 레이어는 다음과 같이 다양한 기능을 담당합니다.

•애플리케이션에 통합 인터페이스를 제공하는 애플리케이션 계층

•프레젠테이션 레이어, 데이터를 다른 시스템과 호환되는 형식으로 변환하는 일을 담당합니다.

•프레젠테이션 계층 엔터티 간의 통신 세션 설정, 관리 및 종료를 담당하는 세션 계층

•종단 간 데이터 전송을 담당하는 전송 계층

•데이터 라우팅, 전달 및 조각화를 담당하는 네트워크 계층;

• 데이터 프레임, 오류 감지 및 MAC 주소 지정을 담당하는 데이터 링크 계층;

•물리적 네트워크에서 데이터 프레임 전송을 담당하는 물리적 계층

OSI 모델은 너무 복잡하기 때문에 제안된 내용은 개념적, 이론적 계층화일 뿐이며 구체적인 구현 계획은 제공되지 않습니다. 실제로 더 일반적이고 실용적인 4계층 모델은 TCP/IP 네트워크 모델입니다. Linux 시스템은 이 네트워크 모델에 따라 네트워크 프로토콜 스택을 구현합니다.

TCP/IP 네트워크 모델에는 애플리케이션 계층, 전송 계층, 네트워크 계층 및 네트워크 인터페이스 계층이라는 4개의 계층이 있습니다.

•HTTP, DNS, FTP 등과 같은 일련의 애플리케이션을 사용자에게 제공하는 역할을 담당하는 애플리케이션 계층;

•TCP, UDP 등 종단 간 통신을 담당하는 전송 계층;

•IP, ICMP 등과 같은 네트워크 패킷의 캡슐화, 단편화, 라우팅 및 전달을 담당하는 네트워크 계층;

•네트워크 패킷 프레이밍, MAC 주소 지정, 오류 감지, 네트워크 카드를 통한 네트워크 프레임 전송 등 물리적 네트워크에서 네트워크 패킷 전송을 담당하는 네트워크 인터페이스 계층

OSI 네트워크 모델과 비교할 때 TCP/IP 네트워크 모델은 훨씬 간단하고 기억하기 쉽습니다.

그러나 우리가 자주 이야기하는 7계층 및 4계층 로드 밸런싱은 OSI 네트워크 모델로 설명됩니다. 계층 7은 애플리케이션 계층에 해당하고 계층 4는 전송 계층에 해당합니다. 운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요

Linux 네트워크 프로토콜 스택

우리 몸은 애플리케이션 레이어의 데이터에, 옷의 맨 아래 레이어는 전송 레이어의 TCP 헤더에, 코트는 네트워크 레이어의 IP 헤더에, 모자와 신발은 프레임 헤더와 프레임에 비교할 수 있습니다. 네트워크 인터페이스 계층의 각각.

겨울철 집에서 놀고 싶을 때는 당연히 기본 옷을 먼저 입고, 따뜻한 재킷을 입고, 마지막으로 모자와 신발을 신고 나가는 과정이 바로 이 과정입니다. 우리가 TCP 프로토콜을 사용하여 통신하는 방법과 같이 네트워크 패킷이 전송되면 애플리케이션 계층 데이터는 네트워크 프로토콜 스택에 따라 계층별로 캡슐화되고 처리됩니다.

아래 그림에서 각 레이어별 애플리케이션 레이어 데이터의 캡슐화 형식을 확인할 수 있습니다.

그중에는: 운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요
•전송 계층은 애플리케이션 데이터 앞에 TCP 헤더를 추가합니다.

•네트워크 계층은 TCP 패킷 앞에 IP 헤더를 추가합니다.

•네트워크 인터페이스 계층은 IP 데이터 패킷 전후에 프레임 헤더와 프레임 트레일러를 추가합니다.

이러한 추가, 헤더 및 꼬리는 모두 고유한 기능을 가지며 특정 프로토콜 형식에 따라 채워집니다. 각 계층은 고유한 프로토콜 헤더를 추가하여 자연스럽게 네트워크 패킷의 크기를 늘리지만 물리적 링크는 다음과 같은 데이터 패킷을 전송할 수 없습니다. 따라서 이더넷에서 최대 전송 단위(MTU)는 1500바이트이며, 이는 단일 전송에 대한 최대 IP 패킷 크기도 지정합니다.

네트워크 패킷이 MTU 크기를 초과하면 조각난 IP 패킷이 MTU 크기를 초과하지 않도록 네트워크 계층에서 조각화됩니다. MTU가 더 작으면 더 많은 패킷이 필요하며 네트워크 처리량 용량이 늘어납니다. 반대로 MTU가 클수록 필요한 패킷이 작을수록 네트워크 처리량이 좋아집니다.

TCP/IP 네트워크 모델과 네트워크 패킷의 캡슐화 원리를 알고 나면 Linux 네트워크 프로토콜 스택이 실제로 TCP/IP의 4계층 구조와 유사하다는 것을 짐작했을 것입니다.

운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요
위 그림의 네트워크 프로토콜 스택에서 다음을 확인할 수 있습니다.

•애플리케이션은 시스템 호출을 통해 소켓 레이어와 상호 작용해야 합니다.

•소켓 계층 아래에는 전송 계층, 네트워크 계층 및 네트워크 인터페이스 계층이 있습니다.

•하위 레이어는 네트워크 카드 드라이버와 하드웨어 네트워크 카드 장치입니다.

네트워크 패킷을 수신하는 Linux 프로세스

네트워크 카드는 네트워크 패킷 수신 및 전송을 담당하는 컴퓨터의 하드웨어입니다. 네트워크 카드가 네트워크 패킷을 수신하면 DMA 기술을 통해 네트워크 패킷을 링 버퍼에 넣습니다. . 커널 메모리의 네트워크 카드 드라이버에 있는 버퍼입니다.

네트워크 패킷을 받은 후 운영 체제에 네트워크 패킷이 도착했음을 어떻게 알려야 할까요?

가장 간단한 방법은 인터럽트를 트리거하는 것입니다. 즉, 네트워크 카드가 네트워크 패킷을 수신할 때마다 인터럽트를 트리거하여 운영 체제에 알립니다.

그러나 고성능 네트워크 시나리오에서는 네트워크 패킷 수가 매우 많아지고 많은 수의 인터럽트가 트리거된다는 점을 알아야 합니다. 현재 수행 중인 작업 및 진행 이러한 네트워크 패킷을 처리하면 처리가 완료된 후에만 다른 작업으로 돌아갑니다. 인터럽트를 너무 자주 트리거하면 CPU에서 끝없는 처리 인터럽트가 발생하여 다른 작업이 앞으로 나아갈 수 없게 될 수 있습니다. 시스템의 전반적인 효율성에 영향을 미칩니다.

그래서 잦은 인터럽트로 인한 성능 오버헤드를 해결하기 위해 Linux 커널은 버전 2.6에서 NAPI 메커니즘을 도입했습니다. 이는 네트워크 패킷을 수신하는 혼합된 "인터럽트 및 폴링" 방법입니다. 그 핵심 개념은 인터럽트 없이 읽는 것입니다. 데이터를 얻으려면 먼저 인터럽트를 사용하여 데이터 수신을 위해 서비스 프로그램을 깨운 다음 ​​폴링 방법을 사용하여 데이터를 폴링합니다.

예를 들어 네트워크 패킷이 도착하면 네트워크 카드가 하드웨어 인터럽트를 시작한 다음 네트워크 카드 하드웨어 인터럽트 처리 기능이 실행됩니다. 인터럽트 처리 기능이 처리된 후에는 "일시적으로 인터럽트를 마스크"해야 하며, 그런 다음 "소프트 인터럽트"를 깨워 더 이상 데이터가 없을 때까지 데이터를 폴링하고 처리합니다. 인터럽트는 새 데이터가 수신될 때만 복원되므로 한 번의 중단으로 여러 네트워크 패킷이 처리되므로 네트워크 카드 중단으로 인한 성능 오버헤드가 줄어듭니다. .

그럼 소프트 인터럽트는 네트워크 패킷을 어떻게 처리하나요? 링 버퍼의 데이터를 커널 구조체 sk_buff 버퍼로 복사하여 계층별 처리를 위한 네트워크 패킷으로 네트워크 프로토콜 스택에 전달될 수 있습니다.

먼저, 이 계층에서는 패킷의 합법성을 검사합니다. 불법이면 네트워크 패킷의 상위 계층 프로토콜 유형을 폐기합니다. 그런 다음 프레임 헤더와 프레임 트레일러를 제거한 다음 네트워크 계층에 넘겨줍니다.

네트워크 계층에서는 IP 패킷을 꺼내어 처리를 위해 상위 계층으로 넘겨줄지, 전달할지 등 네트워크 패킷의 다음 방향을 결정합니다. 네트워크 패킷이 로컬 시스템으로 전송되는 것이 확인되면 IP 헤더를 확인하여 상위 계층 프로토콜의 유형이 TCP인지 UDP인지 확인한 다음 IP 헤더를 제거한 다음 로컬 시스템에 전달합니다. 전송 계층.

전송 계층은 TCP 헤더 또는 UDP 헤더를 꺼내고 4개의 튜플 "원본 IP, 소스 포트, 대상 IP, 대상 포트"를 식별자로 사용하여 해당 소켓을 찾은 다음 데이터를 소켓의 수신 버퍼에 복사합니다.

마지막으로 애플리케이션 계층 프로그램은 소켓 인터페이스를 호출하여 커널의 소켓 수신 버퍼에서 애플리케이션 계층으로 새로 도착한 데이터를 읽습니다.

이 시점에서 네트워크 패킷을 수신하는 과정은 아래 그림의 왼쪽 부분에서도 볼 수 있습니다. 오른쪽 부분은 바로 그 반대이며, 네트워크 패킷을 보내는 과정입니다. .

운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요

Linux의 네트워크 패킷 전송 프로세스

위 그림의 절반에 표시된 것처럼 네트워크 패킷을 보내는 과정은 받는 과정과 정반대입니다.

먼저 애플리케이션은 데이터 패킷을 전송하기 위해 소켓의 인터페이스를 호출합니다. 이는 시스템 호출이므로 커널 상태의 소켓 계층으로 애플리케이션 계층 데이터가 복사됩니다. 소켓 전송 버퍼.

다음으로, 네트워크 프로토콜 스택은 소켓 전송 버퍼에서 데이터 패킷을 꺼내 TCP/IP 프로토콜 스택에 따라 위에서 아래로 계층별로 처리합니다.

TCP 전송 프로토콜을 사용하여 데이터를 보내는 경우 TCP 헤더가 전송 계층에 추가된 다음 네트워크 계층으로 전달됩니다. 네트워크 계층은 데이터 패킷에 IP 패킷을 추가한 후 다음 홉을 확인합니다. 라우팅 테이블을 쿼리하여 IP를 사용하고 조각화를 위해 MTU 크기를 따릅니다.

조각난 네트워크 패킷은 네트워크 인터페이스 계층으로 전송되며, 여기서 다음 홉의 MAC 주소는 ARP 프로토콜을 통해 획득됩니다. 그런 다음 프레임 헤더와 프레임 트레일러가 추가되어 패킷 전송 대기열에 배치됩니다.

이러한 준비가 완료되면 네트워크 카드 드라이버에 전송해야 할 새 네트워크 패킷이 있음을 알리기 위해 소프트 인터럽트가 트리거됩니다. 마지막으로 드라이버는 DMA를 통해 패킷 전송 대기열에서 네트워크 패킷을 읽고 이를 하드웨어 네트워크 카드의 대기열을 확인한 다음 물리적 네트워크 카드에서 이를 보냅니다.

요약

컴퓨터는 일반적으로 통신 네트워크 카드, 스위치, 라우터 등과 같은 네트워크 장치로 서로 연결됩니다. 네트워크 장치의 이질성으로 인해 국제 표준화 기구에서는 7계층 OSI 네트워크 모델을 정의했지만 이 모델은 상대적으로 복잡합니다. . 실제 응용 프로그램에서는 사용되지 않지만 보다 단순화된 TCP/IP 모델이 이 모델에 따라 구현됩니다.

TCP/IP 모델은 주로 애플리케이션 계층, 전송 계층, 네트워크 계층, 네트워크 인터페이스 계층의 4개 계층으로 구분됩니다. 각 계층은 서로 다른 책임을 담당합니다. 이는 Linux 네트워크 프로토콜 스택의 주요 구성 요소이기도 합니다.

응용 프로그램이 소켓 인터페이스를 통해 데이터 패킷을 보낼 때 데이터 패킷은 네트워크 카드 대기열로 전송되기 전에 네트워크 프로토콜 스택에 의해 위에서 아래로 계층별로 처리된 다음 네트워크 카드가 네트워크 패킷을 보냅니다. 밖으로.

네트워크 패킷을 수신할 때 최종적으로 애플리케이션에 전송되기 전에 네트워크 프로토콜 스택에 의해 아래에서 위로 계층별로 처리되어야 합니다.

간단히 말하면, Linux는 무료 오픈 소스 운영 체제로서 기술 분야에 등장하여 널리 사용되고 있습니다. 숙련된 프로그래머이든 일반 사용자이든 자신에게 맞는 Linux 배포판을 선택하면 예상치 못한 많은 이점을 얻을 수 있습니다. 이 글이 리눅스 배포판을 더 잘 이해하는 데 도움이 될 것이라고 믿으며, 여러분의 컴퓨터에서 리눅스의 매력을 경험해보시길 바랍니다.

위 내용은 운영 체제에 대한 이해를 뒤집으십시오 - Linux 배포판 개요의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 良许Linux教程网에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
인터넷은 Linux에서 실행됩니까?인터넷은 Linux에서 실행됩니까?Apr 14, 2025 am 12:03 AM

인터넷은 단일 운영 체제에 의존하지 않지만 Linux는 이에 중요한 역할을합니다. Linux는 서버 및 네트워크 장치에서 널리 사용되며 안정성, 보안 및 확장 성으로 인기가 있습니다.

Linux 운영이란 무엇입니까?Linux 운영이란 무엇입니까?Apr 13, 2025 am 12:20 AM

Linux 운영 체제의 핵심은 명령 줄 인터페이스이며 명령 줄을 통해 다양한 작업을 수행 할 수 있습니다. 1. 파일 및 디렉토리 작업 LS, CD, MKDIR, RM 및 기타 명령을 사용하여 파일 및 디렉토리를 관리합니다. 2. 사용자 및 권한 관리는 UserAdd, Passwd, CHMOD 및 기타 명령을 통해 시스템 보안 및 리소스 할당을 보장합니다. 3. 프로세스 관리는 PS, Kill 및 기타 명령을 사용하여 시스템 프로세스를 모니터링하고 제어합니다. 4. 네트워크 운영에는 Ping, Ifconfig, SSH 및 기타 명령이 포함되어 있으며 네트워크 연결을 구성하고 관리합니다. 5. 시스템 모니터링 및 유지 관리 Top, DF, Du와 같은 명령을 사용하여 시스템의 작동 상태 및 리소스 사용을 이해합니다.

Linux 별칭을 사용하여 사용자 정의 명령 바로 가기로 생산성을 높이십시오Linux 별칭을 사용하여 사용자 정의 명령 바로 가기로 생산성을 높이십시오Apr 12, 2025 am 11:43 AM

소개 Linux는 유연성과 효율성으로 인해 개발자, 시스템 관리자 및 전원 사용자가 선호하는 강력한 운영 체제입니다. 그러나 길고 복잡한 명령을 자주 사용하는 것은 지루하고 응급실이 될 수 있습니다.

Linux는 실제로 좋은 것은 무엇입니까?Linux는 실제로 좋은 것은 무엇입니까?Apr 12, 2025 am 12:20 AM

Linux는 서버, 개발 환경 및 임베디드 시스템에 적합합니다. 1. 서버 운영 체제로서 Linux는 안정적이고 효율적이며 종종 고 대전성 애플리케이션을 배포하는 데 사용됩니다. 2. 개발 환경으로서 Linux는 효율적인 명령 줄 도구 및 패키지 관리 시스템을 제공하여 개발 효율성을 향상시킵니다. 3. 임베디드 시스템에서 Linux는 가볍고 사용자 정의 가능하며 자원이 제한된 환경에 적합합니다.

Linux에서 윤리적 해킹을 마스터하기위한 필수 도구 및 프레임 워크Linux에서 윤리적 해킹을 마스터하기위한 필수 도구 및 프레임 워크Apr 11, 2025 am 09:11 AM

소개 : Linux 기반의 윤리적 해킹으로 디지털 프론티어 보안 점점 더 상호 연결된 세상에서 사이버 보안이 가장 중요합니다. 윤리적 해킹 및 침투 테스트는 취약점을 적극적으로 식별하고 완화하는 데 필수적입니다.

Linux 기본 사항을 배우는 방법?Linux 기본 사항을 배우는 방법?Apr 10, 2025 am 09:32 AM

기본 Linux 학습 방법은 다음과 같습니다. 1. 파일 시스템 및 명령 줄 인터페이스 이해, 2. LS, CD, MKDIR, 3. 파일 생성 및 편집과 같은 파일 작업 배우기, 4. 파이프 라인 및 GREP 명령과 같은 고급 사용법, 5. 연습 및 탐색을 통해 지속적으로 기술을 향상시킵니다.

Linux를 가장 많이 사용하는 것은 무엇입니까?Linux를 가장 많이 사용하는 것은 무엇입니까?Apr 09, 2025 am 12:02 AM

Linux는 서버, 임베디드 시스템 및 데스크탑 환경에서 널리 사용됩니다. 1) 서버 필드에서 Linux는 안정성 및 보안으로 인해 웹 사이트, 데이터베이스 및 응용 프로그램을 호스팅하기에 이상적인 선택이되었습니다. 2) 임베디드 시스템에서 Linux는 높은 사용자 정의 및 효율성으로 인기가 있습니다. 3) 데스크탑 환경에서 Linux는 다양한 사용자의 요구를 충족시키기 위해 다양한 데스크탑 환경을 제공합니다.

리눅스의 단점은 무엇입니까?리눅스의 단점은 무엇입니까?Apr 08, 2025 am 12:01 AM

Linux의 단점에는 사용자 경험, 소프트웨어 호환성, 하드웨어 지원 및 학습 곡선이 포함됩니다. 1. 사용자 경험은 Windows 또는 MacOS만큼 친절하지 않으며 명령 줄 인터페이스에 의존합니다. 2. 소프트웨어 호환성은 다른 시스템만큼 좋지 않으며 많은 상용 소프트웨어의 기본 버전이 부족합니다. 3. 하드웨어 지원은 Windows만큼 포괄적이지 않으며 드라이버를 수동으로 컴파일 할 수 있습니다. 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경