Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
S
suggest-task
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
田川
suggest-task
Commits
0a1d21ba
Commit
0a1d21ba
authored
Feb 07, 2022
by
xupeng
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix code
parent
93b80089
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
29 additions
and
15 deletions
+29
-15
SuggestTask.java
suggest-task/src/main/java/com/secoo/so/suggest/task/SuggestTask.java
+28
-14
PinYinUtils.java
suggest-task/src/main/java/com/secoo/so/suggest/util/PinYinUtils.java
+1
-1
No files found.
suggest-task/src/main/java/com/secoo/so/suggest/task/SuggestTask.java
View file @
0a1d21ba
...
@@ -204,24 +204,48 @@ public class SuggestTask {
...
@@ -204,24 +204,48 @@ public class SuggestTask {
long
batchSize
=
ConfigUtil
.
getLong
(
"suggestTask.batchSize"
,
10000
);
long
batchSize
=
ConfigUtil
.
getLong
(
"suggestTask.batchSize"
,
10000
);
int
threadPoolSize
=
ConfigUtil
.
getInt
(
"suggestTask.threadPoolSize"
,
10
);
int
threadPoolSize
=
ConfigUtil
.
getInt
(
"suggestTask.threadPoolSize"
,
10
);
ExecutorService
execThreadPool
=
Executors
.
newFixedThreadPool
(
threadPoolSize
);
ExecutorService
execThreadPool
=
Executors
.
newFixedThreadPool
(
threadPoolSize
);
int
taskCount
=
0
;
for
(
long
startId
=
minId
;
startId
<=
maxId
;
startId
=
startId
+
batchSize
)
{
for
(
long
startId
=
minId
;
startId
<=
maxId
;
startId
=
startId
+
batchSize
)
{
taskCount
++;
execThreadPool
.
submit
(
new
SearchKeywordProcessTask
(
esSuggestKeywordMap
,
startId
,
startId
+
batchSize
,
startTime
));
execThreadPool
.
submit
(
new
SearchKeywordProcessTask
(
esSuggestKeywordMap
,
startId
,
startId
+
batchSize
,
startTime
));
}
}
execThreadPool
.
shutdown
();
execThreadPool
.
shutdown
();
while
(
true
)
{
while
(
true
)
{
if
(
execThreadPool
.
isTerminated
())
{
if
(
execThreadPool
.
isTerminated
())
{
log
.
info
(
"所有的子线程
都结束了, 关闭线程池成功"
);
log
.
info
(
"所有的子线程
任务 {}个 都结束了, 关闭线程池成功"
,
taskCount
);
break
;
break
;
}
}
ObjectUtils
.
safeSleep
(
5000
);
ObjectUtils
.
safeSleep
(
5000
);
}
}
// 过滤词
List
<
EsSuggestKeywordInfo
>
suggestKeywordInfoList
=
new
ArrayList
<>();
int
processCount
=
0
;
int
totalCount
=
esSuggestKeywordMap
.
values
().
size
();
for
(
EsSuggestKeywordInfo
suggestKeywordInfo
:
esSuggestKeywordMap
.
values
())
{
// 不过滤的suggest词,计算分值写es
if
(!
isFilterSuggestKeyword
(
suggestKeywordInfo
))
{
// 转拼音
suggestKeywordInfo
.
setKeywordPinYin
(
PinYinUtils
.
changeToWithoutTonePinYin
(
suggestKeywordInfo
.
getKeyword
(),
""
));
// 保存es前执行标签清洗
cleanBeforeSaveToEs
(
suggestKeywordInfo
);
suggestKeywordInfoList
.
add
(
suggestKeywordInfo
);
}
processCount
++;
if
(
processCount
>
0
&&
processCount
%
1000
==
0
||
processCount
==
totalCount
)
{
log
.
info
(
"keyword filter process: {} / {}"
,
processCount
,
totalCount
);
}
}
// 保存到es
// 保存到es
// saveSuggestKeywordToEs(
new ArrayList<>(esSuggestKeywordMap.values())
);
// saveSuggestKeywordToEs(
suggestKeywordInfoList
);
// for test
// for test
saveSuggestKeywordToFile
(
new
ArrayList
<>(
esSuggestKeywordMap
.
values
())
);
saveSuggestKeywordToFile
(
suggestKeywordInfoList
);
}
}
/**
/**
...
@@ -238,7 +262,6 @@ public class SuggestTask {
...
@@ -238,7 +262,6 @@ public class SuggestTask {
if
(
suggestKeywordInfo
==
null
)
{
if
(
suggestKeywordInfo
==
null
)
{
suggestKeywordInfo
=
new
EsSuggestKeywordInfo
();
suggestKeywordInfo
=
new
EsSuggestKeywordInfo
();
suggestKeywordInfo
.
setKeyword
(
keyword
);
suggestKeywordInfo
.
setKeyword
(
keyword
);
suggestKeywordInfo
.
setKeywordPinYin
(
PinYinUtils
.
changeToWithoutTonePinYin
(
suggestKeywordInfo
.
getKeyword
(),
""
));
suggestKeywordInfo
.
setYearCount
(
searchKeywordInfo
.
getYearPv
());
suggestKeywordInfo
.
setYearCount
(
searchKeywordInfo
.
getYearPv
());
suggestKeywordInfo
.
setYearClickCount
(
searchKeywordInfo
.
getYearProductClickCount
());
suggestKeywordInfo
.
setYearClickCount
(
searchKeywordInfo
.
getYearProductClickCount
());
...
@@ -270,15 +293,6 @@ public class SuggestTask {
...
@@ -270,15 +293,6 @@ public class SuggestTask {
// 计算suggestKeyword权重等属性
// 计算suggestKeyword权重等属性
processEsSuggestKeywordInfo
(
suggestKeywordInfo
,
searchKeywordInfo
);
processEsSuggestKeywordInfo
(
suggestKeywordInfo
,
searchKeywordInfo
);
// 不过滤的suggest词,计算分值写es
if
(!
isFilterSuggestKeyword
(
suggestKeywordInfo
))
{
// 保存es前执行标签清洗
cleanBeforeSaveToEs
(
suggestKeywordInfo
);
esSuggestKeywordMap
.
put
(
suggestKeywordInfo
.
getKeyword
(),
suggestKeywordInfo
);
}
}
}
}
}
}
}
...
@@ -374,7 +388,7 @@ public class SuggestTask {
...
@@ -374,7 +388,7 @@ public class SuggestTask {
return
;
return
;
}
}
List
<
String
>
tagList
=
StringUtils
.
splitToList
(
suggestKeywordInfo
.
getSuggestTags
(),
","
);
List
<
String
>
tagList
=
StringUtils
.
splitToList
(
suggestKeywordInfo
.
getSuggestTags
(),
","
);
if
(
tagList
.
size
()
>
maxTagSize
)
{
if
(
tagList
!=
null
&&
tagList
.
size
()
>
maxTagSize
)
{
suggestKeywordInfo
.
setSuggestTags
(
StringUtils
.
join
(
CollectionUtils
.
subList
(
tagList
,
0
,
maxTagSize
),
","
));
suggestKeywordInfo
.
setSuggestTags
(
StringUtils
.
join
(
CollectionUtils
.
subList
(
tagList
,
0
,
maxTagSize
),
","
));
}
}
}
}
...
...
suggest-task/src/main/java/com/secoo/so/suggest/util/PinYinUtils.java
View file @
0a1d21ba
...
@@ -101,7 +101,7 @@ public class PinYinUtils {
...
@@ -101,7 +101,7 @@ public class PinYinUtils {
try
{
try
{
tempStr
=
PinyinHelper
.
convertToPinyinString
(
str
,
separator
,
PinyinFormat
.
WITHOUT_TONE
);
tempStr
=
PinyinHelper
.
convertToPinyinString
(
str
,
separator
,
PinyinFormat
.
WITHOUT_TONE
);
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
log
.
error
(
"changeToWithoutTonePinYin error
"
,
e
);
log
.
error
(
"changeToWithoutTonePinYin error
: str:{}"
,
str
,
e
);
}
}
return
tempStr
;
return
tempStr
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment