>백엔드 개발 >PHP 튜토리얼 >PHP+MySQL은 메시지 큐 기능을 생성합니다(코드 포함).

PHP+MySQL은 메시지 큐 기능을 생성합니다(코드 포함).

php中世界最好的语言
php中世界最好的语言원래의
2018-05-11 15:37:161978검색

이번에는 PHP+MySQL을 이용한 메시지 함수(코드 포함)를 가져오겠습니다. 메시지 큐 기능을 사용하기 위한 PHP+MySQL의 주의사항은 무엇입니까?

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

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

그래서 PHP와 MySQL을 사용하여 메시지 큐를 구현하고 문자 메시지를 하나씩 보내려고 생각했습니다. 구체적인 구현 방법은 다음과 같습니다.

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

id,
phone, //휴대폰 번호
content //SMS content

문자 메시지 및 모바일 전송해야 하는 전화번호는 SMS 테이블에 저장됩니다.

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

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

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

php timer_sms.php

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

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

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

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

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

추천 도서:

Puppeteer 보급형 코드


Vue 데이터 모니터링 시계 사용 지침

위 내용은 PHP+MySQL은 메시지 큐 기능을 생성합니다(코드 포함).의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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