easyswoole - 基于swoole扩展实现的一款高性能php框架

學(xué)習(xí)Swoole之如何避免成為被坑哭的程序員

很多剛從傳統(tǒng)fpm模式轉(zhuǎn)到swoole內(nèi)存常駐模式的phper,總會(huì)覺得內(nèi)心委屈,甚至想哭,原因swoole總會(huì)讓你懷疑人生,這真的是我之前所認(rèn)知的那個(gè)php語言嗎?怎么那么坑啊。

swoole下常見的"坑"

  • 為何全局變量無法共享呢

    例如,在以下代碼中

    $http = new swoole_http_server("127.0.0.1", 9501);
    $http->on("request", function ($request, $response) {
        static $i;
        $response->end($i);
        $i++;
    });
    
    $http->start();

    就會(huì)有人發(fā)現(xiàn)在swoole下static $i 和在fpm下所理解的輸出不一致。這是在于出現(xiàn)了進(jìn)程克隆,而每個(gè)進(jìn)程之間的數(shù)據(jù)都是不一致的。

  • echo var_dump 無法輸出到瀏覽器(http響應(yīng))

    我們?cè)趂pm模式下,echo $a 是可以把結(jié)果輸出到瀏覽器中的,為何在swoole中就不行呢,原因在于模式的變更,swoole的運(yùn)行模式不再是fpm,而是cli,如果你需要把數(shù)據(jù)響應(yīng)給瀏覽器,你只能 通過Http request回調(diào)中的response對(duì)象進(jìn)行響應(yīng)

  • http請(qǐng)求參數(shù)獲取

    在同swoole的http服務(wù)的時(shí)候,很多人會(huì)發(fā)現(xiàn)$_GET、$_POST等常見全局變量無法使用。這是因?yàn)?_GET、$_POST等變量都是全局的,在swoole當(dāng)中會(huì)出現(xiàn)問題,如果想獲取請(qǐng)求參數(shù),可以用swoole回調(diào)時(shí)提供的Request對(duì)象來進(jìn)行獲取

  • swoole不能使用die/exit

    phper都習(xí)慣用die/exit來調(diào)試代碼,這是因?yàn)檫@個(gè)命令會(huì)直接退出當(dāng)前進(jìn)程,對(duì)于fpm來講,每個(gè)請(qǐng)求都對(duì)應(yīng)一個(gè)獨(dú)立進(jìn)程,退出了問題不大,但是在swoole當(dāng)中,可能一個(gè)進(jìn)程中會(huì)有多個(gè)請(qǐng)求同時(shí)在處理,如果你exit或者die來退出當(dāng)前進(jìn)程,會(huì)導(dǎo)致數(shù)據(jù)丟失。

  • swoole下為何需要斷線重連

    很多程序員都習(xí)慣性的把數(shù)據(jù)庫連接做單例化處理,這樣很明顯帶來的好處就是節(jié)約了每次請(qǐng)求數(shù)據(jù)庫需要連接多次的開銷。那么為何在swoole下總是報(bào)錯(cuò)提示我數(shù)據(jù)庫斷線了呢? 原因在于,傳統(tǒng)fpm下,請(qǐng)求結(jié)束了,那么就會(huì)執(zhí)行進(jìn)程清理,數(shù)據(jù)庫連接也被清理了,下次進(jìn)來的時(shí)候,才會(huì)執(zhí)行重新連接。這樣就保證了連接都是可用的狀態(tài)。但是在swoole常駐內(nèi)存的情況下, 請(qǐng)求結(jié)束后,該連接并不會(huì)被清理,依舊保留在內(nèi)存空間內(nèi),而該連接若是長時(shí)間沒有使用,或者是因?yàn)榫W(wǎng)絡(luò)波動(dòng),那么就會(huì)斷開。下次請(qǐng)求進(jìn)來的時(shí)候,你沒有判斷連接狀態(tài),就直接去執(zhí)行sql語句,那么就意味著你操作了一個(gè)斷線的數(shù)據(jù)庫連接,因此肯定會(huì)報(bào)錯(cuò)。

  • 內(nèi)存泄露 很多人用swoole寫服務(wù)的時(shí)候,總是跑著跑著就莫名其妙的內(nèi)存不足。這是因?yàn)閟woole是一個(gè)常駐進(jìn)程型的模型,在fpm下,請(qǐng)求結(jié)束之后會(huì)將進(jìn)程內(nèi)的變量進(jìn)行清理,而swoole進(jìn)程全局期的變量并不會(huì)因?yàn)檎?qǐng)求的結(jié)束而被清理,會(huì)一直保存在內(nèi)存中,一方面提高了效率,但是也讓開發(fā)者必須注意到變量回收的必要性。

  • 協(xié)程上下文訪問安全 使用swoole協(xié)程的時(shí)候,會(huì)有人遇到變量的值不符合預(yù)期的情況,這里面可能是變量污染在作祟,在傳統(tǒng)php 同步阻塞的編程模式下,所有的執(zhí)行都是強(qiáng)制順序執(zhí)行的。但是在swoole中,多個(gè)協(xié)程之間是交替執(zhí)行的,可能a協(xié)程讓出執(zhí)行權(quán)的時(shí)候b協(xié)程對(duì)某個(gè)跨協(xié)程變量進(jìn)行了修改,那么當(dāng)a協(xié)程恢復(fù)執(zhí)行權(quán)的時(shí)候這個(gè)跨協(xié)程變量將不是讓出時(shí)的值了(如果你對(duì)mysql有一定了解,就會(huì)發(fā)現(xiàn)這個(gè)情況并不難理解)。 同時(shí)為了解決這個(gè)問題,我們通常在編程是要注意跨協(xié)程變量的使用,以及使用協(xié)程單例的方式來控制變量。

    使用swoole要學(xué)習(xí)的知識(shí)點(diǎn)

以下內(nèi)容中,必須 代表一定要先學(xué)習(xí)的部分,如果不懂會(huì)導(dǎo)致學(xué)習(xí)困難和跑偏,寫的代碼無法應(yīng)用在生產(chǎn)環(huán)境; 應(yīng)該 代表建議學(xué)習(xí)的知識(shí)點(diǎn),但是也可以只是了解; 可以 代表推薦去學(xué)習(xí),通常是開發(fā)者的弱點(diǎn)。

  • 基礎(chǔ)編程知識(shí)

    • 應(yīng)該了解阻塞非阻塞的區(qū)別
    • 必須清楚PHP的GC機(jī)制 這個(gè)必須清楚,大多數(shù)php開發(fā)者都不清楚
    • 必須清楚php面向?qū)ο缶幊?/code> 這里一定要搞清楚對(duì)象引用機(jī)制和對(duì)象與內(nèi)存之間的關(guān)系
    • 必須清楚資源及連接句柄的相關(guān)知識(shí)
  • 多進(jìn)程編程

    • 必須清楚fpmswoole的多進(jìn)程模型及其區(qū)別
    • 必須了解 進(jìn)程間通訊進(jìn)程隔離應(yīng)該了解進(jìn)程信號(hào)量
  • 基礎(chǔ)的TCP/UDP認(rèn)知

    • 應(yīng)該清楚TCP和UDP的區(qū)別
    • 應(yīng)該清楚客戶端和服務(wù)端的區(qū)別
    • 必須了解OSI七層模型中的上四層 了解常見應(yīng)用層協(xié)議如http ftp smtp
  • 協(xié)程

    • 必須清楚swoole協(xié)程工作模式
    • 必須清楚如何判斷變量是否會(huì)跨協(xié)程使用

總結(jié)

總而言之,大多數(shù)php開發(fā)者學(xué)習(xí)swoole時(shí)候都會(huì)覺得坑的原因是來自于自身知識(shí)儲(chǔ)備的不足。對(duì)于很多其他語言開發(fā)者必須掌握的知識(shí),php開發(fā)時(shí)可能就無需掌握,但是這也是欠的技術(shù)債,會(huì)在進(jìn)一步提升的時(shí)候遇到的瓶頸;導(dǎo)致在使用swoole的時(shí)候出了各種各樣的問題。實(shí)際上,swoole是一個(gè)很強(qiáng)大的php拓展,他重新定義了php,讓php有了更強(qiáng)的生命力。

主站蜘蛛池模板: 机械设备回收_二手机器回收_设备拆除回收_广州益美机械设备回收公司 | 在线腐蚀率仪,在线污垢热阻仪,靶式光源仪-北京同德创业科技有限公司 | 郑州润滑油展-第16届中国润滑油、脂及汽车养护展览会-2025年5月27-28日-郑州国际会展中心 | 上海珑析仪表有限公司| 江苏美鑫食品科技有限公司| 油气回收设备厂家_加油站/化工厂油气回收装置解决方案-金辉环保 油漆颜料砂磨机,油墨水砂磨机,水性涂料砂磨机-常州市奥能达机械设备有限公司 | 无锡大型数控龙门铣,喷涂加工,回火抛丸加工,精密不锈钢焊接机床身机床底座制造加工-无锡美高帝机械有限公司 | 呼吸家官网|肺功能检测仪生产厂家|国产肺功能仪知名品牌|肺功能检测仪|肺功能测试仪|婴幼儿肺功能仪|弥散残气肺功能仪|肺功能测试系统|广州红象医疗科技有限公司|便携式肺功能仪|大肺功能仪|呼吸康复一体机|儿童肺功能仪|肺活量计|医用简易肺功能仪|呼吸康复系统|肺功能仪|弥散肺功能仪(大肺)|便携式肺功能检测仪|肺康复|呼吸肌力测定肺功能仪|肺功能测定仪|呼吸神经肌肉刺激仪|便携式肺功能 | 思达测试|山东思达高科机械设备有限公司 | 曲阜市好博医疗器械有限公司_手术无影灯厂家,电动手术台出售,妇科手术台价格 | 永磁耦合_重载永磁软起_能量回馈式调速器_磁力耦合器_江苏磁谷科技股份有限公司官方网站 | 河北浩元保温材料有限公司 | 佳龙食品集团|高端辣条领导品牌 加药装置-排油烟装置-工业滤水器-连云港灵动 | 自动超声波清洗机_五金超声波清洗机厂家_超声波模具价格_东莞劲荣自动化 | 游离二氧化硅处理仪-恒温恒湿称重系统-智能蒸馏仪-硫化物酸化吹气仪-萃取仪-COD消解仪 | 一次性妇科用品_一次性医疗用品_一次性口腔器械盒_天津市双利医疗器械有限责任公司 | 绍兴上虞大成网络有限公司——因为专注,所以专业 | 南京文化墙设计公司,南京包装设计制作印刷,南京PPT设计公司,导视制作公司,企业logo设计 | 重庆监控-监控系统-大型弱电工程-重庆万建电子工程有限责任公司是智能化一级工程公司 | 上海上市答谢酒会_企业年会_新品上市发布会_周年/开业庆典_会议会务_活动策划布置演出公司 | 领先的木工机械生产厂家,原木加工流水线,立式带锯机,数控木工跑车-邢台亚士达机械制造有限公司 | 普利塞HS穿刺活检针-巴德穿刺活检针-美创爱琅Argon活检针同轴针-山东瑞玺源 | 网带式等温正火生产线_燃气式铝合金加热炉_燃气式烘干窑炉-湖州中科炉业科技有限公司 | 氢能展,氢能展会,燃料电池展,加氢设备_氢气储运_制氢设备_氢燃料汽车_加氢站成套设备 | 上海机械加工-机械加工-精密机械加工-上海欧野精工机械有限公司 上海慧泰仪器制造有限公司_一体型马弗炉-可控真空干燥箱-强光稳定性试验箱 | 辽宁大卯新能源供热设备制造有限公司官方网站,大卯新能源,大卯新能源供热设备 | 气动球阀,电动蝶阀,调节阀,衬氟阀门,水利控制阀,大口径阀门生产厂家-上海百钢阀门集团有限公司-官网,上海阀门品牌 | 金刚石线切割-电火花穿孔机-中走丝线切割-泰州锐特 | 暖气片-工程暖气片厂家【专注工程暖气片30年】-北铸暖气片 | 上海联锐精密机械有限公司-【官网】 | 煤泥烘干机,酒糟烘干机,药渣烘干机,酵母烘干机,烘干机厂家-瑞奥新能源 | 益家304不锈钢水管厂家|批发代理|价格|薄壁|广东益家管业有限公司 | 浙江健朗-舒华跑步机|公园运动器材|商用健身设备|户外健身器材厂家 | 徐州户外广告,标识标牌,展陈空间,精神堡垒-徐州雅努思文化发展有限公司 | 强德防盗门-防盗门厂家-中国防盗门十大品牌-强德门业 - 浙江臻品工贸有限公司 | 热电阻_热电偶_压力表_压力变送器_磁翻板液位计 - 淮安忠和测控仪表有限公司 | 铅板-济南鑫玉防辐射材料有限公司| 上海乾乙智能科技有限公司官网 | 思源医疗器械网,雾化器厂家,医用床生产厂家,医疗器械厂家,医疗器械代加工 | 无缝钢管生产厂家-20G-L360N无缝钢管价格-天津海诚无缝钢管集团 无尘投料站-真空上料机-旋振筛|超声波振动筛|摇摆筛|筛分机-新乡市欧霖佳机械有限公司 | 直膨式空调机组_风冷恒温恒湿_转轮式热回收_屋顶式空调机组_德州瑞尼森环保科技有限公司 |