mirror of
https://github.com/nezhahq/nezha.git
synced 2025-02-02 01:28:13 -05:00
Add standalone installation method & OpenRC support for nezha-agent (#300)
* Add standalone installation method & OpenRC support for nezha-agent * Add missing translations & more precise query * bump installer version
This commit is contained in:
parent
d0707b9b05
commit
52703f38cd
@ -11,7 +11,10 @@ NZ_BASE_PATH="/opt/nezha"
|
|||||||
NZ_DASHBOARD_PATH="${NZ_BASE_PATH}/dashboard"
|
NZ_DASHBOARD_PATH="${NZ_BASE_PATH}/dashboard"
|
||||||
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
|
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
|
||||||
NZ_AGENT_SERVICE="/etc/systemd/system/nezha-agent.service"
|
NZ_AGENT_SERVICE="/etc/systemd/system/nezha-agent.service"
|
||||||
NZ_VERSION="v0.15.0"
|
NZ_AGENT_SERVICERC="/etc/init.d/nezha-agent"
|
||||||
|
NZ_DASHBOARD_SERVICE="/etc/systemd/system/nezha-dashboard.service"
|
||||||
|
NZ_DASHBOARD_SERVICERC="/etc/init.d/nezha-dashboard"
|
||||||
|
NZ_VERSION="v0.15.1"
|
||||||
|
|
||||||
red='\033[0;31m'
|
red='\033[0;31m'
|
||||||
green='\033[0;32m'
|
green='\033[0;32m'
|
||||||
@ -71,12 +74,14 @@ pre_check() {
|
|||||||
Get_Docker_URL="get.docker.com"
|
Get_Docker_URL="get.docker.com"
|
||||||
Get_Docker_Argu=" "
|
Get_Docker_Argu=" "
|
||||||
Docker_IMG="ghcr.io\/naiba\/nezha-dashboard"
|
Docker_IMG="ghcr.io\/naiba\/nezha-dashboard"
|
||||||
|
GITHUB_RELEASE_URL="github.com/naiba/nezha/releases/latest/download"
|
||||||
else
|
else
|
||||||
GITHUB_RAW_URL="jihulab.com/nezha/dashboard/-/raw/master"
|
GITHUB_RAW_URL="jihulab.com/nezha/dashboard/-/raw/master"
|
||||||
GITHUB_URL="dn-dao-github-mirror.daocloud.io"
|
GITHUB_URL="dn-dao-github-mirror.daocloud.io"
|
||||||
Get_Docker_URL="get.docker.com"
|
Get_Docker_URL="get.docker.com"
|
||||||
Get_Docker_Argu=" -s docker --mirror Aliyun"
|
Get_Docker_Argu=" -s docker --mirror Aliyun"
|
||||||
Docker_IMG="registry.cn-shanghai.aliyuncs.com\/naibahq\/nezha-dashboard"
|
Docker_IMG="registry.cn-shanghai.aliyuncs.com\/naibahq\/nezha-dashboard"
|
||||||
|
GITHUB_RELEASE_URL="hub.fgit.cf/naiba/nezha/releases/latest/download"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -124,6 +129,7 @@ install_base() {
|
|||||||
(command -v git >/dev/null 2>&1 && command -v curl >/dev/null 2>&1 && command -v wget >/dev/null 2>&1 && command -v unzip >/dev/null 2>&1 && command -v getenforce >/dev/null 2>&1) ||
|
(command -v git >/dev/null 2>&1 && command -v curl >/dev/null 2>&1 && command -v wget >/dev/null 2>&1 && command -v unzip >/dev/null 2>&1 && command -v getenforce >/dev/null 2>&1) ||
|
||||||
(install_soft curl wget git unzip)
|
(install_soft curl wget git unzip)
|
||||||
}
|
}
|
||||||
|
|
||||||
install_arch(){
|
install_arch(){
|
||||||
echo -e "${green}提示: ${plain} Arch安装libselinux需添加nezha-agent用户,安装完会自动删除,建议手动检查一次\n"
|
echo -e "${green}提示: ${plain} Arch安装libselinux需添加nezha-agent用户,安装完会自动删除,建议手动检查一次\n"
|
||||||
read -e -r -p "是否安装libselinux? [Y/n] " input
|
read -e -r -p "是否安装libselinux? [Y/n] " input
|
||||||
@ -204,6 +210,45 @@ install_dashboard() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
install_dashboard_standalone() {
|
||||||
|
install_base
|
||||||
|
|
||||||
|
echo -e "> 安装面板"
|
||||||
|
|
||||||
|
# 哪吒监控文件夹
|
||||||
|
if [ ! -d "${NZ_DASHBOARD_PATH}" ]; then
|
||||||
|
mkdir -p $NZ_DASHBOARD_PATH
|
||||||
|
else
|
||||||
|
echo "您可能已经安装过面板端,重复安装会覆盖数据,请注意备份。"
|
||||||
|
read -e -r -p "是否退出安装? [Y/n] " input
|
||||||
|
case $input in
|
||||||
|
[yY][eE][sS] | [yY])
|
||||||
|
echo "退出安装"
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
[nN][oO] | [nN])
|
||||||
|
echo "继续安装"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "退出安装"
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "${NZ_DASHBOARD_PATH}/resource/template/theme-custom" ] || [ ! -d "${NZ_DASHBOARD_PATH}/resource/static/custom" ]; then
|
||||||
|
mkdir -p "${NZ_DASHBOARD_PATH}/resource/template/theme-custom" "${NZ_DASHBOARD_PATH}/resource/static/custom" >/dev/null 2>&1
|
||||||
|
fi
|
||||||
|
|
||||||
|
chmod 777 -R $NZ_DASHBOARD_PATH
|
||||||
|
|
||||||
|
modify_dashboard_config_standalone 0
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
selinux(){
|
selinux(){
|
||||||
#判断当前的状态
|
#判断当前的状态
|
||||||
if [ "$os_alpine" != 1 ];then
|
if [ "$os_alpine" != 1 ];then
|
||||||
@ -275,6 +320,13 @@ modify_agent_config() {
|
|||||||
echo -e "${red}文件下载失败,请检查本机能否连接 ${GITHUB_RAW_URL}${plain}"
|
echo -e "${red}文件下载失败,请检查本机能否连接 ${GITHUB_RAW_URL}${plain}"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
wget -t 2 -T 10 -O $NZ_AGENT_SERVICERC https://${GITHUB_RAW_URL}/script/nezha-agent >/dev/null 2>&1
|
||||||
|
chmod +x $NZ_AGENT_SERVICERC
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "${red}Fail to download service, please check if the network can link ${GITHUB_RAW_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $# -lt 3 ]; then
|
if [ $# -lt 3 ]; then
|
||||||
@ -308,8 +360,10 @@ modify_agent_config() {
|
|||||||
sed -i "s/nz_client_secret/${nz_client_secret}/" ${NZ_AGENT_SERVICE}
|
sed -i "s/nz_client_secret/${nz_client_secret}/" ${NZ_AGENT_SERVICE}
|
||||||
[ -n "${args}" ] && sed -i "/ExecStart/ s/$/ ${args}/" ${NZ_AGENT_SERVICE}
|
[ -n "${args}" ] && sed -i "/ExecStart/ s/$/ ${args}/" ${NZ_AGENT_SERVICE}
|
||||||
else
|
else
|
||||||
echo "@reboot ${NZ_AGENT_PATH}/nezha-agent -s ${nz_grpc_host}:${nz_grpc_port} -p ${nz_client_secret} ${args}" >> /etc/crontabs/root
|
sed -i "s/nz_grpc_host/${nz_grpc_host}/" ${NZ_AGENT_SERVICERC}
|
||||||
crond
|
sed -i "s/nz_grpc_port/${nz_grpc_port}/" ${NZ_AGENT_SERVICERC}
|
||||||
|
sed -i "s/nz_client_secret/${nz_client_secret}/" ${NZ_AGENT_SERVICERC}
|
||||||
|
[ -n "${args}" ] && sed -i "/command_args/ s/$/ \"${args}\"/" ${NZ_AGENT_SERVICERC}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "Agent配置 ${green}修改成功,请稍等重启生效${plain}"
|
echo -e "Agent配置 ${green}修改成功,请稍等重启生效${plain}"
|
||||||
@ -319,7 +373,8 @@ modify_agent_config() {
|
|||||||
systemctl enable nezha-agent
|
systemctl enable nezha-agent
|
||||||
systemctl restart nezha-agent
|
systemctl restart nezha-agent
|
||||||
else
|
else
|
||||||
nohup ${NZ_AGENT_PATH}/nezha-agent -s ${nz_grpc_host}:${nz_grpc_port} -p ${nz_client_secret} ${args} >/dev/null 2>&1 &
|
rc-update add nezha-agent
|
||||||
|
rc-service nezha-agent restart
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
@ -393,6 +448,78 @@ modify_dashboard_config() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
modify_dashboard_config_standalone() {
|
||||||
|
echo -e "> 修改面板配置"
|
||||||
|
|
||||||
|
echo -e "正在下载配置模板"
|
||||||
|
|
||||||
|
wget -t 2 -T 10 -O /tmp/nezha-config.yaml https://${GITHUB_RAW_URL}/script/config.yaml >/dev/null 2>&1
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "${red}下载文件失败,请检查本机能否连接 ${GITHUB_RAW_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "关于 GitHub Oauth2 应用:在 https://github.com/settings/developers 创建,无需审核,Callback 填 http(s)://域名或IP/oauth2/callback" &&
|
||||||
|
echo "关于 Gitee Oauth2 应用:在 https://gitee.com/oauth/applications 创建,无需审核,Callback 填 http(s)://域名或IP/oauth2/callback" &&
|
||||||
|
read -ep "请输入 OAuth2 提供商(github/gitlab/jihulab/gitee,默认 github): " nz_oauth2_type &&
|
||||||
|
read -ep "请输入 Oauth2 应用的 Client ID: " nz_github_oauth_client_id &&
|
||||||
|
read -ep "请输入 Oauth2 应用的 Client Secret: " nz_github_oauth_client_secret &&
|
||||||
|
read -ep "请输入 GitHub/Gitee 登录名作为管理员,多个以逗号隔开: " nz_admin_logins &&
|
||||||
|
read -ep "请输入站点标题: " nz_site_title &&
|
||||||
|
read -ep "请输入站点访问端口: (默认 8008)" nz_site_port &&
|
||||||
|
read -ep "请输入用于 Agent 接入的 RPC 端口: (默认 5555)" nz_grpc_port
|
||||||
|
|
||||||
|
if [[ -z "${nz_admin_logins}" || -z "${nz_github_oauth_client_id}" || -z "${nz_github_oauth_client_secret}" || -z "${nz_site_title}" ]]; then
|
||||||
|
echo -e "${red}所有选项都不能为空${plain}"
|
||||||
|
before_show_menu
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "${nz_site_port}" ]]; then
|
||||||
|
nz_site_port=8008
|
||||||
|
fi
|
||||||
|
if [[ -z "${nz_grpc_port}" ]]; then
|
||||||
|
nz_grpc_port=5555
|
||||||
|
fi
|
||||||
|
if [[ -z "${nz_oauth2_type}" ]]; then
|
||||||
|
nz_oauth2_type=github
|
||||||
|
fi
|
||||||
|
|
||||||
|
sed -i "s/nz_oauth2_type/${nz_oauth2_type}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_admin_logins/${nz_admin_logins}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_grpc_port/${nz_grpc_port}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_github_oauth_client_id/${nz_github_oauth_client_id}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_github_oauth_client_secret/${nz_github_oauth_client_secret}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_language/zh-CN/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_site_title/${nz_site_title}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/80/${nz_site_port}/" /tmp/nezha-config.yaml
|
||||||
|
|
||||||
|
mkdir -p $NZ_DASHBOARD_PATH/data
|
||||||
|
mv -f /tmp/nezha-config.yaml ${NZ_DASHBOARD_PATH}/data/config.yaml
|
||||||
|
|
||||||
|
echo -e "正在下载服务文件"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ];then
|
||||||
|
wget -t 2 -T 10 -O $NZ_DASHBOARD_SERVICE https://${GITHUB_RAW_URL}/script/nezha-dashboard.service >/dev/null 2>&1
|
||||||
|
else
|
||||||
|
wget -t 2 -T 10 -O $NZ_DASHBOARD_SERVICERC https://${GITHUB_RAW_URL}/script/nezha-dashboard >/dev/null 2>&1
|
||||||
|
chmod +x $NZ_DASHBOARD_SERVICERC
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "${red}文件下载失败,请检查本机能否连接 ${GITHUB_RAW_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
echo -e "面板配置 ${green}修改成功,请稍等重启生效${plain}"
|
||||||
|
|
||||||
|
restart_and_update_standalone
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
restart_and_update() {
|
restart_and_update() {
|
||||||
echo -e "> 重启并更新面板"
|
echo -e "> 重启并更新面板"
|
||||||
|
|
||||||
@ -421,6 +548,40 @@ restart_and_update() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
restart_and_update_standalone() {
|
||||||
|
echo -e "> 重启并更新面板"
|
||||||
|
|
||||||
|
cd $NZ_DASHBOARD_PATH
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl stop nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
wget -qO app.zip $GITHUB_RELEASE_URL/dashboard-linux-$os_arch.zip >/dev/null 2>&1 && unzip -qq app.zip && mv dist/dashboard-linux-$os_arch app && rm -r app.zip dist
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ];then
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable nezha-dashboard
|
||||||
|
systemctl restart nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-update add nezha-dashboard
|
||||||
|
rc-service nezha-dashboard restart
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $? == 0 ]]; then
|
||||||
|
echo -e "${green}哪吒监控 重启成功${plain}"
|
||||||
|
echo -e "默认管理面板地址:${yellow}域名:站点访问端口${plain}"
|
||||||
|
else
|
||||||
|
echo -e "${red}重启失败,可能是因为启动时间超过了两秒,请稍后查看日志信息${plain}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
start_dashboard() {
|
start_dashboard() {
|
||||||
echo -e "> 启动面板"
|
echo -e "> 启动面板"
|
||||||
|
|
||||||
@ -442,6 +603,26 @@ start_dashboard() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
start_dashboard_standalone() {
|
||||||
|
echo -e "> 启动面板"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl start nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard start
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $? == 0 ]]; then
|
||||||
|
echo -e "${green}哪吒监控 启动成功${plain}"
|
||||||
|
else
|
||||||
|
echo -e "${red}启动失败,请稍后查看日志信息${plain}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
stop_dashboard() {
|
stop_dashboard() {
|
||||||
echo -e "> 停止面板"
|
echo -e "> 停止面板"
|
||||||
|
|
||||||
@ -463,6 +644,26 @@ stop_dashboard() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stop_dashboard_standalone() {
|
||||||
|
echo -e "> 停止面板"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl stop nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $? == 0 ]]; then
|
||||||
|
echo -e "${green}哪吒监控 停止成功${plain}"
|
||||||
|
else
|
||||||
|
echo -e "${red}停止失败,请稍后查看日志信息${plain}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
show_dashboard_log() {
|
show_dashboard_log() {
|
||||||
echo -e "> 获取面板日志"
|
echo -e "> 获取面板日志"
|
||||||
|
|
||||||
@ -478,6 +679,20 @@ show_dashboard_log() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_dashboard_log_standalone() {
|
||||||
|
echo -e "> 获取面板日志"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
journalctl -xf -u nezha-dashboard.service
|
||||||
|
else
|
||||||
|
echo "很抱歉,OpenRC 无此功能"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
uninstall_dashboard() {
|
uninstall_dashboard() {
|
||||||
echo -e "> 卸载管理面板"
|
echo -e "> 卸载管理面板"
|
||||||
|
|
||||||
@ -496,12 +711,46 @@ uninstall_dashboard() {
|
|||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
before_show_menu
|
before_show_menu
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
sed -i '/IS_DOCKER_NEZHA/d' ~/.bashrc
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
uninstall_dashboard_standalone() {
|
||||||
|
echo -e "> 卸载管理面板"
|
||||||
|
|
||||||
|
rm -rf $NZ_DASHBOARD_PATH
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl stop nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
rm $NZ_DASHBOARD_SERVICE
|
||||||
|
else
|
||||||
|
rm $NZ_DASHBOARD_SERVICERC
|
||||||
|
fi
|
||||||
|
|
||||||
|
clean_all
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
|
||||||
|
sed -i '/IS_DOCKER_NEZHA/d' ~/.bashrc
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
show_agent_log() {
|
show_agent_log() {
|
||||||
echo -e "> 获取Agent日志"
|
echo -e "> 获取Agent日志"
|
||||||
|
|
||||||
journalctl -xf -u nezha-agent.service
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
journalctl -xf -u nezha-agent.service
|
||||||
|
else
|
||||||
|
echo "很抱歉,OpenRC 无此功能"
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
before_show_menu
|
before_show_menu
|
||||||
@ -517,8 +766,9 @@ uninstall_agent() {
|
|||||||
rm -rf $NZ_AGENT_SERVICE
|
rm -rf $NZ_AGENT_SERVICE
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
else
|
else
|
||||||
grep -q 'nezha-agent' /var/spool/cron/crontabs/root && sed -i "/nezha-agent/d" /var/spool/cron/crontabs/root
|
rc-update del nezha-agent
|
||||||
pkill nezha-agent
|
rc-service nezha-agent stop
|
||||||
|
rm -rf $NZ_AGENT_SERVICERC
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm -rf $NZ_AGENT_PATH
|
rm -rf $NZ_AGENT_PATH
|
||||||
@ -532,7 +782,11 @@ uninstall_agent() {
|
|||||||
restart_agent() {
|
restart_agent() {
|
||||||
echo -e "> 重启Agent"
|
echo -e "> 重启Agent"
|
||||||
|
|
||||||
systemctl restart nezha-agent.service
|
if [ "$os_alpine" != 1 ];then
|
||||||
|
systemctl restart nezha-agent.service
|
||||||
|
else
|
||||||
|
rc-service nezha-agent restart
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
before_show_menu
|
before_show_menu
|
||||||
@ -545,6 +799,17 @@ clean_all() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
select_version() {
|
||||||
|
cd $NZ_DASHBOARD_PATH
|
||||||
|
if command -v docker compose >/dev/null 2>&1; then
|
||||||
|
if docker compose ls | grep -qw "$NZ_DASHBOARD_PATH/docker-compose.yaml" >/dev/null 2>&1; then
|
||||||
|
IS_DOCKER_NEZHA=1
|
||||||
|
fi
|
||||||
|
elif [ -d /opt/nezha/dashboard ]; then
|
||||||
|
IS_DOCKER_NEZHA=0
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
show_usage() {
|
show_usage() {
|
||||||
echo "哪吒监控 管理脚本使用方法: "
|
echo "哪吒监控 管理脚本使用方法: "
|
||||||
echo "--------------------------------------------------------"
|
echo "--------------------------------------------------------"
|
||||||
@ -589,106 +854,208 @@ show_menu() {
|
|||||||
${green}0.${plain} 退出脚本
|
${green}0.${plain} 退出脚本
|
||||||
"
|
"
|
||||||
echo && read -ep "请输入选择 [0-13]: " num
|
echo && read -ep "请输入选择 [0-13]: " num
|
||||||
|
if [[ $IS_DOCKER_NEZHA == 1 ]]; then
|
||||||
case "${num}" in
|
case "${num}" in
|
||||||
0)
|
0)
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
1)
|
1)
|
||||||
install_dashboard
|
install_dashboard
|
||||||
;;
|
;;
|
||||||
2)
|
2)
|
||||||
modify_dashboard_config
|
modify_dashboard_config
|
||||||
;;
|
;;
|
||||||
3)
|
3)
|
||||||
start_dashboard
|
start_dashboard
|
||||||
;;
|
;;
|
||||||
4)
|
4)
|
||||||
stop_dashboard
|
stop_dashboard
|
||||||
;;
|
;;
|
||||||
5)
|
5)
|
||||||
restart_and_update
|
restart_and_update
|
||||||
;;
|
;;
|
||||||
6)
|
6)
|
||||||
show_dashboard_log
|
show_dashboard_log
|
||||||
;;
|
;;
|
||||||
7)
|
7)
|
||||||
uninstall_dashboard
|
uninstall_dashboard
|
||||||
;;
|
;;
|
||||||
8)
|
8)
|
||||||
install_agent
|
install_agent
|
||||||
;;
|
;;
|
||||||
9)
|
9)
|
||||||
modify_agent_config
|
modify_agent_config
|
||||||
;;
|
;;
|
||||||
10)
|
10)
|
||||||
show_agent_log
|
show_agent_log
|
||||||
;;
|
;;
|
||||||
11)
|
11)
|
||||||
uninstall_agent
|
uninstall_agent
|
||||||
;;
|
;;
|
||||||
12)
|
12)
|
||||||
restart_agent
|
restart_agent
|
||||||
;;
|
;;
|
||||||
13)
|
13)
|
||||||
update_script
|
update_script
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo -e "${red}请输入正确的数字 [0-13]${plain}"
|
echo -e "${red}请输入正确的数字 [0-13]${plain}"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
elif [[ $IS_DOCKER_NEZHA == 0 ]]; then
|
||||||
|
case "${num}" in
|
||||||
|
0)
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
1)
|
||||||
|
install_dashboard_standalone
|
||||||
|
;;
|
||||||
|
2)
|
||||||
|
modify_dashboard_config_standalone
|
||||||
|
;;
|
||||||
|
3)
|
||||||
|
start_dashboard_standalone
|
||||||
|
;;
|
||||||
|
4)
|
||||||
|
stop_dashboard_standalone
|
||||||
|
;;
|
||||||
|
5)
|
||||||
|
restart_and_update_standalone
|
||||||
|
;;
|
||||||
|
6)
|
||||||
|
show_dashboard_log_standalone
|
||||||
|
;;
|
||||||
|
7)
|
||||||
|
uninstall_dashboard_standalone
|
||||||
|
;;
|
||||||
|
8)
|
||||||
|
install_agent
|
||||||
|
;;
|
||||||
|
9)
|
||||||
|
modify_agent_config
|
||||||
|
;;
|
||||||
|
10)
|
||||||
|
show_agent_log
|
||||||
|
;;
|
||||||
|
11)
|
||||||
|
uninstall_agent
|
||||||
|
;;
|
||||||
|
12)
|
||||||
|
restart_agent
|
||||||
|
;;
|
||||||
|
13)
|
||||||
|
update_script
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo -e "${red}请输入正确的数字 [0-13]${plain}"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
pre_check
|
pre_check
|
||||||
|
|
||||||
if [[ $# > 0 ]]; then
|
if [[ $# > 0 ]]; then
|
||||||
case $1 in
|
if [[ $IS_DOCKER_NEZHA == 1 ]]; then
|
||||||
"install_dashboard")
|
case $1 in
|
||||||
install_dashboard 0
|
"install_dashboard")
|
||||||
;;
|
install_dashboard 0
|
||||||
"modify_dashboard_config")
|
;;
|
||||||
modify_dashboard_config 0
|
"modify_dashboard_config")
|
||||||
;;
|
modify_dashboard_config 0
|
||||||
"start_dashboard")
|
;;
|
||||||
start_dashboard 0
|
"start_dashboard")
|
||||||
;;
|
start_dashboard 0
|
||||||
"stop_dashboard")
|
;;
|
||||||
stop_dashboard 0
|
"stop_dashboard")
|
||||||
;;
|
stop_dashboard 0
|
||||||
"restart_and_update")
|
;;
|
||||||
restart_and_update 0
|
"restart_and_update")
|
||||||
;;
|
restart_and_update 0
|
||||||
"show_dashboard_log")
|
;;
|
||||||
show_dashboard_log 0
|
"show_dashboard_log")
|
||||||
;;
|
show_dashboard_log 0
|
||||||
"uninstall_dashboard")
|
;;
|
||||||
uninstall_dashboard 0
|
"uninstall_dashboard")
|
||||||
;;
|
uninstall_dashboard 0
|
||||||
"install_agent")
|
;;
|
||||||
shift
|
"install_agent")
|
||||||
if [ $# -ge 3 ]; then
|
shift
|
||||||
install_agent "$@"
|
if [ $# -ge 3 ]; then
|
||||||
else
|
install_agent "$@"
|
||||||
install_agent 0
|
else
|
||||||
fi
|
install_agent 0
|
||||||
;;
|
fi
|
||||||
"modify_agent_config")
|
;;
|
||||||
modify_agent_config 0
|
"modify_agent_config")
|
||||||
;;
|
modify_agent_config 0
|
||||||
"show_agent_log")
|
;;
|
||||||
show_agent_log 0
|
"show_agent_log")
|
||||||
;;
|
show_agent_log 0
|
||||||
"uninstall_agent")
|
;;
|
||||||
uninstall_agent 0
|
"uninstall_agent")
|
||||||
;;
|
uninstall_agent 0
|
||||||
"restart_agent")
|
;;
|
||||||
restart_agent 0
|
"restart_agent")
|
||||||
;;
|
restart_agent 0
|
||||||
"update_script")
|
;;
|
||||||
update_script 0
|
"update_script")
|
||||||
;;
|
update_script 0
|
||||||
*) show_usage ;;
|
;;
|
||||||
esac
|
*) show_usage ;;
|
||||||
|
esac
|
||||||
|
elif [[ $IS_DOCKER_NEZHA == 0 ]]; then
|
||||||
|
case $1 in
|
||||||
|
"install_dashboard")
|
||||||
|
install_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"modify_dashboard_config")
|
||||||
|
modify_dashboard_config_standalone 0
|
||||||
|
;;
|
||||||
|
"start_dashboard")
|
||||||
|
start_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"stop_dashboard")
|
||||||
|
stop_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"restart_and_update")
|
||||||
|
restart_and_update_standalone 0
|
||||||
|
;;
|
||||||
|
"show_dashboard_log")
|
||||||
|
show_dashboard_log_standalone 0
|
||||||
|
;;
|
||||||
|
"uninstall_dashboard")
|
||||||
|
uninstall_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"install_agent")
|
||||||
|
shift
|
||||||
|
if [ $# -ge 3 ]; then
|
||||||
|
install_agent "$@"
|
||||||
|
else
|
||||||
|
install_agent 0
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
"modify_agent_config")
|
||||||
|
modify_agent_config 0
|
||||||
|
;;
|
||||||
|
"show_agent_log")
|
||||||
|
show_agent_log 0
|
||||||
|
;;
|
||||||
|
"uninstall_agent")
|
||||||
|
uninstall_agent 0
|
||||||
|
;;
|
||||||
|
"restart_agent")
|
||||||
|
restart_agent 0
|
||||||
|
;;
|
||||||
|
"update_script")
|
||||||
|
update_script 0
|
||||||
|
;;
|
||||||
|
*) show_usage ;;
|
||||||
|
esac
|
||||||
|
else
|
||||||
|
echo "未检测到 IS_DOCKER_NEZHA 环境变量,请尝试在 Bash 环境下重新执行脚本,或者不带参数执行。"
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
|
select_version
|
||||||
show_menu
|
show_menu
|
||||||
fi
|
fi
|
||||||
|
@ -11,7 +11,10 @@ NZ_BASE_PATH="/opt/nezha"
|
|||||||
NZ_DASHBOARD_PATH="${NZ_BASE_PATH}/dashboard"
|
NZ_DASHBOARD_PATH="${NZ_BASE_PATH}/dashboard"
|
||||||
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
|
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
|
||||||
NZ_AGENT_SERVICE="/etc/systemd/system/nezha-agent.service"
|
NZ_AGENT_SERVICE="/etc/systemd/system/nezha-agent.service"
|
||||||
NZ_VERSION="v0.15.0"
|
NZ_AGENT_SERVICERC="/etc/init.d/nezha-agent"
|
||||||
|
NZ_DASHBOARD_SERVICE="/etc/systemd/system/nezha-dashboard.service"
|
||||||
|
NZ_DASHBOARD_SERVICERC="/etc/init.d/nezha-dashboard"
|
||||||
|
NZ_VERSION="v0.15.1"
|
||||||
|
|
||||||
red='\033[0;31m'
|
red='\033[0;31m'
|
||||||
green='\033[0;32m'
|
green='\033[0;32m'
|
||||||
@ -70,18 +73,20 @@ pre_check() {
|
|||||||
Get_Docker_URL="get.docker.com"
|
Get_Docker_URL="get.docker.com"
|
||||||
Get_Docker_Argu=" "
|
Get_Docker_Argu=" "
|
||||||
Docker_IMG="ghcr.io\/naiba\/nezha-dashboard"
|
Docker_IMG="ghcr.io\/naiba\/nezha-dashboard"
|
||||||
|
GITHUB_RELEASE_URL="github.com/naiba/nezha/releases/latest/download"
|
||||||
else
|
else
|
||||||
GITHUB_RAW_URL="jihulab.com/nezha/dashboard/-/raw/master"
|
GITHUB_RAW_URL="jihulab.com/nezha/dashboard/-/raw/master"
|
||||||
GITHUB_URL="dn-dao-github-mirror.daocloud.io"
|
GITHUB_URL="dn-dao-github-mirror.daocloud.io"
|
||||||
Get_Docker_URL="get.daocloud.io/docker"
|
Get_Docker_URL="get.daocloud.io/docker"
|
||||||
Get_Docker_Argu=" -s docker --mirror Aliyun"
|
Get_Docker_Argu=" -s docker --mirror Aliyun"
|
||||||
Docker_IMG="registry.cn-shanghai.aliyuncs.com\/naibahq\/nezha-dashboard"
|
Docker_IMG="registry.cn-shanghai.aliyuncs.com\/naibahq\/nezha-dashboard"
|
||||||
|
GITHUB_RELEASE_URL="hub.fgit.cf/naiba/nezha/releases/latest/download"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
confirm() {
|
confirm() {
|
||||||
if [[ $# > 1 ]]; then
|
if [[ $# > 1 ]]; then
|
||||||
echo && read -e -p "$1 [Default$2]: " temp
|
echo && read -e -p "$1 [默认$2]: " temp
|
||||||
if [[ x"${temp}" == x"" ]]; then
|
if [[ x"${temp}" == x"" ]]; then
|
||||||
temp=$2
|
temp=$2
|
||||||
fi
|
fi
|
||||||
@ -101,7 +106,7 @@ update_script() {
|
|||||||
curl -sL https://${GITHUB_RAW_URL}/script/install_en.sh -o /tmp/nezha.sh
|
curl -sL https://${GITHUB_RAW_URL}/script/install_en.sh -o /tmp/nezha.sh
|
||||||
new_version=$(cat /tmp/nezha.sh | grep "NZ_VERSION" | head -n 1 | awk -F "=" '{print $2}' | sed 's/\"//g;s/,//g;s/ //g')
|
new_version=$(cat /tmp/nezha.sh | grep "NZ_VERSION" | head -n 1 | awk -F "=" '{print $2}' | sed 's/\"//g;s/,//g;s/ //g')
|
||||||
if [ ! -n "$new_version" ]; then
|
if [ ! -n "$new_version" ]; then
|
||||||
echo -e "Script failed to get, please check if the network can link https://${GITHUB_RAW_URL}/script/install_en.sh"
|
echo -e "Script failed to get, please check if the network can link https://${GITHUB_RAW_URL}/script/install.sh"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
echo -e "The current latest version is: ${new_version}"
|
echo -e "The current latest version is: ${new_version}"
|
||||||
@ -121,8 +126,9 @@ before_show_menu() {
|
|||||||
|
|
||||||
install_base() {
|
install_base() {
|
||||||
(command -v git >/dev/null 2>&1 && command -v curl >/dev/null 2>&1 && command -v wget >/dev/null 2>&1 && command -v unzip >/dev/null 2>&1 && command -v getenforce >/dev/null 2>&1) ||
|
(command -v git >/dev/null 2>&1 && command -v curl >/dev/null 2>&1 && command -v wget >/dev/null 2>&1 && command -v unzip >/dev/null 2>&1 && command -v getenforce >/dev/null 2>&1) ||
|
||||||
(install_soft curl wget git unzip)
|
(install_soft curl wget git unzip tzdata)
|
||||||
}
|
}
|
||||||
|
|
||||||
install_arch(){
|
install_arch(){
|
||||||
echo -e "${green}Info: ${plain} Archlinux needs to add nezha-agent user to install libselinux. It will be deleted automatically after installation. It is recommended to check manually\n"
|
echo -e "${green}Info: ${plain} Archlinux needs to add nezha-agent user to install libselinux. It will be deleted automatically after installation. It is recommended to check manually\n"
|
||||||
read -e -r -p "Do you need to install libselinux? [Y/n] " input
|
read -e -r -p "Do you need to install libselinux? [Y/n] " input
|
||||||
@ -147,7 +153,6 @@ install_arch(){
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
install_soft() {
|
install_soft() {
|
||||||
(command -v yum >/dev/null 2>&1 && yum makecache && yum install $* selinux-policy -y) ||
|
(command -v yum >/dev/null 2>&1 && yum makecache && yum install $* selinux-policy -y) ||
|
||||||
(command -v apt >/dev/null 2>&1 && apt update && apt install $* selinux-utils -y) ||
|
(command -v apt >/dev/null 2>&1 && apt update && apt install $* selinux-utils -y) ||
|
||||||
@ -203,6 +208,45 @@ install_dashboard() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
install_dashboard_standalone() {
|
||||||
|
install_base
|
||||||
|
|
||||||
|
echo -e "> Install Panel"
|
||||||
|
|
||||||
|
# Nezha Monitoring Folder
|
||||||
|
if [ ! -d "${NZ_DASHBOARD_PATH}" ]; then
|
||||||
|
mkdir -p $NZ_DASHBOARD_PATH
|
||||||
|
else
|
||||||
|
echo "You may have already installed the dashboard, repeated installation will overwrite the data, please pay attention to backup."
|
||||||
|
read -e -r -p "Exit the installation? [Y/n] " input
|
||||||
|
case $input in
|
||||||
|
[yY][eE][sS] | [yY])
|
||||||
|
echo "Exit the installation."
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
[nN][oO] | [nN])
|
||||||
|
echo "Continue."
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Exit the installation."
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "${NZ_DASHBOARD_PATH}/resource/template/theme-custom" ] || [ ! -d "${NZ_DASHBOARD_PATH}/resource/static/custom" ]; then
|
||||||
|
mkdir -p "${NZ_DASHBOARD_PATH}/resource/template/theme-custom" "${NZ_DASHBOARD_PATH}/resource/static/custom" >/dev/null 2>&1
|
||||||
|
fi
|
||||||
|
|
||||||
|
chmod 777 -R $NZ_DASHBOARD_PATH
|
||||||
|
|
||||||
|
modify_dashboard_config_standalone 0
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
selinux(){
|
selinux(){
|
||||||
#Check SELinux
|
#Check SELinux
|
||||||
if [ "$os_alpine" != 1 ];then
|
if [ "$os_alpine" != 1 ];then
|
||||||
@ -274,6 +318,13 @@ modify_agent_config() {
|
|||||||
echo -e "${red}Fail to download service, please check if the network can link ${GITHUB_RAW_URL}${plain}"
|
echo -e "${red}Fail to download service, please check if the network can link ${GITHUB_RAW_URL}${plain}"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
wget -t 2 -T 10 -O $NZ_AGENT_SERVICERC https://${GITHUB_RAW_URL}/script/nezha-agent >/dev/null 2>&1
|
||||||
|
chmod +x $NZ_AGENT_SERVICERC
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "${red}Fail to download service, please check if the network can link ${GITHUB_RAW_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $# -lt 3 ]; then
|
if [ $# -lt 3 ]; then
|
||||||
@ -307,8 +358,10 @@ modify_agent_config() {
|
|||||||
sed -i "s/nz_client_secret/${nz_client_secret}/" ${NZ_AGENT_SERVICE}
|
sed -i "s/nz_client_secret/${nz_client_secret}/" ${NZ_AGENT_SERVICE}
|
||||||
[ -n "${args}" ] && sed -i "/ExecStart/ s/$/ ${args}/" ${NZ_AGENT_SERVICE}
|
[ -n "${args}" ] && sed -i "/ExecStart/ s/$/ ${args}/" ${NZ_AGENT_SERVICE}
|
||||||
else
|
else
|
||||||
echo "@reboot ${NZ_AGENT_PATH}/nezha-agent -s ${nz_grpc_host}:${nz_grpc_port} -p ${nz_client_secret} ${args}" >> /etc/crontabs/root
|
sed -i "s/nz_grpc_host/${nz_grpc_host}/" ${NZ_AGENT_SERVICERC}
|
||||||
crond
|
sed -i "s/nz_grpc_port/${nz_grpc_port}/" ${NZ_AGENT_SERVICERC}
|
||||||
|
sed -i "s/nz_client_secret/${nz_client_secret}/" ${NZ_AGENT_SERVICERC}
|
||||||
|
[ -n "${args}" ] && sed -i "/command_args/ s/$/ \"${args}\"/" ${NZ_AGENT_SERVICERC}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "Agent configuration ${green} modified successfully, please wait for agent self-restart to take effect${plain}"
|
echo -e "Agent configuration ${green} modified successfully, please wait for agent self-restart to take effect${plain}"
|
||||||
@ -318,7 +371,8 @@ modify_agent_config() {
|
|||||||
systemctl enable nezha-agent
|
systemctl enable nezha-agent
|
||||||
systemctl restart nezha-agent
|
systemctl restart nezha-agent
|
||||||
else
|
else
|
||||||
nohup ${NZ_AGENT_PATH}/nezha-agent -s ${nz_grpc_host}:${nz_grpc_port} -p ${nz_client_secret} ${args} >/dev/null 2>&1 &
|
rc-update add nezha-agent
|
||||||
|
rc-service nezha-agent restart
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
@ -392,6 +446,78 @@ modify_dashboard_config() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
modify_dashboard_config_standalone() {
|
||||||
|
echo -e "> Modify Panel Configuration"
|
||||||
|
|
||||||
|
echo -e "Download configuration template"
|
||||||
|
|
||||||
|
wget -t 2 -T 10 -O /tmp/nezha-config.yaml https://${GITHUB_RAW_URL}/script/config.yaml >/dev/null 2>&1
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "${red}File failed to get, please check if the network can link ${GITHUB_RAW_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "About the GitHub Oauth2 application: create it at https://github.com/settings/developers, no review required, and fill in the http(s)://domain_or_IP/oauth2/callback" &&
|
||||||
|
echo "(Not recommended) About the Gitee Oauth2 application: create it at https://gitee.com/oauth/applications, no auditing required, and fill in the http(s)://domain_or_IP/oauth2/callback" &&
|
||||||
|
read -ep "Please enter the OAuth2 provider (github/gitlab/jihulab/gitee, default github): " nz_oauth2_type &&
|
||||||
|
read -ep "Please enter the Client ID of the Oauth2 application: " nz_github_oauth_client_id &&
|
||||||
|
read -ep "Please enter the Client Secret of the Oauth2 application: " nz_github_oauth_client_secret &&
|
||||||
|
read -ep "Please enter your GitHub/Gitee login name as the administrator, separated by commas: " nz_admin_logins &&
|
||||||
|
read -ep "Please enter the site title: " nz_site_title &&
|
||||||
|
read -ep "Please enter the site access port: (default 8008)" nz_site_port &&
|
||||||
|
read -ep "Please enter the RPC port to be used for Agent access: (default 5555)" nz_grpc_port
|
||||||
|
|
||||||
|
if [[ -z "${nz_admin_logins}" || -z "${nz_github_oauth_client_id}" || -z "${nz_github_oauth_client_secret}" || -z "${nz_site_title}" ]]; then
|
||||||
|
echo -e "${red}All options cannot be empty${plain}"
|
||||||
|
before_show_menu
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "${nz_site_port}" ]]; then
|
||||||
|
nz_site_port=8008
|
||||||
|
fi
|
||||||
|
if [[ -z "${nz_grpc_port}" ]]; then
|
||||||
|
nz_grpc_port=5555
|
||||||
|
fi
|
||||||
|
if [[ -z "${nz_oauth2_type}" ]]; then
|
||||||
|
nz_oauth2_type=github
|
||||||
|
fi
|
||||||
|
|
||||||
|
sed -i "s/nz_oauth2_type/${nz_oauth2_type}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_admin_logins/${nz_admin_logins}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_grpc_port/${nz_grpc_port}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_github_oauth_client_id/${nz_github_oauth_client_id}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_github_oauth_client_secret/${nz_github_oauth_client_secret}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_language/zh-CN/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/nz_site_title/${nz_site_title}/" /tmp/nezha-config.yaml
|
||||||
|
sed -i "s/80/${nz_site_port}/" /tmp/nezha-config.yaml
|
||||||
|
|
||||||
|
mkdir -p $NZ_DASHBOARD_PATH/data
|
||||||
|
mv -f /tmp/nezha-config.yaml ${NZ_DASHBOARD_PATH}/data/config.yaml
|
||||||
|
|
||||||
|
echo -e "Downloading service file"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ];then
|
||||||
|
wget -t 2 -T 10 -O $NZ_DASHBOARD_SERVICE https://${GITHUB_RAW_URL}/script/nezha-dashboard.service >/dev/null 2>&1
|
||||||
|
else
|
||||||
|
wget -t 2 -T 10 -O $NZ_DASHBOARD_SERVICERC https://${GITHUB_RAW_URL}/script/nezha-dashboard >/dev/null 2>&1
|
||||||
|
chmod +x $NZ_DASHBOARD_SERVICERC
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "${red}File failed to get, please check if the network can link ${GITHUB_RAW_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
echo -e "Dashboard configuration ${green} modified successfully, please wait for Dashboard self-restart to take effect${plain}"
|
||||||
|
|
||||||
|
restart_and_update_standalone
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
restart_and_update() {
|
restart_and_update() {
|
||||||
echo -e "> Restart and Update the Panel"
|
echo -e "> Restart and Update the Panel"
|
||||||
|
|
||||||
@ -420,6 +546,40 @@ restart_and_update() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
restart_and_update_standalone() {
|
||||||
|
echo -e "> Restart and Update the Panel"
|
||||||
|
|
||||||
|
cd $NZ_DASHBOARD_PATH
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl stop nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
wget -qO app.zip $GITHUB_RELEASE_URL/dashboard-linux-$os_arch.zip >/dev/null 2>&1 && unzip -qq app.zip && mv dist/dashboard-linux-$os_arch app && rm -r app.zip dist
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ];then
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable nezha-dashboard
|
||||||
|
systemctl restart nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-update add nezha-dashboard
|
||||||
|
rc-service nezha-dashboard restart
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $? == 0 ]]; then
|
||||||
|
echo -e "${green}Nezha Monitoring Restart Successful${plain}"
|
||||||
|
echo -e "Default panel address: ${yellow}domain:Site_access_port${plain}"
|
||||||
|
else
|
||||||
|
echo -e "${red}The restart failed, probably because the boot time exceeded two seconds, please check the log information later${plain}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
start_dashboard() {
|
start_dashboard() {
|
||||||
echo -e "> Start Panel"
|
echo -e "> Start Panel"
|
||||||
|
|
||||||
@ -441,6 +601,26 @@ start_dashboard() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
start_dashboard_standalone() {
|
||||||
|
echo -e "> Start Panel"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl start nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard start
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $? == 0 ]]; then
|
||||||
|
echo -e "${green}Nezha Monitoring Start Successful${plain}"
|
||||||
|
else
|
||||||
|
echo -e "${red}Failed to start, please check the log message later${plain}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
stop_dashboard() {
|
stop_dashboard() {
|
||||||
echo -e "> Stop Panel"
|
echo -e "> Stop Panel"
|
||||||
|
|
||||||
@ -462,6 +642,26 @@ stop_dashboard() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stop_dashboard_standalone() {
|
||||||
|
echo -e "> Stop Panel"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl stop nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $? == 0 ]]; then
|
||||||
|
echo -e "${green}Nezha Monitoring Stop Successful${plain}"
|
||||||
|
else
|
||||||
|
echo -e "${red}Failed to stop, please check the log message later${plain}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
show_dashboard_log() {
|
show_dashboard_log() {
|
||||||
echo -e "> View Panel Log"
|
echo -e "> View Panel Log"
|
||||||
|
|
||||||
@ -477,6 +677,20 @@ show_dashboard_log() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_dashboard_log_standalone() {
|
||||||
|
echo -e "> View Panel Log"
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
journalctl -xf -u nezha-dashboard.service
|
||||||
|
else
|
||||||
|
echo "Sorry, OpenRC do not have this feature yet."
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
uninstall_dashboard() {
|
uninstall_dashboard() {
|
||||||
echo -e "> Uninstall Panel"
|
echo -e "> Uninstall Panel"
|
||||||
|
|
||||||
@ -489,17 +703,52 @@ uninstall_dashboard() {
|
|||||||
|
|
||||||
rm -rf $NZ_DASHBOARD_PATH
|
rm -rf $NZ_DASHBOARD_PATH
|
||||||
docker rmi -f ghcr.io/naiba/nezha-dashboard > /dev/null 2>&1
|
docker rmi -f ghcr.io/naiba/nezha-dashboard > /dev/null 2>&1
|
||||||
|
docker rmi -f registry.cn-shanghai.aliyuncs.com/naibahq/nezha-dashboard > /dev/null 2>&1
|
||||||
clean_all
|
clean_all
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
before_show_menu
|
before_show_menu
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
sed -i '/IS_DOCKER_NEZHA/d' ~/.bashrc
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
uninstall_dashboard_standalone() {
|
||||||
|
echo -e "> Uninstall Panel"
|
||||||
|
|
||||||
|
rm -rf $NZ_DASHBOARD_PATH
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
systemctl stop nezha-dashboard
|
||||||
|
else
|
||||||
|
rc-service nezha-dashboard stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
rm $NZ_DASHBOARD_SERVICE
|
||||||
|
else
|
||||||
|
rm $NZ_DASHBOARD_SERVICERC
|
||||||
|
fi
|
||||||
|
|
||||||
|
clean_all
|
||||||
|
|
||||||
|
if [[ $# == 0 ]]; then
|
||||||
|
before_show_menu
|
||||||
|
fi
|
||||||
|
|
||||||
|
sed -i '/IS_DOCKER_NEZHA/d' ~/.bashrc
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
show_agent_log() {
|
show_agent_log() {
|
||||||
echo -e "> View Agent Log"
|
echo -e "> > View Agent Log"
|
||||||
|
|
||||||
journalctl -xf -u nezha-agent.service
|
if [ "$os_alpine" != 1 ]; then
|
||||||
|
journalctl -xf -u nezha-agent.service
|
||||||
|
else
|
||||||
|
echo "Sorry, OpenRC do not have this feature yet."
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
before_show_menu
|
before_show_menu
|
||||||
@ -515,8 +764,9 @@ uninstall_agent() {
|
|||||||
rm -rf $NZ_AGENT_SERVICE
|
rm -rf $NZ_AGENT_SERVICE
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
else
|
else
|
||||||
grep -q 'nezha-agent' /var/spool/cron/crontabs/root && sed -i "/nezha-agent/d" /var/spool/cron/crontabs/root
|
rc-update del nezha-agent
|
||||||
pkill nezha-agent
|
rc-service nezha-agent stop
|
||||||
|
rm -rf $NZ_AGENT_SERVICERC
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm -rf $NZ_AGENT_PATH
|
rm -rf $NZ_AGENT_PATH
|
||||||
@ -530,7 +780,11 @@ uninstall_agent() {
|
|||||||
restart_agent() {
|
restart_agent() {
|
||||||
echo -e "> Restart Agent"
|
echo -e "> Restart Agent"
|
||||||
|
|
||||||
systemctl restart nezha-agent.service
|
if [ "$os_alpine" != 1 ];then
|
||||||
|
systemctl restart nezha-agent.service
|
||||||
|
else
|
||||||
|
rc-service nezha-agent restart
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ $# == 0 ]]; then
|
if [[ $# == 0 ]]; then
|
||||||
before_show_menu
|
before_show_menu
|
||||||
@ -543,6 +797,17 @@ clean_all() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
select_version() {
|
||||||
|
cd $NZ_DASHBOARD_PATH
|
||||||
|
if command -v docker compose >/dev/null 2>&1; then
|
||||||
|
if docker compose ls | grep -qw "$NZ_DASHBOARD_PATH/docker-compose.yaml" >/dev/null 2>&1; then
|
||||||
|
IS_DOCKER_NEZHA=1
|
||||||
|
fi
|
||||||
|
elif [ -d /opt/nezha/dashboard ]; then
|
||||||
|
IS_DOCKER_NEZHA=0
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
show_usage() {
|
show_usage() {
|
||||||
echo "Nezha Monitor Management Script Usage: "
|
echo "Nezha Monitor Management Script Usage: "
|
||||||
echo "--------------------------------------------------------"
|
echo "--------------------------------------------------------"
|
||||||
@ -587,106 +852,208 @@ show_menu() {
|
|||||||
${green}0.${plain} Exit Script
|
${green}0.${plain} Exit Script
|
||||||
"
|
"
|
||||||
echo && read -ep "Please enter [0-13]: " num
|
echo && read -ep "Please enter [0-13]: " num
|
||||||
|
if [[ $IS_DOCKER_NEZHA == 1 ]]; then
|
||||||
case "${num}" in
|
case "${num}" in
|
||||||
0)
|
0)
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
1)
|
1)
|
||||||
install_dashboard
|
install_dashboard
|
||||||
;;
|
;;
|
||||||
2)
|
2)
|
||||||
modify_dashboard_config
|
modify_dashboard_config
|
||||||
;;
|
;;
|
||||||
3)
|
3)
|
||||||
start_dashboard
|
start_dashboard
|
||||||
;;
|
;;
|
||||||
4)
|
4)
|
||||||
stop_dashboard
|
stop_dashboard
|
||||||
;;
|
;;
|
||||||
5)
|
5)
|
||||||
restart_and_update
|
restart_and_update
|
||||||
;;
|
;;
|
||||||
6)
|
6)
|
||||||
show_dashboard_log
|
show_dashboard_log
|
||||||
;;
|
;;
|
||||||
7)
|
7)
|
||||||
uninstall_dashboard
|
uninstall_dashboard
|
||||||
;;
|
;;
|
||||||
8)
|
8)
|
||||||
install_agent
|
install_agent
|
||||||
;;
|
;;
|
||||||
9)
|
9)
|
||||||
modify_agent_config
|
modify_agent_config
|
||||||
;;
|
;;
|
||||||
10)
|
10)
|
||||||
show_agent_log
|
show_agent_log
|
||||||
;;
|
;;
|
||||||
11)
|
11)
|
||||||
uninstall_agent
|
uninstall_agent
|
||||||
;;
|
;;
|
||||||
12)
|
12)
|
||||||
restart_agent
|
restart_agent
|
||||||
;;
|
;;
|
||||||
13)
|
13)
|
||||||
update_script
|
update_script
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo -e "${red}Please enter the correct number [0-13]${plain}"
|
echo -e "${red}Please enter the correct number [0-13]${plain}"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
elif [[ $IS_DOCKER_NEZHA == 0 ]]; then
|
||||||
|
case "${num}" in
|
||||||
|
0)
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
1)
|
||||||
|
install_dashboard_standalone
|
||||||
|
;;
|
||||||
|
2)
|
||||||
|
modify_dashboard_config_standalone
|
||||||
|
;;
|
||||||
|
3)
|
||||||
|
start_dashboard_standalone
|
||||||
|
;;
|
||||||
|
4)
|
||||||
|
stop_dashboard_standalone
|
||||||
|
;;
|
||||||
|
5)
|
||||||
|
restart_and_update_standalone
|
||||||
|
;;
|
||||||
|
6)
|
||||||
|
show_dashboard_log_standalone
|
||||||
|
;;
|
||||||
|
7)
|
||||||
|
uninstall_dashboard_standalone
|
||||||
|
;;
|
||||||
|
8)
|
||||||
|
install_agent
|
||||||
|
;;
|
||||||
|
9)
|
||||||
|
modify_agent_config
|
||||||
|
;;
|
||||||
|
10)
|
||||||
|
show_agent_log
|
||||||
|
;;
|
||||||
|
11)
|
||||||
|
uninstall_agent
|
||||||
|
;;
|
||||||
|
12)
|
||||||
|
restart_agent
|
||||||
|
;;
|
||||||
|
13)
|
||||||
|
update_script
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo -e "${red}Please enter the correct number [0-13]${plain}"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
pre_check
|
pre_check
|
||||||
|
|
||||||
if [[ $# > 0 ]]; then
|
if [[ $# > 0 ]]; then
|
||||||
case $1 in
|
if [[ $IS_DOCKER_NEZHA == 1 ]]; then
|
||||||
"install_dashboard")
|
case $1 in
|
||||||
install_dashboard 0
|
"install_dashboard")
|
||||||
;;
|
install_dashboard 0
|
||||||
"modify_dashboard_config")
|
;;
|
||||||
modify_dashboard_config 0
|
"modify_dashboard_config")
|
||||||
;;
|
modify_dashboard_config 0
|
||||||
"start_dashboard")
|
;;
|
||||||
start_dashboard 0
|
"start_dashboard")
|
||||||
;;
|
start_dashboard 0
|
||||||
"stop_dashboard")
|
;;
|
||||||
stop_dashboard 0
|
"stop_dashboard")
|
||||||
;;
|
stop_dashboard 0
|
||||||
"restart_and_update")
|
;;
|
||||||
restart_and_update 0
|
"restart_and_update")
|
||||||
;;
|
restart_and_update 0
|
||||||
"show_dashboard_log")
|
;;
|
||||||
show_dashboard_log 0
|
"show_dashboard_log")
|
||||||
;;
|
show_dashboard_log 0
|
||||||
"uninstall_dashboard")
|
;;
|
||||||
uninstall_dashboard 0
|
"uninstall_dashboard")
|
||||||
;;
|
uninstall_dashboard 0
|
||||||
"install_agent")
|
;;
|
||||||
shift
|
"install_agent")
|
||||||
if [ $# -ge 3 ]; then
|
shift
|
||||||
install_agent "$@"
|
if [ $# -ge 3 ]; then
|
||||||
else
|
install_agent "$@"
|
||||||
install_agent 0
|
else
|
||||||
fi
|
install_agent 0
|
||||||
;;
|
fi
|
||||||
"modify_agent_config")
|
;;
|
||||||
modify_agent_config 0
|
"modify_agent_config")
|
||||||
;;
|
modify_agent_config 0
|
||||||
"show_agent_log")
|
;;
|
||||||
show_agent_log 0
|
"show_agent_log")
|
||||||
;;
|
show_agent_log 0
|
||||||
"uninstall_agent")
|
;;
|
||||||
uninstall_agent 0
|
"uninstall_agent")
|
||||||
;;
|
uninstall_agent 0
|
||||||
"restart_agent")
|
;;
|
||||||
restart_agent 0
|
"restart_agent")
|
||||||
;;
|
restart_agent 0
|
||||||
"update_script")
|
;;
|
||||||
update_script 0
|
"update_script")
|
||||||
;;
|
update_script 0
|
||||||
*) show_usage ;;
|
;;
|
||||||
esac
|
*) show_usage ;;
|
||||||
|
esac
|
||||||
|
elif [[ $IS_DOCKER_NEZHA == 0 ]]; then
|
||||||
|
case $1 in
|
||||||
|
"install_dashboard")
|
||||||
|
install_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"modify_dashboard_config")
|
||||||
|
modify_dashboard_config_standalone 0
|
||||||
|
;;
|
||||||
|
"start_dashboard")
|
||||||
|
start_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"stop_dashboard")
|
||||||
|
stop_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"restart_and_update")
|
||||||
|
restart_and_update_standalone 0
|
||||||
|
;;
|
||||||
|
"show_dashboard_log")
|
||||||
|
show_dashboard_log_standalone 0
|
||||||
|
;;
|
||||||
|
"uninstall_dashboard")
|
||||||
|
uninstall_dashboard_standalone 0
|
||||||
|
;;
|
||||||
|
"install_agent")
|
||||||
|
shift
|
||||||
|
if [ $# -ge 3 ]; then
|
||||||
|
install_agent "$@"
|
||||||
|
else
|
||||||
|
install_agent 0
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
"modify_agent_config")
|
||||||
|
modify_agent_config 0
|
||||||
|
;;
|
||||||
|
"show_agent_log")
|
||||||
|
show_agent_log 0
|
||||||
|
;;
|
||||||
|
"uninstall_agent")
|
||||||
|
uninstall_agent 0
|
||||||
|
;;
|
||||||
|
"restart_agent")
|
||||||
|
restart_agent 0
|
||||||
|
;;
|
||||||
|
"update_script")
|
||||||
|
update_script 0
|
||||||
|
;;
|
||||||
|
*) show_usage ;;
|
||||||
|
esac
|
||||||
|
else
|
||||||
|
echo "Environment variable IS_DOCKER_NEZHA is not detected, Try run the script again in Bash or without arguments."
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
|
select_version
|
||||||
show_menu
|
show_menu
|
||||||
fi
|
fi
|
59
script/nezha-agent
Executable file
59
script/nezha-agent
Executable file
@ -0,0 +1,59 @@
|
|||||||
|
#!/sbin/openrc-run
|
||||||
|
SERVER="nz_grpc_host:nz_grpc_port" #Dashboard 地址 ip:port
|
||||||
|
SECRET="nz_client_secret" #SECRET
|
||||||
|
NZ_BASE_PATH="/opt/nezha"
|
||||||
|
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
|
||||||
|
pidfile="/run/${RC_SVCNAME}.pid"
|
||||||
|
command="/opt/nezha/agent/nezha-agent"
|
||||||
|
command_args="-s ${SERVER} -p ${SECRET}"
|
||||||
|
command_background=true
|
||||||
|
depend() {
|
||||||
|
need net
|
||||||
|
}
|
||||||
|
checkconfig() {
|
||||||
|
GITHUB_URL="github.com"
|
||||||
|
if [ ! -f "${NZ_AGENT_PATH}/nezha-agent" ]; then
|
||||||
|
if [[ $(uname -m | grep 'x86_64') != "" ]]; then
|
||||||
|
os_arch="amd64"
|
||||||
|
elif [[ $(uname -m | grep 'i386\|i686') != "" ]]; then
|
||||||
|
os_arch="386"
|
||||||
|
elif [[ $(uname -m | grep 'aarch64\|armv8b\|armv8l') != "" ]]; then
|
||||||
|
os_arch="arm64"
|
||||||
|
elif [[ $(uname -m | grep 'arm') != "" ]]; then
|
||||||
|
os_arch="arm"
|
||||||
|
elif [[ $(uname -m | grep 's390x') != "" ]]; then
|
||||||
|
os_arch="s390x"
|
||||||
|
elif [[ $(uname -m | grep 'riscv64') != "" ]]; then
|
||||||
|
os_arch="riscv64"
|
||||||
|
fi
|
||||||
|
local version=$(curl -m 10 -sL "https://api.github.com/repos/nezhahq/agent/releases/latest" | grep "tag_name" | head -n 1 | awk -F ":" '{print $2}' | sed 's/\"//g;s/,//g;s/ //g')
|
||||||
|
if [ ! -n "$version" ]; then
|
||||||
|
version=$(curl -m 10 -sL "https://fastly.jsdelivr.net/gh/nezhahq/agent/" | grep "option\.value" | awk -F "'" '{print $2}' | sed 's/nezhahq\/agent@/v/g')
|
||||||
|
fi
|
||||||
|
if [ ! -n "$version" ]; then
|
||||||
|
version=$(curl -m 10 -sL "https://gcore.jsdelivr.net/gh/nezhahq/agent/" | grep "option\.value" | awk -F "'" '{print $2}' | sed 's/nezhahq\/agent@/v/g')
|
||||||
|
fi
|
||||||
|
if [ ! -n "$version" ]; then
|
||||||
|
echo -e "获取版本号失败,请检查本机能否链接 https://api.github.com/repos/nezhahq/agent/releases/latest"
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
echo -e "当前最新版本为: ${version}"
|
||||||
|
fi
|
||||||
|
wget -t 2 -T 10 -O nezha-agent_linux_${os_arch}.zip https://${GITHUB_URL}/nezhahq/agent/releases/download/${version}/nezha-agent_linux_${os_arch}.zip >/dev/null 2>&1
|
||||||
|
if [[ $? != 0 ]]; then
|
||||||
|
echo -e "Release 下载失败,请检查本机能否连接 ${GITHUB_URL}${plain}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
mkdir -p $NZ_AGENT_PATH
|
||||||
|
chmod 755 -R $NZ_AGENT_PATH
|
||||||
|
unzip -qo nezha-agent_linux_${os_arch}.zip && mv nezha-agent $NZ_AGENT_PATH && rm -rf nezha-agent_linux_${os_arch}.zip README.md
|
||||||
|
fi
|
||||||
|
if [ ! -x "${NZ_AGENT_PATH}/nezha-agent" ]; then
|
||||||
|
chmod +x ${NZ_AGENT_PATH}/nezha-agent
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
start_pre() {
|
||||||
|
if [ "${RC_CMD}" != "restart" ]; then
|
||||||
|
checkconfig || return $?
|
||||||
|
fi
|
||||||
|
}
|
16
script/nezha-dashboard
Normal file
16
script/nezha-dashboard
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/sbin/openrc-run
|
||||||
|
pidfile="/run/${RC_SVCNAME}.pid"
|
||||||
|
command="/opt/nezha/dashboard/app"
|
||||||
|
command_args=""
|
||||||
|
command_background=true
|
||||||
|
directory="/opt/nezha/dashboard"
|
||||||
|
|
||||||
|
depend() {
|
||||||
|
need net
|
||||||
|
}
|
||||||
|
|
||||||
|
reload() {
|
||||||
|
ebegin "Reloading ${RC_SVCNAME}"
|
||||||
|
start-stop-daemon --signal HUP --pidfile "${pidfile}"
|
||||||
|
eend $?
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
[Unit]
|
[Unit]
|
||||||
Description=Nezha Dashborad
|
Description=Nezha Dashboard
|
||||||
After=syslog.target
|
After=syslog.target
|
||||||
After=network.target
|
After=network.target
|
||||||
After=mariadb.service mysqld.service postgresql.service memcached.service redis.service
|
After=mariadb.service mysqld.service postgresql.service memcached.service redis.service
|
||||||
@ -14,8 +14,8 @@ After=mariadb.service mysqld.service postgresql.service memcached.service redis.
|
|||||||
Type=simple
|
Type=simple
|
||||||
#User=root
|
#User=root
|
||||||
#Group=root
|
#Group=root
|
||||||
WorkingDirectory=/root/nezha/dashboard/
|
WorkingDirectory=/opt/nezha/dashboard/
|
||||||
ExecStart=/root/nezha/dashboard/nezha-dashboard-linux-amd64
|
ExecStart=/opt/nezha/dashboard/app
|
||||||
Restart=always
|
Restart=always
|
||||||
#Environment=DEBUG=true
|
#Environment=DEBUG=true
|
||||||
|
|
||||||
@ -27,4 +27,4 @@ PrivateTmp=yes
|
|||||||
NoNewPrivileges=true
|
NoNewPrivileges=true
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
Loading…
Reference in New Issue
Block a user