백엔드 개발 PHP 튜토리얼 소켓 fd의 청취 대기열: 3 오류 분석

소켓 fd의 청취 대기열: 3 오류 분석

Jul 29, 2016 am 09:15 AM
listen socket uwsgi

요즘 Django 애플리케이션은 기본적으로 uwsgi를 사용하여 배포됩니다. listen queue of socket "127.0.0.1:9001" (fd: 3) 이 두 가지 오류를 해결하는 과정은 아래와 같습니다.

오류 시나리오

  • centos 6.6
  • uwsgi2.0
  • nginx1.6

오류 로그 가로채기

<code><span>Tue</span><span>Jun</span><span>2</span><span>17</span>:<span>33</span>:<span>27</span><span>2015</span> - *** <span>uWSGI</span><span>listen</span><span>queue</span><span>of</span><span>socket</span><span>"127.0.0.1:9001"</span> (<span>fd</span>: <span>3</span>) <span>full</span><span>!</span><span>!</span><span>!</span> (<span>101</span>/<span>100</span>) ***
<span>Tue</span><span>Jun</span><span>2</span><span>17</span>:<span>33</span>:<span>28</span><span>2015</span> - *** <span>uWSGI</span><span>listen</span><span>queue</span><span>of</span><span>socket</span><span>"127.0.0.1:9001"</span> (<span>fd</span>: <span>3</span>) <span>full</span><span>!</span><span>!</span><span>!</span> (<span>101</span>/<span>100</span>) ***</code>
로그인 후 복사
  • 처음은 차이나유니콤 전산실의 방화벽이 잘못 설정되어 서버 출력이 제한되었기 때문입니다. 즉, 외부 패킷 전송에는 문제가 없었습니다. 그런데 서버가 외부로 패킷을 돌려보내는데 속도가 매우 느리고 거의 사용이 불가능했습니다. 이때 uwsgi 로그에

  • 많은 오류가 나타났습니다. 동시성이 급격히 증가하고 활성 링크 수가 6000개 정도에 머물렀습니다. 이 오류는 대량으로 발생합니다.

분석

이 오류를 토대로 관련 정보를 확인했습니다. 시스템 수준 매개변수에 문제가 있는 것으로 보입니다. 자세한 내용은 Linux Man 페이지를 참조하세요. Listen(2).

lzz 참고: 각 수신 소켓에 대해 수락이 발생하기 전에 대기열 처리를 기다리는 소켓의 길이는 기본적으로 128입니다. Linux(적어도 centos6.6에서는) 컴파일된 uwsgi의 기본값은 100입니다. 이는 시스템 매개변수를 조정하기 전의 가장 높은 값이 128임을 의미합니다.

그럼 대기열의 길이를 더 길게 조정하려면 어떻게 해야 할까요?
* 시스템 매개변수를 효과적으로 조정하려면 시스템 매개변수를 조정해야 합니다.
* uwsgi 구성을 조정한 후 애플리케이션을 다시 시작해야 합니다

작업

시스템 매개변수 수정

구성 파일은 여기에서 직접 수정되며 다시 시작해도 여전히 유효합니다. .

/etc/sysctl.conf 파일을 수정하고 이러한 매개변수 값을 추가하거나 수정합니다. ​​

<code><span>#对于一个经常处理新连接的高负载 web服务环境来说,默认的 128 太小了</span>
net<span>.core</span><span>.somaxconn</span> = <span>262144</span>
?<span>#表示SYN<strong>队列</strong>的长度,默认为1024,加大<strong>队列</strong>长度为8192,可以容纳更多等待连接的网络连接数</span>
net<span>.ipv</span>4<span>.tcp</span>_max_syn_backlog = <span>8192</span><span>#网卡设备将请求放入<strong>队列</strong>的长度</span>
net<span>.core</span><span>.netdev</span>_max_backlog = <span>65536</span></code>
로그인 후 복사

수정이 ​​완료된 후 sysctl -p매개변수를 다시 로드하세요

.

uwsgi 구성인지

조정하거나 명령줄에 옵션을 추가합니다. 예를 들어 다음 구성

<code><span>listen</span>=<span>1024</span></code>
로그인 후 복사

을 .ini 파일에 추가한 후 다시 시작합니다. 응용 프로그램을 실행하고 구성을 다시 로드합니다.

요약

구성을 수정하여 이런 오류가 거의 발생하지 않았으며 시스템 처리량과 동시성이 크게 향상되었습니다. 따라서 전반적인 서비스 품질을 향상시키기 위해서는 시스템 특성과 튜닝이 매우 중요합니다.

참조

  • somaxconn - 성가신 제한.
  • listen(2) - Linux 매뉴얼 페이지

저작권 설명 : 이 기사는 orangleliu(http://blog.csdn.net/orangleliu/)의 원본 기사입니다. 기사를 재인쇄할 때 명시해 주시기 바랍니다.

위에서 관련 측면을 포함하여 소켓 fd:3 오류 분석의 청취 대기열을 소개했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

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

핫 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를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PHP+Socket 시리즈의 IO 다중화 및 웹서버 구현 PHP+Socket 시리즈의 IO 다중화 및 웹서버 구현 Feb 02, 2023 pm 01:43 PM

이 기사에서는 주로 IO 멀티플렉싱을 소개하는 php+socket과 php+socket이 웹 서버를 구현하는 방법에 대한 관련 지식을 제공합니다. 관심 있는 친구들은 아래를 살펴보시면 모두에게 도움이 되길 바랍니다.

Python의 소켓 및 소켓 서버를 사용하는 방법 Python의 소켓 및 소켓 서버를 사용하는 방법 May 28, 2023 pm 08:10 PM

1. TCP 프로토콜 기반 소켓 프로그래밍 1. 소켓 워크플로는 서버 측에서 시작됩니다. 서버는 먼저 소켓을 초기화한 다음 포트에 바인드하고 포트를 수신하며 차단을 위해 승인을 호출하고 클라이언트가 연결될 때까지 기다립니다. 이때 클라이언트가 Socket을 초기화한 후 서버에 연결(connect)하면, 연결에 성공하면 클라이언트와 서버 간의 연결이 성립된다. 클라이언트는 데이터 요청을 보내고, 서버는 요청을 받아 요청을 처리한 후 클라이언트에 응답 데이터를 보내고, 클라이언트는 데이터를 읽고 마지막으로 연결을 종료합니다. 이를 구현하려면 다음 Python 코드를 사용하세요. : importso

Flask 애플리케이션 배포를 위한 Gunicorn과 uWSGI의 성능 비교 Flask 애플리케이션 배포를 위한 Gunicorn과 uWSGI의 성능 비교 Jan 17, 2024 am 08:52 AM

Flask 애플리케이션 배포: Gunicorn과 suWSGI 비교 소개: 경량 Python 웹 프레임워크인 Flask는 많은 개발자들에게 사랑을 받고 있습니다. Flask 애플리케이션을 프로덕션 환경에 배포할 때 적절한 SGI(서버 게이트웨이 인터페이스)를 선택하는 것은 중요한 결정입니다. Gunicorn과 uWSGI는 두 가지 일반적인 SGI 서버입니다. 이 기사에서는 이에 대해 자세히 설명합니다.

Spring Boot+Vue를 사용하여 소켓 알림 푸시를 구현하는 방법 Spring Boot+Vue를 사용하여 소켓 알림 푸시를 구현하는 방법 May 27, 2023 am 08:47 AM

SpringBoot 측의 첫 번째 단계는 종속성을 도입하는 것입니다. 먼저 WebSocket에 필요한 종속성과 com.alibabafastjson1.2.73org.springframework.bootspring-boot-starter-websocket 출력 형식을 처리하기 위한 종속성을 도입해야 합니다. 두 번째 단계는 WebSocket 구성 클래스 importorg를 생성하는 것입니다. springframework.context.annotation.Bean;importorg.springframework.context.annotation.Config

C#의 일반적인 네트워크 통신 및 보안 문제와 솔루션 C#의 일반적인 네트워크 통신 및 보안 문제와 솔루션 Oct 09, 2023 pm 09:21 PM

C#의 일반적인 네트워크 통신 및 보안 문제와 해결 방법 오늘날 인터넷 시대에 네트워크 통신은 소프트웨어 개발에 없어서는 안 될 부분이 되었습니다. C#에서는 일반적으로 데이터 전송 보안, 네트워크 연결 안정성 등과 같은 일부 네트워크 통신 문제가 발생합니다. 이 문서에서는 C#의 일반적인 네트워크 통신 및 보안 문제에 대해 자세히 설명하고 해당 솔루션과 코드 예제를 제공합니다. 1. 네트워크 통신 문제 네트워크 연결 중단: 네트워크 통신 과정에서 네트워크 연결이 중단될 수 있으며, 이로 인해

django 프로젝트를 시작하기 위해 centos+nginx+uwsgi를 배포하는 방법 django 프로젝트를 시작하기 위해 centos+nginx+uwsgi를 배포하는 방법 May 15, 2023 am 08:13 AM

내 Django 프로젝트는 yunwei라고 합니다. 주요 앱은 rabc와 web입니다. 전체 프로젝트는 다음과 같이 /opt/ 아래에 배치됩니다. 관리.pyrbacstatictemplatesuwsgiwebyunwei[루트 @test-codeopt]#lsyunwei/uwsgi/cut_log.shloguwsgi.iniuwsgi.loguwsgi.p

PHP 소켓에 연결할 수 없는 경우 수행할 작업 PHP 소켓에 연결할 수 없는 경우 수행할 작업 Nov 09, 2022 am 10:34 AM

PHP 소켓을 연결할 수 없는 문제에 대한 해결책: 1. PHP에서 소켓 확장이 활성화되어 있는지 확인하십시오. 2. php.ini 파일을 열고 "php_sockets.dll"이 로드되었는지 확인하십시오. 3. "php_sockets.dll"의 주석을 제거하십시오. ".

PHP+Socket 시리즈는 클라이언트와 서버 간의 데이터 전송을 구현합니다. PHP+Socket 시리즈는 클라이언트와 서버 간의 데이터 전송을 구현합니다. Feb 02, 2023 am 11:35 AM

이 기사에서는 php+socket에 대한 관련 지식을 제공합니다. 주로 소켓이 무엇인지 소개합니다. php+socket은 클라이언트-서버 데이터 전송을 어떻게 실현합니까? 관심 있는 친구들은 아래를 살펴보시면 모두에게 도움이 되길 바랍니다.

See all articles