Re: [請益] 關於線上人數統計

看板toberich (創業)作者 (jjdai)時間18年前 (2007/10/14 22:51), 編輯推噓0(005)
留言5則, 2人參與, 最新討論串1/1
※ 引述《pply (幹 吃晚餐去~~)》之銘言: : ※ 引述《pply (幹 吃晚餐去~~)》之銘言: : : 最近花了點時間設計一個線上人數統計的系統 : : 能夠幫網站管理員統計各個網頁的線上人數 : : 也能提供網頁排名的資訊...像是 BBS 的熱門看板一樣 : : 不知道這樣的服務有沒有更大的空間可以發展 : : 一般站長會想使用這樣的東西嗎 : : 網站在這裡~~ : : 還很陽春...我想應該還有很多改進空間...Orz.... : : http://www.incyght.com/ : 有人對技術面有興趣/質疑....那我就說明一下好了 : 當使用者瀏覽包含提供 Code 的網頁時 : 會送出一個包含原網頁網址資訊的要求到伺服器上 : 例如把提供的 code 放在 www.yyy.com/index.htm 上 : 那麼就會把 www.yyy.com/index.htm 這個資訊送到伺服器 : Server 會處理使用者 IP 以及瀏覽的網址 : 紀錄這個 IP 到訪該網址,該網址人數 +1 : 同一個 IP 會離開或者是到訪另外一個網頁 : 如果到訪另外一個網頁....則做相對應的統計工作 : 如果離開....因為瀏覽器並不會主動通知伺服器使用者離開 : 所以這裡會有一個 delay ..... : 我們讓系統定期檢查每一個 IP 多久沒有更新 : 超過 delay 的時間就認定該 IP 離開....做相對應的統計工作 : delay 可以設長設短.... : 我們沒辦法知道 IP 沒更新是為了什麼 : 可能在看一篇長篇小說,也可能只是把瀏覽器關掉,這倒是有進一步研究的空間~~ : 如果可以找到一個具有代表性的期望值是最理想的~~~ : 目前設定五分鐘~~ : 這件事情可以很精確也可以不那麼精確 : 在 HTTP 的環境下不可能絕對準 : 不過還蠻夠用了....大家可以使用來觀察看看 : 總之不是玩弄大家的把戲...: ) 如果網頁是使用 PHP 來寫的話,可以很容易做到基本的統計網站人數功能。 1. 去改寫 session 的處理方式,例如以下是將原本存到 file 的 session 資料變成 存到 MySql之類的 (memory) db. (不想搞變化的話直接去存 session file 的目錄 和子目錄中數數看有幾個檔案即可知道有幾條現存的連線): 去用 session_set_save_handler() 函式改寫 session 在 open(), close(), read(), write(), destroy(), Gc() 時的處理方式。 其中在 read() 時去更新目前的 timestamp 值;Gc() 時去檢查該 session 是否 已經超過時間了(),超過者即刪除之,現存數量即為目前連線數。 (有些細節請到網路上找相關資料) 2. 讓連到網站的連線被紀錄 session: 也就是在 xxx.php 中執行「session_start();」。 3. 預設的連線保留時間是設定在 php.ini 的 「session.gc_maxlifetime」欄位, 又其預設值是 1440 秒,也就是說一個 session 超過約 24 分鐘沒有動作的話, "可能" 會被移除 (這裡講的是 "可能",因為垃圾收集機制不是每一次都會作用 的,網站越熱門的,其狀態越正確。See Also: session.gc_probability, session.gc_divisor)。 經由上述變化處理,就可以很容易達成類似 BBS 的連線統計功能,可以有來源 IP, 連線數, idle 時間, ... 等 ,結果呈現可以參考以下 URL: http://career.zhupiter.com/account/usrlst.php -- jjdai -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 61.64.48.105

10/14 23:31, , 1F
這樣作耗不耗資源?
10/14 23:31, 1F

10/15 23:43, , 2F
啟動session相對沒有啟用是比較耗資源,但自己去算也多少會
10/15 23:43, 2F

10/15 23:46, , 3F
花費一些資源。使用mem. db. 去記session更耗,但跑起來應該
10/15 23:46, 3F

10/15 23:48, , 4F
比較有效率,且可適用於分散式的server farm。這方法用於
10/15 23:48, 4F

10/15 23:54, , 5F
為了要實現類似 BBS 使用者列表的功能時,可能比較適合><
10/15 23:54, 5F
文章代碼(AID): #174YpTwN (toberich)
文章代碼(AID): #174YpTwN (toberich)