http://down.51cto.com/data/2263476  java 多线程编程 入门到精通  将cpu 的那个 张振华

多个用户可以同时用一个 vhost,但是vhost之间是隔离的。

不错的rabbitmq系列教程
http://blog.csdn.net/chwshuang/article/category/6066031

在sort过程中,会把得到的结果,循环的替换*,然后在获取值。 这个很类似于mysql中的左连接

微博关注关系
进入某一个用户的页面(传一个参数,参数为用户的用户名),获取该用户的uid
    $proid = get user:username:"userName":userid
查看我们是否已经关注了该用户
    sismember(followee:"我们自己的id",$proid)//我们已经登录了,故我们自己的id从cookie或者session中是可以获得的
根据是否已关注,来决定页面显示的是“已关注”还是“关注ta”,无论取消关注,还是关注ta,我们都需要传两个参数一个是  你要关注或者取消关注用户的id,和选中的关注状态 0 1

关注逻辑
1.不能自己关注自己,要关注 ,或者取消关注的人,是否存在
2.
    sadd follwee:"当前登陆者的id" 地址栏上接收到的uid
3.    
    sadd follower:"地址栏上接收到的uid" 当前登陆者的id
4.获取你要粉的用户的用户名,或者这个的目的是为了跳转到你粉的人的页面。因为你粉的人的页面,需要传该用户的用户名
    get user:userid:"从地址栏获取到的uid":username
5.取消关注
    srem follwee:"当前登陆者的id" 地址栏上接收到的uid    
    srem follower:"地址栏上接收到的uid" 当前登陆者的id

使用推的方式,发送给粉丝
1.查找自己的粉丝集合
    get smembers follower:"自己的uid"
2.我们为每一个用户都设置一个集合 receivepost:userid,这个集合里面放置的都是该用户自己和他关注的人的微博
当我们发微博的时候我们会循环执行
    lpush receivepost:fansid $postid  把你发的微博的id,发送给你的粉丝们。也就是说你发了一条微博,实际上是发了很多条,你有多少粉丝,就发了多少条
    设置一下链表中,最大能保持的数据了
3.把自己接受到的微博id,都取出来,其中有自己的,自己关注的人的
    ltrim receivepost:"自己的id" 0 49
    排序?
4.通过微博id,把所有微博的内容,时间,发布人都取出来。这里出了一个问题,我们要得到一条微博,需要访问3次redis,有点儿过度设计了,把微博拆的太开了。我们应该把
微博id,时间,发布者,做成一个hash就好了
    
    
自己的粉丝数  和自己的关注数    
求集合的个数
    scart follower:"自己的uid"
我关注的人的个数
    scard followee:"自己的id"

共同关注,求交集即可

3天前的微博,入mysql

刚才我们是通过推的方式去实现粉丝和粉主之间的微博推送,就是说,当粉主发出一条微博的时候,向他的粉丝,一一的推送。每个粉丝推送一份。使用for循环实现。
这就产生了一个问题,有的大V,他们的粉丝上千万,如果他们发一条微博,我们的redis中就会瞬间多出上千万条数据。不合适。
所以比较适合的方式是使用拉的方式。当粉丝登录的时候,自动去获取自己粉主发的微博。我们可以设置一个最多可以关注多少人。2000,这样,最多也就2000次。

增强cookie安全
用户登录的时候,为每一个用户设置一个编码
    set user:userid:"用户的id":authsecret authsecret
在登录持续期间,一直判断cookie的用户名 用户id 和authsecret

所以在判断是否登录的时候,需要判断用户名和密码外还需要判断 authsecret
退出的时候:  需要把cookie销毁,同时需要把redis中的authsecret销毁掉   
    set user:userid:"用户的id":authsecret ""

使用hash结构 更改blog
    hmset post:postid (userid =>发微博用户的id,time=>time(),content=>内容)  
    发微博的时候顺便把username存进去

拉取模式
在我们发微博的同时,维护一个有序的set,该set中维护这我们最新发布的20条微博,zset的权重就是 postid
在每次添加的时候,使用zcard判断zset的数量是否达到20,如果达到20,那么使用Zremrangebyrank starpost:userid:用户的id, 0 ,0把末尾的数据去掉(把权重最小的数据去掉)
Zremrangebyrank 命令用于移除有序集中,指定排名(rank)区间内的所有成员。

每当一个用户登录后,循环他所关注的star的userid,然后从starpost:userid:star的id 里面取出 微博,然后存储在一起,再排序

微博冷数据如mysql
每一个用户在发布微博的同时,维护一个链表,mypost:userid:自己的id,然后把发布的微博id使用lpush命令 推进去
push之后,判断该链表数量是否大于某个值(自己设定,该值即代表着某一个用户自己所发的微博在redis中存多少,1000足以),如果大于这个值,则使用rpoplpush命令,把
多余的数据推到全局链表global:store中,该链表中存储的是所有用户的非热微博数据,待向mysql中写入。

写一个定时任务,定时查看global:store的数量,然后每次去除1000条,拼成sql语句,写入mysql

查看followee:

aid 关注 bid

followee:aid   aid关注的人

follower:bid   关注了bid的人

微博,and java 多线程编程 入门到精通 将cpu 的那个 张振华的更多相关文章

  1. Java入门-浅析Java学习从入门到精通【转】

    一. JDK (Java Development Kit)  JDK是整个Java的核心,包括了Java运行环境(Java Runtime Envirnment),一堆Java工具和Java基础的类库 ...

  2. GPU 编程入门到精通(五)之 GPU 程序优化进阶

    博主因为工作其中的须要,開始学习 GPU 上面的编程,主要涉及到的是基于 GPU 的深度学习方面的知识.鉴于之前没有接触过 GPU 编程.因此在这里特地学习一下 GPU 上面的编程. 有志同道合的小伙 ...

  3. Java多线程编程实战指南(核心篇)读书笔记(五)

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76730459冷血之心的博客) 博主准备恶补一番Java高并发编程相 ...

  4. Java多线程编程实战指南(核心篇)读书笔记(四)

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76690961冷血之心的博客) 博主准备恶补一番Java高并发编程相 ...

  5. Java多线程编程实战指南(核心篇)读书笔记(三)

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76686044冷血之心的博客) 博主准备恶补一番Java高并发编程相 ...

  6. Java多线程编程实战指南(核心篇)读书笔记(二)

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76651408冷血之心的博客) 博主准备恶补一番Java高并发编程相 ...

  7. Java多线程编程实战指南(核心篇)读书笔记(一)

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76422930冷血之心的博客) 博主准备恶补一番Java高并发编程相 ...

  8. 真正的Java学习从入门到精通

    http://www.it.com.cn/f/edu/059/6/169189.htm 一. 工具篇JDK (Java Development Kit) JDK是整个Java的核心,包括了Java运行 ...

  9. Java学习从入门到精通(2) [转载]

    Java Learning Path(二).书籍篇 学习一门新的知识,不可能指望只看一本,或者两本书就能够完全掌握.需要有一个循序渐进的阅读过程.我推荐Oreilly出版的Java系列书籍. 在这里我 ...

随机推荐

  1. Fastjson.tojsonString中$ref对象重复引用问题

    import java.util.ArrayList; import java.util.List; import com.alibaba.fastjson.JSON; import com.alib ...

  2. java 调用可执行文件时,ProcessBuilder异常CreateProcess error=2

    java 调用其他应用程序时,可能在windows下没有问题,但是转到linux下,却会报这样那样的错误,比如有设计文件操作会报FileNotFoundException等等(如下代码): Proce ...

  3. Appium+python自动化12-appium元素定位【转载】

    前言 appium定位app上的元素,可以通过id,name.class这些属性定位到 一.id定位 1.appium的id属性也就是通过UI Automator工具查看的resource-id属性

  4. centos7安装gitlab与gitlab的汉化

    Gitlab概述 GitLab是一个利用 Ruby on Rails 开发的开源应用程序,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目.  GitLab拥有与Github ...

  5. 2018 CCPC 女生专场

    可能是史上最弱的验题人—— Problem A (小)模拟. #include <bits/stdc++.h> using namespace std; int T; int main() ...

  6. 线段树【p2801】教主的魔法

    Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.--.N. 每个人的 ...

  7. POJ 2761 Feed the dogs (主席树)(K-th 值)

                                                                Feed the dogs Time Limit: 6000MS   Memor ...

  8. linux中,在在shadowsoks下怎么更新软件

    在shadowsoks下怎么更新软件 先描述一下我的情况.我们学校不给大一开通校园网,我自己租用了***的vps服务器,搭建shadowsocks,(使用ipv6地址才能连接),开始了自己悲催的上网生 ...

  9. luogu P1122 最大子树和

    题目描述 小明对数学饱有兴趣,并且是个勤奋好学的学生,总是在课后留在教室向老师请教一些问题.一天他早晨骑车去上课,路上见到一个老伯正在修剪花花草草,顿时想到了一个有关修剪花卉的问题.于是当日课后,小明 ...

  10. (转)Unity3D研究院之游戏架构脚本该如何来写(三十九)

     这篇文章MOMO主要想大家说明一下我在Unity3D游戏开发中是如何写游戏脚本的,对于Unity3D这套游戏引擎来说入门极快,可是要想做好却非常的难.这篇文章的目的是让哪些已经上手Unity3D游戏 ...