1.不要相信任務數據,包括請求的外部接口,特別是超時者部分,盡可能的交給task完成。
2.原來可以在入口文件哪里使用超全局變量聲明已經實例化的server服務對象,然后就其他文件使用了。
3.異步任務(協程)里面不能再異步(開啟協程任務),只能是同步(task任務下,redis只能使用同步的模式,使用異步的模式會出錯!)。
4.在使用task任務下,不能使用thinkphp6.0里面的門面(`Facade`),報錯原因是因為找不到這個類(因為沒有加載到這里)。
5.所有耗時的任務叫交給task完成。
6.使用同步redis下的單例模式,指的是同一個請求下只連接一次,后面在這個請求里面不斷重復的都是這個實例,如:
[](javascript:void(0); "復制代碼")
~~~
<?php
namespace app\common\controller;
use think\facade\Config;
use app\common\controller\Redis;
//redis單例模式
class Predis
{
public $redis;
/**
* 定義單例模式的變量
*/
private static $_instance = null;
public function __construct()
{
$this -> redis = new \Redis();
//$result = $this -> redis->connect(Config::get('redis.host'), Config::get('redis.port'), Config::get('redis.timeOut'));
$result = $this -> redis->connect('127.0.0.1', 6379, 5);
if($result === false)
{
throw new \Exception('redis connect error');
}
}
/**
* 1、單例類只能有一個實例。
* 2、單例類必須自己創建自己的唯一實例。
* 3、單例類必須給所有其他對象提供這一實例。
*/
public static function getInstance()
{
if(empty(self::$_instance))
{
self::$_instance = new self();
}
return self::$_instance;
}
/**
* 存儲數據
*/
public function set($key, $value, $time=0)
{
if(empty($key))
{
return "";
}
if(is_array($value))
{
$value = json_encode($value);
}
if(!$time)
{
return $this -> redis -> set($key, $value);
}
return $this -> redis -> setex($key, $time, $value);
}
/**
*獲取數據
*/
public function get($key)
{
if(empty($key))
{
return "";
}
$res = $this -> redis -> get($key);
return $res;
}
}
~~~
[](javascript:void(0); "復制代碼")
使用:
~~~
Predis::getInstance()->set(Redis::smsKey($data['phone']), $data['code']);
~~~
7.在整理task功能的時候,有注意到一個有趣的事情:就是通過一個變量值來調用這個對象的方法,如:
1234567 $obj = new app\common\task\Task();$method = $data['method'];if(empty($method)){ return "method for null";}$flag = $obj -> $method($data['data']);
8.能面向對象的就盡量面向對象,盡可能避免面向過程,主要是對以后維護不好維護。
9.如果需要task來處理事情的話,記得在set的時候寫明task是多少,不然無法開啟task任務,如:
[](javascript:void(0); "復制代碼")
~~~
$this->http->set(
[
'enable_static_handler' => true,
'document_root' => '/www/wwwroot/tp6/public/index',
'worker_num' => 4,//worker的數量
'task_worker_num' => 4,//task的數量
]
);
~~~
[](javascript:void(0); "復制代碼")
10.server里面的事件也有對應的方法,事件!=方法,你要先注冊這個事件,才能使用這個方法!具體請參考server的task方法的使用!
11.使用ob\_end\_clean()方法必須要有輸出才行,不然會報錯!
- thinkphp6執行流程(一)
- php中use關鍵字用法詳解
- Thinkphp6使用騰訊云發送短信步驟
- 路由配置
- Thinkphp6,static靜態資源訪問路徑問題
- ThinkPHP6.0+ 使用Redis 原始用法
- smarty在thinkphp6.0中的最佳實踐
- Thinkphp6.0 搜索器使用方法
- 從已有安裝包(vendor)恢復 composer.json
- tp6with的用法,表間關聯查詢
- thinkphp6.x多對多如何添加中間表限制條件
- thinkphp6 安裝JWT
- 緩存類型
- 請求信息和HTTP頭信息
- 模型事件用法
- 助手函數匯總
- tp6集成Alipay 手機和電腦端支付的方法
- thinkphp6使用jwt
- 6.0session cookie cache
- tp6筆記
- TP6(thinkphp6)隊列與延時隊列
- thinkphp6 command(自定義指令)
- command(自定義指令)
- 本地文件上傳
- 緩存
- 響應
- 公共函數配置
- 七牛云+文件上傳
- thinkphp6:訪問多個redis數據源(thinkphp6.0.5 / php 7.4.9)
- 富文本編輯器wangEditor3
- IP黑名單
- 增刪改查 +文件上傳
- workerman 定時器操作控制器的方法
- 上傳文件到阿里云oss
- 短信或者郵箱驗證碼防刷代碼
- thinkphp6:訪問redis6(thinkphp 6.0.9/php 8.0.14)
- 實現關聯多個id以逗號分開查詢數據
- thinkphp6實現郵箱注冊功能的細節和代碼(點擊鏈接激活方式)
- 用mpdf生成pdf文件(php 8.1.1 / thinkphp v6.0.10LTS )
- 生成帶logo的二維碼(php 8.1.1 / thinkphp v6.0.10LTS )
- mysql數據庫使用事務(php 8.1.1 / thinkphp v6.0.10LTS)
- 一,創建過濾IP的中間件
- 源碼解析請求流程
- 驗證碼生成
- 權限管理
- 自定義異常類
- 事件監聽event-listene
- 安裝與使用think-addons
- 事件與多應用
- Workerman 基本使用
- 查詢用戶列表按拼音字母排序
- 擴展包合集
- 查詢用戶數據,但是可以通過輸入用戶昵稱來搜索用戶同時還要統計用戶的文章和粉絲數
- 根據圖片的minetype類型獲取文件真實拓展名思路
- 到處excel
- 用imagemagick庫生成縮略圖
- 生成zip壓縮包并下載
- API 多版本控制
- 用redis+lua做限流(php 8.1.1 / thinkphp v6.0.10LTS )
- 【thinkphp6源碼分析三】 APP類之父, 容器Container類
- thinkphp6表單重復提交解決辦法
- 小程序授權
- 最簡單的thinkphp6導出Excel
- 根據訪問設備不同訪問不同模塊
- 服務系統
- 前置/后置中間件
- 給接口api做簽名驗證(php 8.1.1 / thinkphp v6.0.10LTS )
- 6實現郵箱注冊功能的細節和代碼(點擊鏈接激活方式)
- 使用前后端分離的驗證碼(thinkphp 6.0.9/php 8.0.14/vue 3.2.26)
- 前后端分離:用jwt+middleware做用戶登錄驗證(php 8.1.1 / thinkphp v6.0.10LTS )
- vue前后端分離多圖上傳
- thinkphp 分組、頁面跳轉與ajax
- thinkphp6 常用方法文檔
- 手冊里沒有的一些用法
- Swagger 3 API 注釋
- PHP 秒級定時任務
- thinkphp6集成gatewayWorker(workerman)實現實時監聽
- thinkphp6按月新增數據表
- 使用redis 實現消息隊列
- api接口 統一結果返回處理類
- 使用swoole+thinkphp6.0+redis 結合開發的登錄模塊
- 給接口api做簽名驗證
- ThinkPHP6.0 + UniApp 實現小程序的 微信登錄
- ThinkPHP6.0 + Vue + ElementUI + axios 的環境安裝到實現 CURD 操作!
- 異常$e
- 參數請求驗證自定義和異常錯誤自定義