android 微信是如何實(shí)現(xiàn)即時(shí)更新好友頭像的
問(wèn)題描述
微信好友的頭像肯定是做緩存的,那么好友頭像修改后,用戶這邊是如何實(shí)現(xiàn)立即就能看到修改后的頭像的呢?
問(wèn)題解答
回答1:如果要做到實(shí)時(shí)更新:就需要使用推送,A修改頭像之后,通知服務(wù)端,服務(wù)端再對(duì)A的好友進(jìn)行推送通知更新A的頭像。
回答2:先拉取的肯定是頭像url啊,本地緩存是根據(jù)url做的,本地每次都拉取頭像url然后通過(guò)加載模塊去加載的時(shí)候會(huì)判斷當(dāng)前緩存的圖片是否與此url一致,不一致才會(huì)通過(guò)新的url去下載。
回答3:數(shù)據(jù)庫(kù)中保存一個(gè)字段:上次頭像修改時(shí)間.
回答4:推測(cè)一下,括號(hào)里的過(guò)程是瞎猜的:用戶A上傳新頭像→服務(wù)器處理新頭像→將新頭像URL存儲(chǔ)到用戶表的某個(gè)字段里,記載更改時(shí)間(→同步頭像到CDN→更新用戶表的頭像URL字段,記載更改時(shí)間)→服務(wù)器向在線的客戶端發(fā)推送→客戶端更新頭像。
回答5:猜測(cè)一下,可以設(shè)置一個(gè)標(biāo)識(shí)字段,默認(rèn)為0,用戶更新頭像時(shí)把它置為1,在推送消息或定期同步時(shí),同時(shí)推送這個(gè)標(biāo)識(shí)。手機(jī)在處理消息或定期同步聯(lián)系人信息的同時(shí),判斷這個(gè)標(biāo)識(shí),如果標(biāo)識(shí)為1,說(shuō)明好友上傳了新頭像,這時(shí)候再GET請(qǐng)求拉取新頭像并緩存在本地,同時(shí)更新服務(wù)器端標(biāo)識(shí)為0,防止下一次同步時(shí)重復(fù)請(qǐng)求頭像。(PS:只是一點(diǎn)個(gè)人的想法。)
相關(guān)文章:
1. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””2. docker-compose中volumes的問(wèn)題3. boot2docker無(wú)法啟動(dòng)4. nignx - docker內(nèi)nginx 80端口被占用5. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.6. dockerfile - 為什么docker容器啟動(dòng)不了?7. node.js - antdesign怎么集合react-redux對(duì)input控件進(jìn)行初始化賦值8. docker容器呢SSH為什么連不通呢?9. java - SSH框架中寫分頁(yè)時(shí)service層中不能注入分頁(yè)類10. 關(guān)于docker下的nginx壓力測(cè)試

網(wǎng)公網(wǎng)安備