swoft使用問題
報錯信息:
Swoft\Annotation\Exception\AnnotationException(code:0) Property or method(App\Helper\bsp\ResourceBsp) with `@xxx` must be define class annotation
解決方法:
//問題通常是由于注解部分的類沒有引用導(dǎo)致的,解決方法是檢查下面幾個類在對應(yīng)情況下是否有引用//bean工廠useSwoft\Bean\Annotation\Mapping\Bean;
//參數(shù)注入
useSwoft\Bean\Annotation\Mapping\Inject;
//請求參數(shù)
useSwoft\Http\Server\Annotation\Mapping\RequestMapping;
//請求方法
useSwoft\Http\Server\Annotation\Mapping\RequestMethod;
//引用
useSwoft\Rpc\Client\Annotation\Mapping\Reference;
//如果是RPC client的控制類,需要引入@Controller注解類,或者引入@Bean注解類

問題詳情:
調(diào)用導(dǎo)出phf等函數(shù),返回的是一個對象,打印日記函數(shù)只能打印數(shù)組,沒有針對對象進行處理
報錯信息:
解決方法:
判斷不是數(shù)組時,直接返回結(jié)果,不做處理

3.swoft_start.sh 命令執(zhí)行報語法錯誤,語法并沒有錯誤
Syntax error: end of file unexpected (expecting “then”)
錯誤原因
在win下重新編輯了文件,換行是\r \n ,在linux中換行只有\(zhòng)n,所以出現(xiàn)語法問題
解決方法(以下都行)
使用linux命令行編輯swoft_start.sh文件:Vim 打開文件,命令模式(冒號模式:)輸入 :set fileformat=unix,然后:wq 保存
或者使用 win編輯器(比如vs)修改該文檔結(jié)束符(LF)
報錯信息
(Swoft\\Connection\\Pool\\Exception\\ConnectionPoolException) Create connection error(Connect failed host=susan-aio-resource port=8099) file(/var/www/swoft/vendor/swoft/rpc-client/src/Connection.php) line (82)
錯誤原因1:
容器的網(wǎng)絡(luò)問題,跟rpc服務(wù)端不在同一個網(wǎng)絡(luò)
先在容器內(nèi) ping
解決方法
服務(wù)訪問進入容器管理界面,添加網(wǎng)絡(luò) 如as_default(具體看自己的網(wǎng)絡(luò)名)

拉到最底部,加入網(wǎng)絡(luò)里面選 as_default

mysql 容器,設(shè)置了mysql默認數(shù)據(jù)庫字符集、表字符集、字段字符集都為utf8mb4,但插入中文數(shù)據(jù),再取出來會顯示為??,只有在Navicat 中顯示為中文;接口訪問和終端工具使用select語句查出來都是亂碼。終端工具直接會插入不了中文
首先進入容器內(nèi)部
docker exec -it mysql /bin/bash
查看字符集狀態(tài)
locale

可以看到,默認的是POSIX字符集,這個傳統(tǒng)的字符集是不支持中文的,所以我們的核心操作就是要更改字符集為支持中文的字符集。
查看容器承載系統(tǒng)支持的所有字符集
locale -a
root@mysql:/# locale -a
C
C.UTF-8
POSIX
C.UTF-8這個字符集,是可以支持中文的,把承載系統(tǒng)的默認字符集修改為C.UTF-8
4.修改profile文件,并重新加載環(huán)境變量
echo "export LANG=C.UTF-8" >>/etc/profile && source /etc/profile
報錯信息:
Warning from https://mirrors.aliyun.com/composer: You are using an outdated version of Composer. Composer 2.0 is now available and you should upgrade. See https://getcomposer.org/2
報錯原因:
公司用的swoft鏡像里面composer的版本是1.9,目前composer新版為2.*,需要升級才能安裝依賴
使用命令 composer self-update 升級composer
在swoft_start.sh腳本文件中加入該命令即可
#!/bin/sh
check_install() {
? ? if? [ ! -e $1 ]; then
? ? composer -v && composer self-update && composer install && touch $1
? ? fi
? ? return $?
}
check_install "install.lock"
if? [ $? -eq 0 ]; then
? ? swoftcli run
else
? ? echo $?
fi
報錯信息
(Swoft\\Rpc\\Client\\Exception\\RpcResponseException)? Route(1.0-App\\Rpc\\Lib\\BspSms\\SmsInterface) is not founded!At /var/www/swoft/vendor/swoft/rpc-server/src/Middleware/DefaultMiddleware.php line 57",
報錯原因:
Rpc客戶端的接口類命名空間跟服務(wù)端的不一致
現(xiàn)在服務(wù)端的接口命名空間全都在App/Rpc/Lib級,調(diào)用服務(wù)時,客戶端接口也只能在App/Rpc/Lib級,否則就會報找不到路由。
報錯信息
pc客戶端請求的數(shù)據(jù)包格式不對,服務(wù)端無法解析,頻繁請求報如下錯誤:
json_decode error: Syntax error
報錯原因,
bean.php加了/r/n注釋代碼,swoft1不能注釋掉這行,請確認服務(wù)端版本是swoft1還是swoft2

提示redis某個方法不能用
報錯原因
swoft官方更新的高版本與其依賴的redis庫不兼容,官方目前已經(jīng)修復(fù),但我們自己使用的直接固定版本就行,目前固定版本為 swoft2.0.10
報錯信息
bytes exhausted (tried to allocate 262144 bytes) in /var/www/swoft/vendor/
報錯原因:
bean文件
- 報錯原因:
一般是bean文件來回注入