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 65a16ec..53ef9ae 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@
LOGO designed by 熊大 .

-GitHub release (with filter)    +GitHub release (with filter)   

: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 dd3f417..0d04ce8 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 0000000..71ffbe9 --- /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 bab6b15..414a30c 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 fda3b70..146a415 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,29 +382,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} - 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配置 ${green}修改成功,请稍等重启生效${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 @@ -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 b0c601f..389145d 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 665bfac..0000000 --- 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 ee2d5dc..0000000 --- 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