가상 호스트 PHP의 Memory_limit는 단일 PHP 스크립트의 단일 실행에 사용 가능한 최대 메모리 제한입니다. 기본 제한은 256MB이고 최대값은 512MB로 조정될 수 있습니다. 아래 편집기에서는 memory_limit를 사용하여 PHP 프로세스의 메모리 사용량을 제한하는 방법을 소개합니다.
memory_limit는 이름에서 알 수 있듯이 PHP 프로세스의 메모리 사용량을 제한합니다. 예:
magento2의 시스템 요구 사항에는 PHP memory_limit에 대한 제한이 있으며 이는 512M보다 낮을 수 없습니다. (기본값은 128M입니다. 변경하지 않으면 Magento의 백그라운드 처리 로직이 정상적으로 실행되지 않습니다.)
PHP 공식 홈페이지 설명을 참고하세요
스크립트가 허용하는 최대 메모리 양을 바이트 단위로 설정합니다. 이는 스크립트가 할당할 수 있는 최대 메모리 양을 바이트 단위로 설정합니다. 이는 잘못 작성된 스크립트가 서버에서 사용 가능한 모든 메모리를 소모하는 것을 방지하는 데 도움이 됩니다. 메모리 제한이 없으면 이 지시어를 -1로 설정하세요.
memory_limit 값, 즉 단일 PHP 프로세스가 차지하는 메모리가 높을수록 메모리가 많을수록 시스템이 동시에 처리할 수 있는 요청이 적어집니다. 예를 들어, 2G 메모리
memory_limit가 128M으로 설정된 시스템은 동시에 최대 16개의 요청을 처리할 수 있습니다. memory_limit가 256M로 설정된 경우 memory_limit는 동시에 최대 8개의 요청을 처리할 수 있습니다. 512M으로 설정하면 동시에 최대 4개의 요청을 처리할 수 있습니다.
memory_limit 값이 클수록 좋을까요?
물론 아닙니다. memory_limit는 주로 프로그램 버그나 무한 루프가 많은 양의 메모리를 점유하여 시스템 다운타임을 일으키는 것을 방지하기 위한 것입니다. 다수의 타사 플러그인이나 코드를 도입할 경우 메모리 제한이 매우 필요합니다.
memory_limit는 각 PHP 프로세스가 고정된 양의 메모리를 차지하도록 합니까?
아니면 할당된 메모리의 상한값인가요?
아이디어를 테스트하고, memory_limit를 10M로 설정하고, PHP 요청에서 2M/20M 문자열을 초기화하고, 시스템 프로세스에서 메모리 사용량을 확인하세요.
Nginx 구성
server { listen 8093; root /home/zhongwei/work/test/memory_limit/; index index.php index.html index.htm; server_name localhost; location / { # try_files $uri $uri/ =404; try_files $uri $uri/ /index.php?q=$uri&$args; } location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_param PHP_VALUE "memory_limit = 10M"; fastcgi_pass unix:/run/php/php7.0-fpm.sock; } }
PHP 테스트 파일
<?php $char_count = 2; $M = 1024 * 1024; echo sprintf("Current memory_limit value is: %s.", ini_get('memory_limit')); echo sprintf('<br/>Amount of memory allocated to PHP: %0.3fM.', memory_get_usage() / $M); $s = str_repeat("a", $M * $char_count); //sleep(30); echo sprintf('<br/>Amount of memory allocated to PHP: %0.3fM.', memory_get_usage() / $M); echo sprintf('<br/>Total memory allocated from system: %0.3fM.', memory_get_usage($real_usage=true) / $M); echo '<br/>success';
테스트 결과
$char_count가 2일 때 2M의 메모리를 차지하는 문자열이 초기화되어 출력 결과는
Current memory_limit value is: 10M. Amount of memory allocated to PHP: 0.344M. Amount of memory allocated to PHP: 2.348M. Total memory allocated from system: 4.004M. success
$char_count가 20일 때 메모리를 차지하는 문자열 20M 문자열로 초기화되면 출력 결과는
Current memory_limit value is: 10M. Amount of memory allocated to PHP: 0.346M.
입니다. HTTP 상태 코드는 500입니다. 이는 문자열이 초기화되면 PHP 프로세스가 시스템에 의해 종료된다는 의미입니다.
Nginx error.log에 기록된 로그 정보를 보세요
2017/03/01 10:41:23 [error] 6903#6903: *39 FastCGI sent in stderr: "PHP message: PHP Fatal error: Allowed memory size of 10485760 bytes exhausted (tried to allocate 20971552 bytes) in /home/zhongwei/work/test/memory_limit/index.php on line 8 PHP message: PHP Stack trace: PHP message: PHP 1. {main}() /home/zhongwei/work/test/memory_limit/index.php:0 PHP message: PHP 2. str_repeat() /home/zhongwei/work/test/memory_limit/index.php:8" while reading response header from upstream, client: 127.0.0.1, server: localhost, request: "GET / HTTP/1.1", upstream: "fastcgi://unix:/run/php/php7.0-fpm.sock:", host: "localhost:8093"
실제 테스트 결과 memory_limit는 프로세스별로 고정 메모리를 할당하는 것이 아니라 PHP 프로세스별로 메모리 사용량 상한만 제한하는 것으로 나타났습니다. 따라서 memory_limit 설정이 더 크다고 해서 동시성 수가 줄어들지는 않습니다. PHP 5.2 이전에
memory_limit의 기본값은 무엇입니까?
위 내용은 memory_limit를 사용하여 PHP 프로세스의 메모리 사용량을 제한하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 산 및 기본 데이터베이스 모델을 비교하여 특성과 적절한 사용 사례를 자세히 설명합니다. 산은 금융 및 전자 상거래 애플리케이션에 적합한 데이터 무결성 및 일관성을 우선시하는 반면 Base는 가용성 및

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

기사는 내장 함수 사용, 화이트리스트 접근 방식 및 서버 측 유효성 검사와 같은 기술에 중점을 둔 보안을 향상시키기 위해 PHP 입력 유효성 검증에 대한 모범 사례를 논의합니다.

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

이 기사에서는 PHP에서 암호를 보호하기 위해 PHP에서 Password_hash 및 Password_Verify 사용의 이점에 대해 설명합니다. 주요 주장은 이러한 기능이 자동 소금 생성, 강한 해싱 알고리즘 및 Secur를 통해 암호 보호를 향상 시킨다는 것입니다.

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 PHP의 XSS 공격을 방지하기위한 전략, 입력 소독, 출력 인코딩 및 보안 향상 라이브러리 및 프레임 워크 사용에 중점을 둔 전략에 대해 설명합니다.

이 기사는 각각의 사용시기에 중점을 둔 PHP의 인터페이스 및 추상 클래스 사용에 대해 설명합니다. 인터페이스는 관련없는 클래스 및 다중 상속에 적합한 구현없이 계약을 정의합니다. 초록 클래스는 일반적인 기능을 제공합니다


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

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

WebStorm Mac 버전
유용한 JavaScript 개발 도구

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