단일 머신의 최대 동시 TCP 연결 수 분석 및 네트워크 프로그래밍에서의 식별 방법
네트워크 프로그래밍 TCP 애플리케이션에서는 서버가 고정된 포트를 미리 도청하고 클라이언트가 적극적으로 연결을 시작하며 3방향 핸드셰이크 후에 TCP 연결이 설정됩니다. 단일 시스템의 최대 동시 TCP 연결 수는 얼마입니까?
TCP 연결을 표시하는 방법 최대 연결 수를 결정하기 전에 먼저 시스템이 TCP 연결을 표시하는 방법을 살펴보겠습니다. 시스템은 TCP 연결을 고유하게 식별하기 위해 4-튜플({localip, localport, Remoteip, Remoteport})을 사용합니다.
클라이언트의 최대 TCP 연결 수입니다. 포트가 바인딩되어 있지 않으면 클라이언트가 TCP 연결 요청을 시작할 때마다 시스템은 일반적으로 유휴 로컬 포트(localport)를 선택하며 다른 TCP 연결과 공유할 수 없습니다. . TCP 포트의 데이터 유형은 unsignedshort이므로 Linux 서버 시스템에서 최대 로컬 포트 수는 65536개만 입니다. 포트 0은 특별한 의미를 가지며 사용할 수 없습니다. 따라서 사용 가능한 최대 포트 수는 65535개입니다. 모두 클라이언트로 사용될 때 최대 TCP 연결 수는 65535입니다. 이 연결은 다른 serverip에 연결될 수 있습니다.
서버의 최대 TCP 연결 수. 서버는 일반적으로 로컬 포트에 고정되어 있으며 클라이언트의 연결 요청을 기다리고 있습니다. 주소 재사용(유닉스의 SO_REUSEADDR 옵션)을 고려하지 않고, 서버 측에 IP가 여러 개 있더라도 로컬 도청 포트도 배타적이므로 4에는 RemoteIP(즉, clientip)와 RemotePort(클라이언트)만 있다. -서버 측 TCP 포트의 튜플)은 가변적이므로 최대 TCP 연결은 클라이언트 IP 수 × 클라이언트 포트 수입니다. IP 주소 분류 및 Linux 소프트웨어와 같은 요소에 관계없이 최대값입니다. TCP 연결 수는 대략 2의 32제곱(IP 수) ×2의 16제곱(포트 수)입니다. Linux tcp 연결 제한 즉, 단일 서버 측의 최대 tcp 연결 수는 약 2의 48승입니다.
단일 서버에 얼마나 많은 동시 TCP 연결이 있을 수 있는지
위에 제시된 것은 단일 머신에 대한 이론적 최대 연결 수입니다. 실제 환경에서는 특히 서버 측에서 머신 리소스, 운영 체제 등에 의해 제한되며 최대 동시 TCP 연결 수는 훨씬 더 많습니다. 이론적 상한선에 도달하지 못하게 됩니다. Unix/Linux에서 연결 수를 제한하는 주된 이유는 비디오 메모리와 허용되는 파일 설명자 수입니다(각 TCP 연결은 일정량의 비디오 메모리를 점유하고 각 소켓은 파일 설명자임). 또한 1024 미만의 포트. 일반적으로 예약된 포트입니다. 기본 2.6 커널 구성에서 테스트 후 각 소켓은 15~20k를 차지합니다. 소켓이 차지하는 메모리에 영향을 미치는 매개변수는 다음과 같습니다: rmem_maxwmem_maxtcp_rmemtcp_wmemtcp_memgrepskbuff/proc/slabinfo. 서버 측에서는 비디오 메모리를 줄이고 최대 파일 설명자 수 및 기타 매개변수를 수정하면 최대 동시 연결 수에는 문제가 없습니다. 단일 시스템의 TCP 연결이 100,000을 초과합니다. 미국 UrbanAirship 회사 프로덕션 환경에서 동시 사용자가 500,000명을 달성했습니다. 실제 애플리케이션, 대규모 네트워크 애플리케이션의 경우 C10K 문제도 고려해야 합니다.
파일 처리 제한과 포트 제한의 두 가지 상식을 설명해 보겠습니다
상식 1: 파일 핸들 제한
Linux에서 네트워크 서버 프로그램을 작성하는 동료는 각 TCP 연결이 파일 설명자를 차지한다는 것을 알아야 합니다. 이 파일 설명자를 모두 사용하면 새 연결이 설정될 때 "Socket/File:Can 'topensemanyfiles'."라는 오류가 반환됩니다.
이때, 열 수 있는 최대 파일 수에 대한 운영 체제의 제한을 이해해야 합니다.
프로세스 제한
Melaksanakan ulimit-n output 1024, menunjukkan bahawa proses hanya boleh membuka sehingga 1024 fail, jadi jika anda menggunakan konfigurasi lalai ini, anda boleh menjalankan beribu-ribu sambungan TCP secara serentak.
Perubahan sementara: ulimit-n1000000, dan perubahan sementara ini hanya sah untuk persekitaran penggunaan semasa pengguna yang sedang log masuk, dan akan menjadi tidak sah selepas sistem dimulakan semula atau pengguna log keluar.
Perubahan yang menjadi tidak sah selepas dimulakan semula (tetapi saya mengujinya di bawah CentOS6.5 dan mendapati tiada ketidaksahihan selepas dimulakan semula): Edit fail /etc/security/limits.conf, dan kandungan yang diubah ialah
*softnofile1000000
*hardnofile1000000
Perubahan kekal: Edit /etc/rc.local dan tambah kandungan berikut selepasnya
ulimit-SHn1000000
Sekatan global
Melaksanakan output cat/proc/sys/fs/file-nr 93440592026, iaitu: 1. Bilangan pemegang fail yang diperuntukkan, 2. Bilangan pemegang fail yang diperuntukkan tetapi tidak digunakan, 3. Bilangan maksimum pemegang fail. Tetapi dalam versi kernel2.6, nilai item kedua sentiasa 0. Ini bukan ralat Ini sebenarnya bermakna semua deskriptor fail yang diperuntukkan telah digunakan tanpa sebarang pembaziran.
Kita boleh menukar nilai ini kepada nilai yang lebih besar dan menukar fail /etc/sysctl.conf dengan keistimewaan root:
fs.file-maks=1000000
net.ipv4.ip_conntrack_max=1000000
filter.ip_conntrack_max=1000000
Akal budi 2: Adakah julat nombor port terhad?
Sepanduk bahagian bawah sistem pengendalian di bawah 1024 dikhaskan oleh sistem dan 1024-65535 digunakan oleh pengguna. Oleh kerana setiap sambungan TCP menduduki nombor port, kami boleh mempunyai sehingga lebih daripada 60,000 sambungan serentak. Rasanya ramai pelajar yang salah idea ni kan? (Saya selalu rasa begini dulu)
Mari kita analisanya
Cara untuk menandakan sambungan TCP: Sistem menggunakan 4-tuple untuk menandakan sambungan TCP secara unik: {localip, localport, remoteip, remoteport}. Baiklah, mari kita ambil penjelasan penerimaan dalam Bab 4 "Pengaturcaraan Rangkaian UNIX: Jilid 1" untuk melihat perkara konseptual Parameter kedua cliaddr mewakili alamat IP dan nombor port pelanggan. Sebagai pelayan, kami sebenarnya hanya menggunakan port ini semasa bind, yang menunjukkan bahawa nombor port 65535 bukanlah had pada jumlah concurrency.
Bilangan maksimum sambungan TCP ke pelayan: Pelayan biasanya ditetapkan pada port tempatan dan mendengar, menunggu permintaan sambungan pelanggan. Tanpa mengambil kira penggunaan semula alamat (pilihan SO_REUSEADDR Unix), walaupun terdapat berbilang IP pada bahagian pelayan, port penyadapan tempatan juga eksklusif Oleh itu, hanya terdapat remoteip (iaitu, clientip) dan remoteport (klien) dalam 4 -tuple bagi sambungan tcp bahagian pelayan) adalah berubah-ubah, jadi sambungan tcp maksimum ialah bilangan ip klien × bilangan port klien Untuk IPV4, tanpa mengira insentif seperti klasifikasi alamat IPHad nombor sambungan tcp Linux. , bilangan maksimum sambungan tcp ialah kira-kira 2 kali 32 kali Kuasa (bilangan IP) × 2 dinaikkan kepada kuasa ke-16 (bilangan port), iaitu bilangan maksimum sambungan TCP pada mesin tunggal di bahagian pelayan adalah kira-kira 2 dinaikkan kepada kuasa ke-48.
위 내용은 단일 머신의 최대 동시 TCP 연결 수 분석 및 네트워크 프로그래밍에서의 식별 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

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

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

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

Linux 관리자의 평균 연봉은 미국에서 $ 75,000 ~ $ 95,000, 유럽에서는 40,000 유로에서 60,000 유로입니다. 급여를 늘리려면 다음과 같이 할 수 있습니다. 1. 클라우드 컴퓨팅 및 컨테이너 기술과 같은 새로운 기술을 지속적으로 배울 수 있습니다. 2. 프로젝트 경험을 축적하고 포트폴리오를 설정합니다. 3. 전문 네트워크를 설정하고 네트워크를 확장하십시오.

Linux 시스템 관리자의 주요 작업에는 시스템 모니터링 및 성능 조정, 사용자 관리, 소프트웨어 패키지 관리, 보안 관리 및 백업, 문제 해결 및 해상도, 성능 최적화 및 모범 사례가 포함됩니다. 1. 상단, HTOP 및 기타 도구를 사용하여 시스템 성능을 모니터링하고 조정하십시오. 2. 사용자 ADD 명령 및 기타 명령을 통해 사용자 계정 및 권한을 관리합니다. 3. APT 및 YUM을 사용하여 소프트웨어 패키지를 관리하여 시스템 업데이트 및 보안을 보장합니다. 4. 방화벽을 구성하고 로그를 모니터링하고 데이터 백업을 수행하여 시스템 보안을 보장합니다. 5. 로그 분석 및 공구 사용을 통해 문제를 해결하고 해결합니다. 6. 커널 매개 변수 및 응용 프로그램 구성을 최적화하고 모범 사례를 따라 시스템 성능 및 안정성을 향상시킵니다.

가상화 지원에서 Linux와 Windows의 주요 차이점은 다음과 같습니다. 1) Linux는 KVM과 Xen을 제공하며, 높은 커스터마이징 환경에 적합한 뛰어난 성능과 유연성을 제공합니다. 2) Windows는 친숙한 인터페이스를 통해 Hyper-V를 통한 가상화를 지원하며 Microsoft 소프트웨어에 의존하는 기업에 적합한 Microsoft Ecosystem과 밀접하게 통합됩니다.

Linux의 주요 용도에는 다음이 포함됩니다. 1. 서버 운영 체제, 2. 임베디드 시스템, 3. 데스크탑 운영 체제, 4. 개발 및 테스트 환경. Linux는이 분야에서 뛰어나 안정성, 보안 및 효율적인 개발 도구를 제공합니다.

Linux를 배우는 것은 어렵지 않습니다. 1.Linux는 UNIX를 기반으로 한 오픈 소스 운영 체제이며 서버, 임베디드 시스템 및 개인용 컴퓨터에서 널리 사용됩니다. 2. 파일 시스템 및 권한 관리 이해가 핵심입니다. 파일 시스템은 계층 적이며 권한에는 읽기, 쓰기 및 실행이 포함됩니다. 3. APT 및 DNF와 같은 패키지 관리 시스템은 소프트웨어 관리를 편리하게 만듭니다. 4. 프로세스 관리는 PS 및 최고 명령을 통해 구현됩니다. 5. MKDIR, CD, Touch 및 Nano와 같은 기본 명령에서 학습을 시작한 다음 쉘 스크립트 및 텍스트 처리와 같은 고급 사용법을 사용해보십시오. 6. 권한 문제와 같은 일반적인 오류는 Sudo 및 CHMod를 통해 해결할 수 있습니다. 7. 성능 최적화 제안에는 HTOP을 사용하여 리소스 모니터링, 불필요한 파일 청소 및 SY 사용이 포함됩니다.

수년 동안 Linux 소프트웨어 배포는 Deb 및 RPM과 같은 기본 형식에 의존하여 각 배포의 생태계에 깊이 뿌리 내 렸습니다. 그러나 Flatpak과 Snap이 등장하여 응용 프로그램 포장에 대한 보편적 인 접근 방식을 약속했습니다. 이 기사는 시험합니다

이 안내서는 시스템 관리자 및 개발자에게 중요한 작업 인 Linux의 텍스트 파일을 비교하기위한 다양한 방법을 살펴 봅니다. 우리는 명령 줄 도구와 시각적 차이 도구를 다루며 강점과 적절한 사용 사례를 강조합니다. 가정하자
