-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathJKCommentCrawler.sh
71 lines (59 loc) · 3.09 KB
/
JKCommentCrawler.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!/bin/bash
# Cron の設定例
## 毎日 00:01・00:15 (予備)・12:01・12:15 (予備) に実行
# 01 00 * * * sudo -u ubuntu /home/ubuntu/JKCommentCrawler/JKCommentCrawler.sh cron_daily
# 15 00 * * * sudo -u ubuntu /home/ubuntu/JKCommentCrawler/JKCommentCrawler.sh cron_daily
# 01 12 * * * sudo -u ubuntu /home/ubuntu/JKCommentCrawler/JKCommentCrawler.sh cron_daily
# 15 12 * * * sudo -u ubuntu /home/ubuntu/JKCommentCrawler/JKCommentCrawler.sh cron_daily
## 5分おきに実行
# */5 * * * * sudo -u ubuntu /home/ubuntu/JKCommentCrawler/JKCommentCrawler.sh cron_minutes
# 現在時刻
current_time=`date +"%Y/%m/%d %H:%M"`
# 自身のスクリプトのフルパスを取得
SCRIPT_PATH="$(readlink -f "$0")"
# スクリプトが存在するディレクトリのパスを取得
SCRIPT_DIR="$(dirname "$SCRIPT_PATH")"
cd ${SCRIPT_DIR}
# ログフォルダがなければ作成
if [ ! -d ${SCRIPT_DIR}/log ]; then
mkdir ${SCRIPT_DIR}/log
fi
# JKCommentCrawler を実行
# Cron(5分ごと)
if [[ $1 = 'cron_minutes' ]]; then
# 今日分の JKCommentCrawler を実行
echo 'JKCommentCrawler.sh (Cron minutes)'
${SCRIPT_DIR}/.venv/bin/python -m jkcommentcrawler all `date +"%Y/%m/%d"` --save-dataset-structure-json \
1> ${SCRIPT_DIR}/log/minutes.log \
2>> ${SCRIPT_DIR}/log/minutes.error.log
# Cron(1日ごと)
elif [[ $1 = 'cron_daily' ]]; then
# 前日分の JKCommentCrawler を実行(取りこぼし防止)
## --force パラメータを付けると、以前取得したログよりサイズが小さくても強制的に保存する
## ニコ生の実況番組の放送終了後にスパム判定されたコメント (特に AA) がごっそり削除されることがあり、
## それによって新しいログが保存されなくなる事態を避ける
echo 'JKCommentCrawler.sh (Cron daily)'
${SCRIPT_DIR}/.venv/bin/python -m jkcommentcrawler all `date -d '-1 day' +"%Y/%m/%d"` --save-dataset-structure-json --force \
1> ${SCRIPT_DIR}/log/daily.log \
2>> ${SCRIPT_DIR}/log/daily.error.log
# 通常実行
else
echo 'JKCommentCrawler.sh (Nornal)'
${SCRIPT_DIR}/.venv/bin/python -m jkcommentcrawler all `date +"%Y/%m/%d"` --save-dataset-structure-json
fi
# Hugging Face (KakologArchives) に commit & push する
# デフォルトでは前回のコミットに上書き追記し、コミット数を削減する
# 前回のコミットメッセージが Add kakolog until 20xx/xx/xx 00:00 or 12:00 の時だけ、前回コミットを上書きせずそのままコミットする
# こうすることで、1日に2回は必ずコミットされるようになる
cd ${SCRIPT_DIR}/kakolog/
last_commit_message=$(git log -1 --pretty=%B)
git add .
if [[ $last_commit_message == *"00:00" ]] || [[ $last_commit_message == *"12:00" ]]; then
git commit -m "Add kakolog until ${current_time}"
else
git commit -m "Add kakolog until ${current_time}" --amend --date=now
fi
git push -f
# 不要な LFS オブジェクトを削除する
## --verify-remote で、リモートに存在することを確認してから削除する
git lfs prune --recent --verify-remote