作者Kelunyang (可倫)
看板PHP
標題[請益] sleep會浪費系統效能嗎?
時間Tue Nov 23 20:43:59 2010
最近在設想一個情況(實際上有遇到)
如果在做多人系統,或是在處理檔案上傳,但是是採用POST到一張會發出HTTP 200
的頁面時,目前小弟的做法是每三十秒或一分鐘送一次ajax request,確認檔案
是不是已經上傳了
但是這樣一來,request會有很多浪費在過程中,後來我發現如果在監測檔案上傳
的PHP中加入sleep()的話,可以延長時間,就不用送這麼多request
現在小弟的問題是,有沒有可能讓PHP進入sleep之後,定期的起床一下檢查
Server端到底處理完了沒,都完成了,再把這個http request給回應,這樣
應該可以節省很多無謂的ajax request吧
只是把一個request給hold在server,我知道我可以透過set_time_limit()延長
單一PHP的執行時間,只是我不確定這樣有沒有可能讓檔案執行太久被Server卡掉
然後這樣做會比原先那種定情送request的方式還佔主機的記憶體嗎@@"
不知道各位前輩的看法如何?
P.S.
這樣好像有點類似Bus的處理方法,可是PHP-DBUS還在測試中,所以想先用這樣
處理,另外就是就檔案上傳來說,可能送多個request是沒差,但是如果做多人系統
為了防止單一檔案被其他人修改,總不能一直送無謂的request,只是為了偵測
這個檔案是不是剛好被其他人開啟了吧...感覺整個就很浪費資源
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 114.36.34.246
1F:→ xam:你確定文章裡面 server-side 跟 client-side 的角色沒搞錯? 11/24 02:54
2F:→ Kelunyang:應該沒有吧@@" 我希望透過把回應滯留在主機上久一點 11/24 11:35
3F:→ Kelunyang:節省重複執行request,只是不知道這樣會不會佔據太多 11/24 11:35
4F:→ Kelunyang:server記憶體,簡單的說就是這樣@@" 11/24 11:35
5F:→ MOONRAKER:放在session不就結了。 11/24 13:03
6F:→ Kelunyang:但是假設有一個上傳會處理5分鐘 11/24 13:21
7F:→ Kelunyang:當然上傳檔案結束之後可以修改session確定上傳結束 11/24 13:21
8F:→ Kelunyang:但在過程中,為了避免不換頁,查詢這個session的PHP 11/24 13:22
9F:→ Kelunyang:該讓他每一分鐘sleep一次,定期檢查,最後回傳結果 11/24 13:22
10F:→ Kelunyang:還是每一分鐘送一次request會比較合適呢? 11/24 13:23
11F:→ Kelunyang:兩者差別在要不要讓這個thread(可能用這樣想)在主機 11/24 13:23
12F:→ Kelunyang:端活5分鐘,一個是每一分鐘製造一個分身去查一次 11/24 13:23
13F:→ Kelunyang:上傳檔案時間是固定的,或許還可以預測,但是異地編輯 11/24 13:24
14F:→ Kelunyang:如果妹一分鐘送一次無謂的request只是要確定檔案能不能 11/24 13:24
15F:→ Kelunyang:用的話,我就不知道哪一種比較好了,所以才想問的@@" 11/24 13:24
16F:→ MOONRAKER:…那這實在很複雜。 11/24 21:21
17F:→ guancheng:搞不懂為啥要用ajax監測檔案上傳,你是用什麼方式上傳 11/24 21:43
18F:→ guancheng:檔案還可以監測@@? 另外問一下你怎麼監測檔案上傳? 11/24 21:44
19F:→ Kelunyang:因為要取得檔案上傳進度啊@@" 11/24 21:47
20F:→ Kelunyang:喔我的方法我之前有說,有人有做出和我類似的方法 11/24 21:47
22F:→ guancheng:你給他sleep那不是就只有判斷是否傳完而以? 11/24 21:57
23F:→ guancheng:沒有很仔細看那個東西,不過應該也是用ajax做上傳動作吧 11/24 21:57
24F:→ guancheng:給個complete的callback不就解決了 11/24 21:58
25F:→ Kelunyang:恩,可是這那張sleep的網頁本身就是在監測某一個session 11/24 22:01
26F:→ Kelunyang:(flag)完成與否,所以完成的時候就代表上傳結束了 11/24 22:01
27F:→ Kelunyang:喔喔因為我目前用的方法是把表單給POST到一個200的頁面 11/24 22:01
28F:→ Kelunyang:所以那個頁面自己不可以有結果回傳@@" 不知道有沒有 11/24 22:02
29F:→ Kelunyang:其他方法@@" 11/24 22:02
30F:→ guancheng:感覺這個方法還蠻妙的@@ 不過我通常是用flash來傳多個 11/24 22:07
31F:→ guancheng:檔,還能取得即時進度 11/24 22:07
32F:→ Kelunyang:恩,那時候我預設是在不依靠其他的外掛情況下做XD 11/24 22:08
33F:→ Kelunyang:不然我現在會願意用silverlight或是HTML5 XD 11/24 22:08
34F:→ Kelunyang:也因此我才在想要每隔幾秒送一次request還是先hold住 11/24 22:09
35F:→ Kelunyang:也是類似你說的callback啦,只是我不知道一個request在 11/24 22:09
36F:→ Kelunyang:server hold太久會怎麼樣Orz 11/24 22:09
37F:→ guancheng:不是很清楚你詳細的作法,不過我猜應該是一個form傳多個 11/24 22:17
38F:→ guancheng:檔案,如果是一個form傳一個檔,用javascript跑就可以抓 11/24 22:19
39F:→ guancheng:到每個form結束的點了吧? 11/24 22:20
40F:→ Kelunyang:但是不能用javascript上傳檔案啊,一定要觸發FORM的 11/24 22:23
41F:→ Kelunyang:submit之後,Server端才會收到POST和FILE @@" 11/24 22:26
42F:→ guancheng:但是javascript可以改form的內容,也可以做form submit 11/24 23:15
43F:→ Kelunyang:我和你的講法是一樣的,但是如果POST的目標是200的網頁 11/25 09:26
44F:→ Kelunyang:200- no content,所以根本沒有回傳值 11/25 09:26
45F:→ Kelunyang:javascript也無法取的這個表單到底處理完了沒... 11/25 09:26