作者jjdai (jjdai)
看板i-enterprise
標題Re: [請益] 關於線上人數統計
時間Sun Oct 14 22:51:08 2007
※ 引述《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
1F:→ BlackCrazy:這樣作耗不耗資源? 10/14 23:31
2F:→ jjdai:啟動session相對沒有啟用是比較耗資源,但自己去算也多少會 10/15 23:43
3F:→ jjdai:花費一些資源。使用mem. db. 去記session更耗,但跑起來應該 10/15 23:46
4F:→ jjdai:比較有效率,且可適用於分散式的server farm。這方法用於 10/15 23:48
5F:→ jjdai:為了要實現類似 BBS 使用者列表的功能時,可能比較適合>< 10/15 23:54