设为首页 收藏本站
查看: 435|回复: 0

[经验分享] 5百万 uid 白名单 之 PHP Bitmap 处理

[复制链接]
发表于 2017-4-9 13:30:47 | 显示全部楼层 |阅读模式
  近日,有同事说有个 5百万 的白名单处理, 到网上查找 相似案例, 说是有个bitmap的解法,
  再次 google ,baidu 无相关 PHP 的解法, 于是自己写了一个:

<?php
/* 5百万 uid 白名单 之 PHP Bitmap 处理
* author: hushuilong
* email: hushuilong at gmail dot com
* */
class Bitmap
{
private $handler = NULL;
private $max = 0;
public function __construct($file)
{
clearstatcache(true, $file);
if(file_exists($file))
$this->handler = @fopen($file , 'r+') OR die('open bitmap file failed');
else
$this->handler = @fopen($file , 'w+') OR die('open bitmap file failed');
$this->max = file_exists($file) ? (filesize($file) * 8 - 1) : 0;
}
public function __destruct()
{
@fclose($this->handler);
}
private function binary_dump($binary_data)
{
return sprintf('%08d',decbin(hexdec(bin2hex($binary_data))));
}
private function num_check($num)
{
($num > -1) OR die('number must be greater than -1');
($num < 4294967296) or die('number must be less than 4294967296'); // 2^32
if ($this->max < $num) {
fseek($this->handler, 0, SEEK_END);
fwrite($this->handler , str_repeat("\x00",ceil(($num - $this->max)/8))); // fill with 0
$this->max = ceil($num/8)*8 - 1;
}
}
public function set($num)
{
$this->num_check($num);
fseek($this->handler, floor($num/8), SEEK_SET);
$bin = fread($this->handler, 1) | pack('C',0x100 >> fmod($num,8)+1); // mark with 1
fseek($this->handler, ftell($this->handler)-1, SEEK_SET); // write a new byte
fwrite($this->handler, $bin);
fflush($this->handler);
}
public function del($num)
{
$this->num_check($num);
fseek($this->handler, floor($num/8), SEEK_SET);
$bin = fread($this->handler, 1) & ~pack('C',0x100 >> fmod($num,8)+1); // mark with 0
fseek($this->handler, ftell($this->handler)-1, SEEK_SET); // write a new byte
fwrite($this->handler, $bin);
fflush($this->handler);
}
public function find($num)
{
if (fseek($this->handler, floor($num/8), SEEK_SET) == -1) return FALSE;
$bin = fread($this->handler , 1);
if ($bin === FALSE || strlen($bin) == 0) return FALSE;
$bin = $bin & pack('C',0x100 >> fmod($num,8)+1);
if($bin === "\x00") return FALSE;
return TRUE;
}
}
$b = new Bitmap('/dev/shm/bitmapdata');
// 设置白名单
$b->set(1); $b->set(3); $b->set(5);
$b->set(7); $b->set(9); $b->set(501);
$uid = 501;
var_dump($b->find($uid)); // 查找白名单
$b->del($uid); // 删除白名单
var_dump($b->find($uid)); // 查找白名单


  其中 “$b = new Bitmap('/dev/shm/bitmapdata');”  把文件,放在内存里,增加读写速度
  执行结果如下:
  hu@xunleiman-desktop:~/web/test/shm$ /bin/sh ./geany_run_script.sh

bool(true)

bool(false)
  生成的bitmapdata文件 在附件里面:
  
DSC0000.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-362462-1-1.html 上篇帖子: JSP,PHP,Python,Ruby,Perl概要及各自特点 下篇帖子: php文件下载IE文件名乱码问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表