Context 협코르틴 컨텍스트

Context는 협코르틴 내에서 데이터베이스 연결, 사용자 정보 등과 같은 컨텍스트 정보를 저장하고 전달하는 데 사용됩니다. 각 협코르틴은 자신의 컨텍스트를 가지며, 서로 다른 협코르틴 간의 컨텍스트는 격리됩니다.

주의
기본적으로 자동으로 드라이버 유형을 인식하며, Swoole/Swow/Fiber 드라이버만 지원합니다.

提示
이 기능은 workerman>=5.1.0이 필요합니다.

<?php

use Workerman\Connection\TcpConnection;
use Workerman\Coroutine;
use Workerman\Coroutine\Context;
use Workerman\Events\Swoole;
use Workerman\Protocols\Http\Request;
use Workerman\Worker;
require_once __DIR__ . '/vendor/autoload.php';

$worker = new Worker('http://0.0.0.0:8001');

$worker->eventLoop = Swoole::class; // Or Swow::class or Fiber::class

$worker->onMessage = function (TcpConnection $connection, Request $request) {
    // 현재 협코르틴에서 context 데이터 설정
    Context::set('user_info', ['id' => 1, 'name' => 'name']);
    // 새로운 협코르틴 생성
    Coroutine::create(function () use ($connection) {
        // 협코르틴 간의 context 데이터는 격리되어 있으므로, 새로운 협코르틴에서 가져오는 값은 null입니다.
        $userInfo = Context::get('user_info');
        var_dump($userInfo); // null 출력
    });
    // 현재 협코르틴의 context 데이터 가져오기
    $userInfo = Context::get('user_info'); // ['id' => 1, 'name' => 'name'] 반환
    $connection->send(json_encode($userInfo));
};

Worker::runAll();

인터페이스 설명

interface ContextInterface
{
    /**
     * 컨텍스트에서 값을 가져오기
     */
    public static function get(string $name, mixed $default = null): mixed;

    /**
     * 컨텍스트에서 값을 설정하기
     */
    public static function set(string $name, mixed $value): void;

    /**
     * 컨텍스트에 지정된 이름의 값이 존재하는지 확인하기
     */
    public static function has(string $name): bool;

    /**
     * 현재 협코르틴 컨텍스트 초기화
     */
    public static function reset(?ArrayObject $data = null): void;

    /**
     * 컨텍스트 파괴
     */
    public static function destroy(): void;

}