php在线人数
⑴ 询问一个200人同时在线的php系统,需要怎么的服务器
200人同时在线并不是一个大的数字
普通4核的服务器就足够用了
xeon5410以上 8G内存 最好用linux系统,不会玩的话windows也没问题
最优的架构应该是LNMP=Linux+Nginx+Mysql+Php
⑵ php利用文件属性和session统计在线人数的原理
<?php
ob_start();
session_start();
$num=0;
$dirpt = "online";
$reftime = 1;
if (is_dir($dirpt) && $dir = opendir($dirpt)) {
while (($file = readdir($dir)) !== false) {
if(strcmp($file,"..")==0 || strcmp($file,".")==0){
continue;
}
$D_[date("Y-m-d H:i:s",filemtime($dirpt."/".$file))]=$file;
$num++;
unset($cum);
}
closedir($dir);
$filename = session_id();
$fp = fopen($dirpt."/".$filename,"w");
fputs($fp,"");
fclose($fp);
$ntime = date("Y-m-d H:i:s",mktime(date("H"),date("i")-1,0,date("m"),date("d"),date("Y")));
$D_[$ntime]="-";
krsort($D_);
$onlinenumber=0;
while(1){
$vkey=key($D_);
$onlinenumber++;
if(strcmp($ntime,$vkey)==0){
break;
}else{
array_shift($D_);
}
}
array_shift($D_);
reset($D_);
while(count($D_)>0){
$ckey=key($D_);
unlink($dirpt."/".$D_[$ckey]);
if(!next($D_)){
break;
}
}
}else{
@chmod("..",0777);
@mkdir($dirpt,0777);
}
$online=$onlinenumber-1;
$retime=60*$reftime;
echo "当前在线<strong><font color=red>$online</font></strong>人<meta http-equiv=refresh content=\"{$retime},url=\">";
ob_end_flush();
?>
<!--
《利用文件属性结合Session进行在线人数统计》
作者:sports98
编写日期: 2003-3-19
-->
⑶ php 统计在线人数 根据IP判断哪个地方多少人, 也就是说,某C段的多少人。这个样子,不知道怎么写判断。
$on = array(0=>array('uid'=>222,'ip'=>'22.121.11.22'),...);
$ip_part= array(-2323,22323,1231232,1231231231,123123123123,12312332131);//ip段的小大顺序排列
$ip_part_count = array();
foreach($on as $k=>$v){
$on[$k]['ip'] = ip2long($v['ip']);
for($i=0;$i<count($ip_part);$i++)
if($on[$k]['ip'] >= $ip_part[$i] and $on[$k]['ip'] <$ip_part[$i+1]){
if(isset($ip_part_count[$i])){
$ip_part_count[$i]++;
}
else{
$ip_part_count[$i] = 1;
}
}
}
}
这里写代码容易出错,不供测试,仅供参考
⑷ PHP如何统计在线人数
原理:根据不同的IP统计出当前有多少人在线。
实现方式:可以用数据库,也可以用文本。
我这里用了文本实现。
$user_online="count.php";//保存人数的文件
touch($user_online);//如果没有此文件,则创建
$timeout=30;//30秒内没动作者,认为掉线
$user_arr=file_get_contents($user_online);
$user_arr=explode('#',rtrim($user_arr,'#'));
print_r($user_arr);
$temp=array();
foreach($user_arras$value){
$user=explode(",",trim($value));
if(($user[0]!=getenv('REMOTE_ADDR'))&&($user[1]>time())){//如果不是本用户IP并时间没有超时则放入到数组中
array_push($temp,$user[0].",".$user[1]);
}
}
array_push($temp,getenv('REMOTE_ADDR').",".(time()+($timeout)).'#');//保存本用户的信息
$user_arr=implode("#",$temp);
//写入文件
$fp=fopen($user_online,"w");
flock($fp,LOCK_EX);//flock()不能在NFS以及其他的一些网络文件系统中正常工作
fputs($fp,$user_arr);
flock($fp,LOCK_UN);
fclose($fp);
echo"当前有".count($temp)."人在线";
⑸ 关于 php 获取在线人数
function online_user() {
global $tablepre, $db, $localtime;
// 超时时间
$outtime = $localtime - (60 * 15);
// 用户相关参数
$uid = isset($_SESSION['s_userid']) ? intval($_SESSION['s_userid']) : 0;
$ip = $_SERVER['REMOTE_ADDR'];
$sid = substr(md5($ip), 0, 5);
// 删除同Ip用户
$user = $db -> fetch_one_array("SELECT * FROM {$tablepre}onlineuser WHERE sid = '$sid' AND ip = '$ip' ");
if (!empty($user)) {
// 更新当前用户状态
$db -> query("UPDATE {$tablepre}onlineuser SET uid = $uid, activetime = $localtime WHERE sid = '$sid' AND ip = '$ip' ");
} else {
// 写入当前用户状态
$db -> query("INSERT INTO {$tablepre}onlineuser (sid,uid,activetime,ip) VALUES ('$sid',$uid,$localtime,'$ip')");
}
// 删除超时用户
$db -> query("DELETE FROM {$tablepre}onlineuser WHERE activetime < $outtime ");
}
数据库字段:sid,uid,activetime,ip
在程序入口外调用
⑹ 用dz做个php的地方论坛的,如果1000人同时在线,100M空间,50M数据库够用么
1000人同时在线,你的网站都赶上现在主流的一些站了..校内网,51同时在线1000也不是一直OK的
如果真的这样,别说100M了,你还是租服务器吧
IIS连接限制1000以上,流量不限制,CPU5%以上
本地论坛,同时在线50人就算很牛了..可以说不是一般的牛,如果能稳定一天同时在线50人,你论坛可以说的上是你们当地最牛的论坛了
刚开始买个空间300M 50M数据库,IIS 100左右,流量不限,CPU1 2都可以..足够了
⑺ PHP中如何实现在线人数的统计和显示
要使用数据库,建立一个表,比如名字是online,至少有以下列:
name_ip 存放登录用户名,未登录的存放IP,char类型
url 存放每个页面的地址,char类型
last_time 存放刷新页面的最后时间,int类型
表的主键是:name_ip+url
每个页面一开始就要刷新这个表,使用的SQL是:
$name_ip='用户名或者IP';//你能搞定
$url=$_SERVER["PHP_SELF"];
$time=time();
$sql="replace delayed into online (name_ip,url,last_time) values ('$name_ip','$url',$time)";
mysql_query($sql);
获取某页面在线人数的查询是语句
$limit=time()-10*60;//10分钟内访问的认为在线,10分钟*60秒/分钟
$sql="select count(*) from online where url='$url' and last_time>=$limit";
$res=mysql_query($sql);
list($online_count)=mysql_fetch_row($res);
mysql_free_result($res);
echo "本页面在线人数: $online_count";
⑻ php 统计在线人数 根据IP判断哪个地方多少人, 也就是说...
php 统计在线人数 根据IP判断哪个地方多少人, 也就是说...
使用数据库,建立一个表,比如名字是online,至少有以下列:
name_ip 存放登录用户名,未登录的存放IP,char类型
url 存放每个页面的地址,char类型
last_time 存放刷新页面的最后时间,int类型
表的主键是:name_ip+url
每个页面一开始就要刷新这个表,使用的SQL是:
$name_ip='用户名或者IP';//你能搞定
$url=$_SERVER["PHP_SELF"];
$time=time();
$sql="replace delayed into online (name_ip,url,last_time) values ('$name_ip','$url',$time)";
mysql_query($sql);
获取某页面在线人数的查询是语句
$limit=time()-10*60;//10分钟内访问的认为在线,10分钟*60秒/分钟
$sql="select count(*) from online where url='$url' and last_time>=$limit";
$res=mysql_query($sql);
list($online_count)=mysql_fetch_row($res);
mysql_free_result($res);
echo "本页面在线人数: $online_count";
一帆风顺吉星到 万事如意福临门 财源广进
⑼ php 通过ajax做浏览量和在线人数,要求包括访问缓存的次数,怎么做
这个是把session存放在数据库,这个技术lamp兄弟连的视频教程有讲。
你可以找一下兄弟连的视频教程。希望对你有帮助
⑽ Linux的虚拟主机 4核的电脑 CPU和并发连接数都不限 一个PHP网站的同时在线人数峰值可以到多少
不是看硬件的一般linux上都是lamp apache+php+mysql
Apache2.0以上最大连接数为4000-6000
一般峰值超过4000个并发连接apache就差不多了,再上去性能就不行了。
Nginx号称可以最大并发连接数超过10000个,实际达到8000左右。
不过这些都是在硬件高新能的情况下的。你的4核应该不是问题了。
一般提高并发访问连接有如下方法:1。 使用反向代理
2。 建立lamp集群 + 反向代理 (大型网站多是如此)