当前位置: 首页 > news >正文

网站目录结构设计应注意的问题常德网站优化公司

网站目录结构设计应注意的问题,常德网站优化公司,宁波网站建设公司哪有,儿童摄影网页制作代码html功能点设计 统计文章点赞的总数,用户所有文章的点赞数,因此设计的点赞功能模块具有以下功能点: 某篇文章的点赞数用户所有文章的点赞数用户点赞的文章持久化到MySQL数据库数据库设计 1、Redis数据库设计Redis是K-V数据库,没有统…

功能点设计

统计文章点赞的总数,用户所有文章的点赞数,因此设计的点赞功能模块具有以下功能点:

  • 某篇文章的点赞数
  • 用户所有文章的点赞数
  • 用户点赞的文章
  • 持久化到MySQL数据库

数据库设计

1、Redis数据库设计
RedisK-V数据库,没有统一的数据结构,针对不同的功能点设计了不同的K-V存储结构

  • 用户某篇文章的点赞数:使用HashMap数据结构,HashMap中的keyarticleIdvalueSetSet中的值为用户ID,即HashMap<String, Set<String>>
  • 用户总的点赞数:使用HashMap数据结构,HashMap中的keyuserIdvalueString记录总的点赞数
  • 用户点赞的文章:使用HashMap数据结构,HashMap中的keyuserIdvalueSetSet中的值为文章ID,即HashMap<String, Set<String>>

2、MySQL数据库设计
article表结构(文章总的点赞数需要和Redis中的点赞数进行同步)

字段值字段类型说明
article_namevarchar文章名字
contentblob文章内容
total_like_countbigint文章总点赞数

user_like_article表结构(记录用户点赞文章的信息,是一张中间表)

字段值字段类型说明
user_idbigint用户ID
article_idbigint文章ID

 说明:表结构设计省略了iddeletedgmt_creategmt_modified字段


流程图

 流程图比较简单,点赞和取消点赞基本实现步骤相同

  • 参数校验
    对传入的参数进行null值判断
  • 逻辑校验
    对于用户点赞,用户不能重复点赞相同的文章
    对于取消点赞,用户不能取消未点赞的文章
  • 存入Redis
    存入的数据主要有所有文章的点赞数、某篇文章的点赞数、用户点赞的文章
  • 定时任务
    通过定时【1小时执行一次】,从Redis读取数据持久化到MySQL

代码功能实现

  • 点赞
 /*** 用户点赞某篇文章** @param likedUserId 被点赞用户ID* @param likedPostId 点赞用户* @param articleId   文章ID*/public void likeArticle(Long articleId, Long likedUserId, Long likedPostId) {validateParam(articleId, likedUserId, likedPostId);  //参数验证log.info("点赞数据存入redis开始,articleId:{},likedUserId:{},likedPostId:{}", articleId, likedUserId, likedPostId);//只有未点赞的用户才可以进行点赞likeArticleLogicValidate(articleId, likedUserId, likedPostId);//1.用户总点赞数+1redisTemplate.opsForHash().increment(TOTAL_LIKE_COUNT_KEY, String.valueOf(likedUserId), 1);synchronized (this) {//2.用户喜欢的文章+1String userLikeResult = (String) redisTemplate.opsForHash().get(USER_LIKE_ARTICLE_KEY, String.valueOf(likedPostId));Set<Long> articleIdSet = userLikeResult == null ? new HashSet<>() : FastjsonUtil.deserializeToSet(userLikeResult, Long.class);articleIdSet.add(articleId);redisTemplate.opsForHash().put(USER_LIKE_ARTICLE_KEY, String.valueOf(likedPostId), FastjsonUtil.serialize(articleIdSet));//3.文章点赞数+1String articleLikedResult = (String) redisTemplate.opsForHash().get(ARTICLE_LIKED_USER_KEY, String.valueOf(articleId));Set<Long> likePostIdSet = articleLikedResult == null ? new HashSet<>() : FastjsonUtil.deserializeToSet(articleLikedResult, Long.class);likePostIdSet.add(likedPostId);redisTemplate.opsForHash().put(ARTICLE_LIKED_USER_KEY, String.valueOf(articleId), FastjsonUtil.serialize(likePostIdSet));log.info("取消点赞数据存入redis结束,articleId:{},likedUserId:{},likedPostId:{}", articleId, likedUserId, likedPostId);}}
  • 取消点赞
 public void unlikeArticle(Long articleId, Long likedUserId, Long likedPostId) {validateParam(articleId, likedUserId, likedPostId);  //参数校验log.info("取消点赞数据存入redis开始,articleId:{},likedUserId:{},likedPostId:{}", articleId, likedUserId, likedPostId);//1.用户总点赞数-1synchronized (this) {//只有点赞的用户才可以取消点赞unlikeArticleLogicValidate(articleId, likedUserId, likedPostId);Long totalLikeCount = Long.parseLong((String) redisTemplate.opsForHash().get(TOTAL_LIKE_COUNT_KEY, String.valueOf(likedUserId)));redisTemplate.opsForHash().put(TOTAL_LIKE_COUNT_KEY, String.valueOf(likedUserId), String.valueOf(--totalLikeCount));//2.用户喜欢的文章-1String userLikeResult = (String) redisTemplate.opsForHash().get(USER_LIKE_ARTICLE_KEY, String.valueOf(likedPostId));Set<Long> articleIdSet = FastjsonUtil.deserializeToSet(userLikeResult, Long.class);articleIdSet.remove(articleId);redisTemplate.opsForHash().put(USER_LIKE_ARTICLE_KEY, String.valueOf(likedPostId), FastjsonUtil.serialize(articleIdSet));//3.取消用户某篇文章的点赞数String articleLikedResult = (String) redisTemplate.opsForHash().get(ARTICLE_LIKED_USER_KEY, String.valueOf(articleId));Set<Long> likePostIdSet = FastjsonUtil.deserializeToSet(articleLikedResult, Long.class);likePostIdSet.remove(likedPostId);redisTemplate.opsForHash().put(ARTICLE_LIKED_USER_KEY, String.valueOf(articleId), FastjsonUtil.serialize(likePostIdSet));}log.info("取消点赞数据存入redis结束,articleId:{},likedUserId:{},likedPostId:{}", articleId, likedUserId, likedPostId);}
  • 异步落库
@Scheduled(cron = "0 0 0/1 * * ? ")
public void redisDataToMySQL() {logger.info("time:{},开始执行Redis数据持久化到MySQL任务", LocalDateTime.now().format(formatter));//1.更新文章总的点赞数Map<String, String> articleCountMap = redisTemplate.opsForHash().entries(ARTICLE_LIKED_USER_KEY);for (Map.Entry<String, String> entry : articleCountMap.entrySet()) {String articleId = entry.getKey();Set<Long> userIdSet = FastjsonUtil.deserializeToSet(entry.getValue(), Long.class);//1.同步某篇文章总的点赞数到MySQLsynchronizeTotalLikeCount(articleId, userIdSet);//2.同步用户喜欢的文章synchronizeUserLikeArticle(articleId, userIdSet);}logger.info("time:{},结束执行Redis数据持久化到MySQL任务", LocalDateTime.now().format(formatter));
}

说明:

  • 针对存在并发的问题,通过添加synchronize关键字实现
  • 另外还有获取某篇文章的点赞数、用户所有文章的点赞数、用户点赞的文章方法实现,方法实现比较简单不说明,可以在我的码云仓库中找到

目前存在的不足

  • 用户点赞\取消点赞方法中,Redis事务没有保证
  • 该应用只适用于单机环境,分布式环境下存在并发问题,分布式锁待完成
http://www.lbrq.cn/news/2426689.html

相关文章:

  • 深圳中小型网站建设公司最好的推广平台是什么软件
  • 荆州市做网站的play商店
  • 100款软件app免费下载大全站群seo
  • 一个域名一个ip做多个网站电商网站排名
  • wordpress漫画站主题西安网站建设制作公司
  • wordpress 内容编码错误哈尔滨企业网站seo
  • 公司注册资金可以乱写吗武汉seo招聘信息
  • 简单动态网页制作代码关键词优化心得
  • 怎样在网站图片做超级链接百度精准引流推广
  • 金融网站建设公司排名dsp投放方式
  • 设计网络网站建设百度搜索引擎收录
  • 山东一级造价师考试时间南宁seo多少钱报价
  • 做科学实验的网站谷歌官方app下载
  • 湖南住房和城乡建设厅网站免费培训课程
  • 站长之家 网站模板百度企业推广
  • 基于h5的个人网站建设推广关键词优化
  • 网络品牌网站建设行业关键词
  • 百度网站推广关键词怎么查合肥网站关键词优化公司
  • 怎么做类似美团的网站吗免费发帖推广网站
  • 做网站什么商品好百度官方
  • 邢台网站建设信息危机公关处理五大原则
  • 中文网站模板免费下载企业培训系统
  • 做建网站百度竞价推广计划
  • 廊坊百度推广电话长安seo排名优化培训
  • myeclipse做网站长春seo
  • 做网站用图片算侵犯著作权吗网站seo顾问
  • 张家港江阴网站设计免费建网站最新视频教程
  • 网站建设找工作宁波网络营销怎么做
  • 网站备案怎么弄中山谷歌推广
  • 郑州机械网站制作网络公司推广公司
  • Linux研学-MySQL安装
  • Visual Studio Code 远端云服务器开发使用指南
  • C语言-字符串数组
  • 神经网络:池化层
  • BLIP、InternVL Series(下)
  • The FastMCP Client