From eaba7abd3558b10f442bae3d4ca144657641db40 Mon Sep 17 00:00:00 2001
From: UUBulb <35923940+uubulb@users.noreply.github.com>
Date: Tue, 21 May 2024 23:11:43 +0800
Subject: [PATCH] Use agent's builtin support for services instead (#357)
---
README.md | 2 +-
.../template/dashboard-default/server.html | 5 +
script/install.command | 291 ++++++++++++++++++
script/install.ps1 | 53 ++--
script/install.sh | 62 +---
script/install_en.sh | 60 +---
script/nezha-agent | 19 --
script/nezha-agent.service | 30 --
8 files changed, 343 insertions(+), 179 deletions(-)
create mode 100644 script/install.command
delete mode 100755 script/nezha-agent
delete mode 100644 script/nezha-agent.service
diff --git a/README.md b/README.md
index 65a16eca46..53ef9aeaac 100644
--- a/README.md
+++ b/README.md
@@ -4,7 +4,7 @@
LOGO designed by 熊大 .
-
+
:trollface: Nezha Monitoring: Self-hostable, lightweight, servers and websites monitoring and O&M tool.
diff --git a/resource/template/dashboard-default/server.html b/resource/template/dashboard-default/server.html
index dd3f417da7..0d04ce8630 100644
--- a/resource/template/dashboard-default/server.html
+++ b/resource/template/dashboard-default/server.html
@@ -69,6 +69,11 @@
data-tooltip="{{tr "ClickToCopy"}}">
+
{{$server.Note}} |
diff --git a/script/install.command b/script/install.command
new file mode 100644
index 0000000000..71ffbe994d
--- /dev/null
+++ b/script/install.command
@@ -0,0 +1,291 @@
+#!/bin/bash
+
+#========================================================
+# System Required: macOS 10.13+
+# Description: Nezha Agent Install Script (macOS)
+# Github: https://github.com/naiba/nezha
+#========================================================
+
+NZ_BASE_PATH="/opt/nezha"
+NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
+
+red='\033[0;31m'
+green='\033[0;32m'
+yellow='\033[0;33m'
+plain='\033[0m'
+export PATH=$PATH:/usr/local/bin
+
+pre_check() {
+ # check root
+ [[ $EUID -ne 0 ]] && echo -e "${red}ERROR: ${plain} This script must be run with the root user!\n" && exit 1
+
+ ## os_arch
+ if [[ $(uname -m | grep 'x86_64') != "" ]]; then
+ os_arch="amd64"
+ elif [[ $(uname -m | grep 'arm64\|arm64e') != "" ]]; then
+ os_arch="arm64"
+ fi
+
+ ## China_IP
+ if [[ -z "${CN}" ]]; then
+ if [[ $(curl -m 10 -s https://ipapi.co/json | grep 'China') != "" ]]; then
+ echo "According to the information provided by ipapi.co, the current IP may be in China"
+ read -e -r -p "Is the installation done with a Chinese Mirror? [Y/n] (Custom Mirror Input 3):" input
+ case $input in
+ [yY][eE][sS] | [yY])
+ echo "Use Chinese Mirror"
+ CN=true
+ ;;
+
+ [nN][oO] | [nN])
+ echo "No Use Chinese Mirror"
+ ;;
+
+ [3])
+ echo "Use Custom Mirror"
+ read -e -r -p "Please enter a custom image (e.g. :dn-dao-github-mirror.daocloud.io), leave blank to nouse: " input
+ case $input in
+ *)
+ CUSTOM_MIRROR=$input
+ ;;
+ esac
+
+ ;;
+ *)
+ echo "No Use Chinese Mirror"
+ ;;
+ esac
+ fi
+ fi
+
+ if [[ -n "${CUSTOM_MIRROR}" ]]; then
+ GITHUB_RAW_URL="gitee.com/naibahq/nezha/raw/master"
+ GITHUB_URL=$CUSTOM_MIRROR
+ else
+ if [[ -z "${CN}" ]]; then
+ GITHUB_RAW_URL="raw.githubusercontent.com/naiba/nezha/master"
+ GITHUB_URL="github.com"
+ Get_Docker_URL="get.docker.com"
+ Get_Docker_Argu=" "
+ Docker_IMG="ghcr.io\/naiba\/nezha-dashboard"
+ else
+ GITHUB_RAW_URL="gitee.com/naibahq/nezha/raw/master"
+ GITHUB_URL="github.com"
+ Get_Docker_URL="get.docker.com"
+ Get_Docker_Argu=" -s docker --mirror Aliyun"
+ Docker_IMG="registry.cn-shanghai.aliyuncs.com\/naibahq\/nezha-dashboard"
+ fi
+ fi
+}
+
+before_show_menu() {
+ echo && echo -n -e "${yellow}* Press Enter to return to the main menu *${plain}" && read temp
+ show_menu
+}
+
+install_agent() {
+ echo -e "> Install Nezha Agent"
+
+ echo -e "Obtaining Agent version"
+
+ 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 "Fail to obtaine agent version, please check if the network can link https://api.github.com/repos/nezhahq/agent/releases/latest"
+ return 0
+ else
+ echo -e "The current latest version is: ${version}"
+ fi
+
+ # Nezha Agent Folder
+ mkdir -p $NZ_AGENT_PATH
+ chmod -R 777 $NZ_AGENT_PATH
+
+ echo -e "Downloading Agent"
+ curl -o nezha-agent_darwin_${os_arch}.zip -L -f --retry 2 --retry-max-time 60 https://${GITHUB_URL}/nezhahq/agent/releases/download/${version}/nezha-agent_darwin_${os_arch}.zip >/dev/null 2>&1
+ if [[ $? != 0 ]]; then
+ echo -e "${red}Fail to download agent, please check if the network can link ${GITHUB_URL}${plain}"
+ return 0
+ fi
+
+ unzip -qo nezha-agent_darwin_${os_arch}.zip &&
+ mv nezha-agent $NZ_AGENT_PATH &&
+ rm -rf nezha-agent_darwin_${os_arch}.zip README.md
+
+ if [ $# -ge 3 ]; then
+ modify_agent_config "$@"
+ else
+ modify_agent_config 0
+ fi
+
+ if [[ $# == 0 ]]; then
+ before_show_menu
+ fi
+}
+
+modify_agent_config() {
+ echo -e "> Modify Agent Configuration"
+
+ if [ $# -lt 3 ]; then
+ echo "Please add Agent in the admin panel first, record the secret" &&
+ read -ep "Please enter a domain that resolves to the IP where the panel is located (no CDN sets): " nz_grpc_host &&
+ read -ep "Please enter the panel RPC port (default 5555): " nz_grpc_port &&
+ read -ep "Please enter the Agent secret: " nz_client_secret &&
+ read -ep "Do you want to enable SSL/TLS encryption for the gRPC port (--tls)? Press [y] if yes, the default is not required, and users can press Enter to skip if you don't understand: " nz_grpc_proxy
+ grep -qiw 'Y' <<<"${nz_grpc_proxy}" && args='--tls'
+ if [[ -z "${nz_grpc_host}" || -z "${nz_client_secret}" ]]; then
+ echo -e "${red}All options cannot be empty${plain}"
+ before_show_menu
+ return 1
+ fi
+ if [[ -z "${nz_grpc_port}" ]]; then
+ nz_grpc_port=5555
+ fi
+ else
+ nz_grpc_host=$1
+ nz_grpc_port=$2
+ nz_client_secret=$3
+ shift 3
+ if [ $# -gt 0 ]; then
+ args=" $*"
+ fi
+ fi
+
+ ${NZ_AGENT_PATH}/nezha-agent service install -s "$nz_grpc_host:$nz_grpc_port" -p $nz_client_secret $args >/dev/null 2>&1
+
+ if [ $? -ne 0 ]; then
+ ${NZ_AGENT_PATH}/nezha-agent service uninstall >/dev/null 2>&1
+ ${NZ_AGENT_PATH}/nezha-agent service install -s "$nz_grpc_host:$nz_grpc_port" -p $nz_client_secret $args >/dev/null 2>&1
+ fi
+
+ echo -e "Agent configuration ${green} modified successfully, please wait for agent self-restart to take effect${plain}"
+
+ #if [[ $# == 0 ]]; then
+ # before_show_menu
+ #fi
+}
+
+show_agent_log() {
+ echo -e "> > View Agent Log"
+
+ tail -n 10 /var/log/nezha-agent.err.log
+
+ if [[ $# == 0 ]]; then
+ before_show_menu
+ fi
+}
+
+uninstall_agent() {
+ echo -e "> Uninstall Agent"
+
+ ${NZ_AGENT_PATH}/nezha-agent service uninstall
+
+ rm -rf $NZ_AGENT_PATH
+ clean_all
+
+ if [[ $# == 0 ]]; then
+ before_show_menu
+ fi
+}
+
+restart_agent() {
+ echo -e "> Restart Agent"
+
+ ${NZ_AGENT_PATH}/nezha-agent service restart
+
+ if [[ $# == 0 ]]; then
+ before_show_menu
+ fi
+}
+
+clean_all() {
+ if [ -z "$(ls -A ${NZ_BASE_PATH})" ]; then
+ rm -rf ${NZ_BASE_PATH}
+ fi
+}
+
+show_usage() {
+ echo "Nezha Agent Management Script Usage: "
+ echo "--------------------------------------------------------"
+ echo "./nezha.sh install_agent - Install Agent"
+ echo "./nezha.sh modify_agent_config - Modify Agent Configuration"
+ echo "./nezha.sh show_agent_log - View Agent Log"
+ echo "./nezha.sh uninstall_agent - Uninstall Agent"
+ echo "./nezha.sh restart_agent - Restart Agent"
+ echo "./nezha.sh update_script - Update Script"
+ echo "--------------------------------------------------------"
+}
+
+show_menu() {
+ echo -e "
+ ${green}Nezha Agent Management Script${plain} ${red}macOS${plain}
+ --- https://github.com/naiba/nezha ---
+ ${green}1.${plain} Install Agent
+ ${green}2.${plain} Modify Agent Configuration
+ ${green}3.${plain} View Agent Log
+ ${green}4.${plain} Uninstall Agent
+ ${green}5.${plain} Restart Agent
+ ————————————————-
+ ${green}0.${plain} Exit Script
+ "
+ echo && read -ep "Please enter [0-5]: " num
+ case "${num}" in
+ 0)
+ exit 0
+ ;;
+ 1)
+ install_agent
+ ;;
+ 2)
+ modify_agent_config
+ ;;
+ 3)
+ show_agent_log
+ ;;
+ 4)
+ uninstall_agent
+ ;;
+ 5)
+ restart_agent
+ ;;
+ *)
+ echo -e "${red}Please enter the correct number [0-5]${plain}"
+ ;;
+ esac
+}
+
+pre_check
+
+if [[ $# > 0 ]]; then
+ case $1 in
+ "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
+ ;;
+ *) show_usage ;;
+ esac
+else
+ show_menu
+fi
\ No newline at end of file
diff --git a/script/install.ps1 b/script/install.ps1
index bab6b157f6..414a30cec1 100644
--- a/script/install.ps1
+++ b/script/install.ps1
@@ -7,64 +7,69 @@ if($PSVersionTable.PSVersion.Major -lt 5){
exit
}
$agentrepo = "nezhahq/agent"
-$nssmrepo = "nezhahq/nssm-backup"
-# x86 or x64
+# x86 or x64 or arm64
if ([System.Environment]::Is64BitOperatingSystem) {
- $file = "nezha-agent_windows_amd64.zip"
+ if ($env:PROCESSOR_ARCHITECTURE -eq "ARM64") {
+ $file = "nezha-agent_windows_arm64.zip"
+ } else {
+ $file = "nezha-agent_windows_amd64.zip"
+ }
}
else {
$file = "nezha-agent_windows_386.zip"
}
$agentreleases = "https://api.github.com/repos/$agentrepo/releases"
-$nssmreleases = "https://api.github.com/repos/$nssmrepo/releases"
#重复运行自动更新
-if (Test-Path "C:\nezha") {
+if (Test-Path "C:\nezha\nezha-agent.exe") {
Write-Host "Nezha monitoring already exists, delete and reinstall" -BackgroundColor DarkGreen -ForegroundColor White
- C:/nezha/nssm.exe stop nezha
- C:/nezha/nssm.exe remove nezha
+ C:\nezha\nezha-agent.exe service uninstall
Remove-Item "C:\nezha" -Recurse
}
#TLS/SSL
Write-Host "Determining latest nezha release" -BackgroundColor DarkGreen -ForegroundColor White
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
$agenttag = (Invoke-WebRequest -Uri $agentreleases -UseBasicParsing | ConvertFrom-Json)[0].tag_name
-$nssmtag = (Invoke-WebRequest -Uri $nssmreleases -UseBasicParsing | ConvertFrom-Json)[0].tag_name
+if ([string]::IsNullOrWhiteSpace($agenttag)) {
+ $optionUrl = "https://fastly.jsdelivr.net/gh/nezhahq/agent/"
+ Try {
+ $response = Invoke-WebRequest -Uri $optionUrl -UseBasicParsing -TimeoutSec 10
+ if ($response.StatusCode -eq 200) {
+ $versiontext = $response.Content | findstr /c:"option.value"
+ $version = [regex]::Match($versiontext, "@(\d+\.\d+\.\d+)").Groups[1].Value
+ $agenttag = "v" + $version
+ }
+ } Catch {
+ $optionUrl = "https://gcore.jsdelivr.net/gh/nezhahq/agent/"
+ $response = Invoke-WebRequest -Uri $optionUrl -UseBasicParsing -TimeoutSec 10
+ if ($response.StatusCode -eq 200) {
+ $versiontext = $response.Content | findstr /c:"option.value"
+ $version = [regex]::Match($versiontext, "@(\d+\.\d+\.\d+)").Groups[1].Value
+ $agenttag = "v" + $version
+ }
+ }
+}
#Region判断
$ipapi= Invoke-RestMethod -Uri "https://api.myip.com/" -UserAgent "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.163 Safari/535.1"
$region=$ipapi.cc
echo $ipapi
if($region -ne "CN"){
$download = "https://github.com/$agentrepo/releases/download/$agenttag/$file"
-$nssmdownload="https://github.com/$nssmrepo/releases/download/$nssmtag/nssm.zip"
Write-Host "Location:$region,connect directly!" -BackgroundColor DarkRed -ForegroundColor Green
}else{
$download = "https://github.com/$agentrepo/releases/download/$agenttag/$file"
-$nssmdownload="https://github.com/$nssmrepo/releases/download/$nssmtag/nssm.zip"
Write-Host "Location:CN,use mirror address" -BackgroundColor DarkRed -ForegroundColor Green
}
echo $download
-echo $nssmdownload
Invoke-WebRequest $download -OutFile "C:\nezha.zip"
-#使用nssm安装服务
-Invoke-WebRequest $nssmdownload -OutFile "C:\nssm.zip"
#解压
Expand-Archive "C:\nezha.zip" -DestinationPath "C:\temp" -Force
-Expand-Archive "C:\nssm.zip" -DestinationPath "C:\temp" -Force
if (!(Test-Path "C:\nezha")) { New-Item -Path "C:\nezha" -type directory }
#整理文件
Move-Item -Path "C:\temp\nezha-agent.exe" -Destination "C:\nezha\nezha-agent.exe"
-if ($file = "nezha-agent_windows_amd64.zip") {
- Move-Item -Path "C:\temp\nssm-2.24\win64\nssm.exe" -Destination "C:\nezha\nssm.exe"
-}
-else {
- Move-Item -Path "C:\temp\nssm-2.24\win32\nssm.exe" -Destination "C:\nezha\nssm.exe"
-}
#清理垃圾
Remove-Item "C:\nezha.zip"
-Remove-Item "C:\nssm.zip"
Remove-Item "C:\temp" -Recurse
#安装部分
-C:\nezha\nssm.exe install nezha C:\nezha\nezha-agent.exe -s $server -p $key $tls -d
-C:\nezha\nssm.exe start nezha
+C:\nezha\nezha-agent.exe service install -s $server -p $key $tls
#enjoy
-Write-Host "Enjoy It!" -BackgroundColor DarkGreen -ForegroundColor Red
+Write-Host "Enjoy It!" -BackgroundColor DarkGreen -ForegroundColor Red
\ No newline at end of file
diff --git a/script/install.sh b/script/install.sh
index fda3b70cff..146a415af7 100755
--- a/script/install.sh
+++ b/script/install.sh
@@ -10,11 +10,9 @@
NZ_BASE_PATH="/opt/nezha"
NZ_DASHBOARD_PATH="${NZ_BASE_PATH}/dashboard"
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
-NZ_AGENT_SERVICE="/etc/systemd/system/nezha-agent.service"
-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.16.2"
+NZ_VERSION="v0.16.3"
red='\033[0;31m'
green='\033[0;32m'
@@ -359,21 +357,6 @@ install_agent() {
modify_agent_config() {
echo -e "> 修改Agent配置"
- if [ "$os_alpine" != 1 ]; then
- wget -t 2 -T 60 -O $NZ_AGENT_SERVICE https://${GITHUB_RAW_URL}/script/nezha-agent.service >/dev/null 2>&1
- if [[ $? != 0 ]]; then
- echo -e "${red}文件下载失败,请检查本机能否连接 ${GITHUB_RAW_URL}${plain}"
- return 0
- fi
- else
- wget -t 2 -T 60 -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
-
if [ $# -lt 3 ]; then
echo "请先在管理面板上添加Agent,记录下密钥" &&
read -ep "请输入一个解析到面板所在IP的域名(不可套CDN): " nz_grpc_host &&
@@ -399,28 +382,14 @@ modify_agent_config() {
fi
fi
- if [ "$os_alpine" != 1 ]; then
- sed -i "s/nz_grpc_host/${nz_grpc_host}/" ${NZ_AGENT_SERVICE}
- sed -i "s/nz_grpc_port/${nz_grpc_port}/" ${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}
- else
- sed -i "s/nz_grpc_host/${nz_grpc_host}/" ${NZ_AGENT_SERVICERC}
- 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
-
- echo -e "Agent配置 ${green}修改成功,请稍等重启生效${plain}"
+ ${NZ_AGENT_PATH}/nezha-agent service install -s "$nz_grpc_host:$nz_grpc_port" -p $nz_client_secret $args >/dev/null 2>&1
- if [ "$os_alpine" != 1 ]; then
- systemctl daemon-reload
- systemctl enable nezha-agent
- systemctl restart nezha-agent
- else
- rc-update add nezha-agent
- rc-service nezha-agent restart
+ if [ $? -ne 0 ]; then
+ ${NZ_AGENT_PATH}/nezha-agent service uninstall >/dev/null 2>&1
+ ${NZ_AGENT_PATH}/nezha-agent service install -s "$nz_grpc_host:$nz_grpc_port" -p $nz_client_secret $args >/dev/null 2>&1
fi
+
+ echo -e "Agent配置 ${green}修改成功,请稍等重启生效${plain}"
#if [[ $# == 0 ]]; then
# before_show_menu
@@ -709,16 +678,7 @@ show_agent_log() {
uninstall_agent() {
echo -e "> 卸载Agent"
- if [ "$os_alpine" != 1 ]; then
- systemctl disable nezha-agent.service
- systemctl stop nezha-agent.service
- rm -rf $NZ_AGENT_SERVICE
- systemctl daemon-reload
- else
- rc-update del nezha-agent
- rc-service nezha-agent stop
- rm -rf $NZ_AGENT_SERVICERC
- fi
+ ${NZ_AGENT_PATH}/nezha-agent service uninstall
rm -rf $NZ_AGENT_PATH
clean_all
@@ -731,11 +691,7 @@ uninstall_agent() {
restart_agent() {
echo -e "> 重启Agent"
- if [ "$os_alpine" != 1 ]; then
- systemctl restart nezha-agent.service
- else
- rc-service nezha-agent restart
- fi
+ ${NZ_AGENT_PATH}/nezha-agent service restart
if [[ $# == 0 ]]; then
before_show_menu
diff --git a/script/install_en.sh b/script/install_en.sh
index b0c601f901..389145de65 100755
--- a/script/install_en.sh
+++ b/script/install_en.sh
@@ -10,11 +10,9 @@
NZ_BASE_PATH="/opt/nezha"
NZ_DASHBOARD_PATH="${NZ_BASE_PATH}/dashboard"
NZ_AGENT_PATH="${NZ_BASE_PATH}/agent"
-NZ_AGENT_SERVICE="/etc/systemd/system/nezha-agent.service"
-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.16.2"
+NZ_VERSION="v0.16.3"
red='\033[0;31m'
green='\033[0;32m'
@@ -355,21 +353,6 @@ install_agent() {
modify_agent_config() {
echo -e "> Modify Agent Configuration"
- if [ "$os_alpine" != 1 ]; then
- wget -t 2 -T 60 -O $NZ_AGENT_SERVICE https://${GITHUB_RAW_URL}/script/nezha-agent.service >/dev/null 2>&1
- if [[ $? != 0 ]]; then
- echo -e "${red}Fail to download service, please check if the network can link ${GITHUB_RAW_URL}${plain}"
- return 0
- fi
- else
- wget -t 2 -T 60 -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
-
if [ $# -lt 3 ]; then
echo "Please add Agent in the admin panel first, record the secret" &&
read -ep "Please enter a domain that resolves to the IP where the panel is located (no CDN sets): " nz_grpc_host &&
@@ -395,29 +378,15 @@ modify_agent_config() {
fi
fi
- if [ "$os_alpine" != 1 ]; then
- sed -i "s/nz_grpc_host/${nz_grpc_host}/" ${NZ_AGENT_SERVICE}
- sed -i "s/nz_grpc_port/${nz_grpc_port}/" ${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}
- else
- sed -i "s/nz_grpc_host/${nz_grpc_host}/" ${NZ_AGENT_SERVICERC}
- 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}
+ ${NZ_AGENT_PATH}/nezha-agent service install -s "$nz_grpc_host:$nz_grpc_port" -p $nz_client_secret $args >/dev/null 2>&1
+
+ if [ $? -ne 0 ]; then
+ ${NZ_AGENT_PATH}/nezha-agent service uninstall >/dev/null 2>&1
+ ${NZ_AGENT_PATH}/nezha-agent service install -s "$nz_grpc_host:$nz_grpc_port" -p $nz_client_secret $args >/dev/null 2>&1
fi
echo -e "Agent configuration ${green} modified successfully, please wait for agent self-restart to take effect${plain}"
- if [ "$os_alpine" != 1 ]; then
- systemctl daemon-reload
- systemctl enable nezha-agent
- systemctl restart nezha-agent
- else
- rc-update add nezha-agent
- rc-service nezha-agent restart
- fi
-
#if [[ $# == 0 ]]; then
# before_show_menu
#fi
@@ -705,16 +674,7 @@ show_agent_log() {
uninstall_agent() {
echo -e "> Uninstall Agent"
- if [ "$os_alpine" != 1 ]; then
- systemctl disable nezha-agent.service
- systemctl stop nezha-agent.service
- rm -rf $NZ_AGENT_SERVICE
- systemctl daemon-reload
- else
- rc-update del nezha-agent
- rc-service nezha-agent stop
- rm -rf $NZ_AGENT_SERVICERC
- fi
+ ${NZ_AGENT_PATH}/nezha-agent service uninstall
rm -rf $NZ_AGENT_PATH
clean_all
@@ -727,11 +687,7 @@ uninstall_agent() {
restart_agent() {
echo -e "> Restart Agent"
- if [ "$os_alpine" != 1 ]; then
- systemctl restart nezha-agent.service
- else
- rc-service nezha-agent restart
- fi
+ ${NZ_AGENT_PATH}/nezha-agent service restart
if [[ $# == 0 ]]; then
before_show_menu
diff --git a/script/nezha-agent b/script/nezha-agent
deleted file mode 100755
index 665bfac201..0000000000
--- a/script/nezha-agent
+++ /dev/null
@@ -1,19 +0,0 @@
-#!/sbin/openrc-run
-supervisor=supervise-daemon
-name=nezha-agent
-output_log=/var/log/${name}.log
-error_log=/var/log/${name}.err
-SERVER="nz_grpc_host:nz_grpc_port" #Dashboard 地址 ip:port
-SECRET="nz_client_secret" #SECRET
-pidfile="/run/${RC_SVCNAME}.pid"
-command="/opt/nezha/agent/nezha-agent"
-command_args="-s ${SERVER} -p ${SECRET}"
-command_background=true
-
-depend() {
- need net
-}
-
-start_pre() {
- checkpath -f -m 0644 -o root:root "/var/log/${name}.log"
-}
diff --git a/script/nezha-agent.service b/script/nezha-agent.service
deleted file mode 100644
index ee2d5dc006..0000000000
--- a/script/nezha-agent.service
+++ /dev/null
@@ -1,30 +0,0 @@
-[Unit]
-Description=Nezha Agent
-After=syslog.target
-#After=network.target
-#After=nezha-dashboard.service
-
-[Service]
-# Modify these two values and uncomment them if you have
-# repos with lots of files and get an HTTP error 500 because
-# of that
-###
-#LimitMEMLOCK=infinity
-#LimitNOFILE=65535
-Type=simple
-User=root
-Group=root
-WorkingDirectory=/opt/nezha/agent/
-ExecStart=/opt/nezha/agent/nezha-agent -s nz_grpc_host:nz_grpc_port -p nz_client_secret
-Restart=always
-#Environment=DEBUG=true
-
-# Some distributions may not support these hardening directives. If you cannot start the service due
-# to an unknown option, comment out the ones not supported by your version of systemd.
-#ProtectSystem=full
-#PrivateDevices=yes
-#PrivateTmp=yes
-#NoNewPrivileges=true
-
-[Install]
-WantedBy=multi-user.target
\ No newline at end of file
|