swoft使用問題(隨手記)

swoft使用問題

swoft-ll使用說明

1.注解類引用相關(guān)

報錯信息:

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注解類


2.打印日記的工具函數(shù)無法打印對象

問題詳情:

調(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)

4.rpc 連接錯誤,提示創(chuàng)建連接失敗

報錯信息

(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


5.解決docker容器不支持中文的問題

問題描述

mysql 容器,設(shè)置了mysql默認數(shù)據(jù)庫字符集、表字符集、字段字符集都為utf8mb4,但插入中文數(shù)據(jù),再取出來會顯示為??,只有在Navicat 中顯示為中文;接口訪問和終端工具使用select語句查出來都是亂碼。終端工具直接會插入不了中文

解決方法

一.查看mysql官方鏡像啟動的容器中字符集狀態(tài)

首先進入容器內(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

6.composer提示版本太舊,安裝依賴一直安裝不了

問題描述

報錯信息:

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

7.Rpc連接報錯, 修改命名空間后提示路由找不到,

問題描述

報錯信息

(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級,否則就會報找不到路由。

8.Rpc連接報錯,json數(shù)據(jù)格式錯誤

問題描述

報錯信息

pc客戶端請求的數(shù)據(jù)包格式不對,服務(wù)端無法解析,頻繁請求報如下錯誤:

json_decode error: Syntax error

報錯原因,

bean.php加了/r/n注釋代碼,swoft1不能注釋掉這行,請確認服務(wù)端版本是swoft1還是swoft2


9. Rpc報錯,redis方法錯誤

問題描述

提示redis某個方法不能用

報錯原因

swoft官方更新的高版本與其依賴的redis庫不兼容,官方目前已經(jīng)修復(fù),但我們自己使用的直接固定版本就行,目前固定版本為 swoft2.0.10

10.swoft容器內(nèi)存溢出,

問題描述

報錯信息

bytes exhausted (tried to allocate 262144 bytes) in /var/www/swoft/vendor/

報錯原因:

bean文件

- 報錯原因:

一般是bean文件來回注入

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容