PHP長串連使用案例分析

來源:互聯網
上載者:User
這次給大家帶來PHP長串連使用案例分析,PHP長串連使用的注意事項有哪些,下面就是實戰案例,一起來看一下。

長串連技術(Long Polling)

在伺服器端hold住一個串連, 不立即返回, 直到有資料才返回, 這就是長串連技術的原理

長串連技術的關鍵在於hold住一個HTTP請求, 直到有新資料時才響應請求, 然後用戶端再次自動發起長串連請求.

那怎麼樣hold住一個請求呢?伺服器端的代碼可能看起來像這樣的

set_time_limit(0); //這句很重要, 不至於運行逾時while (true) {  if (hasNewMessage()) {    echo json_encode(getNewMessage());    break;  }  usleep(100000);   //避免太過頻繁的查詢}

沒錯,就是通過迴圈來實現hold住一個請求, 不至於立即返回. 查詢到有新資料之後才響應請求. 然後用戶端處理資料後,再次發起長串連請求.

用戶端的代碼是像這樣的

<script type="text/javascript">  (function longPolling() {    $.ajax({      'url': 'server.php',      'data': data,      'dataType': 'json',      'success': function(data) {        processData(data);        longPolling();      },      'error': function(data) {        longPolling();      }    });  })();</script>

一個簡易的聊天室

通過長串連, 我們可以開發一個簡易的web聊天室

下面, 我們通過redis開發一個簡易的web聊天室

1. 每一個用戶端發起長串連時, 在伺服器端產生一個訊息佇列, 對應該使用者. 然後監聽有無新資料, 有則返回資料到用戶端進行處理, 並再起發起長串連請求.

2. 每一個用戶端發起訊息時, 進行訊息佇列的廣播.

下面是程式碼片段:

<?phpnamespace church\LongPolling;use Closure;use church\LongPolling\Queue\RedisQueue;use Symfony\Component\HttpFoundation\Request;use Symfony\Component\HttpFoundation\JsonResponse;class Server{  public $event = [];  public $redisQueue = null;  public $request = null;  public $response = null;  public function construct()  {    $this->redisQueue = new RedisQueue();    $this->request = Request::createFromGlobals();    $this->response = new JsonResponse();  }  public function on($event, Closure $closure)  {    if (is_callable($closure)) {      $this->event[$event][] = $closure;    }  }  public function fire($event)  {    if (isset($this->event[$event])) {      foreach ($this->event[$event] as $callback) {        call_user_func($callback, $this);      }    }  }  public function sendMessage($data)  {    switch ($data['type']) {      case 'unicast':   //單播        $this->unicast($data['target'], $data['data'], $data['resource']);        break;      case 'multicast':    //組播        foreach ($data['target'] as $target) {          $this->unicast($target, $data['data'], $data['resource']);        }        break;      case 'broadcast':    //廣播        foreach ($this->redisQueue->setQueueName('connections') as $target) {          $this->unicast($target, $data['data'], $data['resource']);        }        break;    }    $this->fire('message');  }  public function unicast($target, $message, $resource = 'system')  {    $redis_queue = new RedisQueue();    $redis_queue->setQueueName($target)->push($resource . ':' . $message);  }  public function getMessage($target)  {    return $this->redisQueue->setQueueName($target)->pop();  }  public function hasMessage($target)  {    return count($this->redisQueue->setQueueName($target));  }  public function run()  {    $data = $this->request->request;    while (true) {      if ($data->get('action') == 'getMessage') {        if ($this->hasMessage($data->get('target'))) {          $this->response->setData([            'state' => 'ok',            'message' => '擷取成功',            'data' => $this->getMessage($data->get('target'))          ]);          $this->response->send();          break;        }      } elseif ($data->get('action') == 'connect') {        $exist = false;        foreach ($this->redisQueue->setQueueName('connections') as $connection) {          if ($connection == $data->get('data')) {            $exist = true;          }        }        if (! $exist) {          $this->redisQueue->setQueueName('connections')->push($data->get('data'));        }        $this->fire('connect');        break;      }      usleep(100000);    }  }}

長串連避免了過於頻繁的輪詢. 但伺服器維持一個長串連也有額外的資源消耗. 大並發時效能不理想. 在小型應用裡面可以考慮使用

更建議用戶端使用html5的websocket協議, 伺服器端使用swoole.

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

php命名空間使用詳解

PHP中文工具類ChineseUtil怎樣轉換漢字與拼音

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.