Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
智布道
OneBlog
提交
d8b4bd4d
O
OneBlog
项目概览
智布道
/
OneBlog
8 个月 前同步成功
通知
11
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
OneBlog
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
d8b4bd4d
编写于
7月 15, 2019
作者:
智布道
👁
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of
https://gitee.com/yadong.zhang/DBlog
上级
904d7f8b
a55e778a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
57 addition
and
28 deletion
+57
-28
blog-web/src/main/java/com/zyd/blog/core/schedule/ArticleLookTask.java
...main/java/com/zyd/blog/core/schedule/ArticleLookTask.java
+32
-28
blog-web/src/main/java/com/zyd/blog/runner/TaskRunner.java
blog-web/src/main/java/com/zyd/blog/runner/TaskRunner.java
+25
-0
未找到文件。
blog-web/src/main/java/com/zyd/blog/core/schedule/ArticleLookTask.java
浏览文件 @
d8b4bd4d
...
...
@@ -3,14 +3,14 @@ package com.zyd.blog.core.schedule;
import
com.zyd.blog.business.entity.ArticleLook
;
import
com.zyd.blog.business.service.BizArticleLookService
;
import
com.zyd.blog.business.service.BizArticleService
;
import
lombok.RequiredArgsConstructor
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.data.redis.core.BoundListOperations
;
import
org.springframework.data.redis.core.RedisTemplate
;
import
org.springframework.scheduling.annotation.Scheduled
;
import
org.springframework.stereotype.Component
;
import
javax.annotation.PostConstruct
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.concurrent.ArrayBlockingQueue
;
import
java.util.concurrent.BlockingQueue
;
/**
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
...
...
@@ -21,20 +21,14 @@ import javax.annotation.PostConstruct;
*/
@Slf4j
@Component
@RequiredArgsConstructor
public
class
ArticleLookTask
{
@Autowired
private
BizArticleService
bizArticleService
;
@Autowired
private
BizArticleLookService
articleLookService
;
@Autowired
private
RedisTemplate
redisTemplate
;
private
BoundListOperations
<
String
,
ArticleLook
>
listOperations
;
private
final
BizArticleService
bizArticleService
;
@PostConstruct
public
void
init
()
{
this
.
listOperations
=
redisTemplate
.
boundListOps
(
"article-look-cache"
);
}
private
final
BizArticleLookService
articleLookService
;
private
BlockingQueue
<
ArticleLook
>
queue
=
new
ArrayBlockingQueue
<>(
1024
);
/**
* 保存文章的浏览记录,先进先出
...
...
@@ -43,22 +37,32 @@ public class ArticleLookTask {
if
(
null
==
articleLook
)
{
return
;
}
listOperations
.
rightPush
(
articleLook
);
queue
.
offer
(
articleLook
);
}
/**
* 每分钟保存一次文章的浏览记录
*/
@Scheduled
(
cron
=
"0 0/1 * * * ? "
)
// @Scheduled(cron = "0/5 * * * * ? ")
public
void
save
()
{
ArticleLook
articleLook
=
null
;
while
(
null
!=
(
articleLook
=
listOperations
.
leftPop
()))
{
if
(!
bizArticleService
.
isExist
(
articleLook
.
getArticleId
()))
{
log
.
warn
(
"{}-该文章不存在!"
,
articleLook
.
getArticleId
());
return
;
List
<
ArticleLook
>
bufferList
=
new
ArrayList
<>();
while
(
true
)
{
try
{
bufferList
.
add
(
queue
.
take
());
for
(
ArticleLook
articleLook
:
bufferList
)
{
if
(!
bizArticleService
.
isExist
(
articleLook
.
getArticleId
()))
{
log
.
warn
(
"{}-该文章不存在!"
,
articleLook
.
getArticleId
());
continue
;
}
articleLookService
.
insert
(
articleLook
);
}
}
catch
(
InterruptedException
e
)
{
log
.
error
(
"保存文章浏览记录失败--->[{}]"
,
e
.
getMessage
());
// 防止缓冲队列填充数据出现异常时不断刷屏
try
{
Thread
.
sleep
(
1000
);
}
catch
(
Exception
err
)
{
log
.
error
(
err
.
getMessage
());
}
}
finally
{
bufferList
.
clear
();
}
articleLookService
.
insert
(
articleLook
);
}
}
...
...
blog-web/src/main/java/com/zyd/blog/runner/TaskRunner.java
0 → 100644
浏览文件 @
d8b4bd4d
package
com.zyd.blog.runner
;
import
com.zyd.blog.core.schedule.ArticleLookTask
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.ApplicationArguments
;
import
org.springframework.boot.ApplicationRunner
;
import
org.springframework.stereotype.Component
;
/**
* 执行保存文章浏览记录任务
*
* @author kongchong
* date: 2019-07-10 11:17
*/
@Component
public
class
TaskRunner
implements
ApplicationRunner
{
@Autowired
private
ArticleLookTask
articleLookTask
;
@Override
public
void
run
(
ApplicationArguments
args
)
{
articleLookTask
.
save
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录