>  기사  >  백엔드 개발  >  PHP+MySQL을 사용하여 메시지 대기열을 구현하는 단계에 대한 자세한 설명

PHP+MySQL을 사용하여 메시지 대기열을 구현하는 단계에 대한 자세한 설명

php中世界最好的语言
php中世界最好的语言원래의
2018-05-16 10:21:362047검색

이번에는 PHP + MySQL로 메시지 를 구현하는 단계에 대해 자세히 설명하겠습니다. PHP + MySQL에서 메시지 큐를 구현하기 위한 주의 사항은 무엇입니까? 다음은 실제 사례입니다. .

최근 문자 메시지를 일괄적으로 보내야 하는 필요성을 느꼈습니다. 문자 메시지 인터페이스는 타사에서 제공됩니다. 처음에는 휴대폰 번호를 받은 후 루프에서 인터페이스를 호출하여 보내는 것으로 충분하지 않을까 생각했습니다.

하지만 문제는 빨리 발견되었습니다. 문자 메시지의 양이 많으면 시간이 많이 걸릴 뿐만 아니라 성공률도 낮습니다.

그래서 PHP와 MySQL을 사용하여 메시지 큐를 구현하고 문자 메시지를 하나씩 보내려고 생각했습니다. 구체적인 구현 방법은 아래에 소개되어 있습니다.

먼저 다음 필드를 포함하는 SMS 데이터 테이블을 만듭니다.

id,
phone, //手机号
content //短信内容

보내야 하는 문자 메시지와 휴대폰 번호를 SMS 테이블에 저장합니다.

다음으로 PHP를 사용하여 timer를 구현하고, 정기적으로 기록을 읽고, 문자 메시지를 보내야 합니다.

<?php
$db = new Db();
$sms = new Sms();
while(true){
  $item = $db->getFirstRecord(); //获取数据表第一条记录
  if(!$item){
    //如果队列中没有数据,则结束定时器
    break;
  }
  $res = $sms->send($item[&#39;phone&#39;],$item[&#39;content&#39;]); //发送短信
  if($res){
    $db->deleteFristRecord(); //删除发送成功的记录
    echo $item[&#39;phone&#39;].&#39;发送成功&#39;;
  }else{
    echo $item[&#39;phone&#39;].&#39;发送失败,稍后继续尝试&#39;;
  }
  sleep(10); //每隔十秒循环一次
}
echo &#39;发送完毕!&#39;;
?>

코드를 타이머_sms.php로 저장하고, 명령줄을 열고, 타이머를 실행하세요.

php timer_sms.php

알겠습니다. PHP 타이머는 설정된 시간 간격(여기에서는 10초로 설정됨)에 따라 문자 메시지를 보내는 작업을 자동으로 완료합니다. 작업이 완료되면 타이머가 자동으로 종료되고 더 이상 서버 리소스를 차지하지 않습니다.

내 테스트에 따르면 PHP 타이머는 많은 리소스를 차지하지 않으며 서버에 부담을 주지 않습니다. 또한 데이터베이스에 비동기적으로 액세스해도 데이터베이스 작동에는 영향을 미치지 않습니다.

이 방법의 장점은 다음과 같습니다.

1. 백그라운드에서 실행되므로 프런트 데스크에서 기다릴 필요가 없습니다.

2. 성공률이 높고 실패한 기록은 성공할 때까지 자동으로 재전송됩니다. 이 기사 방법의 사례를 읽은 후 마스터했습니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사에 주목하세요!

추천 자료:

Vue


노드를 사용해 WeChat 개인 계정 로봇

을 생성하여 드래그 앤 드롭 기능을 구현하는 단계에 대한 자세한 설명

위 내용은 PHP+MySQL을 사용하여 메시지 대기열을 구현하는 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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