내 홈페이지의 동시 접속자수는 몇명이나 될지 궁금할 때가 있습니다. 이런 필요로 동시 접속자수를 알려주는 위젯도 있고 제 블로그에서도 플래시 위젯으로 동시 접속자수를 알려주는 위젯을 제공하고 있기도 합니다. 그러나 직접 만들어서 동시접속자를 알려주는 것이 좀더 매력적이라고 생각하는 분들이 있다면 아래 소스 코드를 참고 하세요.^^
웹서비스의 특성상 완벽한 동시접속자를 알아 낼 수 없으므로 약간의 편법이 필요합니다. 웹서비스는 요청한 웹페이지를 내보내주고 접속을 끊으므로 같은 사용자라는 것을 알려주는 세션(session)을 발행합니다. 세션이 같으면 같은 사용자라고 볼 수 있습니다. 이 세션을 구분하는 ID 와 카운트 하고 있는 페이지(page) URL 그리고 시간(ctime)을 기록하고 현재 시간을 기준으로 적당한 시간(30초 ~ 60초) 이내에 있는 기록만 남기고 삭제 합니다. 그러면 남아 있는 레코드의 갯수가 동시 접속자수가 됩니다. 이런 작업을 하기 위해 데이타베이스에 아래와 같은 테이블을 만들고 세션 ID(session)는 주키로 시간(ctime)을 인덱스로 만듭니다.

CREATE TABLE abc_siteon (
    session varchar(64) NOT NULL default '',
    page varchar(255) default '',
    ctime datetime default NULL,
    PRIMARY KEY (session),
    KEY ctime (ctime)
)

그리고 아래와 같은 페이지(siteon_counter.php)를 만들고 원하는 홈페이지에 보이지 않는 이미지로 출력합니다. 또는 해당 홈페이지의 로고(images/siteon.gif)를 출력하거나 GD 라이브러리를 사용할 수 있는 분들은 아래 소스 마지막 라인에 이미지 출력 대신 레코드의 갯수를 숫자 이미지로 출력해주는 코드를 입력하실 수 있습니다.

<?
session_start();
$connect = @mysql_connect("localhost", "user", "password") or die("");
@mysql_select_db("database") or die("");
@mysql_query("set names utf8");
//mysql_query("set names latin1");
//mysql_query("set names euckr");
$table_name = 'abc_siteon';
$session_id = session_id();
$page = $_SERVER['HTTP_REFERER'];
if (strlen($page)<1) $page="direct";
$query = "insert into $table_name set session='$session_id'";
@mysql_query($query);
$query = "update $table_name set page='$page', ctime=now() where session='$session_id'";
@mysql_query($query);
$query = "delete from $table_name where ctime < DATE_SUB(NOW(), INTERVAL 60 SECOND)";
@mysql_query($query);
@readfile("images/siteon.gif");
?>

<img
src="/siteon_counter.php" width="1" height="1">


아래의 소스 코드(siteon.php)를 이용해 노출하고 싶은 홈페이지의 적당한 위치에 동시 접속자수를 표시해주면 동접자 구현이 완료됩니다.

<?
$connect = @mysql_connect("localhost", "user", "password") or die("");
@mysql_select_db("database") or die("");
@mysql_query("set names utf8");
$table_name = 'abc_siteon';
$query = "select count(*) total from $table_name";
$result = mysql_query($query);
$total = 0;
if ($result) {
    $row = mysql_fetch_row($result);
    if ($row) {
        $total = intval($row[0]);
    }
}
echo "동접 ".$total."명";
?>

관리자 페이지에 현재 레코드 현황을 확인할 수 있는 페이지를 만들고 페이지별 동접자수를 확인할 수 있도록 하는 것도 유용합니다. 그리고 리눅스/유닉스용 스캐쥴러인 크론(cron)을 이용해서 1분마다 동접자수를 기록하고 이를 그래프화 하면 홈페이지 트래픽을 보기좋게 파악할 수 있는 유용한 홈페이지 관리 도구가 됩니다. PHP 초급자도 파악할 수 있는 수준으로 소스 코드가 작성되었으므로 차근 차근 소스 코드를 살펴보시면 이해가 될 것이라 생각합니다.

웹프로그래머의 홈페이지 정보 블로그 http://hompy.info
이올린에 북마크하기(0) 이올린에 추천하기(0)

트랙백 주소 :: http://hompy.info/trackback/494

  1. Subject: 홈페이지 동시접속자수 구현을 위한 PHP 소스 코드

    Tracked from Holu's Note 2008/09/16 10:19  삭제

    오홋~!!! " target=_blank>" target=_blank>< http://hompy.info/494" target=_blank>> 내 홈페이지의 동시 접속자수는 몇명이나 될지 궁금할 때가 있습니다. 이런 필요로 동시 접속자수를 알려주는 위젯도 있고 제 블로그에서도 플래시 위젯으로 동시 접속자수를 알려주는 위젯을 제공하고 있기도 합니다. 그러나 직접 만들어서 동시접속자를 알려주는 것이 좀더 매력적이라고 생각하는 분들이 있다면...

댓글을 달아 주세요

  1. 활의노래 2008/09/16 12:23  댓글주소  수정/삭제  댓글쓰기

    아쉽게도 티스토리에선 써먹기가 힘든 방법이네요. 그래도 잘 보고 갑니다. ^^

  2. 초보개발자 2008/09/26 17:13  댓글주소  수정/삭제  댓글쓰기

    오늘 검색하다가 처음 알게되었습니다. 바로 즐찾했습니다.
    미칠듯한 방대한 자료. 많이 얻어가겠습니다.

  3. 지나가다가 2008/10/03 10:14  댓글주소  수정/삭제  댓글쓰기

    동접자수를 구하는데 있어서 Windows 가 아닌 Linux, Unix 환경에서는 구지 CRON, DB 까지 사용하지 않아도 PHP 에서 제공하는 세션함수만으로 구현이 가능합니다.