찾다
백엔드 개발PHP 튜토리얼nginx HTTP 모듈 구성

원본링크: http://cjhust.blog.163.com/blog/static/17582715720124544047608/

1, 데이터 구조

ngx_conf_s

struct ngx_conf_s {

char *name; ngx_array_t *args; //

명령 매개변수, 파일에서 읽어서 이 배열에 넣습니다.

ngx_cycle_t *cycle; //

시스템 매개변수를 가리킵니다 ngx_pool_t *pool; //

메모리 풀 ngx_pool_t *temp_pool;

ngx_conf_file_t *conf_file; //

구성 파일 정보 “./conf/main.conf” ngx_log_t *log; //

로그

void *ctx *ctx; //(void ****)cycle->conf_ctx

설치됨 모든 모듈 구성 정보

ngx_uint_t module_type;

//현재 명령어를 처리하는 모듈의 종류 ngx_uint_t

이 명령을 처리하는 명령 유형

ngx_conf_handler_pt 핸들러; //

명령어 처리 기능

char *handler_conf; //

위의

handler};

참고: 이 구조는 주로 사용됩니다. 구성 읽기 이때

ngx_conf_s

는 구성 파일과 시스템 매개변수 사이의 브리지 역할을 합니다. typedef 구조체 {

void **main_conf;

void **srv_conf;

void **loc_conf;

} ngx_http_conf_ctx_t;

비고 : HTTP 블록의 구성 구조는 크게 3, 메인, 서버{}, 위치{}. typedef struct {

ngx_int_t (*사전 구성)(ngx_conf_t *cf); ngx_int_t (*사후 구성)(ngx_conf_t *cf);

void *( * create_main_conf)(ngx_conf_t *cf);

char *(*init_main_conf)(ngx_conf_t *cf, void *conf);

void *(*create_srv_conf)(ngx_conf_t *cf);

char *(*merge_srv_conf)(ngx_conf_t *cf, void *prev, void *conf);

void *(*create_loc_conf)(ngx_conf_t *cf);

char *(*merge_loc_conf ) (ngx_conf_t *cf, void *prev, void *conf);

} ngx_http_module_t;

비고:

HTTP

ctx주로 위 내용을 포함

8 기능. ngx_command_sstruct ngx_command_s { ngx_str_t 이름;

ngx_uint_t 유형; 문자                                               cf, ngx_command_t *cmd, 무효 * conf);

ngx_uint_t conf;

ngx_uint_t offset;

void ngx_null_string , 0, NULL, 0, 0, NULL }

2, HTTP ctx

2.1 create_main_conf(ngx_conf_t *cf)

매개변수: ngx_conf_t *cf, 구성 구조

반환 값: void *

참고: 의 반환 값은 ngx_http_conf_get_module_main_confgx_http로 반환될 수 있습니다. _get_module_ main _conf 결과; static void * ngx_http_barrier_create_conf(ngx_conf_t *cf)

{

ngx_http_barrier_conf_t *conf; //

사용자 정의 구조

conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_barrier_conf_t )); //pcalloc으로 초기화

if (conf == NULL) { NULL 반환;

}

conf->enable = NGX_CONF_UNSET;

return conf; 🎜>

2.2 create_srv_conf(ngx_conf_t *cf)

매개변수: ngx_conf_t * cf, 구성 구조

반환 값: void *

🎜>

ngx_http_conf_get_module_srv_conf gx_http _get_module_ srv_conf; 🎜>

static void * ngx_http_barrier_create_conf(ngx_conf_t *cf)

{ ngx_http_barrier_conf_t * conf; //사용자 정의 구조

conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_barrier_conf_t) ); //pcalloc으로 초기화 if (conf == NULL) { NULL 반환; }

conf->enable = NGX_CONF_UNSET; return conf; 🎜>

2.3 create_loc_conf(ngx_conf_t *cf)

매개변수: ngx_conf_t *cf , 구성 구조

반환 값:

void *

>

ngx_http_conf_get_module_loc_conf

gx_http _get_module_loc_conf

; >

static void * ngx_http_barrier_create_conf(ngx_conf_t *cf){

ngx_http_barrier_conf_t *conf ; //

사용자 정의 구조

conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_barrier_conf_t)); //pcalloc으로 초기화

if (conf == NULL) {

NULL 반환;

}

conf ->enable = NGX_CONF_UNSET;

conf 반환 🎜> }

2.4 사전 구성(ngx_conf_t *cf)

매개변수:

ngx_conf_t *cf, 구성 구조; 반환 값:

ngx_int_t; 참고:

연산이 올바른지 판단하는 데 사용됩니다. >정적 ngx_int_tngx_http_ssl_add_variables(ngx_conf_t *cf)

{ ngx_http_variable_t *var, *v;

for (v = ngx_http_ssl_vars; v->name.len; v++) {

var = ngx_http_add_variable(cf, &v->name, v->flags);

if(var == NULL) {

NGX_ERROR 반환;

}

var->get_handler = v->get_handler;

var->data = v->data;

}

return NGX_OK;

}

2.5 init_main_conf(ngx_conf_t *cf, void *conf)

매개변수:

ngx_conf_t *cf

conf,

conf는 여기서 create_main을 매개변수로 사용한 경우의 반환 값입니다. >반환 값: 문자 *, NGX_CONF_OK 은 성공을 나타냅니다.

비고: 반환 값은 작업 여부를 판단하는 데에만 사용됩니다. 맞습니다. 예: 정적 문자 *

ngx_http_core_init_main_conf(ngx_conf_t *cf, void *conf){

ngx_http_core_main_conf_t *cmcf = conf;

//create_main

if (cmcf->server_names_hash_max_size == NGX_CONF_UNSET_UINT) {

cmcf->server_names_hash_max_size = 512;

초기화

}

if (cmcf->server_names_hash_bucket_size == NGX_CONF_UNSET_UINT) {

cmcf->server_names_hash_bucket_size = ng x_cacheline_size; }

cmcf->server_names_hash_bucket_size =

            ngx_align(cmcf->server_names_hash_bucket_size, ngx_cacheline_size);

 

 

    if (cmcf->variables_hash_max_size == NGX_CONF_UNSET_UINT) {

        cmcf->variables_hash_max_size = 512;

    }

 

    if (cmcf->variables_hash_bucket_size == NGX_CONF_UNSET_UINT) {

        cmcf-> variables_hash_bucket_size = 64;

    }

 

    cmcf->variables_hash_bucket_size =

              ngx_align(cmcf->variables_hash_bucket_size, ngx_cacheline_size);

 

    (cm cf-> ncaptures) {

        cmcf->ncaptures = (cmcf->ncaptures + 1) * 3;

    }

 

    return NGX_CONF_OK;

}

2.6 merge_srv_conf(ngx_conf_t *cf, void *prev, void *conf)

参数:ngx_conf_t *cf,配置结构体,이전메인적配置结构体,conf서버적配置结构体;prev =cf->ctx.srv_conf[ctx_index],c/span>

返回值:문자 *,正确返回值是NGX_CONF_OK;

备注:返回值只是작품为操작품是否正确的一个判断;

示例:

정적 문자 * ngx_http_barrier_merge_conf(ngx_conf_t *cf, void *parent, void *child)

{

  ngx_http_barrier_conf_t *prev = parent;

  ngx_http_barrier_conf_t *conf = child;

 

if (conf->shm_zone == NULL){

     *conf = *prev;

  }

 

  ngx_conf_merge_value(conf->enable, prev->enable, 0);  //기본값은 0

  return NGX_CONF_OK;

}

备注: 병합 서버적주주要功能是,如果메인里配置了enable=1,而서버{}enable= NGX_CONF_UNSET,则将서버enable=mainenable=1;

2.7 merge_loc_conf(ngx_conf_t *cf, void *prev, void *conf)

원리동merge_srv_conf(ngx_conf_t *cf, void *prev, void *conf)

2.8 사후 구성(ngx_conf_t *cf)

参数:ngx_conf_t *cf;

返回值:ngx_int_t,正确返回值是NGX_OK;> 🎜>

示例:

static ngx_int_t ngx_http_tracker_init(ngx_conf_t *cf)

{

ngx_tracker_flag = 0;

return NGX_OK;

}

참고: 전역 변수 교체 플래그배리어 모듈이 있는지 확인하기 위해 지워집니다. 지워지지 않으면 배리어가 구성에 추가되지 않은 경우가 됩니다. zone, kill –HUP일 때 전역 변수 flag의 값은 변경되지 않기 때문입니다. , 0, 이 아닙니다. 사용자가 traker 명령을 실행하면, 분할 오류가 발생합니다. HTTP 명령

4, 자주 사용하는 변수

#define NGX_HTTP_MAIN_CONF 0x02000000 //

명령어 저장 위치# NGX_HTTP_SRV_CONF 0x04000000

#define NGX_HTTP_LOC_CONF 0x08000000#define NGX_HTTP_UP S_CONF 0x1000000 0#정의 NGX_HTTP_SIF_CONF 0x20000000

#define NGX_HTTP_LIF_CONF 0x40000000

#define NGX_HTTP_LMT_CONF 0x80000000

#define NGX_HTTP_MAIN_CONF_OFFSET 오프셋of(ngx_http_conf_ctx_t, main_conf)

#define NGX_HTTP_SRV_CONF_OFFSET 오프셋of(ngx_http_conf_ctx_t, srv_conf)

#define NGX_HTTP_LOC_CONF_OFFSET offsetof(ngx_http_conf_ctx_t, loc_conf)

예:

static ngx_command_t ngx_http_print_commands[] = {

{

ngx_string("print"), NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,

ngx_http_print_setup, ngx_http_print_setup, 🎜>       //set()

은 매개변수를 변환합니다. 통과 읽기 명령을 실행하고 적절한 값을 구성 구조

NGX_HTTP_LOC_CONF_OFFSET,

offsetof(ngx_http_print_loc_conf_t에 저장합니다. , 편집),

NULL

},

ngx_null_command

};

5

, 일반적으로 사용함수

5.1

처리

요청 ngx_http_get_module_main_conf

기능: 요청에 따라 요청 및 모듈은

main구성을 가져옵니다.

#define ngx_http_get_module_main_conf(r, 모듈) (r)-&g t;main_conf[ 모듈 .ctx_index]

ngx_http_get_module_srv_conf

기능: 에 따름 요청 요청 및 모듈은 서버가 구성됩니다.

#define ngx_http_get_module_srv_conf(r, 모듈) (r)->srv_conf[module.ctx_index]

ngx_http_get_module_loc_conf

기능 기능: 에 따름 요청 요청 및 모듈은 위치가 구성됩니다.

#define ngx_http_get_module_loc_conf(r, 모듈) (r)->loc_conf[module.ctx_index]

5.2 파싱conf

ngx_http_conf_get_module_main_conf

기능 기능: 에 따름conf 구조와 모듈은 main 구성됩니다.

#define ngx_http_conf_get_module_main_conf(cf, module) ctx_t *) cf->main_conf[module.ctx_index]

ngx_http_conf_get_module_srv_conf

기능 기능:

에 따르면 conf 구조와 모듈을 사용하면 server 구성을 얻을 수 있습니다. #define ngx_http_conf_get_module_srv_conf(cf, module) _conf_ctx_t *) cf->ctx)->srv_conf[module.ctx_index]

ngx_http_conf_get_module_loc_conf

기능 기능: 에 따르면

conf

구조 및 모듈, 위치 구성을 가져옵니다. #define ngx_http_conf_get_module_loc_conf(cf, 모듈) conf_ctx_t *) cf->ctx)->loc_conf[module.ctx_index]

5.3 사이클

ngx_http_cycle_get_module_main_conf

#define ngx_http_cycle_get_module_main_conf(사이클, 모듈) 🎜> (cycle->conf_ctx [ngx_http_module.index] ? 🎜>

     —>main_ conf [module.ctx_index]:                                                                                                                           🎜> 위 내용은 내용의 측면을 포함하여 nginx HTTP 모듈의 구성을 소개하고 있으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

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

thesecrettokeepingAphp-poweredwebsiterunningsmoothlydlyUnderHeavyloadInvolvesEveralKeyStrategies : 1) ubstractOpCodeCachingWithOpCacheTecescripteExecutionTime, 2) usedatabasequeryCachingwithRedSendatabaseload, 3) LeverAgeCdnslikeCloudforforporerververforporporpin

PHP의 종속성 주입 : 초보자를위한 코드 예제PHP의 종속성 주입 : 초보자를위한 코드 예제May 14, 2025 am 12:08 AM

Code는 코드가 더 명확하고 유지 관리하기 쉽기 때문에 의존성 주입 (DI)에 관심을 가져야합니다. 1) DI는 클래스를 분리하여 더 모듈 식으로 만들고, 2) 테스트 및 코드 유연성의 편의성을 향상시키고, 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하지만 성능 영향 및 순환 종속성에주의를 기울이십시오. 4) 모범 사례는 추상 인터페이스에 의존하여 느슨한 커플 링을 달성하는 것입니다.

PHP 성능 : 응용 프로그램을 최적화 할 수 있습니까?PHP 성능 : 응용 프로그램을 최적화 할 수 있습니까?May 14, 2025 am 12:04 AM

예, PPAPPLICATIONISPOSSIBLEADESLESTION.1) INVERECINGUSINGAPCUTERODUCEDABASELOAD.2) INCODINCEDEXING, ENGICIONEQUERIES 및 CONNECTIONPOULING.3) 향상된 보드 바이어링, 플로 팅 포르코 잉을 피하는 최적화 된 APPCUTERODECEDATABASELOAD.2)

PHP 성능 최적화 : 궁극적 인 가이드PHP 성능 최적화 : 궁극적 인 가이드May 14, 2025 am 12:02 AM

theKeyStrategiesToSINCINTIFILINTINTIFILINTINTHPPORMATIONPERFORMANCEARE : 1) USEOPCODECACHING-CCHACHETEDECUTECUTINGTIME, 2) 최적화 된 ABESINSTEMENTEMENDSTEMENTEMENDSENDSTATEMENTENDS 및 PROPERINDEXING, 3) ConfigureWebSerVERSLIKENGINXXWITHPMFORBETPERMERCORMANCES, 4)

PHP 의존성 주입 컨테이너 : 빠른 시작PHP 의존성 주입 컨테이너 : 빠른 시작May 13, 2025 am 12:11 AM

aphpdectionenceindectioncontainerisatoolthatmanagesclassdependencies, 향상 Codemodularity, testability 및 maintainability.itactAsacentralHubForCreatingAndingDinjectingDingingDingingdecting.

PHP의 종속성 주입 대 서비스 로케이터PHP의 종속성 주입 대 서비스 로케이터May 13, 2025 am 12:10 AM

대규모 응용 프로그램의 경우 SELLENCIONINGESS (DI)를 선택하십시오. ServicElocator는 소규모 프로젝트 또는 프로토 타입에 적합합니다. 1) DI는 생성자 주입을 통한 코드의 테스트 가능성과 모듈성을 향상시킵니다. 2) Servicelocator는 센터 등록을 통해 서비스를 얻습니다. 이는 편리하지만 코드 커플 링이 증가 할 수 있습니다.

PHP 성능 최적화 전략.PHP 성능 최적화 전략.May 13, 2025 am 12:06 AM

phPapplicationSCanBeoptimizedForsPeedandefficiencyby : 1) ENABLEOPCACHEINPHP.INI, 2) PREPAREDSTATEMENTSWITHPDOFORDATABASEQUERIES 사용

PHP 이메일 검증 : 이메일이 올바르게 전송되도록합니다PHP 이메일 검증 : 이메일이 올바르게 전송되도록합니다May 13, 2025 am 12:06 AM

phpeMailValidationInvoLvestHreesteps : 1) formatValidationUsingRegularexpressionsTochemailformat; 2) dnsValidationToErethedomainHasaValidMxRecord; 3) smtpvalidation, theSTHOROUGHMETHOD, theCheckSiftheCefTHECCECKSOCCONNECTERTETETETETETETWERTETWERTETWER

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 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

SecList

SecList

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