该问题已被锁定!
18
关注
6184
浏览

关于用户量上万后通知表数据量暴增问题

AI智能回复搜索中,请稍后...

为什么被折叠? 0 个回复被折叠
wb_sood 注册会员 用户来自于: 江苏省苏州市
2015-09-10 13:28
通知算法 加个是否 “已读”判断,如果已有新通知 未读 不再重复发送通知 ,如果 没有新通知 或已读 则 发送通知!
kenw2004 高级会员 用户来自于: 四川省成都市
2015-09-09 19:17
这的确是个大问题,会导致大流量的网站不敢使用wecenter程序。   定期清理也只能暂时缓解,我认为要彻底,还是只能改进通知算法,放弃不必要的通知。不然,就必须上大负载的服务器来缓存。
AWSupport 初级会员 用户来自于: 广东省深圳市龙岗区
2015-09-09 14:23
可以二次开发采用数据分表算法与定期删除过期通知来解决,下个版本会增加定期删除已读通知功能
    /**
     * 定期清理已读通知
     * 
     * @param $period 周期, 单位: 秒
     */
    public function clean_mark_read_notifications($period)
    {
        while ($notifications = $this->fetch_all('notification', 'read_flag = 1 AND add_time < ' . (time() - $period), 'notification_id ASC', 1000))
        {
            foreach ($notifications AS $k => $v)
            {
                $this->delete('notification', 'notification_id = ' . $v['notification_id']);
                $this->delete('notification_data', 'notification_id = ' . $v['notification_id']);
            }
        }
        
        return true;
    }
加在计划任务里即可,一个月是 2592000 秒
阿弥陀佛 初级会员 用户来自于: 广东省中山市
2015-09-09 10:44
能不能一个问题以及一个操作类型只记录一次,通知时只通知最新相关id?
wave460 初级会员 用户来自于: 河南省郑州市
2015-09-08 15:48
放出来 学习一下   我是个爱学习的人!
某一家 初级会员 用户来自于: 四川省成都市
2015-09-08 15:25
6666666666666
苏逸融 核心会员 用户来自于: 美国
2015-09-08 14:00
放网址出来,围观一下

关于作者

问题动态

发布时间
2015-09-08 13:37
更新时间
2015-09-10 13:28
关注人数
18 人关注

相关问题

一个feature,关于发布文章的
关于内容中URL的不完整性
关于新版微信扫一扫的咨询
关于如何接入微软账号?
关于头部固定问题,根据教程加了代码后,发现虽然固定了,但是头顶多了一块空白??
关于泄露用户信息bug的最简单解决办法及修复方法
为什么我威望会减少的,在通知那里又看不到什么信息哦,太坑了。
关于手机版的一些建议,在2.0正式版之前
今天新下载的2.1版本,后台没有看到关于微信的控制项,为什么?
关于管理员问题

推荐内容

升级3.0功能失效的BUG
后台发生邮件提醒:could not open socket,怎么解决,求
【紧急漏洞】微信登录跳转链接未过滤导致被恶意使用【已修复】
注册BUG 注册时,用己注册的邮箱,不会提示XX,还是正确的
BUG:3.0 Beta 2相关话题无法编辑删除
用户列表里找不到新注册的用户
WC为何首页会显示302状态码?
问题页错位,见图
发文章时提示:页面停留时间过长,或内容已提交,请刷新页面。怎么办?
搜索话题出现这个提示 有时候好有时候坏 在anwsion搜索会页面全市代码