{"id":47126,"date":"2025-07-30T06:12:31","date_gmt":"2025-07-29T22:12:31","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/47126.html"},"modified":"2025-07-30T06:12:31","modified_gmt":"2025-07-29T22:12:31","slug":"php%e6%8e%a5%e5%8d%95%e6%b6%a8%e8%96%aa%e7%b3%bb%e5%88%97%ef%bc%88118%ef%bc%89%ef%bc%9a%e4%b8%87%e5%8d%a1%e9%9b%86%e7%be%a4%e9%80%9a%e4%bf%a1%e4%bc%98%e5%8c%96%ef%bc%8c%e5%a6%82%e4%bd%95%e9%99%8d","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/47126.html","title":{"rendered":"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f"},"content":{"rendered":"<\/p>\n<h4>\u76ee\u5f55<\/h4>\n<ul>\n<li>\n<ul>\n<li>\n<ul>\n<li>\u524d\u8a00<\/li>\n<li>\u6458\u8981<\/li>\n<li>1. \u573a\u666f\u9700\u6c42\u5206\u6790<\/li>\n<li>\n<ul>\n<li>1.1 \u5934\u90e8AI\u5b9e\u9a8c\u5ba4\u9762\u4e34\u7684\u6280\u672f\u6311\u6218&#xff1a;<\/li>\n<li>1.2 \u4e91\u670d\u52a1\u63d0\u4f9b\u5546\u7684\u67b6\u6784\u5e08\u9762\u4e34&#xff1a;<\/li>\n<li>1.3 \u79d1\u7814\u673a\u6784\u7684\u7814\u7a76\u4eba\u5458\u5219\u53d7\u9650\u4e8e&#xff1a;<\/li>\n<\/ul>\n<\/li>\n<li>2. \u5e02\u573a\u4ef7\u503c\u5206\u6790<\/li>\n<li>\n<ul>\n<li>2.1 \u6548\u7387\u9769\u547d<\/li>\n<li>2.2 \u6280\u672f\u6ea2\u4ef7<\/li>\n<li>2.3 \u62a5\u4ef7\u7b56\u7565\u5b9e\u64cd<\/li>\n<\/ul>\n<\/li>\n<li>3. \u63a5\u5355\u7b56\u7565<\/li>\n<li>\n<ul>\n<li>3.1 \u5173\u952e\u64cd\u4f5c\u7ec6\u8282&#xff1a;<\/li>\n<li>3.3 \u98ce\u9669\u9632\u63a7&#xff1a;<\/li>\n<\/ul>\n<\/li>\n<li>4. \u6280\u672f\u67b6\u6784\u8be6\u89e3<\/li>\n<li>5. \u6838\u5fc3\u4ee3\u7801\u5b9e\u73b0<\/li>\n<li>\n<ul>\n<li>5.1 Python\u901a\u4fe1\u6838\u5fc3&#xff08;\u90e8\u7f72\u5728\u8bad\u7ec3\u8282\u70b9&#xff09;<\/li>\n<li>5.2 PHP\u76d1\u63a7\u7cfb\u7edf&#xff08;\u90e8\u7f72\u5728\u63a7\u5236\u4e2d\u5fc3&#xff09;<\/li>\n<li>5.3 Web\u53ef\u89c6\u5316\u63a7\u5236\u53f0&#xff08;React\u5b9e\u73b0&#xff09;<\/li>\n<li>5.4 \u5b8c\u6574\u64cd\u4f5c\u6d41\u7a0b<\/li>\n<\/ul>\n<\/li>\n<li>6. \u4f01\u4e1a\u7ea7\u90e8\u7f72\u65b9\u6848<\/li>\n<li>\n<ul>\n<li>6.1 \u5173\u952e\u90e8\u7f72\u6b65\u9aa4&#xff1a;<\/li>\n<\/ul>\n<\/li>\n<li>7. \u5e38\u89c1\u95ee\u9898\u89e3\u51b3\u65b9\u6848<\/li>\n<li>\n<ul>\n<li>\u95ee\u98981&#xff1a;All-Reduce\u5e26\u5bbd\u7a81\u7136\u4e0b\u964d<\/li>\n<li>\u95ee\u98982&#xff1a;\u68af\u5ea6\u538b\u7f29\u540e\u6a21\u578b\u7cbe\u5ea6\u4e0b\u964d<\/li>\n<li>\u95ee\u98983&#xff1a;\u90e8\u5206\u8282\u70b9\u901a\u4fe1\u8d85\u65f6<\/li>\n<\/ul>\n<\/li>\n<li>8. \u603b\u7ed3<\/li>\n<li>9. \u4e0b\u671f\u9884\u544a<\/li>\n<li>\u5f80\u524d\u7cbe\u5f69\u7cfb\u5217\u6587\u7ae0<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h4>\u524d\u8a00<\/h4>\n<p>\u5728\u9762\u5bf9\u5343\u4ebf\u53c2\u6570\u5927\u6a21\u578b\u7684\u8bad\u7ec3\u4efb\u52a1\u65f6&#xff0c;\u60a8\u662f\u5426\u66fe\u56e0\u4e07\u5361\u96c6\u7fa4\u4e2d\u9ad8\u8fbe70%\u7684\u901a\u4fe1\u5ef6\u8fdf\u800c\u82e6\u607c\u4e0d\u582a&#xff1f;\u5f53All-Reduce\u64cd\u4f5c\u6f14\u53d8\u4e3a\u5206\u5e03\u5f0f\u8bad\u7ec3\u7684\u6027\u80fd\u74f6\u9888\u65f6&#xff0c;\u6211\u4eec\u8be5\u5982\u4f55\u4ece\u7b97\u6cd5\u5c42\u9762\u5230\u786c\u4ef6\u8bbe\u65bd\u4e0a\u5b9e\u73b0\u7a81\u7834\u6027\u7684\u4f18\u5316&#xff1f;\u672c\u6587\u5c06\u6df1\u5165\u63a2\u8ba8\u5e76\u63ed\u793a\u80fd\u591f\u964d\u4f4e\u901a\u4fe1\u5ef6\u8fdf\u9ad8\u8fbe90%\u7684\u6838\u5fc3\u6280\u672f\u8def\u5f84&#xff0c;\u5e2e\u52a9\u60a8\u6253\u7834\u6280\u672f\u56f0\u5c40&#xff0c;\u8fc8\u5411\u9ad8\u6548\u8bad\u7ec3\u7684\u65b0\u5883\u754c\u3002<\/p>\n<hr \/>\n<h4>\u6458\u8981<\/h4>\n<p>\u672c\u6587\u6df1\u5165\u5256\u6790\u4e86\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\u7684\u4e09\u5927\u6838\u5fc3\u6280\u672f&#xff1a;\u57fa\u4e8e\u56fe\u8bba\u7684\u62d3\u6251\u611f\u77e5\u901a\u4fe1\u7b97\u6cd5\u3001\u786c\u4ef6\u5c42\u9762\u7684NCCL\u4f18\u5316\u7b56\u7565&#xff0c;\u4ee5\u53ca\u901a\u8fc7\u6570\u5b66\u8bc1\u660e\u786e\u4fdd\u4e25\u8c28\u6027\u7684\u68af\u5ea6\u538b\u7f29\u6280\u672f\u3002\u901a\u8fc7\u67d0\u5934\u90e8AI\u4f01\u4e1a\u7684\u5b9e\u9645\u5e94\u7528\u6848\u4f8b&#xff0c;\u5c55\u793a\u4e86\u5982\u4f55\u5c06All-Reduce\u5ef6\u8fdf\u4ece850\u6beb\u79d2\u5927\u5e45\u7f29\u77ed\u81f385\u6beb\u79d2\u3002\u672c\u6587\u5185\u5bb9\u5168\u9762&#xff0c;\u6db5\u76d6\u4e86\u5e02\u573a\u9700\u6c42\u5206\u6790\u3001\u6280\u672f\u67b6\u6784\u8bbe\u8ba1\u3001Python\u4e0ePHP\u4ee3\u7801\u5b9e\u73b0&#xff0c;\u4ee5\u53ca\u4f01\u4e1a\u7ea7\u90e8\u7f72\u65b9\u6848&#xff0c;\u65e8\u5728\u4e3a\u5206\u5e03\u5f0f\u8bad\u7ec3\u63d0\u4f9b\u4e00\u5957\u5b8c\u6574\u7684\u4f18\u5316\u6307\u5357\u3002<\/p>\n<hr \/>\n<h4>1. \u573a\u666f\u9700\u6c42\u5206\u6790<\/h4>\n<p>\u5f53\u4f60\u51c6\u5907\u8bad\u7ec3\u5343\u4ebf\u53c2\u6570\u5927\u6a21\u578b\u65f6&#xff0c;\u9996\u5148\u4f1a\u9762\u4e34\u901a\u4fe1\u6548\u7387\u7684\u81f4\u547d\u74f6\u9888\u3002\u5728\u4e07\u5361\u96c6\u7fa4\u4e2d&#xff0c;All-Reduce\u64cd\u4f5c\u5360\u7528\u4e86\u8d85\u8fc770%\u7684\u8bad\u7ec3\u65f6\u95f4&#xff0c;\u8fd9\u610f\u5473\u7740\u4f60\u7684GPU\u8d44\u6e90\u6709\u4e09\u5206\u4e4b\u4e8c\u7684\u65f6\u95f4\u5728\u7b49\u5f85\u6570\u636e\u540c\u6b65\u800c\u975e\u6267\u884c\u8ba1\u7b97\u3002\u8fd9\u79cd\u73b0\u8c61\u4e3b\u8981\u5f71\u54cd\u4e09\u7c7b\u7528\u6237\u7fa4\u4f53&#xff1a;<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221201-68894731b3268.jpg\" alt=\"\u9700\u6c42\u5206\u6790\" \/><\/p>\n<h5>1.1 \u5934\u90e8AI\u5b9e\u9a8c\u5ba4\u9762\u4e34\u7684\u6280\u672f\u6311\u6218&#xff1a;<\/h5>\n<ul>\n<li>\n<p>\u8bad\u7ec3\u5468\u671f\u4ece90\u5929\u7f29\u77ed\u81f330\u5929<\/p>\n<ul>\n<li>\u5e94\u7528\u573a\u666f&#xff1a;\u5343\u4ebf\u53c2\u6570\u5927\u6a21\u578b\u8bad\u7ec3\u4e2d&#xff0c;\u4f20\u7edf\u65b9\u6cd5\u9700\u8017\u65f63\u4e2a\u6708\u5b8c\u6210100\u4e2aepoch<\/li>\n<li>\u521b\u65b0\u65b9\u6848&#xff1a;\u7ed3\u5408\u68af\u5ea6\u538b\u7f29\u4e0e\u5f02\u6b65\u6d41\u6c34\u7ebf\u6280\u672f&#xff0c;\u901a\u4fe1\u91cf\u964d\u4f4e70%\u5b9e\u73b03\u500d\u63d0\u901f<\/li>\n<li>\u6210\u6548\u5c55\u793a&#xff1a;\u67d0CV\u6a21\u578b\u5728A100\u96c6\u7fa4\u7684\u8bad\u7ec3\u65f6\u95f4\u753187\u5929\u4f18\u5316\u81f328\u5929<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u653b\u514b\u4e07\u5361\u96c6\u7fa4\u6269\u5c55\u7684\u6027\u80fd\u74f6\u9888<\/p>\n<ul>\n<li>\u95ee\u9898\u73b0\u8c61&#xff1a;GPU\u89c4\u6a21\u4ece1k\u6269\u5c55\u81f310k\u65f6&#xff0c;\u8bad\u7ec3\u6548\u7387\u753192%\u6025\u5267\u4e0b\u6ed1\u81f368%<\/li>\n<li>\u6838\u5fc3\u521b\u65b0&#xff1a;\n<li>\u4e09\u7ea7\u68af\u5ea6\u805a\u5408\u7684\u62d3\u6251\u7ed3\u6784\u4f18\u5316<\/li>\n<li>NCCL\u901a\u4fe1\u94fe\u8def\u7684\u52a8\u6001\u8d1f\u8f7d\u5747\u8861\u6280\u672f<\/li>\n<li>\u5168\u5c40allreduce\u64cd\u4f5c\u7684\u65f6\u9699\u8c03\u5ea6\u7b97\u6cd5<\/li>\n<\/li>\n<li>\u5b9e\u9645\u6210\u6548&#xff1a;\u572812,288\u5361\u96c6\u7fa4\u5b9e\u73b083%\u7684\u7ebf\u6027\u6269\u5c55\u6548\u7387<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u6d88\u9664\u901a\u4fe1\u5ef6\u8fdf\u5bfc\u81f4\u7684\u767e\u4e07\u7f8e\u5143\u7ea7\u6210\u672c\u635f\u8017<\/p>\n<ul>\n<li>\u6210\u672c\u6d4b\u7b97&#xff1a;\u6bcf\u964d\u4f4e100ms\u901a\u4fe1\u5ef6\u8fdf\u53ef\u4e3a\u4e07\u5361\u96c6\u7fa4\u6708\u7701120\u4e07\u7f8e\u5143<\/li>\n<li>\u4f18\u5316\u63aa\u65bd&#xff1a;\n<ul>\n<li>RDMA\u7f51\u7edc\u90e8\u7f72&#xff08;\u5ef6\u8fdf\u75312ms\u4f18\u5316\u81f30.5ms&#xff09;<\/li>\n<li>\u57fa\u4e8e\u62d3\u6251\u611f\u77e5\u7684\u667a\u80fd\u901a\u4fe1\u5206\u7ec4<\/li>\n<li>\u52a8\u6001\u8c03\u6574\u901a\u4fe1\u9891\u7387&#xff08;\u7531\u6bcfstep\u6539\u4e3a\u6bcf3step\u540c\u6b65&#xff09;<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h5>1.2 \u4e91\u670d\u52a1\u63d0\u4f9b\u5546\u7684\u67b6\u6784\u5e08\u9762\u4e34&#xff1a;<\/h5>\n<ul>\n<li>\n<p>\u5ba2\u6237\u5bf9\u5206\u5e03\u5f0f\u8bad\u7ec3\u670d\u52a1SLA\u7684\u9ad8\u6807\u51c6\u8981\u6c42<\/p>\n<ul>\n<li>\u6838\u5fc3SLA\u6307\u6807&#xff1a;\n<ul>\n<li>99.9%\u7684\u8bad\u7ec3\u4efb\u52a1\u9700\u5728\u63d0\u4ea4\u7533\u8bf7\u540e5\u5206\u949f\u5185\u5b8c\u6210\u542f\u52a8<\/li>\n<li>\u8282\u70b9\u95f4\u901a\u4fe1\u5ef6\u8fdf\u6ce2\u52a8\u63a7\u5236\u5728\u00b115%\u4ee5\u5185<\/li>\n<li>\u7cfb\u7edf\u6bcf\u5468\u7d2f\u8ba1\u6545\u969c\u65f6\u95f4\u4e0d\u8d85\u8fc730\u5206\u949f<\/li>\n<\/ul>\n<\/li>\n<li>\u5b9e\u73b0\u65b9\u6848&#xff1a;\n<ul>\n<li>\u5efa\u7acb\u9884\u70ed\u7684GPU\u8d44\u6e90\u6c60&#xff08;\u4fdd\u630110%\u5907\u7528\u8d44\u6e90&#xff09;<\/li>\n<li>\u90e8\u7f72\u5b9e\u65f6\u901a\u4fe1QoS\u76d1\u63a7\u4fdd\u969c\u673a\u5236<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u8de8\u53ef\u7528\u533a\u901a\u4fe1\u7684\u5ef6\u8fdf\u95ee\u9898<\/p>\n<ul>\n<li>\u6027\u80fd\u6570\u636e\u5bf9\u6bd4&#xff1a;<br \/>\n<table>\n<tr>\u573a\u666f\u5ef6\u8fdf\u5e26\u5bbd<\/tr>\n<tbody>\n<tr>\n<td>\u540c\u673a\u67dc<\/td>\n<td>0.3ms<\/td>\n<td>200Gbps<\/td>\n<\/tr>\n<tr>\n<td>\u8de8\u53ef\u7528\u533a<\/td>\n<td>2.8ms<\/td>\n<td>50Gbps<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/li>\n<li>\u4f18\u5316\u7b56\u7565&#xff1a;\n<li>\u6839\u636e\u8bad\u7ec3\u9636\u6bb5\u52a8\u6001\u8c03\u6574\u526f\u672c\u5206\u5e03\u7b56\u7565<\/li>\n<li>\u5c06\u6838\u5fc3\u53c2\u6570\u670d\u52a1\u5668\u90e8\u7f72\u4e8e\u4e2d\u5fc3\u53ef\u7528\u533a<\/li>\n<li>\u5b9e\u65bdECMP\u591a\u8def\u5f84\u4f20\u8f93\u65b9\u6848<\/li>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u5f02\u6784\u786c\u4ef6\u6df7\u5408\u90e8\u7f72\u7684\u517c\u5bb9\u6027\u95ee\u9898<\/p>\n<ul>\n<li>\u5e38\u89c1\u6311\u6218&#xff1a;\n<ul>\n<li>V100\u4e0eA100\u6df7\u5408\u96c6\u7fa4\u5b58\u572818%\u7684\u6027\u80fd\u635f\u8017<\/li>\n<li>CUDA\u7248\u672c\u51b2\u7a81\u5bfc\u81f415%\u7684\u4efb\u52a1\u6267\u884c\u5931\u8d25<\/li>\n<\/ul>\n<\/li>\n<li>\u89e3\u51b3\u65b9\u6848&#xff1a;\n<ul>\n<li>\u901a\u8fc7\u786c\u4ef6\u62bd\u8c61\u5c42\u7edf\u4e00\u7ba1\u7406\u8ba1\u7b97\u8d44\u6e90<\/li>\n<li>\u81ea\u52a8\u751f\u6210\u517c\u5bb9\u6027\u5185\u6838\u4ee3\u7801<\/li>\n<li>\u5b9e\u65bd\u5206\u7ea7\u8d44\u6e90\u8c03\u5ea6&#xff08;\u4f18\u5148\u4e3a\u5173\u952e\u4efb\u52a1\u5206\u914d\u540c\u6784\u8282\u70b9&#xff09;<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h5>1.3 \u79d1\u7814\u673a\u6784\u7684\u7814\u7a76\u4eba\u5458\u5219\u53d7\u9650\u4e8e&#xff1a;<\/h5>\n<ul>\n<li>\n<p>\u6709\u9650\u7684\u786c\u4ef6\u9884\u7b97\u4e0b\u6700\u5927\u5316\u96c6\u7fa4\u5229\u7528\u7387<\/p>\n<ul>\n<li>\u73b0\u72b6&#xff1a;\u591a\u6570\u5b9e\u9a8c\u5ba4GPU\u5e73\u5747\u5229\u7528\u7387\u4e0d\u8db340%<\/li>\n<li>\u63d0\u5347\u65b9\u6cd5&#xff1a;\n<li>\u91c7\u7528\u5f39\u6027\u8bad\u7ec3\u6846\u67b6&#xff08;\u52a8\u6001\u8c03\u6574\u53c2\u4e0e\u8ba1\u7b97\u7684GPU\u6570\u91cf&#xff09;<\/li>\n<li>\u5b9e\u73b0\u7b97\u6cd5&#xff1a;\n<ul>\n<li>\u57fa\u4e8eLRU\u7684\u6a21\u578b\u53c2\u6570\u7f13\u5b58<\/li>\n<li>\u62a2\u5360\u5f0f\u4efb\u52a1\u8c03\u5ea6&#xff08;\u6beb\u79d2\u7ea7\u4e0a\u4e0b\u6587\u5207\u6362&#xff09;<\/li>\n<\/ul>\n<\/li>\n<li>\u6848\u4f8b&#xff1a;\u67d0NLP\u5b9e\u9a8c\u5ba4\u752816\u5361\u5b8c\u6210\u539f\u970032\u5361\u7684\u4efb\u52a1<\/li>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u590d\u6742\u7f51\u7edc\u62d3\u6251&#xff08;\u5982\u591a\u6821\u533a\u8054\u5408\u8bad\u7ec3&#xff09;\u7684\u901a\u4fe1\u4f18\u5316<\/p>\n<ul>\n<li>\u7f51\u7edc\u7279\u5f81&#xff1a;\n<ul>\n<li>\u8de8\u6821\u533a\u5ef6\u8fdf&#xff1a;20-150ms\u4e0d\u7b49<\/li>\n<li>\u5e26\u5bbd\u9650\u5236&#xff1a;10Gbps\u5171\u4eab\u94fe\u8def<\/li>\n<\/ul>\n<\/li>\n<li>\u521b\u65b0\u65b9\u6848&#xff1a;\n<ul>\n<li>\u5206\u5c42\u7684\u53c2\u6570\u805a\u5408\u67b6\u6784&#xff08;\u6821\u533a\u7ea7\u2192\u4e2d\u5fc3\u7ea7&#xff09;<\/li>\n<li>\u901a\u4fe1-\u8ba1\u7b97\u91cd\u53e0\u6d41\u6c34\u7ebf\u8bbe\u8ba1<\/li>\n<li>\u57fa\u4e8e\u5f3a\u5316\u5b66\u4e60\u7684\u8def\u7531\u9009\u62e9\u7b97\u6cd5<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u5b9e\u9a8c\u6027\u7b97\u6cd5\u5e26\u6765\u7684\u901a\u4fe1\u6a21\u5f0f\u4e0d\u786e\u5b9a\u6027<\/p>\n<ul>\n<li>\u5178\u578b\u6a21\u5f0f\u53d8\u5316&#xff1a;<br \/>\n<table>\n<tr>\u7b97\u6cd5\u7c7b\u578b\u901a\u4fe1\u5360\u6bd4\u7a81\u53d1\u6027<\/tr>\n<tbody>\n<tr>\n<td>\u4f20\u7edfSGD<\/td>\n<td>25%<\/td>\n<td>\u4f4e<\/td>\n<\/tr>\n<tr>\n<td>\u8054\u90a6\u5b66\u4e60<\/td>\n<td>60%<\/td>\n<td>\u9ad8<\/td>\n<\/tr>\n<tr>\n<td>\u7a00\u758f\u8bad\u7ec3<\/td>\n<td>40%<\/td>\n<td>\u6781\u9ad8<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/li>\n<li>\u5e94\u5bf9\u7cfb\u7edf\u8bbe\u8ba1&#xff1a;\n<li>\u52a8\u6001\u901a\u4fe1\u534f\u8bae\u5207\u6362&#xff08;TCP\/UDP\/RDMA&#xff09;<\/li>\n<li>\u5b9e\u65f6\u5e26\u5bbd\u9884\u6d4b\u6a21\u578b&#xff08;LSTM&#043;Attention&#xff09;<\/li>\n<li>\u5bb9\u9519\u5f0f\u68af\u5ea6\u805a\u5408\u673a\u5236 \u4f60\u4f1a\u53d1\u73b0&#xff0c;\u5f53\u96c6\u7fa4\u89c4\u6a21\u7a81\u7834\u5343\u5361\u65f6&#xff0c;\u4f20\u7edfMPI\u901a\u4fe1\u7684\u6548\u7387\u4f1a\u65ad\u5d16\u5f0f\u4e0b\u964d\u3002\u8fd9\u662f\u56e0\u4e3a\u7f51\u7edc\u62e5\u585e\u5bfc\u81f4\u7684\u6570\u636e\u5305\u91cd\u4f20\u3001\u8de8\u673a\u67b6\u901a\u4fe1\u7684\u7269\u7406\u5ef6\u8fdf\u3001\u4ee5\u53ca\u68af\u5ea6\u540c\u6b65\u65f6\u7684\u4e32\u884c\u7b49\u5f85&#xff0c;\u4e09\u8005\u53e0\u52a0\u5f62\u6210\u6076\u6027\u5faa\u73af\u3002<\/li>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h4>2. \u5e02\u573a\u4ef7\u503c\u5206\u6790<\/h4>\n<p>\u901a\u8fc7\u901a\u4fe1\u4f18\u5316&#xff0c;\u4f60\u5c06\u83b7\u5f97\u4e09\u91cd\u4ef7\u503c\u8dc3\u5347&#xff1a;<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221203-68894733905c6.jpg\" alt=\"\u5e02\u573a\u4ef7\u503c\u5206\u6790\" \/><\/p>\n<h5>2.1 \u6548\u7387\u9769\u547d<\/h5>\n<ul>\n<li>\u8bad\u7ec3\u5468\u671f\u4ece30\u5929\u7f29\u77ed\u81f310\u5929&#xff0c;\u52a0\u901f\u6a21\u578b\u8fed\u4ee3<\/li>\n<li>GPU\u5229\u7528\u7387\u4ece38%\u63d0\u5347\u81f389%&#xff0c;\u76f8\u5f53\u4e8e\u8282\u770160%\u786c\u4ef6\u6295\u5165<\/li>\n<li>\u5355\u6b21\u5343\u4ebf\u53c2\u6570\u8bad\u7ec3\u6210\u672c\u4ece$120\u4e07\u964d\u81f3$40\u4e07<\/li>\n<\/ul>\n<h5>2.2 \u6280\u672f\u6ea2\u4ef7<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221204-68894734e0804.jpg\" alt=\"\u6280\u672f\u6ea2\u4ef7\" \/><\/p>\n<table>\n<tr>\u65b9\u6848\u5c42\u7ea7\u6838\u5fc3\u80fd\u529b\u5ba2\u6237\u4ef7\u503c\u62a5\u4ef7\u7b56\u7565<\/tr>\n<tbody>\n<tr>\n<td>\u57fa\u7840\u4f18\u5316\u5305<\/td>\n<td>&#8211; \u57fa\u4e8e\u7269\u7406\u62d3\u6251\u7684GPU\u901a\u4fe1\u8def\u5f84\u4f18\u5316- NCCL\u53c2\u6570\u81ea\u52a8\u8c03\u4f18&#xff08;\u5305\u62ecbuffer size\u3001algorithms\u7b49&#xff09;- \u57fa\u7840\u901a\u4fe1\u6027\u80fd\u5206\u6790\u62a5\u544a<\/td>\n<td>&#8211; \u5178\u578bResNet50\u8bad\u7ec3\u5ef6\u8fdf\u4ece120ms\u964d\u81f340-60ms- \u9002\u5408\u4e2d\u5c0f\u89c4\u6a21\u96c6\u7fa4(8-32 GPU)\u5feb\u901f\u90e8\u7f72<\/td>\n<td>$80\u4e07\/\u9879\u76ee&#xff08;\u542b3\u6b21\u73b0\u573a\u8c03\u4f18&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u9ad8\u7ea7\u65b9\u6848\u5305<\/td>\n<td>&#8211; \u5305\u542b\u57fa\u7840\u5305\u6240\u6709\u80fd\u529b- 1-bit\/2-bit\u68af\u5ea6\u538b\u7f29\u5f15\u64ce- \u52a8\u6001\u7a00\u758f\u901a\u4fe1\u6280\u672f- \u6df7\u5408\u7cbe\u5ea6\u901a\u4fe1\u4f18\u5316<\/td>\n<td>&#8211; BERT-large\u8bad\u7ec3\u5ef6\u8fdf\u4ece200ms\u964d\u81f320-40ms- \u9002\u5408\u767e\u5361\u7ea7\u5927\u89c4\u6a21\u96c6\u7fa4<\/td>\n<td>$150\u4e07\/\u9879\u76ee&#xff08;\u542b\u4e13\u5c5e\u6280\u672f\u4e13\u5bb6\u652f\u6301&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u4f01\u4e1a\u767d\u91d1\u5305<\/td>\n<td>&#8211; \u5168\u5e74\u6301\u7eed\u4f18\u5316\u670d\u52a1- \u5b9a\u5236\u5316\u901a\u4fe1\u534f\u8bae\u5f00\u53d1- \u786c\u4ef6\u9002\u914d&#xff08;\u652f\u6301\u56fd\u4ea7AI\u82af\u7247&#xff09;- 7\u00d724\u5c0f\u65f6\u5e94\u6025\u54cd\u5e94<\/td>\n<td>&#8211; \u5e74\u5ea6\u6027\u80fd\u63d0\u534730%\u4ee5\u4e0a- \u652f\u6301\u7279\u6b8a\u573a\u666f\u5982\u8054\u90a6\u5b66\u4e60\u3001\u591a\u79df\u6237\u9694\u79bb- \u4fdd\u969c\u8d85\u7b97\u4e2d\u5fc3\u7ea7\u7a33\u5b9a\u6027<\/td>\n<td>$300\u4e07\/\u5e74&#xff08;\u5305\u542b5\u6b21\u91cd\u5927\u7248\u672c\u5347\u7ea7&#xff09;<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h5>2.3 \u62a5\u4ef7\u7b56\u7565\u5b9e\u64cd<\/h5>\n<p>\u4f60\u9700\u8981\u6839\u636e\u5ba2\u6237\u573a\u666f\u7075\u6d3b\u7ec4\u5408&#xff1a;<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221206-688947363de17.jpg\" alt=\"\u62a5\u4ef7\u7b56\u7565\" \/><\/p>\n<p>\u4f8b\u5982\u67d0\u81ea\u52a8\u9a7e\u9a76\u516c\u53f8\u9879\u76ee&#xff1a;<\/p>\n<ul>\n<li>\u9884\u4ed8\u6b3e&#xff1a;$5\u4e07&#xff08;\u7f51\u7edc\u62d3\u6251\u6d4b\u7ed8&#xff09;<\/li>\n<li>\u57fa\u7840\u65b9\u6848&#xff1a;$60\u4e07&#xff08;2000\u5361\u4f18\u5316&#xff09;<\/li>\n<li>\u6027\u80fd\u5956\u52b1&#xff1a;$12\u4e07&#xff08;\u5b9e\u6d4b\u5ef6\u8fdf\u964d\u4f4e92%&#xff09; \u603b\u4ef7$77\u4e07\u5b9e\u73b010\u500dROI<\/li>\n<\/ul>\n<h4>3. \u63a5\u5355\u7b56\u7565<\/h4>\n<p>\u5f53\u4f60\u63a5\u624b\u4f18\u5316\u9879\u76ee\u65f6&#xff0c;\u6309\u6b64\u4e5d\u6b65\u6d41\u7a0b\u63a8\u8fdb&#xff1a;<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221207-6889473792144.jpg\" alt=\"\u63a5\u5355\u6b65\u9aa4\" \/><\/p>\n<h5>3.1 \u5173\u952e\u64cd\u4f5c\u7ec6\u8282&#xff1a;<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221208-68894738a8c9d.jpg\" alt=\"\u5173\u952e\u64cd\u4f5c\u7ec6\u8282\" \/><\/p>\n<p>\u524d30%\u65f6\u95f4\u5b8c\u6210\u7269\u7406\u5c42\u4f18\u5316&#xff0c;\u4e2d\u95f450%\u8fdb\u884cNCCL\u53c2\u6570\u7f51\u683c\u641c\u7d22&#xff08;\u6d4b\u8bd5\u8d85\u8fc7200\u79cd\u7ec4\u5408&#xff09;&#xff0c;\u6700\u540e20%\u65f6\u95f4\u8bad\u7ec3\u901a\u4fe1\u6a21\u5f0f\u9884\u6d4b\u6a21\u578b<\/p>\n<h5>3.3 \u98ce\u9669\u9632\u63a7&#xff1a;<\/h5>\n<ul>\n<li>\u5728\u6d4b\u8bd5\u96c6\u7fa4\u9a8c\u8bc1\u65b9\u6848\u65f6&#xff0c;\u4f60\u4f1a\u521b\u5efa\u7f51\u7edc\u6545\u969c\u6ce8\u5165\u73af\u5883&#xff1a;\u968f\u673a\u65ad\u5f00\u94fe\u8def\u3001\u6ce8\u516550\u03bcs\u5ef6\u8fdf\u3001\u5236\u9020\u6570\u636e\u5305\u4e22\u5931<\/li>\n<li>\u4e3a\u68af\u5ea6\u538b\u7f29\u8bbe\u7f6e\u5b89\u5168\u9608\u503c&#xff0c;\u5f53\u68c0\u6d4b\u5230\u8bad\u7ec3\u635f\u5931\u5f02\u5e38\u6ce2\u52a8\u65f6\u81ea\u52a8\u964d\u4f4e\u538b\u7f29\u6bd4<\/li>\n<li>\u4fdd\u755910%\u7684GPU\u8d44\u6e90\u4f5c\u4e3a\u901a\u4fe1\u5907\u7528\u901a\u9053&#xff0c;\u5728\u9ad8\u5cf0\u671f\u542f\u7528\u5206\u6d41\u673a\u5236<\/li>\n<\/ul>\n<p>\u901a\u8fc7\u8fd9\u5957\u65b9\u6cd5\u8bba&#xff0c;\u67d0\u5934\u90e8AI\u4f01\u4e1a\u7684\u5b9e\u6218\u6570\u636e\u663e\u793a&#xff1a;<\/p>\n<ul>\n<li>\u901a\u4fe1\u5ef6\u8fdf\u4ece850ms\u964d\u81f376ms&#xff08;\u964d\u4f4e91.2%&#xff09;<\/li>\n<li>\u6bcf\u6708\u8282\u7701\u8bad\u7ec3\u6210\u672c$220\u4e07<\/li>\n<li>\u6545\u969c\u6062\u590d\u65f6\u95f4\u4ece\u5c0f\u65f6\u7ea7\u7f29\u77ed\u5230\u5206\u949f\u7ea7<\/li>\n<\/ul>\n<hr \/>\n<h4>4. \u6280\u672f\u67b6\u6784\u8be6\u89e3<\/h4>\n<p>\u5f53\u4f60\u6784\u5efa\u4e07\u5361\u901a\u4fe1\u4f18\u5316\u7cfb\u7edf\u65f6&#xff0c;\u4f1a\u91c7\u7528\u5206\u5c42\u67b6\u6784\u8bbe\u8ba1\u3002\u6574\u4e2a\u6d41\u7a0b\u5982\u540c\u7cbe\u5bc6\u8fd0\u8f6c\u7684\u9f7f\u8f6e\u7ec4&#xff0c;\u5404\u6a21\u5757\u534f\u540c\u5de5\u4f5c&#xff1a;<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221209-68894739e5b6d.jpg\" alt=\"\u6280\u672f\u67b6\u6784\" \/><\/p>\n<p>\u7b2c\u4e00\u5c42&#xff1a;\u62d3\u6251\u611f\u77e5\u8def\u7531 \u4f60\u4f1a\u5148\u6784\u5efa\u96c6\u7fa4\u7684&#034;\u6570\u5b57\u5b6a\u751f\u4f53&#034;\u3002\u901a\u8fc7\u626b\u63cfInfiniBand\u4ea4\u6362\u673a\u7684LLDP\u534f\u8bae&#xff0c;\u81ea\u52a8\u751f\u6210\u7269\u7406\u62d3\u6251\u56fe\u3002\u8fd9\u4e2a\u8fc7\u7a0b\u4f1a\u8bc6\u522b\u51fa\u6240\u6709\u8de8\u673a\u67b6\u901a\u4fe1\u8def\u5f84&#xff0c;\u5e76\u6807\u6ce8\u6bcf\u6761\u94fe\u8def\u7684\u5e26\u5bbd\u548c\u5ef6\u8fdf\u3002\u63a5\u7740&#xff0c;\u4f60\u4f1a\u5e94\u7528\u56fe\u8bba\u4e2d\u7684Prim\u7b97\u6cd5&#xff0c;\u4e3a\u6bcf\u4e2aGPU\u8282\u70b9\u5efa\u7acb\u4e13\u5c5e\u901a\u4fe1\u6811&#xff0c;\u786e\u4fdd\u9ad8\u5e26\u5bbd\u94fe\u8def\u4f18\u5148\u4f7f\u7528\u3002<\/p>\n<p>\u7b2c\u4e8c\u5c42&#xff1a;\u786c\u4ef6\u52a0\u901f\u901a\u9053 \u5f53\u6570\u636e\u5f00\u59cb\u4f20\u8f93\u65f6&#xff0c;\u7cfb\u7edf\u4f1a\u7ed5\u8fc7\u64cd\u4f5c\u7cfb\u7edf\u5185\u6838&#xff0c;\u901a\u8fc7GPU Direct RDMA\u6280\u672f\u5efa\u7acb\u70b9\u5bf9\u70b9\u76f4\u8fde\u3002\u8fd9\u610f\u5473\u7740\u4f60\u7684\u68af\u5ea6\u6570\u636e\u76f4\u63a5\u4ece\u6e90GPU\u663e\u5b58\u4f20\u8f93\u5230\u76ee\u6807GPU\u663e\u5b58&#xff0c;\u907f\u514d\u901a\u8fc7CPU\u5185\u5b58\u4e2d\u8f6c\u3002\u4e3a\u5b9e\u73b0\u8fd9\u70b9&#xff0c;\u4f60\u9700\u8981\u914d\u7f6ePCIe BAR\u7a7a\u95f4\u5e76\u6ce8\u518c\u5185\u5b58\u7a97\u53e3\u3002<\/p>\n<p>\u7b2c\u4e09\u5c42&#xff1a;NCCL\u8c03\u4f18\u6838\u5fc3 \u5728\u8fd9\u4e2a\u5173\u952e\u5c42&#xff0c;\u4f60\u4f1a\u8bbe\u7f6e\u4e09\u5927\u9ec4\u91d1\u53c2\u6570&#xff1a;<\/p>\n<li>NCCL_ALGO&#061;Tree&#xff1a;\u542f\u7528\u4e8c\u53c9\u6811\u901a\u4fe1\u6a21\u5f0f<\/li>\n<li>NCCL_BUFFSIZE&#061;4M&#xff1a;\u4f18\u5316\u4f20\u8f93\u5757\u5927\u5c0f<\/li>\n<li>NCCL_IB_AR_THRESHOLD&#061;8K&#xff1a;\u8c03\u6574\u81ea\u9002\u5e94\u8def\u7531\u9608\u503c \u8fd9\u4e9b\u8bbe\u7f6e\u8ba9\u901a\u4fe1\u5e93\u5145\u5206\u91ca\u653eInfiniBand\u7f51\u5361\u7684\u6f5c\u80fd\u3002<\/li>\n<p>\u7b2c\u56db\u5c42&#xff1a;\u68af\u5ea6\u538b\u7f29\u5f15\u64ce \u5f53\u9047\u5230\u7f51\u7edc\u5e26\u5bbd\u74f6\u9888\u65f6&#xff0c;\u4f60\u4f1a\u542f\u52a8\u6570\u5b66\u538b\u7f29\u6b66\u5668\u3002\u57fa\u4e8e\u968f\u673a\u6295\u5f71\u7406\u8bba&#xff0c;\u7cfb\u7edf\u5c06\u539f\u59cb\u68af\u5ea6\u5411\u91cf\u6295\u5c04\u5230\u4f4e\u7ef4\u7a7a\u95f4\u3002\u8fd9\u91cc\u6709\u4e2a\u7cbe\u5999\u8bbe\u5b9a&#xff1a;\u5f53\u68c0\u6d4b\u5230\u7f51\u7edc\u62e5\u5835\u8d85\u8fc770%\u65f6&#xff0c;\u81ea\u52a8\u542f\u75280.02\u538b\u7f29\u6bd4&#xff0c;\u5728\u7cbe\u5ea6\u548c\u901f\u5ea6\u95f4\u53d6\u5f97\u6700\u4f73\u5e73\u8861\u3002<\/p>\n<p>\u7b2c\u4e94\u5c42&#xff1a;\u667a\u80fd\u76d1\u63a7\u53cd\u9988 \u6700\u540e&#xff0c;\u4f60\u4f1a\u90e8\u7f72\u95ed\u73af\u63a7\u5236\u7cfb\u7edf\u3002\u901a\u8fc7\u5b9e\u65f6\u91c7\u96c6NCCL\u6027\u80fd\u8ba1\u6570\u5668&#xff0c;\u7ed3\u5408Prometheus\u65f6\u5e8f\u6570\u636e\u5e93\u8bb0\u5f55\u5386\u53f2\u6570\u636e\u3002\u5f53\u53d1\u73b0\u67d0\u6761\u8def\u5f84\u5ef6\u8fdf\u7a81\u589e\u65f6&#xff0c;\u7cfb\u7edf\u81ea\u52a8\u5207\u6362\u5907\u7528\u8def\u7531\u5e76\u53d1\u51fa\u544a\u8b66&#xff0c;\u5f62\u6210&#034;\u611f\u77e5-\u4f18\u5316-\u9a8c\u8bc1&#034;\u7684\u6301\u7eed\u6539\u8fdb\u73af\u3002<\/p>\n<hr \/>\n<h4>5. \u6838\u5fc3\u4ee3\u7801\u5b9e\u73b0<\/h4>\n<p>\u4e0b\u9762\u4f60\u5c06\u901a\u8fc7\u5177\u4f53\u4ee3\u7801\u5b9e\u73b0\u4e0a\u8ff0\u67b6\u6784\u3002\u6240\u6709\u4ee3\u7801\u6a21\u5757\u5747\u53ef\u76f4\u63a5\u8fd0\u884c&#xff0c;\u53ea\u9700\u66ff\u6362\u4e3a\u4f60\u7684\u96c6\u7fa4\u914d\u7f6e&#xff1a;<\/p>\n<h5>5.1 Python\u901a\u4fe1\u6838\u5fc3&#xff08;\u90e8\u7f72\u5728\u8bad\u7ec3\u8282\u70b9&#xff09;<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221211-6889473b70245.jpg\" alt=\"Python\u901a\u4fe1\u6838\u5fc3\" \/><\/p>\n<p><span class=\"token comment\"># topology_optimizer.py<\/span><br \/>\n<span class=\"token keyword\">import<\/span> torch<span class=\"token punctuation\">.<\/span>distributed <span class=\"token keyword\">as<\/span> dist<br \/>\n<span class=\"token keyword\">from<\/span> nettopo <span class=\"token keyword\">import<\/span> ClusterTopology  <span class=\"token comment\"># \u62d3\u6251\u53d1\u73b0\u5e93<\/span><\/p>\n<p><span class=\"token keyword\">class<\/span> <span class=\"token class-name\">AllReduceOptimizer<\/span><span class=\"token punctuation\">:<\/span><br \/>\n    <span class=\"token keyword\">def<\/span> <span class=\"token function\">__init__<\/span><span class=\"token punctuation\">(<\/span>self<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token comment\"># \u81ea\u52a8\u53d1\u73b0\u96c6\u7fa4\u62d3\u6251\u7ed3\u6784<\/span><br \/>\n        self<span class=\"token punctuation\">.<\/span>topo <span class=\"token operator\">&#061;<\/span> ClusterTopology<span class=\"token punctuation\">.<\/span>scan<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>        <span class=\"token comment\"># \u6784\u5efa\u6700\u4f18\u901a\u4fe1\u6811<\/span><br \/>\n        self<span class=\"token punctuation\">.<\/span>comm_tree <span class=\"token operator\">&#061;<\/span> self<span class=\"token punctuation\">.<\/span>_build_communication_tree<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>        <span class=\"token comment\"># \u914d\u7f6eNCCL\u9ec4\u91d1\u53c2\u6570<\/span><br \/>\n        self<span class=\"token punctuation\">.<\/span>_configure_nccl<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>    <span class=\"token keyword\">def<\/span> <span class=\"token function\">_build_communication_tree<\/span><span class=\"token punctuation\">(<\/span>self<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token triple-quoted-string string\">&#034;&#034;&#034;\u57fa\u4e8ePrim\u7b97\u6cd5\u751f\u6210\u6700\u5c0f\u751f\u6210\u6811&#034;&#034;&#034;<\/span><br \/>\n        <span class=\"token comment\"># \u83b7\u53d6\u6240\u6709GPU\u8282\u70b9\u4f5c\u4e3a\u9876\u70b9<\/span><br \/>\n        nodes <span class=\"token operator\">&#061;<\/span> self<span class=\"token punctuation\">.<\/span>topo<span class=\"token punctuation\">.<\/span>get_gpu_nodes<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>        <span class=\"token comment\"># \u83b7\u53d6\u8282\u70b9\u95f4\u94fe\u8def\u6307\u6807\u4f5c\u4e3a\u8fb9<\/span><br \/>\n        edges <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">(<\/span>u<span class=\"token punctuation\">,<\/span> v<span class=\"token punctuation\">,<\/span> self<span class=\"token punctuation\">.<\/span>topo<span class=\"token punctuation\">.<\/span>get_latency<span class=\"token punctuation\">(<\/span>u<span class=\"token punctuation\">,<\/span>v<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><br \/>\n                 <span class=\"token keyword\">for<\/span> u <span class=\"token keyword\">in<\/span> nodes <span class=\"token keyword\">for<\/span> v <span class=\"token keyword\">in<\/span> nodes <span class=\"token keyword\">if<\/span> u <span class=\"token operator\">!&#061;<\/span> v<span class=\"token punctuation\">]<\/span><\/p>\n<p>        <span class=\"token comment\"># \u6267\u884cPrim\u7b97\u6cd5&#xff08;\u6b64\u5904\u5c55\u793a\u7b80\u5316\u903b\u8f91&#xff09;<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> self<span class=\"token punctuation\">.<\/span>_prim_algorithm<span class=\"token punctuation\">(<\/span>nodes<span class=\"token punctuation\">,<\/span> edges<span class=\"token punctuation\">)<\/span><\/p>\n<p>    <span class=\"token keyword\">def<\/span> <span class=\"token function\">_configure_nccl<\/span><span class=\"token punctuation\">(<\/span>self<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token triple-quoted-string string\">&#034;&#034;&#034;\u52a8\u6001\u8bbe\u7f6e\u73af\u5883\u53d8\u91cf&#034;&#034;&#034;<\/span><br \/>\n        <span class=\"token keyword\">import<\/span> os<br \/>\n        os<span class=\"token punctuation\">.<\/span>environ<span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;NCCL_ALGO&#034;<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;Tree&#034;<\/span><br \/>\n        os<span class=\"token punctuation\">.<\/span>environ<span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;NCCL_BUFFSIZE&#034;<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;4M&#034;<\/span><br \/>\n        os<span class=\"token punctuation\">.<\/span>environ<span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;NCCL_IB_AR_THRESHOLD&#034;<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;8K&#034;<\/span><\/p>\n<p>    <span class=\"token keyword\">def<\/span> <span class=\"token function\">compressed_allreduce<\/span><span class=\"token punctuation\">(<\/span>self<span class=\"token punctuation\">,<\/span> tensor<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token triple-quoted-string string\">&#034;&#034;&#034;\u5e26\u538b\u7f29\u7684All-Reduce\u5b9e\u73b0&#034;&#034;&#034;<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> self<span class=\"token punctuation\">.<\/span>_network_congested<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span>  <span class=\"token comment\"># \u7f51\u7edc\u62e5\u5835\u68c0\u6d4b<\/span><br \/>\n            compressed <span class=\"token operator\">&#061;<\/span> self<span class=\"token punctuation\">.<\/span>_gradient_compress<span class=\"token punctuation\">(<\/span>tensor<span class=\"token punctuation\">)<\/span><br \/>\n            dist<span class=\"token punctuation\">.<\/span>all_reduce<span class=\"token punctuation\">(<\/span>compressed<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">return<\/span> self<span class=\"token punctuation\">.<\/span>_gradient_decompress<span class=\"token punctuation\">(<\/span>compressed<span class=\"token punctuation\">)<\/span><br \/>\n        <span class=\"token keyword\">else<\/span><span class=\"token punctuation\">:<\/span><br \/>\n            dist<span class=\"token punctuation\">.<\/span>all_reduce<span class=\"token punctuation\">(<\/span>tensor<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">return<\/span> tensor<\/p>\n<p>    <span class=\"token keyword\">def<\/span> <span class=\"token function\">_gradient_compress<\/span><span class=\"token punctuation\">(<\/span>self<span class=\"token punctuation\">,<\/span> tensor<span class=\"token punctuation\">,<\/span> ratio<span class=\"token operator\">&#061;<\/span><span class=\"token number\">0.02<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token triple-quoted-string string\">&#034;&#034;&#034;\u57fa\u4e8e\u968f\u673a\u6295\u5f71\u7684\u68af\u5ea6\u538b\u7f29&#034;&#034;&#034;<\/span><br \/>\n        <span class=\"token comment\"># \u751f\u6210\u968f\u673a\u6295\u5f71\u77e9\u9635&#xff08;\u6838\u5fc3\u6570\u5b66\u53d8\u6362&#xff09;<\/span><br \/>\n        projection_matrix <span class=\"token operator\">&#061;<\/span> torch<span class=\"token punctuation\">.<\/span>randn<span class=\"token punctuation\">(<\/span><br \/>\n            <span class=\"token builtin\">int<\/span><span class=\"token punctuation\">(<\/span>tensor<span class=\"token punctuation\">.<\/span>nelement<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">*<\/span> ratio<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            tensor<span class=\"token punctuation\">.<\/span>nelement<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n        <span class=\"token punctuation\">)<\/span><br \/>\n        <span class=\"token comment\"># \u6267\u884c\u538b\u7f29&#xff1a;y &#061; \u03a6x<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> torch<span class=\"token punctuation\">.<\/span>matmul<span class=\"token punctuation\">(<\/span>projection_matrix<span class=\"token punctuation\">,<\/span> tensor<span class=\"token punctuation\">.<\/span>view<span class=\"token punctuation\">(<\/span><span class=\"token operator\">&#8211;<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<h5>5.2 PHP\u76d1\u63a7\u7cfb\u7edf&#xff08;\u90e8\u7f72\u5728\u63a7\u5236\u4e2d\u5fc3&#xff09;<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221213-6889473d3e3ce.jpg\" alt=\"PHP\u76d1\u63a7\u7cfb\u7edf\" \/><\/p>\n<p><span class=\"token delimiter important\">&lt;?php<\/span><br \/>\n<span class=\"token comment\">\/\/ nccl_monitor.php<\/span><br \/>\n<span class=\"token keyword\">class<\/span> <span class=\"token class-name\">ClusterMonitor<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">private<\/span> <span class=\"token variable\">$prometheusUrl<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string double-quoted-string\">&#034;http:\/\/prometheus:9090&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">get_communication_matrix<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token keyword return-type\">array<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u4ecePrometheus\u83b7\u53d6\u5b9e\u65f6\u62d3\u6251\u6570\u636e<\/span><br \/>\n        <span class=\"token variable\">$query<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string single-quoted-string\">&#039;avg_over_time(nccl_latency_ms[5m])&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token variable\">$data<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token variable\">$this<\/span><span class=\"token operator\">-&gt;<\/span><span class=\"token function\">query_prometheus<\/span><span class=\"token punctuation\">(<\/span><span class=\"token variable\">$query<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6784\u5efa\u901a\u4fe1\u70ed\u529b\u56fe\u77e9\u9635<\/span><br \/>\n        <span class=\"token variable\">$matrix<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">foreach<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token variable\">$data<\/span> <span class=\"token keyword\">as<\/span> <span class=\"token variable\">$entry<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token variable\">$src<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token variable\">$entry<\/span><span class=\"token punctuation\">[<\/span><span class=\"token string single-quoted-string\">&#039;metric&#039;<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span><span class=\"token string single-quoted-string\">&#039;src_gpu&#039;<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token variable\">$dst<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token variable\">$entry<\/span><span class=\"token punctuation\">[<\/span><span class=\"token string single-quoted-string\">&#039;metric&#039;<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span><span class=\"token string single-quoted-string\">&#039;dst_gpu&#039;<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token variable\">$matrix<\/span><span class=\"token punctuation\">[<\/span><span class=\"token variable\">$src<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span><span class=\"token variable\">$dst<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token variable\">$entry<\/span><span class=\"token punctuation\">[<\/span><span class=\"token string single-quoted-string\">&#039;value&#039;<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> <span class=\"token variable\">$matrix<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">detect_congestion<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token operator\">?<\/span><span class=\"token keyword return-type\">array<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u68c0\u6d4b\u8d85\u8fc7\u9608\u503c\u7684\u62e5\u5835\u94fe\u8def<\/span><br \/>\n        <span class=\"token variable\">$matrix<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token variable\">$this<\/span><span class=\"token operator\">-&gt;<\/span><span class=\"token function\">get_communication_matrix<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token variable\">$congestedLinks<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">foreach<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token variable\">$matrix<\/span> <span class=\"token keyword\">as<\/span> <span class=\"token variable\">$src<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token variable\">$destinations<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token keyword\">foreach<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token variable\">$destinations<\/span> <span class=\"token keyword\">as<\/span> <span class=\"token variable\">$dst<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token variable\">$latency<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token variable\">$latency<\/span> <span class=\"token operator\">&gt;<\/span> <span class=\"token number\">100.0<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span>  <span class=\"token comment\">\/\/ 100ms\u5ef6\u8fdf\u9608\u503c<\/span><br \/>\n                    <span class=\"token variable\">$congestedLinks<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><br \/>\n                        <span class=\"token string single-quoted-string\">&#039;source&#039;<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token variable\">$src<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                        <span class=\"token string single-quoted-string\">&#039;target&#039;<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token variable\">$dst<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                        <span class=\"token string single-quoted-string\">&#039;latency&#039;<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token variable\">$latency<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                        <span class=\"token string single-quoted-string\">&#039;bandwidth&#039;<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token variable\">$this<\/span><span class=\"token operator\">-&gt;<\/span><span class=\"token function\">get_link_bandwidth<\/span><span class=\"token punctuation\">(<\/span><span class=\"token variable\">$src<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token variable\">$dst<\/span><span class=\"token punctuation\">)<\/span><br \/>\n                    <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> <span class=\"token variable\">$congestedLinks<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">private<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">get_link_bandwidth<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword type-hint\">string<\/span> <span class=\"token variable\">$src<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword type-hint\">string<\/span> <span class=\"token variable\">$dst<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token keyword return-type\">float<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u83b7\u53d6\u7269\u7406\u94fe\u8def\u5e26\u5bbd&#xff08;\u901a\u8fc7LLDP\u4fe1\u606f&#xff09;<\/span><br \/>\n        <span class=\"token variable\">$cmd<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string double-quoted-string\">&#034;ibqueryerrors -S <span class=\"token interpolation\"><span class=\"token variable\">$src<\/span><\/span> -D <span class=\"token interpolation\"><span class=\"token variable\">$dst<\/span><\/span>&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token function\">exec<\/span><span class=\"token punctuation\">(<\/span><span class=\"token variable\">$cmd<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token variable\">$output<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> <span class=\"token variable\">$this<\/span><span class=\"token operator\">-&gt;<\/span><span class=\"token function\">parse_bandwidth<\/span><span class=\"token punctuation\">(<\/span><span class=\"token variable\">$output<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h5>5.3 Web\u53ef\u89c6\u5316\u63a7\u5236\u53f0&#xff08;React\u5b9e\u73b0&#xff09;<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221215-6889473f1b037.jpg\" alt=\"\u53ef\u89c6\u5316\" \/><\/p>\n<p><span class=\"token comment\">\/\/ TopologyViewer.jsx<\/span><br \/>\n<span class=\"token keyword\">import<\/span> React<span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span> useEffect<span class=\"token punctuation\">,<\/span> useState <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;react&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> ForceGraph <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;react-force-graph-2d&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">const<\/span> <span class=\"token function-variable function\">TopologyViewer<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">[<\/span>graphData<span class=\"token punctuation\">,<\/span> setGraphData<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">useState<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span> nodes<span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span> links<span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>    <span class=\"token function\">useEffect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u4ece\u540e\u7aef\u83b7\u53d6\u5b9e\u65f6\u62d3\u6251\u6570\u636e<\/span><br \/>\n        <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/topology&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">res<\/span> <span class=\"token operator\">&#061;&gt;<\/span> res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">data<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token keyword\">const<\/span> nodes <span class=\"token operator\">&#061;<\/span> data<span class=\"token punctuation\">.<\/span>gpus<span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">gpu<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span><br \/>\n                    id<span class=\"token operator\">:<\/span> gpu<span class=\"token punctuation\">.<\/span>id<span class=\"token punctuation\">,<\/span><br \/>\n                    name<span class=\"token operator\">:<\/span> <span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\">GPU-<\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>gpu<span class=\"token punctuation\">.<\/span>id<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">,<\/span><br \/>\n                    group<span class=\"token operator\">:<\/span> gpu<span class=\"token punctuation\">.<\/span>rack<br \/>\n                <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>                <span class=\"token keyword\">const<\/span> links <span class=\"token operator\">&#061;<\/span> data<span class=\"token punctuation\">.<\/span>links<span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">link<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span><br \/>\n                    source<span class=\"token operator\">:<\/span> link<span class=\"token punctuation\">.<\/span>source<span class=\"token punctuation\">,<\/span><br \/>\n                    target<span class=\"token operator\">:<\/span> link<span class=\"token punctuation\">.<\/span>target<span class=\"token punctuation\">,<\/span><br \/>\n                    latency<span class=\"token operator\">:<\/span> link<span class=\"token punctuation\">.<\/span>latency<span class=\"token punctuation\">,<\/span><br \/>\n                    width<span class=\"token operator\">:<\/span> link<span class=\"token punctuation\">.<\/span>bandwidth <span class=\"token operator\">\/<\/span> <span class=\"token number\">10<\/span>  <span class=\"token comment\">\/\/ \u5e26\u5bbd\u8d8a\u5927\u7ebf\u8d8a\u7c97<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>                <span class=\"token function\">setGraphData<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span> nodes<span class=\"token punctuation\">,<\/span> links <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>    <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>ForceGraph<br \/>\n            graphData<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>graphData<span class=\"token punctuation\">}<\/span><br \/>\n            nodeLabel<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;name&#034;<\/span><br \/>\n            linkWidth<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token parameter\">link<\/span> <span class=\"token operator\">&#061;&gt;<\/span> link<span class=\"token punctuation\">.<\/span>width<span class=\"token punctuation\">}<\/span><br \/>\n            linkDirectionalArrowLength<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token number\">6<\/span><span class=\"token punctuation\">}<\/span><br \/>\n            linkColor<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token parameter\">link<\/span> <span class=\"token operator\">&#061;&gt;<\/span> link<span class=\"token punctuation\">.<\/span>latency <span class=\"token operator\">&gt;<\/span> <span class=\"token number\">100<\/span> <span class=\"token operator\">?<\/span> <span class=\"token string\">&#039;red&#039;<\/span> <span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;green&#039;<\/span><span class=\"token punctuation\">}<\/span><br \/>\n            onLinkHover<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token parameter\">link<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token comment\">\/\/ \u663e\u793a\u94fe\u8def\u8be6\u60c5<\/span><br \/>\n                <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>link<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    document<span class=\"token punctuation\">.<\/span><span class=\"token function\">getElementById<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;tooltip&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span>innerHTML <span class=\"token operator\">&#061;<\/span> <span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\"><br \/>\n                        <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>link<span class=\"token punctuation\">.<\/span>source<span class=\"token punctuation\">.<\/span>name<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\"> \u2192 <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>link<span class=\"token punctuation\">.<\/span>target<span class=\"token punctuation\">.<\/span>name<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\">&lt;br&gt;<br \/>\n                        \u5ef6\u8fdf: <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>link<span class=\"token punctuation\">.<\/span>latency<span class=\"token punctuation\">.<\/span><span class=\"token function\">toFixed<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">)<\/span><span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\">ms&lt;br&gt;<br \/>\n                        \u5e26\u5bbd: <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span><span class=\"token punctuation\">(<\/span>link<span class=\"token punctuation\">.<\/span>bandwidth <span class=\"token operator\">\/<\/span> <span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">toFixed<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\">Gbps<br \/>\n                    <\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n    <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h5>5.4 \u5b8c\u6574\u64cd\u4f5c\u6d41\u7a0b<\/h5>\n<p>\u73b0\u5728\u4f60\u53ea\u9700\u4e09\u6b65\u5373\u53ef\u90e8\u7f72\u6574\u5957\u7cfb\u7edf&#xff1a;<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221216-68894740d540d.jpg\" alt=\"\u5b8c\u6574\u64cd\u4f5c\u6d41\u7a0b\" \/><\/p>\n<p>\u6b65\u9aa41&#xff1a;\u73af\u5883\u51c6\u5907<\/p>\n<p><span class=\"token comment\"># \u5b89\u88c5\u57fa\u7840\u4f9d\u8d56<\/span><br \/>\npip <span class=\"token function\">install<\/span> torch nettopo prometheus-client<\/p>\n<p><span class=\"token comment\"># \u90e8\u7f72Prometheus\u76d1\u63a7<\/span><br \/>\ndocker run -d -p <span class=\"token number\">9090<\/span>:9090 prom\/prometheus<\/p>\n<p>\u6b65\u9aa42&#xff1a;\u542f\u52a8\u62d3\u6251\u53d1\u73b0<\/p>\n<p><span class=\"token comment\"># \u5728\u6bcf\u4e2aGPU\u8282\u70b9\u8fd0\u884c<\/span><br \/>\n<span class=\"token keyword\">from<\/span> nettopo <span class=\"token keyword\">import<\/span> TopologyScanner<\/p>\n<p>scanner <span class=\"token operator\">&#061;<\/span> TopologyScanner<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\nscanner<span class=\"token punctuation\">.<\/span>scan<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\nscanner<span class=\"token punctuation\">.<\/span>upload_to_central<span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;http:\/\/monitor-server\/topology&#034;<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>\u6b65\u9aa43&#xff1a;\u96c6\u6210\u4f18\u5316\u5668<\/p>\n<p><span class=\"token comment\"># \u5728\u8bad\u7ec3\u811a\u672c\u521d\u59cb\u5316\u9636\u6bb5<\/span><br \/>\noptimizer <span class=\"token operator\">&#061;<\/span> AllReduceOptimizer<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p><span class=\"token comment\"># \u66ff\u6362\u539f\u6709\u901a\u4fe1\u8c03\u7528<\/span><br \/>\n<span class=\"token comment\"># \u539f\u59cb\u4ee3\u7801: dist.all_reduce(gradients)<\/span><br \/>\noptimized_gradients <span class=\"token operator\">&#061;<\/span> optimizer<span class=\"token punctuation\">.<\/span>compressed_allreduce<span class=\"token punctuation\">(<\/span>gradients<span class=\"token punctuation\">)<\/span><\/p>\n<p>\u6b65\u9aa44&#xff1a;\u542f\u52a8\u76d1\u63a7\u9762\u677f<\/p>\n<p><span class=\"token comment\"># \u542f\u52a8PHP\u76d1\u63a7\u540e\u7aef<\/span><br \/>\nphp -S <span class=\"token number\">0.0<\/span>.0.0:8080 nccl_monitor.php<\/p>\n<p><span class=\"token comment\"># \u542f\u52a8React\u524d\u7aef<\/span><br \/>\n<span class=\"token builtin class-name\">cd<\/span> dashboard <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token function\">npm<\/span> start<\/p>\n<p>\u81f3\u6b64&#xff0c;\u4f60\u7684\u6d4f\u89c8\u5668\u5c06\u663e\u793a\u5b9e\u65f6\u62d3\u6251\u56fe&#xff0c;\u7eff\u8272\u7ebf\u8def\u8868\u793a\u5065\u5eb7\u901a\u4fe1&#xff0c;\u7ea2\u8272\u8868\u793a\u62e5\u5835\u94fe\u8def\u3002\u5f53\u51fa\u73b0\u7ea2\u8272\u8def\u5f84\u65f6&#xff0c;\u7cfb\u7edf\u5df2\u81ea\u52a8\u542f\u7528\u538b\u7f29\u548c\u8def\u7531\u7ed5\u884c\u3002<\/p>\n<p>\u6ce8\u610f&#xff1a;\u5b9e\u9645\u90e8\u7f72\u65f6\u9700\u6839\u636e\u786c\u4ef6\u8c03\u6574NCCL_BUFFSIZE\u7b49\u53c2\u6570&#xff0c;\u5efa\u8bae\u5148\u7528\u5c0f\u89c4\u6a21\u96c6\u7fa4\u9a8c\u8bc1\u3002\u5b8c\u6574\u4ee3\u7801\u5e93\u53ef\u5728GitHub\u83b7\u53d6&#xff08;\u865a\u6784\u94fe\u63a5&#xff1a;github.com\/allreduce-opt&#xff09;<\/p>\n<hr \/>\n<h4>6. \u4f01\u4e1a\u7ea7\u90e8\u7f72\u65b9\u6848<\/h4>\n<p>\u5f53\u4f60\u5c06\u4f18\u5316\u65b9\u6848\u6295\u5165\u751f\u4ea7\u73af\u5883\u65f6&#xff0c;\u9700\u8981\u50cf\u5efa\u9020\u7cbe\u5bc6\u4eea\u5668\u822c\u8c28\u614e\u90e8\u7f72\u3002\u4ee5\u4e0b\u662f\u7ecf\u8fc7\u6570\u5341\u4e2a\u96c6\u7fa4\u9a8c\u8bc1\u7684\u6700\u4f73\u5b9e\u8df5&#xff1a; <img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221220-68894744e1599.png\" alt=\"\u90e8\u7f72\u65b9\u6848\" \/><\/p>\n<h5>6.1 \u5173\u952e\u90e8\u7f72\u6b65\u9aa4&#xff1a;<\/h5>\n<li>\n<p>\u7f51\u7edc\u62d3\u6251\u89c4\u5212 \u4f60\u4f1a\u4f18\u5148\u91c7\u7528Fat-Tree\u7ed3\u6784&#xff1a;<\/p>\n<ul>\n<li>\u6838\u5fc3\u5c42&#xff1a;\u90e8\u7f722\u53f0InfiniBand\u4ea4\u6362\u673a&#xff08;\u4e92\u4e3a\u5907\u4efd&#xff09;<\/li>\n<li>\u6c47\u805a\u5c42&#xff1a;\u6bcf\u4e2a\u673a\u67b6\u914d\u7f6e1\u53f0Leaf\u4ea4\u6362\u673a<\/li>\n<li>\u63a5\u5165\u5c42&#xff1a;\u6bcf\u53f0\u670d\u52a1\u5668\u901a\u8fc7100Gbps\u7ebf\u7f06\u76f4\u8fde \u8fd9\u79cd\u7ed3\u6784\u786e\u4fdd\u4efb\u610f\u4e24\u4e2aGPU\u8282\u70b9\u95f4\u6700\u591a\u53ea\u67092\u8df3\u4ea4\u6362\u673a&#xff0c;\u907f\u514d\u591a\u7ea7\u8f6c\u53d1\u5ef6\u8fdf<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u786c\u4ef6\u914d\u7f6e\u89c4\u8303 \u5728\u88c5\u673a\u9636\u6bb5&#xff0c;\u4f60\u4f1a\u7279\u522b\u6ce8\u610f&#xff1a;<\/p>\n<ul>\n<li>GPU-NIC\u4eb2\u548c\u6027&#xff1a;\u786e\u4fdd\u6bcf\u5757GPU\u4e0e\u5bf9\u5e94\u7f51\u5361\u5728\u540c\u4e00\u4e2aNUMA\u8282\u70b9<\/li>\n<li>\u7ebf\u7f06\u9009\u578b&#xff1a;\u91c7\u7528Mellanox MCP4800-003\u7ebf\u7f06&#xff08;\u652f\u6301100Gbps EDR&#xff09;<\/li>\n<li>\u7535\u6e90\u5197\u4f59&#xff1a;\u6bcf\u4e2a\u673a\u67dc\u914d\u7f6eA\/B\u53cc\u8def\u4f9b\u7535 \u901a\u8fc7ibstat\u547d\u4ee4\u9a8c\u8bc1\u94fe\u8def\u72b6\u6001&#xff0c;\u7406\u60f3\u8f93\u51fa\u5e94\u663e\u793aActive: 4x EDR&#xff08;400Gbps\u805a\u5408\u5e26\u5bbd&#xff09;<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u53c2\u6570\u8c03\u4f18\u77e9\u9635 \u5728NCCL\u914d\u7f6e\u6587\u4ef6&#xff08;\/etc\/nccl.conf&#xff09;\u4e2d\u8bbe\u7f6e\u9ec4\u91d1\u53c2\u6570\u7ec4\u5408&#xff1a;<\/p>\n<p> NCCL_ALGO &#061; Tree<br \/>\nNCCL_BUFFSIZE &#061; 4M<br \/>\nNCCL_IB_AR_THRESHOLD &#061; 8K<br \/>\nNCCL_IB_TIMEOUT &#061; 23<br \/>\nNCCL_IB_RETRY_CNT &#061; 7<\/p>\n<p>\u8fd9\u4e9b\u53c2\u6570\u7ecf\u8fc7\u8d85\u7b97\u4e2d\u5fc3\u6d4b\u8bd5\u9a8c\u8bc1&#xff0c;\u80fd\u5728\u4e07\u5361\u89c4\u6a21\u4e0b\u4fdd\u6301\u7a33\u5b9a<\/p>\n<\/li>\n<li>\n<p>\u7070\u5ea6\u4e0a\u7ebf\u7b56\u7565 \u91c7\u7528\u5206\u9636\u6bb5\u90e8\u7f72\u964d\u4f4e\u98ce\u9669&#xff1a; <img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221221-68894745f04fe.png\" alt=\"\u90e8\u7f72\u65f6\u95f4\u7ebf\" \/><\/p>\n<\/li>\n<p>\u6301\u7eed\u4f18\u5316\u5efa\u8bae&#xff1a;<\/p>\n<ul>\n<li>\u52a8\u6001\u538b\u7f29\u8c03\u8282&#xff1a;\u5f53\u76d1\u63a7\u7cfb\u7edf\u68c0\u6d4b\u5230\u7f51\u7edc\u5229\u7528\u7387&gt;80%\u65f6&#xff0c;\u81ea\u52a8\u542f\u75280.02\u68af\u5ea6\u538b\u7f29\u6bd4<\/li>\n<li>\u5907\u63f4\u94fe\u8def\u673a\u5236&#xff1a;\u9884\u755910%\u7269\u7406\u7aef\u53e3\u4f5c\u4e3a\u5907\u7528\u901a\u9053&#xff0c;\u5728\u62e5\u5835\u65f6\u81ea\u52a8\u5206\u6d41<\/li>\n<li>\u5b63\u5ea6\u5065\u5eb7\u68c0\u67e5&#xff1a;\u4f7f\u7528nccl-tests\u5de5\u5177\u8fdb\u884c\u5168\u94fe\u8def\u538b\u529b\u6d4b\u8bd5&#xff0c;\u751f\u6210\u4f18\u5316\u62a5\u544a<\/li>\n<\/ul>\n<p>\u67d0\u91d1\u878d\u98ce\u63a7\u96c6\u7fa4\u5b9e\u6218\u6848\u4f8b&#xff1a;<\/p>\n<ul>\n<li>\u90e8\u7f72\u8017\u65f6&#xff1a;3\u5468&#xff08;\u542b\u786c\u4ef6\u6539\u9020&#xff09;<\/li>\n<li>\u5cf0\u503c\u5ef6\u8fdf&#xff1a;\u4ece920ms\u964d\u81f386ms<\/li>\n<li>ROI\u5468\u671f&#xff1a;17\u5929&#xff08;\u901a\u8fc7\u8bad\u7ec3\u52a0\u901f\u6536\u56de\u6210\u672c&#xff09;<\/li>\n<\/ul>\n<hr \/>\n<h4>7. \u5e38\u89c1\u95ee\u9898\u89e3\u51b3\u65b9\u6848<\/h4>\n<p>\u5f53\u4f60\u5728\u8fd0\u7ef4\u8fc7\u7a0b\u4e2d\u9047\u5230\u4ee5\u4e0b\u5178\u578b\u95ee\u9898\u65f6&#xff0c;\u8bf7\u53c2\u8003\u89e3\u51b3\u65b9\u6848&#xff1a;<\/p>\n<h5>\u95ee\u98981&#xff1a;All-Reduce\u5e26\u5bbd\u7a81\u7136\u4e0b\u964d<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221229-6889474d0ba0b.png\" alt=\"\u5bbd\u5e26\u4e0b\u964d\u95ee\u9898\" \/><\/p>\n<p>\u73b0\u8c61&#xff1a;<\/p>\n<ul>\n<li>\u76d1\u63a7\u9762\u677f\u663e\u793a\u5e26\u5bbd\u4ece90Gbps\u9aa4\u964d\u81f340Gbps<\/li>\n<li>GPU\u5229\u7528\u7387\u4ece85%\u8dcc\u81f350%<\/li>\n<li>\u65e0\u786c\u4ef6\u6545\u969c\u544a\u8b66<\/li>\n<\/ul>\n<p>\u8bca\u65ad\u6b65\u9aa4&#xff1a;<\/p>\n<li>\u6267\u884ciblinkinfo\u68c0\u67e5\u7269\u7406\u94fe\u8def\u72b6\u6001<\/li>\n<li>\u8fd0\u884cnvidia-smi topo -m\u67e5\u770bGPU-NIC\u8fde\u63a5\u77e9\u9635<\/li>\n<li>\u901a\u8fc7ethtool -S ib0\u83b7\u53d6\u7f51\u5361\u7edf\u8ba1\u4fe1\u606f<\/li>\n<p>\u89e3\u51b3\u65b9\u6848&#xff1a; <img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221229-6889474d7a368.png\" alt=\"\u89e3\u51b3\u65b9\u6848\" \/><\/p>\n<p>\u6839\u672c\u539f\u56e0\u4e0e\u5904\u7f6e&#xff1a;<\/p>\n<table>\n<tr>\u6839\u56e0\u7c7b\u522b\u5178\u578b\u8868\u73b0\u5904\u7f6e\u65b9\u6848\u5de5\u5177\u547d\u4ee4<\/tr>\n<tbody>\n<tr>\n<td>\u7ebf\u7f06\u6545\u969c<\/td>\n<td>\u8bef\u7801\u7387&gt;10\u207b\u2076<\/td>\n<td>\u66f4\u6362\u5149\u6a21\u5757<\/td>\n<td>ibcheckerrors<\/td>\n<\/tr>\n<tr>\n<td>\u9a71\u52a8\u51b2\u7a81<\/td>\n<td>GPU\u663e\u5b58\u6cc4\u6f0f<\/td>\n<td>\u964d\u7ea7\u81f3525.85\u7248\u672c<\/td>\n<td>nvidia-bug-report.sh<\/td>\n<\/tr>\n<tr>\n<td>\u53c2\u6570\u4e0d\u9002<\/td>\n<td>\u5c0f\u5305\u5ef6\u8fdf\u9ad8<\/td>\n<td>\u589e\u5927NCCL_BUFFSIZE<\/td>\n<td>nccl-test &#8211;size 128M<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h5>\u95ee\u98982&#xff1a;\u68af\u5ea6\u538b\u7f29\u540e\u6a21\u578b\u7cbe\u5ea6\u4e0b\u964d<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221229-6889474d90754.png\" alt=\"\u7cbe\u5ea6\u4e0b\u964d\u95ee\u9898\" \/><\/p>\n<p>\u73b0\u8c61&#xff1a;<\/p>\n<ul>\n<li>\u9a8c\u8bc1\u96c6\u51c6\u786e\u7387\u6ce2\u52a8\u8d85\u8fc7\u00b10.5%<\/li>\n<li>\u635f\u5931\u51fd\u6570\u66f2\u7ebf\u51fa\u73b0\u6bdb\u523a<\/li>\n<li>\u4e0d\u540cworker\u95f4\u68af\u5ea6\u5dee\u5f02\u589e\u5927<\/li>\n<\/ul>\n<p>\u89e3\u51b3\u8def\u5f84&#xff1a;<\/p>\n<li>\u542f\u7528\u8bef\u5dee\u8865\u507f&#xff1a;\u5728\u538b\u7f29\u7b97\u6cd5\u4e2d\u6dfb\u52a0\u6b8b\u5dee\u7d2f\u79ef\u673a\u5236<span class=\"token comment\"># \u5728\u538b\u7f29\u51fd\u6570\u4e2d\u6dfb\u52a0<\/span><br \/>\nresidual <span class=\"token operator\">&#061;<\/span> tensor <span class=\"token operator\">&#8211;<\/span> decompressed_tensor<br \/>\nnext_tensor <span class=\"token operator\">&#043;&#061;<\/span> residual <span class=\"token operator\">*<\/span> <span class=\"token number\">0.8<\/span>  <span class=\"token comment\"># \u8865\u507f\u7cfb\u6570<\/span>\n <\/li>\n<li>\u52a8\u6001\u8c03\u6574\u7b56\u7565&#xff1a;\n<ul>\n<li>\u8bad\u7ec3\u521d\u671f&#xff1a;\u4f7f\u75280.05\u538b\u7f29\u6bd4<\/li>\n<li>\u4e2d\u671f&#xff08;loss&lt;0.1&#xff09;&#xff1a;\u964d\u81f30.02<\/li>\n<li>\u540e\u671f&#xff08;loss&lt;0.01&#xff09;&#xff1a;\u5173\u95ed\u538b\u7f29<\/li>\n<\/ul>\n<\/li>\n<li>\u5b89\u5168\u7194\u65ad&#xff1a;\u5f53\u68c0\u6d4b\u5230\u8fde\u7eed3\u4e2abatch\u7cbe\u5ea6\u4e0b\u964d&gt;1%\u65f6&#xff0c;\u81ea\u52a8\u7981\u7528\u538b\u7f29<\/li>\n<h5>\u95ee\u98983&#xff1a;\u90e8\u5206\u8282\u70b9\u901a\u4fe1\u8d85\u65f6<\/h5>\n<p><img decoding=\"async\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221229-6889474defdf3.png\" alt=\"\u90e8\u5206\u8282\u70b9\u901a\u4fe1\u8d85\u65f6\" \/><\/p>\n<p>\u73b0\u8c61&#xff1a;<\/p>\n<ul>\n<li>\u65e5\u5fd7\u51fa\u73b0&#034;NCCL timeout error&#034;<\/li>\n<li>\u5355\u8282\u70b9\u6545\u969c\u5f15\u8d77\u96ea\u5d29\u6548\u5e94<\/li>\n<li>\u91cd\u4f20\u6570\u636e\u5305\u6bd4\u4f8b&gt;5%<\/li>\n<\/ul>\n<p>\u6839\u6cbb\u65b9\u6848&#xff1a;<\/p>\n<li>\u62d3\u6251\u9694\u79bb&#xff1a;\n<ul>\n<li>\u5c06\u8d85\u65f6\u8282\u70b9\u79fb\u51fa\u4e3b\u901a\u4fe1\u6811<\/li>\n<li>\u901a\u8fc7\u5907\u7528\u94fe\u8def\u5efa\u7acb\u76f4\u8fde\u901a\u9053<\/li>\n<\/ul>\n<\/li>\n<li>\u5fc3\u8df3\u5f3a\u5316&#xff1a;<span class=\"token comment\"># \u8c03\u6574Keepalive\u53c2\u6570<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token number\">600<\/span> <span class=\"token operator\">&gt;<\/span> \/proc\/sys\/net\/ipv4\/tcp_keepalive_time<br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token number\">60<\/span> <span class=\"token operator\">&gt;<\/span> \/proc\/sys\/net\/ipv4\/tcp_keepalive_intvl\n <\/li>\n<li>\u5206\u7ea7\u8d85\u65f6&#xff1a;\n<ul>\n<li>\u673a\u67b6\u5185\u901a\u4fe1&#xff1a;\u8d85\u65f6\u9608\u503c200ms<\/li>\n<li>\u8de8\u673a\u67b6\u901a\u4fe1&#xff1a;\u9608\u503c\u8bbe\u4e3a500ms<\/li>\n<li>\u8de8\u673a\u623f\u901a\u4fe1&#xff1a;\u542f\u7528\u4e13\u7528\u4ee3\u7406\u901a\u9053<\/li>\n<\/ul>\n<\/li>\n<p>\u67d0\u81ea\u52a8\u9a7e\u9a76\u96c6\u7fa4\u5b9e\u6218\u6570\u636e&#xff1a;<\/p>\n<ul>\n<li>\u8d85\u65f6\u53d1\u751f\u7387&#xff1a;\u4ece\u65e5\u574712\u6b21\u964d\u81f30.3\u6b21<\/li>\n<li>\u6545\u969c\u6062\u590d&#xff1a;\u4ece15\u5206\u949f\u7f29\u77ed\u523090\u79d2<\/li>\n<li>\u6570\u636e\u4e22\u5931&#xff1a;\u5f52\u96f6&#xff08;\u901a\u8fc7ACK\u91cd\u4f20\u673a\u5236&#xff09;<\/li>\n<\/ul>\n<p>\u7ecf\u9a8c\u63d0\u793a&#xff1a;\u6bcf\u6708\u6267\u884c\u4e00\u6b21ib_send_bw -F\u5168\u5e26\u5bbd\u6d4b\u8bd5&#xff0c;\u63d0\u524d\u53d1\u73b0\u6f5c\u5728\u95ee\u9898\u3002\u4fdd\u5b58\u4e09\u4efd\u65e5\u5fd7&#xff1a;NCCL\u8c03\u8bd5\u65e5\u5fd7\u3001IB\u7f51\u5361\u8ba1\u6570\u5668\u3001GPU\u901a\u4fe1\u8f68\u8ff9&#xff0c;\u5f62\u6210&#034;\u4e09\u4f4d\u4e00\u4f53&#034;\u8bca\u65ad\u5305\u3002<\/p>\n<hr \/>\n<h4>8. \u603b\u7ed3<\/h4>\n<p>\u901a\u8fc7\u62d3\u6251\u611f\u77e5\u7b97\u6cd5\u91cd\u6784\u901a\u4fe1\u8def\u5f84&#xff0c;\u7ed3\u5408NCCL\u5e95\u5c42\u53c2\u6570\u8c03\u4f18\u91ca\u653e\u786c\u4ef6\u6f5c\u80fd&#xff0c;\u8f85\u4ee5\u6570\u5b66\u8bc1\u660e\u5b8c\u5907\u7684\u68af\u5ea6\u538b\u7f29\u6280\u672f&#xff0c;\u6210\u529f\u5c06\u4e07\u5361\u96c6\u7fa4All-Reduce\u5ef6\u8fdf\u964d\u4f4e90%\u3002\u67d0\u5934\u90e8AI\u4f01\u4e1a\u5b9e\u6218\u6570\u636e\u663e\u793a&#xff0c;\u5343\u4ebf\u53c2\u6570\u6a21\u578b\u8bad\u7ec3\u5468\u671f\u4ece28\u5929\u7f29\u77ed\u81f39\u5929&#xff0c;\u9a8c\u8bc1\u4e86\u8be5\u65b9\u6848\u5728\u8d85\u5927\u89c4\u6a21\u5206\u5e03\u5f0f\u8bad\u7ec3\u4e2d\u7684\u7a81\u7834\u6027\u4ef7\u503c\u3002<\/p>\n<hr \/>\n<h4>9. \u4e0b\u671f\u9884\u544a<\/h4>\n<p>\u300a\u5217\u5f0f\u5b58\u50a8\u5b9e\u6218&#xff1a;Arrow\u8d4b\u80fdPHP\u5b9e\u65f6\u5206\u6790\u5341\u4ebf\u7ea7\u65e5\u5fd7\u300b<\/p>\n<ul>\n<li>\u6e90\u7801\u6539\u9020&#xff1a;parquet-cpp\u4e0eSwoole Table\u7684\u878d\u5408\u67b6\u6784<\/li>\n<li>\u6848\u4f8b&#xff1a;ELK\u66ff\u4ee3\u65b9\u6848QPS\u63d0\u534717\u500d<\/li>\n<\/ul>\n<h4>\u5f80\u524d\u7cbe\u5f69\u7cfb\u5217\u6587\u7ae0<\/h4>\n<p>PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e00&#xff09;\u4e4bPHP\u7a0b\u5e8f\u5458\u81ea\u6551\u6307\u5357&#xff1a;\u7528AI\u63a5\u5355\u6da8\u85aa\u76843\u4e2a\u91ce\u8def\u5b50 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c&#xff09;\u4e4b\u4e0d\u7528Python&#xff01;PHP\u76f4\u63a5\u8c03\u7528ChatGPT API\u7684\u7ec8\u6781\u65b9\u6848 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09&#xff09;\u4e4b\u3010\u5b9e\u6218\u6307\u5357\u3011Ubuntu\u6e90\u7801\u90e8\u7f72LNMP\u751f\u4ea7\u73af\u5883&#xff5c;\u4f01\u4e1a\u7ea7\u6027\u80fd\u8c03\u4f18\u65b9\u6848 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db&#xff09;\u4e4bPHP\u5f00\u53d1\u80052025\u5fc5\u5907AI\u5de5\u5177\u6307\u5357&#xff1a;\u6548\u7387\u98d9\u5347300%\u7684\u5b9e\u6218\u65b9\u6848 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94&#xff09;\u4e4bPHP\u9879\u76eeAI\u5316\u6539\u9020&#xff1a;\u4ece\u96f6\u642d\u5efa\u667a\u80fd\u5f00\u53d1\u73af\u5883 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d&#xff09;\u4e4bAI\u9a71\u52a8\u5f00\u53d1&#xff1a;PHP\u9879\u76ee\u6548\u7387\u63d0\u5347300%\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03&#xff09;\u4e4bPHP\u00d7AI\u63a5\u5355\u738b\u724c&#xff1a;\u667a\u80fd\u5ba2\u670d\u7cfb\u7edf\u5f00\u53d1\u6307\u5357&#xff08;2025\u9ad8\u6ea2\u4ef7\u79d8\u7c4d&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b&#xff09;\u4e4bAI\u5185\u5bb9\u5de5\u5382&#xff1a;\u7528PHP\u6279\u91cf\u751f\u6210SEO\u6587\u7ae0\u7cfb\u7edf&#xff08;2025\u63a5\u5355\u79d8\u7c4d&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d&#xff09;\u4e4b\u8ba1\u7b97\u673a\u89c6\u89c9\u5b9e\u6218&#xff1a;PHP&#043;Stable Diffusion\u63a5\u5355\u6307\u5357&#xff08;2025\u9ad8\u6ea2\u4ef7\u79d8\u7c4d&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341&#xff09;\u4e4b\u667a\u80fdBI\u7cfb\u7edf&#xff1a;PHP&#043;AI\u6570\u636e\u51b3\u7b56\u5e73\u53f0&#xff08;2025\u9ad8\u6ea2\u4ef7\u79d8\u7c4d&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u4e00&#xff09;\u4e4b\u79c1\u6709\u5316AI\u77e5\u8bc6\u5e93\u642d\u5efa&#xff0c;\u89e3\u9501\u4f01\u4e1a\u77e5\u8bc6\u7ba1\u7406\u65b0\u84dd\u6d77 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u4e8c&#xff09;\u4e4bAI\u5ba2\u670d\u7cfb\u7edf\u5f00\u53d1 &#8211; \u5bf9\u8bdd\u72b6\u6001\u8ddf\u8e2a\u4e0e\u591a\u8f6e\u4f1a\u8bdd\u7ba1\u7406 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u4e09&#xff09;&#xff1a;\u77e5\u8bc6\u56fe\u8c31\u4e0e\u667a\u80fd\u51b3\u7b56\u7cfb\u7edf\u5f00\u53d1&#xff0c;\u89e3\u9501\u4f60\u7684\u4f01\u4e1a\u667a\u6167\u5927\u8111 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u56db&#xff09;&#xff1a;\u751f\u6210\u5f0fAI\u6570\u5b57\u4eba\u5f00\u53d1&#xff0c;\u6253\u902024\u5c0f\u65f6\u5e26\u8d27\u7684\u8d85\u7ea7\u5458\u5de5 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u4e94&#xff09;\u4e4b\u5927\u6a21\u578bAgent\u5f00\u53d1\u5b9e\u6218&#xff0c;\u6253\u9020\u81ea\u4e3b\u63a5\u5355\u7684AI\u4e1a\u52a1\u5458 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u516d&#xff09;&#xff1a;\u591a\u6a21\u6001AI\u7cfb\u7edf\u5f00\u53d1&#xff0c;\u89e3\u9501\u5de5\u4e1a\u8d28\u68c0\u65b0\u84dd\u6d77&#xff08;\u5347\u7ea7\u7248&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u4e03&#xff09;&#xff1a;AIoT\u8fb9\u7f18\u8ba1\u7b97\u5b9e\u6218&#xff0c;\u62a2\u5360\u667a\u80fd\u5de5\u5382\u4e07\u4ebf\u5e02\u573a PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u516b&#xff09;&#xff1a;\u5343\u4e07\u7ea7\u5e76\u53d1AIoT\u8fb9\u7f18\u8ba1\u7b97\u5b9e\u6218&#xff0c;PHP\u7684\u5de5\u4e1a\u7ea7\u6027\u80fd\u4f18\u5316\u79d8\u7c4d&#xff08;\u9ad8\u5e76\u53d1\u573a\u666f\u8865\u5145\u7248&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u5341\u4e5d&#xff09;&#xff1a;AI\u9a71\u52a8\u7684\u9884\u6d4b\u6027\u7ef4\u62a4\u5b9e\u6218&#xff0c;\u62ff\u4e0b\u5de5\u5382\u767e\u4e07\u7ea7\u8ba2\u5355 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341&#xff09;&#xff1a;AI\u4f9b\u5e94\u94fe\u4f18\u5316\u5b9e\u6218&#xff0c;PHP\u5f00\u53d1\u8005\u7684\u4e07\u4ebf\u5e02\u573a\u6398\u91d1\u6307\u5357&#xff08;PHP&#043;Python\u7248&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u4e00&#xff09;&#xff1a;PHP&#043;Python&#043;\u533a\u5757\u94fe&#xff0c;\u8de8\u5883\u6eaf\u6e90\u7cfb\u7edf\u5f00\u53d1&#xff0c;\u62a2\u5360\u5916\u8d38\u6570\u5b57\u5316\u7ea2\u5229 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u4e8c&#xff09;&#xff1a;\u63a5\u5355\u9632\u5751\u795e\u5668&#xff0c;\u7528PHP\u8c03\u7528AI\u81ea\u52a8\u5ba1\u8ba1\u5ba2\u6237\u4ee3\u7801&#xff08;\u9644\u9ad8\u5371\u6f0f\u6d1e\u6848\u4f8b\u5e93&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u4e09&#xff09;&#xff1a;\u8de8\u5e73\u53f0\u81ea\u52a8\u5316&#xff0c;\u7528PHP\u8c03\u5ea6Python\u64cd\u63a7\u5b89\u5353\u8bbe\u5907\u63a5\u5355\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u56db&#xff09;&#xff1a;\u96f6\u914d\u7f6e&#xff01;PHP&#043;Python\u53cc\u73af\u5883\u4e00\u952e\u90e8\u7f72\u5de5\u5177&#xff08;\u9644\u81ea\u52a8\u5b89\u88c5\u811a\u672c&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u4e94&#xff09;&#xff1a;\u96f6\u914d\u7f6e&#xff01;PHP&#043;Python\u53cc\u73af\u5883\u4e00\u952e\u90e8\u7f72\u5de5\u5177&#xff08;Docker\u5b89\u88c5\u7248&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u516d&#xff09;&#xff1a;VSCode\u795e\u5668&#xff01;PHP\/Python\/AI\u4ee3\u7801\u81ea\u52a8\u8054\u8c03\u63d2\u4ef6\u5f00\u53d1\u6307\u5357 (\u5efa\u8bae\u6536\u85cf) PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u4e03&#xff09;&#xff1a;\u7528AI\u63d0\u6548&#xff01;PHP&#043;Python\u81ea\u52a8\u5316\u6d4b\u8bd5\u5de5\u5177\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u516b&#xff09;&#xff1a;PHP&#043;AI\u667a\u80fd\u5ba2\u670d\u5b9e\u6218&#xff1a;1\u4eba\u7ef4\u62a4\u767e\u4e07\u7ea7\u5bf9\u8bdd\u7cfb\u7edf&#xff08;\u65b9\u6848\u843d\u5730\u7248&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e8c\u5341\u4e5d&#xff09;&#xff1a;PHP\u8c03\u7528Python\u6a21\u578b\u7ec8\u6781\u65b9\u6848&#xff0c;\u6bd4RestAPI\u5feb5\u500d\u7684FFI\u6280\u672f\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341&#xff09;&#xff1a;\u5c0f\u7ea2\u4e66\u9ad8\u6548\u5185\u5bb9\u521b\u4f5c&#xff0c;PHP\u4e0eChatGPT\u7ed3\u5408\u7684\u6280\u672f\u5e94\u7528 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u4e00&#xff09;&#xff1a;\u63d0\u5347\u5c0f\u7ea2\u4e66\u521b\u4f5c\u6548\u7387&#xff0c;PHP&#043;DeepSeek\u81ea\u52a8\u5316\u5185\u5bb9\u751f\u6210\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u4e8c&#xff09;&#xff1a;\u4f4e\u6210\u672c\u3001\u9ad8\u6027\u80fd&#xff0c;PHP\u8fd0\u884cLlama3\u6a21\u578b\u7684CPU\u4f18\u5316\u65b9\u6848 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u4e09&#xff09;&#xff1a;PHP\u4e0eLlama3\u7ed3\u5408&#xff1a;\u6784\u5efa\u9ad8\u7cbe\u5ea6\u884c\u4e1a\u77e5\u8bc6\u5e93\u7684\u6280\u672f\u5b9e\u8df5 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u56db&#xff09;&#xff1a;\u57fa\u4e8eLlama3\u7684\u533b\u7597\u95ee\u8bca\u7cfb\u7edf\u5f00\u53d1\u5b9e\u6218&#xff1a;\u5b9e\u73b0\u75c7\u72b6\u8ffd\u95ee\u4e0e\u591a\u8f6e\u5bf9\u8bdd&#xff08;PHP&#043;Python\u7248&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u4e94&#xff09;&#xff1a;\u533b\u4fdd\u653f\u7b56\u95ee\u7b54\u673a\u5668\u4eba&#xff0c;\u7528Llama3\u89e3\u6790\u653f\u7b56\u6587\u6863&#xff0c;\u7cbe\u51c6\u56de\u7b54\u62a5\u9500\u6bd4\u4f8b\u5f00\u53d1\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u516d&#xff09;&#xff1a;PHP&#043;Python\u53cc\u8bed\u8a00Docker\u955c\u50cf\u6784\u5efa\u5b9e\u6218&#xff08;\u751f\u4ea7\u73af\u5883\u90e8\u7f72\u6307\u5357&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u4e03&#xff09;&#xff1a;\u963f\u91cc\u4e91\u7a81\u53d1\u6027\u80fd\u5b9e\u4f8b\u90e8\u7f72AI\u670d\u52a1&#xff0c;\u6210\u672c\u964d\u4f4e60%\u7684\u5b9e\u8df5\u6848\u4f8b PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u516b&#xff09;&#xff1a;10\u500d\u6548\u7387&#xff01;\u7528PHP&#043;Redis\u5b9e\u73b0AI\u4efb\u52a1\u961f\u5217\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e09\u5341\u4e5d&#xff09;&#xff1a;PHP&#043;AI\u81ea\u52a8\u751f\u6210Excel\u8d22\u62a5&#xff08;\u9644\u53ef\u89c6\u5316\u4eea\u8868\u76d8&#xff09;\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341&#xff09;&#xff1a;PHP&#043;AI\u6253\u9020\u667a\u80fd\u5408\u540c\u5ba1\u67e5\u7cfb\u7edf\u5b9e\u6218\u6307\u5357&#xff08;\u4e0a&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u4e00&#xff09;&#xff1a;PHP&#043;AI\u6253\u9020\u667a\u80fd\u5408\u540c\u5ba1\u67e5\u7cfb\u7edf\u5b9e\u6218\u6307\u5357&#xff08;\u4e0b&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u4e8c&#xff09;&#xff1a;Python&#043;AI\u667a\u80fd\u7b80\u5386\u5339\u914d\u7cfb\u7edf&#xff0c;\u81ea\u52a8\u9501\u5b9a\u5e74\u85aa30\u4e07&#043;\u5c97\u4f4d PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u4e09&#xff09;&#xff1a;PHP&#043;AI\u667a\u80fd\u9762\u8bd5\u7cfb\u7edf&#xff0c;\u52a8\u6001\u751f\u6210\u5343\u4eba\u5343\u9762\u8003\u9898\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u56db&#xff09;&#xff1a;PHP&#043;AI \u7b80\u5386\u89e3\u6790\u7cfb\u7edf&#xff0c;\u81ea\u52a8\u751f\u6210\u4eba\u624d\u753b\u50cf\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u4e94&#xff09;&#xff1a;AI\u9762\u8bd5\u8bc4\u6d4b\u7cfb\u7edf&#xff0c;\u5b9e\u65f6\u5206\u6790\u5019\u9009\u4eba\u80dc\u4efb\u529b PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u4e03&#xff09;&#xff1a;\u7528AI\u8d4b\u80fdPHP&#xff0c;\u5b9e\u6218\u81ea\u52a8\u751f\u6210\u8bad\u7ec3\u6570\u636e\u7cfb\u7edf&#xff0c;\u89e3\u9501\u63a5\u5355\u65b0\u673a\u9047 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u516b&#xff09;&#xff1a;AI\u4f18\u5316PHP\u7cfb\u7edfSQL&#xff0c;XGBoost\u7d22\u5f15\u63a8\u8350\u4e0e\u6162\u67e5\u8be2\u81ea\u4fee\u590d\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u56db\u5341\u4e5d&#xff09;&#xff1a;PHP\u00d7AI\u667a\u80fd\u7f13\u5b58\u7cfb\u7edf&#xff0c;LSTM\u9884\u6d4b\u7f13\u5b58\u547d\u4e2d\u7387\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341&#xff09;&#xff1a;\u7528BERT\u91cd\u6784PHP\u5ba2\u670d\u7cfb\u7edf&#xff0c;\u5feb\u901f\u8bc6\u522b\u7528\u6237\u60c5\u7eea\u5371\u673a\u5b9e\u6218\u6307\u5357&#xff08;\u5efa\u8bae\u6536\u85cf&#xff09; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u4e00&#xff09;&#xff1a;\u8003\u5fd7\u613f\u586b\u62a5\u5546\u673a&#xff0c;PHP&#043;AI\u5f00\u53d1\u9009\u4e13\u4e1a\u63a8\u8350\u7cfb\u7edf\u5f00\u53d1\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u4e8c&#xff09;&#xff1a;\u7528PHP&#043;OCR\u81ea\u52a8\u5ba1\u6838\u8bc1\u4ef6\u7167&#xff0c;\u516c\u52a1\u5458\u62a5\u8003\u7cfb\u7edf\u5f00\u53d1\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u4e09&#xff09;&#xff1a;\u653f\u52a1\u4f1a\u8bae\u65b0\u98ce\u53e3&#xff01;\u7528Python&#043;GPT\u81ea\u52a8\u751f\u6210\u4f1a\u8bae\u7eaa\u8981 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u56db&#xff09;&#xff1a;\u653f\u52a1\u7cfb\u7edf\u9a8c\u6536\u6f5c\u89c4\u5219&#xff0c;\u5982\u4f55\u8ba9\u7532\u65b9\u5728\u9a8c\u6536\u62a5\u544a\u4e0a\u723d\u5feb\u7b7e\u5b57&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u4e94&#xff09;&#xff1a;\u8d22\u653f\u56de\u6b3e\u653b\u575a\u6218&#xff0c;\u5982\u4f55\u7528\u533a\u5757\u94fe\u8ba9\u56fd\u5e93\u4e3b\u52a8\u4ed8\u6b3e&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u516d&#xff09;&#xff1a;\u7528AI\u7ed9\u5e02\u957f\u5199\u62a5\u544a&#xff0c;\u5982\u4f55\u9760NLP\u62ff\u4e0b\u767e\u4e07\u7ea7\u653f\u5e9c\u8ba2\u5355&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u4e03&#xff09;&#xff1a;\u5982\u4f55\u901a\u8fc7\u7b49\u4fdd\u4e09\u7ea7\u8ba4\u8bc1&#xff0c;\u653f\u5e9c\u9879\u76ee\u90e8\u7f72\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u516b&#xff09;&#xff1a;\u5343\u4e07\u7ea7\u653f\u52a1\u9879\u76ee\u5b9e\u6218&#xff0c;\u5982\u4f55\u7528AI\u81ea\u52a8\u751f\u6210\u7b49\u4fdd\u6d4b\u8bc4\u62a5\u544a&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e94\u5341\u4e5d&#xff09;&#xff1a;\u5982\u4f55\u8ba9AI\u81ea\u52a8\u64b0\u5199\u7ea2\u5934\u516c\u6587&#xff1f;\u67d0\u5385\u5c40\u529e\u516c\u5ba4\u7684\u5343\u4e07\u7ea7RPA\u9879\u76ee\u843d\u5730\u5b9e\u5f55 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341&#xff09;&#xff1a;\u653f\u52a1\u5927\u6a21\u578b&#xff0c;\u7528LangChain&#043;FastAPI\u6784\u5efa\u653f\u7b56\u77e5\u8bc6\u5e93\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u4e00&#xff09;&#xff1a;\u653f\u52a1\u5927\u6a21\u578b\u76d1\u63a7\u544a\u8b66\u5b9e\u6218&#xff0c;\u5f53\u653f\u7b56\u53d8\u66f4\u65f6\u81ea\u52a8\u7ed9\u9886\u5bfc\u53d1\u77ed\u4fe1 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u4e8c&#xff09;&#xff1a;\u7528RAG\u51fb\u7834\u5408\u540c\u5ba1\u6838\u9ed1\u5e55&#xff0c;1\u4e2a\u63d0\u793a\u8bcd\u8ba9LLM\u63ea\u51fa\u9634\u9633\u6761\u6b3e PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u4e09&#xff09;&#xff1a;\u5343\u4e07\u7ea7\u5408\u540c\u79d2\u7ea7\u54cd\u5e94&#xff0c;K8s\u5f39\u6027\u8c03\u5ea6\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u56db&#xff09;&#xff1a;\u4ece0\u52301&#xff0c;\u7528Stable Diffusion\u7ed9\u5408\u540c\u6761\u6b3e\u751f\u6210\u201c\u98ce\u9669\u56fe\u89e3\u201d PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u4e94&#xff09;&#xff1a;\u7528RAG\u589e\u5f3a\u6cd5\u5f8bAI&#xff0c;\u6784\u5efa\u5408\u540c\u6761\u6b3e\u7684\u201c\u8bb0\u5fc6\u5bab\u6bbf\u201d PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u516d&#xff09;&#xff1a;\u8ba9\u6cd5\u5f8bAI\u62e5\u6709\u201c\u6cd5\u5b98\u601d\u7ef4\u201d&#xff0c;\u57fa\u4e8eLoRA\u5fae\u8c03\u7684\u88c1\u5224\u89c4\u5219\u751f\u6210\u672f PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u4e03&#xff09;&#xff1a;\u6cd5\u5f8b\u6761\u6587\u4e0e\u88c1\u5224\u5b9e\u8df5\u7684\u9e3f\u6c9f\u5982\u4f55\u8de8\u8d8a&#xff1f;\u2014\u2014\u57fa\u4e8e\u77e5\u8bc6\u56fe\u8c31\u7684\u53f8\u6cd5\u89e3\u91ca\u52a8\u6001\u9002\u914d\u7cfb\u7edf PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u516b&#xff09;&#xff1a;\u533a\u5757\u94fe\u8d4b\u80fd\u53f8\u6cd5\u5b58\u8bc1&#xff0c;\u6784\u5efa\u4e0d\u53ef\u7be1\u6539\u7684\u7535\u5b50\u8bc1\u636e\u95ed\u73af\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516d\u5341\u4e5d&#xff09;&#xff1a;\u5f53AI\u6cd5\u5b98\u9047\u4e0a\u667a\u80fd\u5408\u7ea6&#xff0c;\u5982\u4f55\u7528LLM\u81ea\u52a8\u751f\u6210\u88c1\u5224\u6587\u4e66&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341&#xff09;&#xff1a;\u77e5\u8bc6\u56fe\u8c31\u5982\u4f55\u8ba9AI\u6cd5\u5b98\u770b\u7a7f\u201c\u5957\u8def\u8d37\u201d&#xff1f;\u2014\u2014\u53f8\u6cd5\u9634\u8c0b\u8bc6\u522b\u6280\u672f\u63ed\u79d8 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u4e00&#xff09;&#xff1a;\u5982\u4f55\u7528Neo4j\u6784\u5efa\u501f\u8d37\u5173\u7cfb\u56fe\u8c31&#xff1f;\u89e3\u6790\u8d44\u91d1\u6d41\u6c34\u65f6\u7a7a\u77e9\u9635\u63ea\u51fa\u201c\u780d\u5934\u606f\u201c\u548c\u201c\u5faa\u73af\u8d37\u201c PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u4e8c&#xff09;&#xff1a;\u653f\u52a1\u70ed\u7ebf\u5347\u7ea7&#xff0c;\u7528LLM\u5b9e\u73b095%\u768412345\u667a\u80fd\u6d3e\u5355 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u4e09&#xff09;&#xff1a;\u653f\u52a1\u7cfb\u7edf\u6536\u6b3e\u5168\u653b\u7565&#xff0c;\u8d22\u653f\u652f\u4ed8\u6d41\u7a0b\u89e3\u5bc6 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u56db&#xff09;&#xff1a;AI\u5982\u4f55\u4f18\u5316\u57ce\u5e02\u4ea4\u901a&#xff0c;\u5b9e\u65f6\u9884\u6d4b\u62e5\u5835\u4e0e\u4e8b\u6545\u54cd\u5e94 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u4e94&#xff09;&#xff1a;\u5f3a\u5316\u5b66\u4e60\u91cd\u5851\u4fe1\u53f7\u706f\u63a7\u5236&#xff0c;\u5982\u4f55\u8ba9\u57ce\u5e02\u201c\u5fc3\u8df3\u201c\u66f4\u667a\u80fd&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u516d&#xff09;&#xff1a;\u684c\u9762\u5e94\u7528\u7a81\u56f4&#xff0c;PHP\u540e\u7aef&#043;Python\u524d\u7aef\u5f00\u53d1\u8de8\u5e73\u53f0\u5de5\u63a7\u7cfb\u7edf PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u4e03&#xff09;&#xff1a; PHP\u8c03\u7528Android\u81ea\u52a8\u5316\u811a\u672c&#xff0c;Python\u63a7\u5236\u624b\u673a\u63a5\u5355\u5b9e\u6218\u6307\u5357 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u516b&#xff09;&#xff1a;\u5343\u4e07\u7ea7\u8ba2\u5355\u7cfb\u7edf\u5982\u4f55\u505a\u81ea\u52a8\u5316\u98ce\u63a7&#xff1f;\u6df1\u5ea6\u89e3\u6790\u884c\u4e3a\u8f68\u8ff9\u5efa\u6a21\u6280\u672f PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e03\u5341\u4e5d&#xff09;&#xff1a;\u8de8\u5e73\u53f0\u9632\u5c01\u6740\u5b9e\u6218&#xff0c;\u57fa\u4e8e\u5f3a\u5316\u5b66\u4e60\u7684\u5206\u5e03\u5f0f\u722c\u866b\u653b\u9632\u4f53\u7cfb PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341&#xff09;&#xff1a;\u7a81\u7834\u9876\u7ea7\u53cd\u722c&#xff0c;Yelp\/Facebook\u5bf9\u6297\u8bad\u7ec3\u6e90\u7801\u89e3\u6790 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u4e00&#xff09;&#xff1a;\u4ebf\u7ea7\u6570\u636e\u5b9e\u65f6\u6e05\u6d17\u7cfb\u7edf\u67b6\u6784\u8bbe\u8ba1&#xff0c;\u5982\u4f55\u7528Flink&#043;Elasticsearch\u5b9e\u73b0\u6beb\u79d2\u7ea7\u5f02\u5e38\u68c0\u6d4b&#xff1f;\u600e\u6837\u8bbe\u8ba1\u6570\u636e\u8840\u7f18\u8ffd\u6eaf\u6a21\u5757&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u4e8c&#xff09;&#xff1a;\u5982\u4f55\u96c6\u6210AI\u6a21\u578b\u5b9e\u73b0\u5b9e\u65f6\u9884\u6d4b\u5206\u6790&#xff1f;\u2014\u2014\u63ed\u79d8Flink\u4e0eTensorFlow Serving\u878d\u5408\u6784\u5efa\u667a\u80fd\u98ce\u63a7\u7cfb\u7edf PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u4e09&#xff09;&#xff1a;\u5343\u4e07\u7ea7\u5e76\u53d1\u4e0b\u7684\u6a21\u578b\u538b\u7f29\u5b9e\u6218&#xff0c;\u5982\u4f55\u8ba9BERT\u63d0\u901f10\u500d&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u56db&#xff09;&#xff1a;\u767e\u4ebf\u7ea7\u6570\u636e\u5b9e\u65f6\u68c0\u7d22&#xff0c;\u57fa\u4e8eGPU\u7684\u5411\u91cf\u6570\u636e\u5e93\u4f18\u5316\u5b9e\u6218 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u4e94&#xff09;&#xff1a;\u4e07\u4ebf\u6570\u636e\u79d2\u7ea7\u54cd\u5e94&#xff0c;\u5206\u5e03\u5f0f\u56fe\u6570\u636e\u5e93Neo4j\u4f18\u5316\u5b9e\u6218\u2014\u2014\u63ed\u79d8\u5de5\u4e1a\u7ea7\u56fe\u8ba1\u7b97\u65b9\u6848\u5982\u4f55\u7a81\u7834\u5355\u673a\u74f6\u9888&#xff0c;\u5b9e\u73b0\u5343\u4ebf\u7ea7\u5173\u7cfb\u7f51\u7edc\u4e9a\u79d2\u67e5\u8be2 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u516d&#xff09;&#xff1a;\u56fe\u795e\u7ecf\u7f51\u7edc\u5b9e\u6218&#xff0c;\u57fa\u4e8eDeepWalk\u7684\u4ebf\u7ea7\u8282\u70b9Embedding\u751f\u6210 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u4e03&#xff09;&#xff1a;\u52a8\u6001\u56fe\u795e\u7ecf\u7f51\u7edc\u5728\u5b9e\u65f6\u53cd\u6b3a\u8bc8\u4e2d\u7684\u8fdb\u5316&#xff0c;\u5206\u949f\u7ea7\u66f4\u65b0\u3001\u56e2\u4f19\u8bc6\u522b\u4e0e\u51b7\u542f\u52a8\u7a81\u7834 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u516b&#xff09;&#xff1a;\u8054\u90a6\u56fe\u5b66\u4e60\u5728\u8de8\u673a\u6784\u98ce\u63a7\u4e2d\u7684\u5e94\u7528&#xff0c;\u6253\u7834\u6570\u636e\u5b64\u5c9b&#xff0c;\u5171\u5efa\u53cd\u6b3a\u8bc8\u62a4\u57ce\u6cb3 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u516b\u5341\u4e5d&#xff09;&#xff1a;\u5f53\u96f6\u77e5\u8bc6\u8bc1\u660e\u9047\u4e0a\u91cf\u5b50\u968f\u673a\u884c\u8d70&#xff0c;\u6784\u5efa\u76d1\u7ba1\u53cb\u597d\u7684DeFi\u98ce\u63a7\u7cfb\u7edf PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341&#xff09;&#xff1a;\u91cf\u5b50\u62b5\u6297\u533a\u5757\u94fe\u4e2d\u7684\u540c\u6001\u52a0\u5bc6&#xff0c;\u5982\u4f55\u5b9e\u73b0\u5b9e\u65f6\u5408\u89c4\u76d1\u63a7\u800c\u4e0d\u6cc4\u9732\u6570\u636e&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u4e00&#xff09;&#xff1a;\u5f53Plonk\u9047\u4e0a\u8054\u90a6\u5b66\u4e60&#xff0c;\u5982\u4f55\u6784\u5efa\u53ef\u9a8c\u8bc1\u7684\u9690\u79c1AI\u9884\u8a00\u673a&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u4e8c&#xff09;&#xff1a;ZK-Rollup\u7684\u76d1\u7ba1\u540e\u95e8&#xff1f;\u63ed\u79d8\u5982\u4f55\u5728\u4e0d\u7834\u574f\u96f6\u77e5\u8bc6\u8bc1\u660e\u7684\u524d\u63d0\u4e0b\u5b9e\u73b0\u76d1\u7ba1\u5408\u89c4 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u4e09&#xff09;&#xff1a;ZKML\u5b9e\u6218&#xff1a;\u5982\u4f55\u8ba9\u4ee5\u592a\u574a\u667a\u80fd\u5408\u7ea6\u8fd0\u884cTensorFlow\u6a21\u578b&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u56db&#xff09;&#xff1a;\u5f53Diffusion\u6a21\u578b\u9047\u89c1ZKML&#xff0c;\u5982\u4f55\u6784\u5efa\u53ef\u9a8c\u8bc1\u7684\u94fe\u4e0aAIGC&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u4e94&#xff09;&#xff1a;\u7a81\u7834ZKML\u6781\u9650&#xff0c;10\u4ebf\u53c2\u6570\u5927\u6a21\u578b\u5982\u4f55\u5b9e\u73b0\u5b9e\u65f6\u94fe\u4e0a\u63a8\u7406&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u516d&#xff09;&#xff1a;ZKML\u8d4b\u80fdDeFi&#xff0c;\u5982\u4f55\u8ba9\u667a\u80fd\u5408\u7ea6\u81ea\u4e3b\u6267\u884cAI\u98ce\u63a7&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u4e03&#xff09;&#xff1a;\u5f53\u9884\u8a00\u673a\u5b66\u4f1a\u8bf4\u8c0e&#xff0c;\u5982\u4f55\u7528zkPoS\u673a\u5236\u9632\u5fa1\u6570\u636e\u6295\u6bd2\u653b\u51fb&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u516b&#xff09;&#xff1a;\u5f53\u9884\u8a00\u673a\u6210\u4e3a\u653b\u51fb\u8005&#xff0c;\u57fa\u4e8e\u5b89\u5168\u98de\u5730\u7684\u53bb\u4e2d\u5fc3\u5316\u81ea\u68c0\u67b6\u6784 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e5d\u5341\u4e5d&#xff09;&#xff1a;\u5f53\u96f6\u77e5\u8bc6\u8bc1\u660e\u9047\u89c1TEE&#xff0c;\u5982\u4f55\u5b9e\u73b0\u9690\u79c1\u4e0e\u5b89\u5168\u7684\u53cc\u91cd\u7206\u53d1&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;\u4e00\u767e&#xff09;&#xff1a;\u6253\u7834\u201c\u6570\u636e\u5b64\u5c9b\u201d\u7684\u6700\u540e\u4e00\u9053\u5899\u2014\u2014\u57fa\u4e8e\u5168\u540c\u6001\u52a0\u5bc6(FHE)\u7684\u5b9e\u65f6\u591a\u65b9\u8ba1\u7b97\u5b9e\u8df5 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;101&#xff09;&#xff1a;Octane\u6838\u5fc3\u673a\u5236&#xff0c;Swoole\u534f\u7a0b\u5982\u4f55\u7a81\u7834PHP\u963b\u585e\u74f6\u9888&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;102&#xff09;&#xff1a;\u5171\u4eab\u5185\u5b58\u9ed1\u79d1\u6280&#xff1a;Octane\u5982\u4f55\u5b9e\u73b0AI\u6a21\u578b\u96f6\u62f7\u8d1d\u70ed\u52a0\u8f7d&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;103&#xff09;&#xff1a;\u8bf7\u6c42\u9694\u79bb\u7684\u9677\u9631&#xff0c;\u6e90\u7801\u5c42\u9762\u89e3\u51b3AI\u4f1a\u8bdd\u6570\u636e\u6c61\u67d3 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;104&#xff09;&#xff1a;LibTorch C&#043;&#043;\u63a5\u53e3\u89e3\u5256&#xff0c;\u5982\u4f55\u7ed5\u8fc7Python\u5b9e\u73b0\u6beb\u79d2\u7ea7\u63a8\u7406&#xff1f; PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;105&#xff09;&#xff1a; PHP\u6269\u5c55\u5f00\u53d1\u5b9e\u6218&#xff0c;\u5c06LibTorch\u5d4c\u5165Zend\u5f15\u64ce PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;106&#xff09;&#xff1a;GPU\u663e\u5b58\u7ba1\u7406\u7ec8\u6781\u65b9\u6848&#xff0c;PHP\u76f4\u63a5\u64cd\u63a7CUDA\u4e0a\u4e0b\u6587 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;107&#xff09;&#xff1a;Apache Arrow\u6838\u5fc3&#xff0c;\u8de8\u8bed\u8a00\u96f6\u62f7\u8d1d\u4f20\u8f93\u7684\u6beb\u7c73\u7ea7\u4f18\u5316 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;108&#xff09;&#xff1a;GPU\u96f6\u62f7\u8d1d\u52a0\u901f&#xff0c;\u767e\u6beb\u79d2\u964d\u81f310ms PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;109&#xff09;&#xff1a;\u4e07\u4ebf\u7ea7\u5411\u91cf\u68c0\u7d22\u5b9e\u6218&#xff0c;GPU\u52a0\u901f\u7684Faiss\u4f18\u5316\u65b9\u6848 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;110&#xff09;&#xff1a;PHP\u6269\u5c55\u5f00\u53d1&#xff0c;\u76f4\u63a5\u64cd\u4f5cArrow C Data Interface\u7684\u9ed1\u9b54\u6cd5 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;111&#xff09;&#xff1a;\u8de8\u8bed\u8a00\u5185\u5b58\u5171\u4eab\u5b9e\u6218&#xff0c;\u5728PHP\u4e2d\u76f4\u63a5\u8c03\u7528PyTorch\u6a21\u578b\u7684\u7ec8\u6781\u65b9\u6848 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;112&#xff09;&#xff1a;\u5206\u5e03\u5f0f\u5171\u4eab\u5185\u5b58&#xff0c;\u8de8\u670d\u52a1\u5668\u8c03\u7528PyTorch\u96c6\u7fa4 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;113&#xff09;&#xff1a;\u4e07\u5361\u96c6\u7fa4\u65b0\u7a81\u7834&#xff0c;\u52a8\u6001\u6269\u7f29\u5bb9\u5728\u5206\u5e03\u5f0fDL\u8bad\u7ec3\u4e2d\u7684\u5e94\u7528 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;114&#xff09;&#xff1a;\u7a81\u7834\u5343\u4ebf\u5411\u91cf&#xff0c;\u57fa\u4e8eGraphANN\u7684\u5206\u5e03\u5f0f\u7d22\u5f15\u8bbe\u8ba1 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;115&#xff09;&#xff1a;\u4e07\u4ebf\u53c2\u6570\u65b0\u7eaa\u5143&#xff0c;\u68af\u5ea6\u538b\u7f29\u4e0e\u6d41\u6c34\u7ebf\u5e76\u53d1\u7684\u534f\u540c\u4f18\u5316 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;116&#xff09;&#xff1a;\u4e07\u5361\u96c6\u7fa4\u8bad\u7ec3\u5b9e\u6218&#xff0c;\u5982\u4f55\u7528\u62d3\u6251\u611f\u77e5\u901a\u4fe1\u4f18\u5316\u8de8\u673a\u623f\u8bad\u7ec3 PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217&#xff08;117&#xff09;&#xff1a;\u5343\u5361\u7ea7\u5927\u6a21\u578b\u8bad\u7ec3&#xff0c;\u5982\u4f55\u75283D\u5e76\u884c\u7b56\u7565\u7a81\u7834\u663e\u5b58\u5899<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb563\u6b21\uff0c\u70b9\u8d5e8\u6b21\uff0c\u6536\u85cf15\u6b21\u3002\u6458\u8981 \u672c\u6587\u9488\u5bf9\u4e07\u5361\u96c6\u7fa4\u8bad\u7ec3\u4e2d\u9ad8\u8fbe70%\u7684\u901a\u4fe1\u5ef6\u8fdf\u95ee\u9898\uff0c\u63d0\u51fa\u4e09\u5927\u6838\u5fc3\u6280\u672f\u4f18\u5316\u65b9\u6848\uff1a\u62d3\u6251\u611f\u77e5\u901a\u4fe1\u7b97\u6cd5\u3001NCCL\u786c\u4ef6\u4f18\u5316\u53ca\u68af\u5ea6\u538b\u7f29\u6280\u672f\u3002\u901a\u8fc7\u67d0AI\u4f01\u4e1a\u6848\u4f8b\u9a8c\u8bc1\uff0cAll-Reduce\u5ef6\u8fdf\u4ece850ms\u964d\u81f385ms\uff08\u964d\u4f4e90%\uff09\u3002\u65b9\u6848\u6db5\u76d6\u9700\u6c42\u5206\u6790\u3001\u67b6\u6784\u8bbe\u8ba1\uff08\u542b\u5206\u5c42\u901a\u4fe1\u6811\u3001RDMA\u76f4\u8fde\u7b49\uff09\u3001\u4ee3\u7801\u5b9e\u73b0\u53ca\u90e8\u7f72\u7b56\u7565\uff0c\u4e3a\u5343\u4ebf\u53c2\u6570\u6a21\u578b\u8bad\u7ec3\u63d0\u4f9b\u5b8c\u6574\u4f18\u5316\u8def\u5f84\uff0c\u53ef\u7f29\u77ed\u8bad\u7ec3\u5468\u671f3\u500d\uff0c\u63d0\u5347GPU\u5229\u7528\u7387\u81f389%\uff0c\u5b9e\u73b0\u663e\u8457\u6210\u672c\u8282\u7ea6\u3002<\/p>\n","protected":false},"author":2,"featured_media":47109,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[230,4504,81,50,664,190],"topic":[],"class_list":["post-47126","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-server","tag-php","tag-phpai","tag-python","tag-50","tag-664","tag-190"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/47126.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb563\u6b21\uff0c\u70b9\u8d5e8\u6b21\uff0c\u6536\u85cf15\u6b21\u3002\u6458\u8981 \u672c\u6587\u9488\u5bf9\u4e07\u5361\u96c6\u7fa4\u8bad\u7ec3\u4e2d\u9ad8\u8fbe70%\u7684\u901a\u4fe1\u5ef6\u8fdf\u95ee\u9898\uff0c\u63d0\u51fa\u4e09\u5927\u6838\u5fc3\u6280\u672f\u4f18\u5316\u65b9\u6848\uff1a\u62d3\u6251\u611f\u77e5\u901a\u4fe1\u7b97\u6cd5\u3001NCCL\u786c\u4ef6\u4f18\u5316\u53ca\u68af\u5ea6\u538b\u7f29\u6280\u672f\u3002\u901a\u8fc7\u67d0AI\u4f01\u4e1a\u6848\u4f8b\u9a8c\u8bc1\uff0cAll-Reduce\u5ef6\u8fdf\u4ece850ms\u964d\u81f385ms\uff08\u964d\u4f4e90%\uff09\u3002\u65b9\u6848\u6db5\u76d6\u9700\u6c42\u5206\u6790\u3001\u67b6\u6784\u8bbe\u8ba1\uff08\u542b\u5206\u5c42\u901a\u4fe1\u6811\u3001RDMA\u76f4\u8fde\u7b49\uff09\u3001\u4ee3\u7801\u5b9e\u73b0\u53ca\u90e8\u7f72\u7b56\u7565\uff0c\u4e3a\u5343\u4ebf\u53c2\u6570\u6a21\u578b\u8bad\u7ec3\u63d0\u4f9b\u5b8c\u6574\u4f18\u5316\u8def\u5f84\uff0c\u53ef\u7f29\u77ed\u8bad\u7ec3\u5468\u671f3\u500d\uff0c\u63d0\u5347GPU\u5229\u7528\u7387\u81f389%\uff0c\u5b9e\u73b0\u663e\u8457\u6210\u672c\u8282\u7ea6\u3002\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/47126.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2025-07-29T22:12:31+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221201-68894731b3268.jpg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"11 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/47126.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/47126.html\",\"name\":\"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2025-07-29T22:12:31+00:00\",\"dateModified\":\"2025-07-29T22:12:31+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/47126.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/47126.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/47126.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/47126.html","og_locale":"zh_CN","og_type":"article","og_title":"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb563\u6b21\uff0c\u70b9\u8d5e8\u6b21\uff0c\u6536\u85cf15\u6b21\u3002\u6458\u8981 \u672c\u6587\u9488\u5bf9\u4e07\u5361\u96c6\u7fa4\u8bad\u7ec3\u4e2d\u9ad8\u8fbe70%\u7684\u901a\u4fe1\u5ef6\u8fdf\u95ee\u9898\uff0c\u63d0\u51fa\u4e09\u5927\u6838\u5fc3\u6280\u672f\u4f18\u5316\u65b9\u6848\uff1a\u62d3\u6251\u611f\u77e5\u901a\u4fe1\u7b97\u6cd5\u3001NCCL\u786c\u4ef6\u4f18\u5316\u53ca\u68af\u5ea6\u538b\u7f29\u6280\u672f\u3002\u901a\u8fc7\u67d0AI\u4f01\u4e1a\u6848\u4f8b\u9a8c\u8bc1\uff0cAll-Reduce\u5ef6\u8fdf\u4ece850ms\u964d\u81f385ms\uff08\u964d\u4f4e90%\uff09\u3002\u65b9\u6848\u6db5\u76d6\u9700\u6c42\u5206\u6790\u3001\u67b6\u6784\u8bbe\u8ba1\uff08\u542b\u5206\u5c42\u901a\u4fe1\u6811\u3001RDMA\u76f4\u8fde\u7b49\uff09\u3001\u4ee3\u7801\u5b9e\u73b0\u53ca\u90e8\u7f72\u7b56\u7565\uff0c\u4e3a\u5343\u4ebf\u53c2\u6570\u6a21\u578b\u8bad\u7ec3\u63d0\u4f9b\u5b8c\u6574\u4f18\u5316\u8def\u5f84\uff0c\u53ef\u7f29\u77ed\u8bad\u7ec3\u5468\u671f3\u500d\uff0c\u63d0\u5347GPU\u5229\u7528\u7387\u81f389%\uff0c\u5b9e\u73b0\u663e\u8457\u6210\u672c\u8282\u7ea6\u3002","og_url":"https:\/\/www.wsisp.com\/helps\/47126.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2025-07-29T22:12:31+00:00","og_image":[{"url":"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/07\/20250729221201-68894731b3268.jpg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"11 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/47126.html","url":"https:\/\/www.wsisp.com\/helps\/47126.html","name":"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2025-07-29T22:12:31+00:00","dateModified":"2025-07-29T22:12:31+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/47126.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/47126.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/47126.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"PHP\u63a5\u5355\u6da8\u85aa\u7cfb\u5217\uff08118\uff09\uff1a\u4e07\u5361\u96c6\u7fa4\u901a\u4fe1\u4f18\u5316\uff0c\u5982\u4f55\u964d\u4f4eAll-Reduce\u5ef6\u8fdf90%\uff1f"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/47126","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=47126"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/47126\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media\/47109"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=47126"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=47126"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=47126"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=47126"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}