>  기사  >  PHP 프레임워크  >  Workerman 개발: HTTP2 프로토콜을 기반으로 웹 서버를 구현하는 방법

Workerman 개발: HTTP2 프로토콜을 기반으로 웹 서버를 구현하는 방법

王林
王林원래의
2023-11-07 11:25:57957검색

Workerman 개발: HTTP2 프로토콜을 기반으로 웹 서버를 구현하는 방법

Workerman 개발: HTTP2 프로토콜을 기반으로 웹 서버를 구현하는 방법

HTTP2는 HTTP 프로토콜의 차세대 버전으로 성능과 보안이 크게 향상되었습니다. Workerman은 일반적으로 사용되는 PHP 실시간 통신 프레임워크로 고성능, 쉬운 확장 및 사용 편의성이라는 장점을 가지고 있습니다. HTTP2 프로토콜을 기반으로 웹 서버를 구현하는 방법은 무엇입니까? 이 기사에서는 다음과 같은 측면을 소개합니다.

  1. HTTP2 프로토콜의 특성 이해
  2. Workerman이 HTTP2 프로토콜을 지원하는 방법
  3. 특정 HTTP2 프로토콜을 구현하는 웹 서버
  4. 코드 예제

1. HTTP2 프로토콜의 특성 이해 HTTP2 프로토콜

HTTP2 프로토콜은 HTTP 프로토콜의 차세대 버전으로 성능과 보안이 크게 향상되었습니다. HTTP1.x 프로토콜과 비교하면 다음과 같은 특징이 있습니다.

  1. 바이너리 프로토콜: HTTP2는 바이너리 프로토콜을 사용하는 반면 HTTP1.x는 텍스트 프로토콜을 사용합니다. 바이너리 프로토콜은 데이터를 더 빠르게 구문 분석하고 전송합니다.
  2. 다중화: HTTP2는 동일한 연결에서 여러 요청과 응답을 병렬로 전송할 수 있습니다. 이를 통해 연결 설정 및 대기 시간이 줄어들고 웹 사이트의 전반적인 응답성이 향상됩니다.
  3. 헤더 압축: HTTP2는 HPACK 알고리즘을 사용하여 요청 및 응답의 헤더를 압축하여 데이터 전송 크기를 줄이고 성능을 향상시킵니다.
  4. 서버 푸시: HTTP2는 웹 페이지 관련 리소스 파일을 클라이언트에 적극적으로 푸시하여 클라이언트 요청 수를 줄이고 웹 페이지 열기 속도를 향상시킬 수 있습니다.

2. Workerman은 어떻게 HTTP2 프로토콜을 지원하나요?

Workerman은 일반적으로 사용되는 PHP 실시간 통신 프레임워크로 원래는 TCP 프로토콜 기반으로 고성능 통신을 구현하도록 설계되었지만 HTTP 프로토콜도 지원합니다. . Workerman은 기본적으로 HTTP1.x 프로토콜을 사용하지만 HTTP2 프로토콜도 지원합니다.

HTTP2 프로토콜은 암호화 모드에서만 사용을 지원하기 때문에 HTTP2 프로토콜을 구현하기 위한 기본 조건은 SSL 인증서가 있어야 합니다. 따라서 HTTP2 프로토콜을 지원하려면 Workerman에서 SSL 인증서를 구성해야 합니다. 구체적인 구성 방법은 다음과 같습니다.

$context = array(
    // 这是key, 一般和crt放在一起
    'ssl' => array(
        // 请使用绝对路径
        'local_cert' => '/your/path/to/server.crt', // 服务端证书
        'local_pk' => '/your/path/to/server.key', // 服务端证书的私钥
        'verify_peer' => false, // 是否需要验证客户端证书
    )
);

// 初始化一个Worker监听http://0.0.0.0:443
$worker = new Worker("http://0.0.0.0:443", $context);

// 开启对HTTP2.0的支持
$worker->transport = 'ssl';
$worker->protocol = "Http2";

3. 특정 HTTP2 프로토콜 웹 서버 구현

Workerman이 HTTP2 프로토콜을 지원하면 HTTP2 프로토콜 웹 서버를 구현할 수 있습니다. 구체적인 구현 방법에는 여러 가지가 있습니다. 여기서는 기본 HTTP2 프로토콜 웹 서버 구현을 예로 들어 보겠습니다.

  1. http2_server.php라는 PHP 파일을 만들고 다음 코드를 입력하세요.
<?php
require_once __DIR__ . '/../vendor/autoload.php';

$context = array(
    'ssl' => array(
        'local_cert' => '/your/path/to/server.crt',
        'local_pk' => '/your/path/to/server.key',
        'verify_peer' => false,
    )
);

$worker = new WorkermanWorker('http://0.0.0.0:443', $context);

$worker->transport = 'ssl';
$worker->protocol = "Http2";

$worker->onConnect = function($connection) {
    echo "new connection from ip " . $connection->getRemoteIp() . "
";
};

$worker->onMessage = function($connection, $data) {
    $request_uri = $_SERVER['REQUEST_URI'];
    $response = "Hello, HTTP2!
";
    $connection->send($response);
};

Worker::runAll();
  1. 웹 서버 시작

다음 명령을 실행하여 웹 서버를 시작하세요.

php http2_server.php start -d

이때, https: //localhost에 액세스하는 브라우저를 사용하면 Hello, HTTP2! 콘텐츠가 포함된 페이지를 볼 수 있습니다.

4. 코드 예

코드는 세 번째 부분에 제공되었으며, 전체 코드는 여기에서 다시 제공됩니다. /your/path/to/server.crt 및 /your/path/to/server.key를 자체 SSL 인증서 경로로 바꾸면 됩니다.

<?php
require_once __DIR__ . '/../vendor/autoload.php';

$context = array(
    'ssl' => array(
        'local_cert' => '/your/path/to/server.crt',
        'local_pk' => '/your/path/to/server.key',
        'verify_peer' => false,
    )
);

$worker = new WorkermanWorker('http://0.0.0.0:443', $context);

$worker->transport = 'ssl';
$worker->protocol = "Http2";

$worker->onConnect = function($connection) {
    echo "new connection from ip " . $connection->getRemoteIp() . "
";
};

$worker->onMessage = function($connection, $data) {
    $request_uri = $_SERVER['REQUEST_URI'];
    $response = "Hello, HTTP2!
";
    $connection->send($response);
};

Worker::runAll();

요약

HTTP2 프로토콜은 HTTP 프로토콜의 차세대 버전으로, HTTP1.x 프로토콜에 비해 성능과 보안 측면에서 크게 향상되었습니다. Workerman은 HTTP2 프로토콜을 지원하는 일반적으로 사용되는 PHP 실시간 통신 프레임워크입니다. 이 기사에서는 Workerman을 사용하여 SSL 인증서 구성 및 특정 웹 서버 구현을 포함하여 HTTP2 프로토콜 기반 웹 서버를 구현하는 방법을 설명합니다.

위 내용은 Workerman 개발: HTTP2 프로토콜을 기반으로 웹 서버를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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