mirror of
https://github.com/bin456789/reinstall.git
synced 2025-01-18 20:39:14 +08:00
core: 使用 websocket
This commit is contained in:
parent
508661d676
commit
05c15c0964
@ -11,8 +11,9 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
#log-container {
|
#log-container {
|
||||||
height: calc(100vh - 24px);
|
height: calc(100vh);
|
||||||
padding: 12px;
|
margin: 0;
|
||||||
|
padding: 8px;
|
||||||
overflow-y: scroll;
|
overflow-y: scroll;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -20,7 +21,7 @@
|
|||||||
position: fixed;
|
position: fixed;
|
||||||
bottom: 24px;
|
bottom: 24px;
|
||||||
right: 24px;
|
right: 24px;
|
||||||
background-color: #007bff;
|
background-color: #0099FF;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
border: none;
|
border: none;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
@ -30,9 +31,21 @@
|
|||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#scroll-to-bottom:hover {
|
||||||
|
background-color: #00CCFF;
|
||||||
|
}
|
||||||
|
|
||||||
#scroll-to-bottom svg {
|
#scroll-to-bottom svg {
|
||||||
fill: #fff;
|
fill: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.done {
|
||||||
|
background-color: #cfc;
|
||||||
|
}
|
||||||
|
|
||||||
|
.error {
|
||||||
|
background-color: #fcc;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
@ -44,44 +57,14 @@
|
|||||||
</svg>
|
</svg>
|
||||||
</button>
|
</button>
|
||||||
|
|
||||||
|
<script
|
||||||
|
src="https://lf3-cdn-tos.bytecdntp.com/cdn/expire-1-d/reconnecting-websocket/1.0.0/reconnecting-websocket.min.js"
|
||||||
|
type="application/javascript"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
const logContainer = document.getElementById('log-container');
|
const logContainer = document.getElementById('log-container');
|
||||||
const scrollToBottomButton = document.getElementById('scroll-to-bottom');
|
const scrollToBottomButton = document.getElementById('scroll-to-bottom');
|
||||||
let shouldScrollToBottom = true;
|
let shouldScrollToBottom = true;
|
||||||
let logFetchInterval;
|
|
||||||
|
|
||||||
async function getLogContent() {
|
|
||||||
try {
|
|
||||||
const response = await fetch('reinstall.log', {
|
|
||||||
cache: 'no-store'
|
|
||||||
});
|
|
||||||
|
|
||||||
if (response.ok) {
|
|
||||||
const logContent = await response.text();
|
|
||||||
// 修复 wget 换行符为 \r 导致不换行
|
|
||||||
logContainer.textContent = logContent.replace(/[\r\n]+/g, "\n");;
|
|
||||||
|
|
||||||
if (shouldScrollToBottom) {
|
|
||||||
logContainer.scrollTop = logContainer.scrollHeight;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (logContent.includes("Error:")) {
|
|
||||||
clearInterval(logFetchInterval);
|
|
||||||
alert("Error occurred.");
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
|
||||||
console.error('Failed to fetch log file.');
|
|
||||||
}
|
|
||||||
|
|
||||||
} catch (error) {
|
|
||||||
console.error('An error occurred: ' + error.message);
|
|
||||||
}
|
|
||||||
|
|
||||||
finally {
|
|
||||||
logFetchInterval = setTimeout(getLogContent, 2000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
scrollToBottomButton.addEventListener('click', () => {
|
scrollToBottomButton.addEventListener('click', () => {
|
||||||
logContainer.scrollTop = logContainer.scrollHeight;
|
logContainer.scrollTop = logContainer.scrollHeight;
|
||||||
@ -98,7 +81,31 @@
|
|||||||
shouldScrollToBottom = isAtBottom;
|
shouldScrollToBottom = isAtBottom;
|
||||||
});
|
});
|
||||||
|
|
||||||
getLogContent();
|
var ws = new ReconnectingWebSocket('ws://' + location.host + '/');
|
||||||
|
ws.onopen = function () {
|
||||||
|
logContainer.textContent += '\nWebSocket Connected.';
|
||||||
|
};
|
||||||
|
ws.onclose = function () {
|
||||||
|
logContainer.textContent += '\nWebSocket Disconnected.';
|
||||||
|
};
|
||||||
|
ws.onmessage = function (event) {
|
||||||
|
logContainer.textContent += '\n' + event.data;
|
||||||
|
if (shouldScrollToBottom) {
|
||||||
|
logContainer.scrollTop = logContainer.scrollHeight;
|
||||||
|
}
|
||||||
|
// 开始/重新开始
|
||||||
|
if (event.data.includes('***** START TRANS *****')) {
|
||||||
|
document.body.className = ''
|
||||||
|
}
|
||||||
|
// 错误
|
||||||
|
else if (event.data.includes('***** ERROR *****')) {
|
||||||
|
document.body.className = 'error'
|
||||||
|
}
|
||||||
|
// 完成
|
||||||
|
else if (event.data.includes('***** DONE *****')) {
|
||||||
|
document.body.className = 'done'
|
||||||
|
}
|
||||||
|
};
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
|
21
trans.sh
21
trans.sh
@ -17,6 +17,7 @@ EFI_UUID=C12A7328-F81F-11D2-BA4B-00A0C93EC93B
|
|||||||
error() {
|
error() {
|
||||||
color='\e[31m'
|
color='\e[31m'
|
||||||
plain='\e[0m'
|
plain='\e[0m'
|
||||||
|
echo -e "${color}***** ERROR *****${plain}" >&2
|
||||||
echo -e "${color}Error: $*${plain}" >&2
|
echo -e "${color}Error: $*${plain}" >&2
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -236,6 +237,16 @@ setup_nginx() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setup_websocketd() {
|
||||||
|
apk add websocketd
|
||||||
|
wget $confhome/logviewer.html -O /tmp/index.html
|
||||||
|
apk add coreutils
|
||||||
|
killall websocketd || true
|
||||||
|
# websocketd 遇到 \n 才推送,因此要转换 \r 为 \n
|
||||||
|
websocketd --loglevel=fatal --staticdir=/tmp \
|
||||||
|
stdbuf -oL -eL sh -c "tail -fn+0 /reinstall.log | tr '\r' '\n'" &
|
||||||
|
}
|
||||||
|
|
||||||
get_approximate_ram_size() {
|
get_approximate_ram_size() {
|
||||||
# lsmem 需要 util-linux
|
# lsmem 需要 util-linux
|
||||||
if false && is_have_cmd lsmem; then
|
if false && is_have_cmd lsmem; then
|
||||||
@ -255,8 +266,8 @@ setup_web_if_enough_ram() {
|
|||||||
if [ $total_ram -gt 400 ]; then
|
if [ $total_ram -gt 400 ]; then
|
||||||
# lighttpd 虽然运行占用内存少,但安装占用空间大
|
# lighttpd 虽然运行占用内存少,但安装占用空间大
|
||||||
# setup_lighttpd
|
# setup_lighttpd
|
||||||
setup_nginx
|
# setup_nginx
|
||||||
# setup_websocketd
|
setup_websocketd
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4692,15 +4703,15 @@ fi
|
|||||||
case 1 in
|
case 1 in
|
||||||
1)
|
1)
|
||||||
# ChatGPT 说这种性能最高
|
# ChatGPT 说这种性能最高
|
||||||
exec > >(exec tee -a $(get_ttys /dev/) /reinstall.log) 2>&1
|
exec > >(exec tee $(get_ttys /dev/) /reinstall.log) 2>&1
|
||||||
trans
|
trans
|
||||||
;;
|
;;
|
||||||
2)
|
2)
|
||||||
exec > >(tee -a $(get_ttys /dev/) /reinstall.log) 2>&1
|
exec > >(tee $(get_ttys /dev/) /reinstall.log) 2>&1
|
||||||
trans
|
trans
|
||||||
;;
|
;;
|
||||||
3)
|
3)
|
||||||
trans 2>&1 | tee -a $(get_ttys /dev/) /reinstall.log
|
trans 2>&1 | tee $(get_ttys /dev/) /reinstall.log
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user