-
Notifications
You must be signed in to change notification settings - Fork 0
/
fastsync.sh
executable file
·78 lines (63 loc) · 2.48 KB
/
fastsync.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
72
73
74
75
76
77
#!/bin/bash
minername=$(docker ps -a|grep miner|awk -F" " '{print $NF}')
newheight=`curl --silent https://snapshots-wtf.sensecapmx.cloud/latest-snap.json|awk -F':' '{print $3}'| rev | cut -c2- | rev`
echo "Snapshot height is $newheight";
echo "Stopping the miner... "
sudo docker stop $minername
echo "Clearing blockchain data... "
sudo rm -rf /home/pi/hnt/miner/blockchain.db
sudo rm -rf /home/pi/hnt/miner/ledger.db
echo -n "Starting the miner... "
sudo docker start $minername
filepath=/tmp/snap-$newheight;
if [ ! -f "$filepath" ]; then
echo "Downloading latest snapshot"
wget -q --show-progress https://snapshots-wtf.sensecapmx.cloud/snap-$newheight -O /tmp/snap-$newheight
else
modified=`stat -c %Y $filepath`
now=`date +%s`
longago=`expr $now - $modified`
longagominutes=`expr $longago / 60`
#NUM_SECS=`expr $HOW_LONG % 60`
echo "Up-to-date snapshot already downloaded $longagominutes minutes ago"
sleep 5; # Wait until the miner is fully functional
fi
sudo docker exec $minername cp /opt/miner/bin/miner /opt/miner/bin/miner_load
sudo docker cp $minername:/opt/miner/bin/miner ~/miner_load
sudo sed -i 's/export RELX_RPC_TIMEOUT/RELX_RPC_TIMEOUT=3600\nexport RELX_RPC_TIMEOUT/g' ~/miner_load
sudo docker cp ~/miner_load $minername:/opt/miner/bin/miner_load
echo -n "Pausing sync... "
sudo docker exec $minername miner repair sync_pause
echo -n "Cancelling pending sync... "
sudo docker exec $minername miner repair sync_cancel
echo "Deleting stale snapshots"
sudo rm -f /home/pi/hnt/miner/snap/*
echo "Loading snapshot. This can take up to 20 minutes"
sudo cp /tmp/snap-$newheight /home/pi/hnt/miner/snap/snap-$newheight
> /tmp/load_result
now=`date +%s`
((docker exec $minername miner_load snapshot load /var/data/snap/snap-$newheight > /tmp/load_result) > /dev/null 2>&1 &)
#(((sleep 30 && echo "ok") > /tmp/load_result) > /dev/null 2>&1 &)
while :
do
result=$(cat /tmp/load_result);
if [ "$result" = "ok" ]; then
modified=`stat -c %Y /tmp/load_result`
longago=`expr $modified - $now`
longagominutes=`expr $longago / 60`
echo " "
echo "Snapshot loaded in $longagominutes minutes"
sudo rm -f /home/pi/hnt/miner/snap/snap-$newheight
rm /tmp/load_result
echo -n "Resuming sync... "
docker exec $minername miner repair sync_resume
echo "Done!"
break;
elif [ "$result" = "" ];then
echo -n "."
else
echo "Error: Snapshot could not be loaded. Try again"
break;
fi
sleep 10
done