使用Ajax 與 img 標記
10年的文水網(wǎng)站建設經(jīng)驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設備顯示端的尺寸不同,自動調(diào)整文水建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)公司從事“文水網(wǎng)站設計”,“文水網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
原理,服務器返回的html中插入Ajax 代碼或 img 標記,img的src為需要執(zhí)行的程序。
優(yōu)點:實現(xiàn)簡單,服務端無需執(zhí)行任何調(diào)用
缺點:在執(zhí)行期間,瀏覽器會一直處于loading狀態(tài),因此這種方法并不算真正的異步調(diào)用。
$.get("doRequest.php",?{?name:?"fdipzone"}?);
img?src="doRequest.php?name=fdipzone"
使用popen
使用popen執(zhí)行命令,語法:
優(yōu)點:執(zhí)行速度快
缺點:
1).只能在本機執(zhí)行
2).不能傳遞大量參數(shù)
3).訪問量高時會創(chuàng)建很多進程
//?popen?—?打開進程文件指針??
resource?popen?(?string?$command?,?string?$mode?)
pclose(popen('php?/home/fdipzone/doRequest.php?',?'r'));
使用curl
設置curl的超時時間 CURLOPT_TIMEOUT 為1 (最小為1),因此客戶端需要等待1秒
?php?
$ch?=?curl_init();?
$curl_opt?=?array(?
CURLOPT_URL,?''
CURLOPT_RETURNTRANSFER,1,?
CURLOPT_TIMEOUT,1?
);?
curl_setopt_array($ch,?$curl_opt);?
curl_exec($ch);?
curl_close($ch);?
?
使用fsockopen
fsockopen是最好的,缺點是需要自己拼接header部分。
?php?
$url?=?'';?
$param?=?array(?
'name'='fdipzone',?
'gender'='male',?
'age'=30?
);?
doRequest($url,?$param);?
function?doRequest($url,?$param=array()){?
$urlinfo?=?parse_url($url);?
$host?=?$urlinfo['host'];?
$path?=?$urlinfo['path'];?
$query?=?isset($param)??http_build_query($param)?:?'';?
$port?=?80;?
$errno?=?0;?
$errstr?=?'';?
$timeout?=?10;?
$fp?=?fsockopen($host,?$port,?$errno,?$errstr,?$timeout);?
$out?=?"POST?".$path."?HTTP/1.1\r\n";?
$out?.=?"host:".$host."\r\n";?
$out?.=?"content-length:".strlen($query)."\r\n";?
$out?.=?"content-type:application/x-www-form-urlencoded\r\n";?
$out?.=?"connection:close\r\n\r\n";?
$out?.=?$query;?
fputs($fp,?$out);?
fclose($fp);?
}?
?
注意:當執(zhí)行過程中,客戶端連接斷開或連接超時,都會有可能造成執(zhí)行不完整,因此需要加上
ignore_user_abort(true);?//?忽略客戶端斷開?
set_time_limit(0);????//?設置執(zhí)行不超時
jquery中的ajax有個async:false,設為這個屬性就可以同時調(diào)用php
默認是true:異步,false:同步。
$.ajax({
type: "post",
url: "path",
cache:false,
async:false,
success: function(data){
}
});
首先 php 7以下 不支持異步方式(有個類庫 可以勉強算是支持了異步 名字忘了)
其次 php腳本 由于是逐行解析的,不常駐線程(當然可以設置為永久連接,不自動超時退出) 異步意義不大。
第三 我懷疑你是想問javascript的異步請求? 如何用php處理?
如果沒問錯的話 可以用其他方式來解決異步問題,就是同時發(fā)出多個web request請求 等多個請求成功之后將結果寫入數(shù)據(jù)庫(文件) 然后 有一個 一直在等待結果的php請求進程 一旦讀取到了這個寫入完畢的(數(shù)據(jù)庫)文件結果 馬上返回給瀏覽器
利用php的系統(tǒng)調(diào)用,開啟新的進程來實現(xiàn)。
php
提供了fsockopen函數(shù),此函數(shù)的功能為初始化一個套接字連接到指定主機,默認情況下將以阻塞模式開啟套接字連接。當然你可以通過stream_set_blocking()將它轉換到非阻塞模式。這是關鍵。所以,思路就是:開啟一個非阻塞的套接字連接到本機,本機收到之后作一些耗時處理。
?php
class?Analytics_SomeConsumer?{
public?function?__construct()?{
$this-socket?=?socket_create(AF_INET,?SOCK_STREAM,?SOL_TCP);
socket_set_nonblock($this-socket);
socket_connect($this-socket,?$this-host,?$this-port);
$this-queue?=?array();
}
public?function?__destruct()?{
$payload?=?json_encode($this-queue);
#?...?//?wait?for?socket?to?be?writeable
socket_write($this-socket,?$payload);
socket_close($this-socket);
}
public?function?track($item)?{
array_push($this-queue,?$item);
}
?
php 高并發(fā)解決思路解決方案,如何應對網(wǎng)站大流量高并發(fā)情況。本文為大家總結了常用的處理方式,但不是細節(jié),后續(xù)一系列細節(jié)教程給出。希望大家喜歡。
一 高并發(fā)的概念
在互聯(lián)網(wǎng)時代,并發(fā),高并發(fā)通常是指并發(fā)訪問。也就是在某個時間點,有多少個訪問同時到來。
二 高并發(fā)架構相關概念
1、QPS (每秒查詢率) : 每秒鐘請求或者查詢的數(shù)量,在互聯(lián)網(wǎng)領域,指每秒響應請求數(shù)(指 HTTP 請求)
2、PV(Page View):綜合瀏覽量,即頁面瀏覽量或者點擊量,一個訪客在 24 小時內(nèi)訪問的頁面數(shù)量
--注:同一個人瀏覽你的網(wǎng)站的同一頁面,只記做一次 pv
3、吞吐量(fetches/sec) :單位時間內(nèi)處理的請求數(shù)量 (通常由 QPS 和并發(fā)數(shù)決定)
4、響應時間:從請求發(fā)出到收到響應花費的時間
5、獨立訪客(UV):一定時間范圍內(nèi),相同訪客多次訪問網(wǎng)站,只計算為 1 個獨立訪客
6、帶寬:計算帶寬需關注兩個指標,峰值流量和頁面的平均大小
7、日網(wǎng)站帶寬: PV/統(tǒng)計時間(換算到秒) * 平均頁面大小(kb)* 8
三 需要注意點:
1、QPS 不等于并發(fā)連接數(shù)(QPS 是每秒 HTTP 請求數(shù)量,并發(fā)連接數(shù)是系統(tǒng)同時處理的請求數(shù)量)
2、峰值每秒請求數(shù)(QPS)= (總 PV 數(shù)*80%)/ (六小時秒數(shù)*20%)【代表 80%的訪問量都集中在 20%的時間內(nèi)】
3、壓力測試: 測試能承受的最大并發(fā)數(shù) 以及測試最大承受的 QPS 值
4、常用的性能測試工具【ab,wrk,httpload,Web Bench,Siege,Apache JMeter】
四 優(yōu)化
1、當 QPS 小于 50 時
優(yōu)化方案:為一般小型網(wǎng)站,不用考慮優(yōu)化
2、當 QPS 達到 100 時,遇到數(shù)據(jù)查詢瓶頸
優(yōu)化方案: 數(shù)據(jù)庫緩存層,數(shù)據(jù)庫的負載均衡
3、當 QPS 達到 800 時, 遇到帶寬瓶頸
優(yōu)化方案:CDN 加速,負載均衡
4、當 QPS 達到 1000 時
優(yōu)化方案: 做 html 靜態(tài)緩存
5、當 QPS 達到 2000 時
優(yōu)化方案: 做業(yè)務分離,分布式存儲
五、高并發(fā)解決方案案例:
1、流量優(yōu)化
防盜鏈處理(去除惡意請求)
2、前端優(yōu)化
(1) 減少 HTTP 請求[將 css,js 等合并]
(2) 添加異步請求(先不將所有數(shù)據(jù)都展示給用戶,用戶觸發(fā)某個事件,才會異步請求數(shù)據(jù))
(3) 啟用瀏覽器緩存和文件壓縮
(4) CDN 加速
(5) 建立獨立的圖片服務器(減少 I/O)
3、服務端優(yōu)化
(1) 頁面靜態(tài)化
(2) 并發(fā)處理
(3) 隊列處理
4、數(shù)據(jù)庫優(yōu)化
(1) 數(shù)據(jù)庫緩存
(2) 分庫分表,分區(qū)
(3) 讀寫分離
(4) 負載均衡
5、web 服務器優(yōu)化
(1) nginx 反向代理實現(xiàn)負載均衡
(2) lvs 實現(xiàn)負載均衡
新聞標題:php數(shù)據(jù)異步請求,php curl異步請求
文章地址:http://www.chinadenli.net/article14/hegoge.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航、商城網(wǎng)站、外貿(mào)建站、網(wǎng)站排名、軟件開發(fā)、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)