Maison >cadre php >PensezPHP >Le processus d'intégration de phpsocketio avec thinkphp5 était un piège sur lequel j'ai personnellement marché !

Le processus d'intégration de phpsocketio avec thinkphp5 était un piège sur lequel j'ai personnellement marché !

藏色散人
藏色散人avant
2021-08-31 16:37:562577parcourir

thinkphpLa colonne du tutoriel sur le framework vous présentera le guide complet sur l'intégration de phpsocketio avec thinkphp 5.0. J'espère que cela sera utile aux amis dans le besoin !

Guide complet pour intégrer phpsocketio avec thinkphp 5.0, en évitant les pièges

Environnement d'utilisation : thinkphp5.0

Exigences du projet

Passez une commande au front-end, acceptez-la au backend et effectuez vous invite immédiatement. Par exemple : Meituan Takeaway, une fois que le client a passé une commande avec succès, le commerçant recevra immédiatement une invite vocale pour recevoir la commande.

Environnement de développement

  • thinkphp5.0
  • phpsocketio

(Puisque le service socket doit être démarré, il doit être utilisé dans un environnement qui peut satisfaire le shell)

avantages socketio

Ce n'est que mon avis, après tout, je n'ai pas étudié socketio en profondeur, j'ai donc juste donné un bref résumé :

  • Réduisez la charge d'E/S du serveur
  • Une connexion longue est plus fiable que les sondages ajax ajax轮询靠谱
  • 服务稳定,支持动态

初略的看了一下,内存占用很小,而且只有1个进程,根据官方报道来说1个进程也能容纳1W人次的高并发,所以,对于我的项目来说,已经绰绰有余

官方文档

https://github.com/walkor/php...

开始开发

安装 phpsocketio

首先cd到thinkphp的项目根目录。使用以下命令

composer require workerman/phpsocket.io

( 这里composer不做解释,如果有什么问题,度娘一下,应该能够解决 )

安装好以后,vendor文件夹下面应该就有一个workerman的文件夹,如果存在,就恭喜你,已经安装完毕了

服务入口文件

回到项目根目录,新建socketio.php,开始编辑

#!/usr/bin/env php
<?php
define(&#39;APP_PATH&#39;, __DIR__ . &#39;/application/&#39;);
define(&#39;BIND_MODULE&#39;,&#39;socketio/Server/index&#39;);
// 加载框架引导文件
require __DIR__ . &#39;/thinkphp/start.php&#39;;

这里只要写好就OK。后续的所有东西,可以忽略他的存在

创建服务控制器

上一步的socketio.php文件里面,模块绑定到了&#39;socketio/Server/index&#39;,这里就需要我们手动创建了。为了能理解,我用目录展示

├─application           应用目录
│  ├─socketio           新创建目录
│  │  ├─controller      
│  │  │  ├─Server.php   启动文件

Server.php

入口文件只是绑定到了这个控制器,所以这个是整个socketio的核心。

<?php
/*
 * (c) U.E Dream Development Studio
 *
 * Author: 李益达 - Ekey.Lee <ekey.lee@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace app\socketio\controller;

require_once VENDOR_PATH . "workerman/phpsocket.io/src/autoload.php";

use PHPSocketIO\SocketIO;
use Workerman\Worker;

class Server
{

    public function index()
    {
        $io = new SocketIO(8080);//socket的端口
        $io->on('workerStart', function () use ($io) {
            $inner_http_worker = new Worker('http://0.0.0.0:5880');//这里IP不用改变,用的内网通讯,端口不能与socket端口想通
            $inner_http_worker->onMessage = function ($http_connection, $data) use ($io) {
                
                $io->emit('new_msg', '44444');//这里写了固定数据,请根据自己项目需求去做调整,不懂这里的可以看看官方文档,很清楚
                $http_connection->send('ok');
            };
            $inner_http_worker->listen();
        });

        // 当有客户端连接时
        $io->on('connection', function ($socket) use ($io) {
            // 定义chat message事件回调函数
            $socket->on('chat message', function ($msg) use ($io) {
                // 触发所有客户端定义的chat message from server事件
                $io->emit('chat message from server', $msg);
            });
        });

        Worker::runAll();
    }
}

创建API 触发socketio

同样你可以在socketio下面新建一个API控制器,这里仅供测试

 public function api()
    {
        // 推送的url地址,使用自己的服务器地址
        $push_api_url = "http://0.0.0.0:5880";//这里同样不需要更改IP。只是端口一定需要和server.php onworker的一样
        $post_data = array(
           "type" => "publish",
           "content" => "这个是推送的测试数据",
        );
        $ch = curl_init ();
        curl_setopt ( $ch, CURLOPT_URL, $push_api_url );
        curl_setopt ( $ch, CURLOPT_POST, 1 );
        curl_setopt ( $ch, CURLOPT_HEADER, 0 );
        curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 );
        curl_setopt ( $ch, CURLOPT_POSTFIELDS, $post_data );
        curl_setopt ($ch, CURLOPT_HTTPHEADER, array("Expect:"));
        $return = curl_exec ( $ch );
        curl_close ( $ch );
        var_export($return);
    }

现在有了server服务端,API触发端,接下来就需要显示出来了,就是我们的前端

前端

现在要写的就是,商家端收到的提示。之前写的server服务端提供phpsocketio监控与socket服务,API提供事件触发,也就是有人下单后的触发,下单作为事件去触发服务器socket,让他回应到前端

代码开始前请注意:这里的端口和域名比较的绕

 <script src=&#39;//cdn.bootcss.com/socket.io/1.3.7/socket.io.js&#39;></script>
  <script>
            // 连接服务端
            var socket = io('http://xxxx.com:8080');//这里请填写你的域名,外网,端口为socket端口
          // 后端推送来消息时
            socket.on('new_msg', function (msg) {//这里的new_msg请一定要注意,官方文档都写的是content,但是后端发送的自定义是new_msg,后端定义成new_msg,前端却接受content的字段。所以是接受不了的
                swal({ title: "包厢点餐提醒", text: "哆啦a梦包厢有新订单" })
                //console.log("收到消息:" + msg);
            });

</script>

以上有两个我之前出问题的地方

  • 端口与域名:域名是外网的域名,当然是需要和你的socket服务在同一个IP下面,即:你的socket部署在114.114.114.114的IP下面。这个域名就必须是在114.114.114.114的IP下面。端口则是后端服务里面new SocketIO的端口了。
  • socket.on()文档里面都是socket.on('content',function(msg){....}),但是可以看我们Server.php里面$io->emit('new_msg', '');这里自定义的事件明明叫做new_msg,但是却被写成了content,可能是本人眼拙,没有看清楚,但是也提醒一下,这里确实要注意回调事件名

部署完毕开始运行

现在所有的文件就算是部署好了,进入服务器管理,打开shellcd到项目根目录。然后执行

php socketio.php start
php socketio.php start    启动
php socketio.php stop    停止
php socketio.php restart    重启
Le service est stable et prend en charge la dynamique
php socketio.php status
Initial Après un rapide coup d'œil, j'ai constaté que l'utilisation de la mémoire est très faible et qu'il n'y a qu'un seul processus. Selon les rapports officiels, un processus peut accueillir une simultanéité élevée de 10 000 personnes, donc c'est largement suffisant pour mon projet

Documentation officielle

https://github.com/walkor/php...
Démarrer le développement

Installer phpsocketio

Premier CD dans le répertoire racine du projet de thinkphp . Utilisez la commande suivante
rrreee🎜(le compositeur ne l'expliquera pas ici. S'il y a des problèmes, demandez-moi et vous devriez pouvoir le résoudre)🎜🎜Après l'installation, il devrait y en avoir un sous le dossier fournisseur Dossier Workerman, s'il existe, félicitations, il a été installé🎜

Fichier d'entrée de service

🎜Retournez dans le répertoire racine du projet et créez un nouveau socketio.php. Commencez à éditer 🎜rrreee🎜 Écrivez-le simplement ici et c'est OK. Pour toutes les choses ultérieures, vous pouvez ignorer son existence🎜🎜🎜Créer un contrôleur de service🎜🎜🎜Dans le fichier socketio.php de l'étape précédente, le module est lié à 'socketio/Server /index' , nous devons le créer manuellement ici. Pour comprendre, j'utilise le répertoire pour afficher 🎜rrreee

Server.php

🎜Le fichier d'entrée est uniquement lié à ce contrôleur, c'est donc le cœur de tout le socketio. 🎜rrreee🎜🎜Créer une API pour déclencher socketio🎜🎜🎜De même, vous pouvez créer un nouveau contrôleur API sous socketio, ceci est uniquement pour tester🎜rrreee🎜Maintenant, il y a un serveur server, API code> Fin de déclenchement, ensuite il doit être affiché, qui est notre front end🎜🎜🎜front end🎜🎜🎜Ce que nous devons écrire maintenant, c'est l'invite reçue par le commerçant. Le serveur <code>server précédemment écrit fournit des services de surveillance et de socket phpsocketio. L'API fournit le déclenchement d'événements, qui est déclenché après que quelqu'un passe une commande. La commande est utilisée comme événement pour déclencher la commande. socket du serveur. Laissez-le répondre au front-end🎜🎜Veuillez noter avant de commencer le code : le port et le nom de domaine ici prêtent à confusion🎜rrreee🎜Il y a deux endroits où j'ai eu des problèmes avant🎜🎜🎜Port et nom de domaine : Le nom de domaine est le nom de domaine du réseau externe, bien sûr. Il doit être sous la même IP que votre service socket, c'est-à-dire : votre socket est déployée sous l'IP de 114.114.114.114. Ce nom de domaine doit être sous l'IP de 114.114.114.114. Le port est le port du nouveau SocketIO dans le service backend. 🎜🎜socket.on()Les documents sont tous socket.on('content',function(msg){....}), mais vous pouvez voir notre Serveur Dans .php $io->emit('new_msg', ''); l'événement personnalisé ici est clairement appelé new_msg, mais il est écrit comme content , peut-être que ma vue est mauvaise et que je ne l'ai pas vu clairement, mais je voudrais aussi vous rappeler que vous devez vraiment faire attention au nom de l'événement de rappel ici🎜🎜🎜🎜Une fois le déploiement terminé, il va commencer à fonctionner🎜🎜🎜Maintenant que tous les fichiers ont été déployés, entrez dans la gestion du serveur, ouvrez le shell. cd dans le répertoire racine du projet. Ensuite, exécutez 🎜rrreee🎜🎜
php socketio.php start Démarrer 🎜🎜🎜🎜<table><thead><tr class="firstRow"><th> <code>php socketio.php stop Arrêter 🎜🎜🎜🎜
php socketio.php restart Redémarrer🎜🎜🎜🎜
php socketio.php status Statut actuel du service🎜🎜🎜🎜🎜🎜Résumé🎜🎜🎜Cette fois, c'est juste un résumé de travail. En raison de contraintes de temps, je n'ai pas étudié davantage sur socketio. Il peut y avoir quelques défauts à certains endroits, mais je. Je suis à 100%, je vous garantis qu'il s'agit de mon propre test et que j'ai parcouru étape par étape tous les pièges mentionnés. S'il y a quelque chose qui ne va pas, faites-le-moi savoir ^_^🎜🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer