[ 项目 ] 修改CI CD流程 - 4
This commit is contained in:
@@ -10,7 +10,7 @@ spring:
|
|||||||
port: 20672
|
port: 20672
|
||||||
username: boge
|
username: boge
|
||||||
password: boge8tingH
|
password: boge8tingH
|
||||||
virtual-host: /wdd
|
virtual-host: /
|
||||||
listener:
|
listener:
|
||||||
simple:
|
simple:
|
||||||
retry:
|
retry:
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ DependLibFiles=(
|
|||||||
)
|
)
|
||||||
|
|
||||||
OctopusAgentUrl=https://happybirthday.107421.xyz/octopus-agent/
|
OctopusAgentUrl=https://happybirthday.107421.xyz/octopus-agent/
|
||||||
|
AgentConfigUrl=https://happybirthday.107421.xyz/agent-config/
|
||||||
RepoSourcePath=https://happybirthday.107421.xyz/shell
|
RepoSourcePath=https://happybirthday.107421.xyz/shell
|
||||||
OctopusAgentPath=/octopus-agent/shell
|
OctopusAgentPath=/octopus-agent/shell
|
||||||
##### environment variables ######
|
##### environment variables ######
|
||||||
@@ -261,38 +261,61 @@ DownloadAllFile() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# description
|
||||||
|
# Globals:
|
||||||
|
# AgentConfigUrl
|
||||||
|
# BLUE
|
||||||
|
# GREEN
|
||||||
|
# LinuxRelease
|
||||||
|
# OctopusAgentUrl
|
||||||
|
# agentConfig
|
||||||
|
# agentConfigFileList
|
||||||
|
# Arguments:
|
||||||
|
# None
|
||||||
|
#######################################
|
||||||
CheckAndDownloadLatestVersion() {
|
CheckAndDownloadLatestVersion() {
|
||||||
FunctionStart
|
FunctionStart
|
||||||
|
|
||||||
colorEcho $BLUE "checking for the latest version"
|
colorEcho $BLUE "checking for the latest version"
|
||||||
local latestVersion=$(curl $OctopusAgentUrl | grep -v h1 | grep "a href=" | head -1 | awk '{print$2}' | cut -d">" -f2 | cut -d"<" -f1 | cut -d"_" -f4-)
|
local latestVersion=$(curl $OctopusAgentUrl | grep -v h1 | grep "a href=" | head -1 | awk '{print$2}' | cut -d">" -f2 | cut -d"<" -f1 | cut -d"_" -f4-)
|
||||||
|
|
||||||
|
|
||||||
rm -rf /octopus-agent/octopus-agent*
|
rm -rf /octopus-agent/octopus-agent*
|
||||||
cd /octopus-agent
|
cd /octopus-agent
|
||||||
|
|
||||||
colorEcho $BLUE "start to download the latest version !"
|
colorEcho $BLUE "start to download the latest version !"
|
||||||
|
|
||||||
# Agent二进制文件的命名规则为 octopus-agent_linux_amd64_<version>
|
# Agent二进制文件的命名规则为 octopus-agent_linux_amd64_<version>
|
||||||
local latestAgentVersion="octopus-agent_linux_${LinuxRelease}_${latestVersion}"
|
local latestAgentVersion="octopus-agent_linux_${LinuxRelease}_${latestVersion}"
|
||||||
colorEcho $BLUE ""
|
colorEcho $BLUE ""
|
||||||
colorEcho $BLUE "octopus agent latest version is => [ $latestAgentVersion ]"
|
colorEcho $BLUE "octopus agent latest version is => [ $latestAgentVersion ]"
|
||||||
colorEcho $BLUE ""
|
colorEcho $BLUE ""
|
||||||
|
|
||||||
wget -q "$OctopusAgentUrl$latestAgentVersion"
|
wget -q "$OctopusAgentUrl$latestAgentVersion"
|
||||||
cp "$latestAgentVersion" octopus-agent
|
cp "$latestAgentVersion" octopus-agent
|
||||||
chmod +x octopus-agent
|
chmod +x octopus-agent
|
||||||
echo ""
|
echo ""
|
||||||
echo ""
|
|
||||||
colorEcho $GREEN "---------------- ls the /octopus-agent ----------------------"
|
colorEcho $GREEN "---------------- ls the /octopus-agent ----------------------"
|
||||||
ls /octopus-agent/ | grep octopus-agent
|
ls /octopus-agent/ | grep octopus-agent
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
colorEcho $BLUE "start to download the agent config!"
|
||||||
|
agentConfigFileList=$(curl $AgentConfigUrl | grep -v h1 | grep "a href=" | awk '{print$2}' | cut -d">" -f2 | cut -d"<" -f1 | cut -d"_" -f4-)
|
||||||
|
|
||||||
|
for agentConfig in "${agentConfigFileList[@]}"; do
|
||||||
|
colorEcho $BLUE "agent config file is => $agentConfig"
|
||||||
|
wget -q "$AgentConfigUrl$agentConfig"
|
||||||
|
echo ""
|
||||||
|
done
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
colorEcho $GREEN "---------------- ls the /octopus-agent ----------------------"
|
||||||
|
ls /octopus-agent/ | grep ".yaml"
|
||||||
|
echo ""
|
||||||
|
|
||||||
FunctionSuccess
|
FunctionSuccess
|
||||||
FunctionEnd
|
FunctionEnd
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# description
|
# description
|
||||||
# Globals:
|
# Globals:
|
||||||
@@ -391,7 +414,6 @@ ExecStop=/bin/kill -15 \$MAINPID
|
|||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
|
||||||
colorEcho ${BLUE} "开始配置Agent日志输出文件!"
|
colorEcho ${BLUE} "开始配置Agent日志输出文件!"
|
||||||
# https://www.benzhu.xyz/linux12/
|
# https://www.benzhu.xyz/linux12/
|
||||||
cat >/etc/rsyslog.d/octopus-agent.conf <<EOF
|
cat >/etc/rsyslog.d/octopus-agent.conf <<EOF
|
||||||
@@ -635,7 +657,7 @@ CleanOldOctopusAgent() {
|
|||||||
|
|
||||||
colorEcho $BLUE "start to kill old octopus-agent"
|
colorEcho $BLUE "start to kill old octopus-agent"
|
||||||
|
|
||||||
agentPid=$(ps -ef | grep -v "color="| grep -c "octopus-agent")
|
agentPid=$(ps -ef | grep -v "color=" | grep -c "octopus-agent")
|
||||||
if [[ $agentPid -gt 0 ]]; then
|
if [[ $agentPid -gt 0 ]]; then
|
||||||
colorEcho $BLUE "old agent existed ! start to kill"
|
colorEcho $BLUE "old agent existed ! start to kill"
|
||||||
colorEcho $BLUE "old agent existed ! start to kill"
|
colorEcho $BLUE "old agent existed ! start to kill"
|
||||||
@@ -645,9 +667,7 @@ CleanOldOctopusAgent() {
|
|||||||
|
|
||||||
rm -rf /etc/systemd/system/octopus-agent.service
|
rm -rf /etc/systemd/system/octopus-agent.service
|
||||||
|
|
||||||
fi
|
fi FunctionSuccess
|
||||||
|
|
||||||
FunctionSuccess
|
|
||||||
FunctionEnd
|
FunctionEnd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -34,10 +34,14 @@ agentVersion=""
|
|||||||
### tmp usage
|
### tmp usage
|
||||||
ioavg=""
|
ioavg=""
|
||||||
public_ipv4=""
|
public_ipv4=""
|
||||||
|
inner_ipv4=""
|
||||||
|
public_ipv6=""
|
||||||
|
inner_ipv6=""
|
||||||
country=""
|
country=""
|
||||||
region=""
|
region=""
|
||||||
city=""
|
city=""
|
||||||
org=""
|
org=""
|
||||||
|
managePort=""
|
||||||
#### CollectSystemInfo ####
|
#### CollectSystemInfo ####
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
@@ -140,6 +144,11 @@ StartIOTest() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# description
|
||||||
|
# Arguments:
|
||||||
|
# None
|
||||||
|
#######################################
|
||||||
GetAgentLatestVersion() {
|
GetAgentLatestVersion() {
|
||||||
|
|
||||||
ls /octopus-agent | grep "octopus-agent" | cut -d "-" -f3- | cut -d"." -f1
|
ls /octopus-agent | grep "octopus-agent" | cut -d "-" -f3- | cut -d"." -f1
|
||||||
@@ -216,6 +225,15 @@ Check_Virtualization() {
|
|||||||
virt="Dedicated"
|
virt="Dedicated"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
}
|
||||||
|
GetManagePort(){
|
||||||
|
|
||||||
|
tmpManagePorts=$(netstat -ntulp | grep sshd | grep -w tcp | grep -v "127.0.0.1"| awk '{print$4}' | cut -d":" -f2)
|
||||||
|
|
||||||
|
managePort=$(echo $tmpManagePorts | tr '\n' ' ')
|
||||||
|
|
||||||
|
log "manage Port is => $managePort"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
@@ -233,6 +251,7 @@ GetIpv4Info() {
|
|||||||
|
|
||||||
log "start to get system public ip info !"
|
log "start to get system public ip info !"
|
||||||
|
|
||||||
|
# public ip info
|
||||||
org="$(wget -q -T10 -O- ipinfo.io/org)"
|
org="$(wget -q -T10 -O- ipinfo.io/org)"
|
||||||
city="$(wget -q -T10 -O- ipinfo.io/city)"
|
city="$(wget -q -T10 -O- ipinfo.io/city)"
|
||||||
country="$(wget -q -T10 -O- ipinfo.io/country)"
|
country="$(wget -q -T10 -O- ipinfo.io/country)"
|
||||||
@@ -240,6 +259,46 @@ GetIpv4Info() {
|
|||||||
public_ipv4="$(wget -q -T10 -O- ipinfo.io/ip)"
|
public_ipv4="$(wget -q -T10 -O- ipinfo.io/ip)"
|
||||||
public_ipv6="$(curl --max-time 5 -6 https://ifconfig.co/ip)"
|
public_ipv6="$(curl --max-time 5 -6 https://ifconfig.co/ip)"
|
||||||
|
|
||||||
|
if [ -z "$public_ipv4" ] ; then
|
||||||
|
public_ipv4=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$public_ipv6" ] ; then
|
||||||
|
public_ipv6=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$public_ipv4" ] ; then
|
||||||
|
public_ipv4=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# inner ipinfo
|
||||||
|
interface_prefix=(" eth[0-9]{1,2}" " ens[0-9]{1,3}" " eno[0-9]{1,3}" " enp[0-9]{1,2}")
|
||||||
|
real_interface="eth90"
|
||||||
|
|
||||||
|
for interface in "${interface_prefix[@]}"; do
|
||||||
|
echo $(ip link show) | grep -oE ${interface}
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
real_interface=$(echo $(ip link show) | grep -oE ${interface} | cut -d" " -f2)
|
||||||
|
echo "当前主机的真实内网网卡为 => $real_interface"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# 提取IPv4地址(CIDR格式)
|
||||||
|
ipv4_regex="inet (25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\/[0-9]{1,2}"
|
||||||
|
|
||||||
|
# 提取IPv6地址(CIDR格式)
|
||||||
|
ipv6_regex="inet6 ([0-9a-fA-F]{0,4}(:[0-9a-fA-F]{0,4}){1,7})\/[0-9]{1,3}"
|
||||||
|
|
||||||
|
# 查找IPv4地址
|
||||||
|
inner_ipv4=$(echo $(ip addr show $real_interface) | grep -oE $ipv4_regex | cut -d" " -f2)
|
||||||
|
echo "Interface: $interface, IPv4 Address: $inner_ipv4"
|
||||||
|
|
||||||
|
# 查找IPv6地址
|
||||||
|
inner_ipv6=$(echo $(ip addr show $real_interface) | grep -oE $ipv6_regex | cut -d" " -f2)
|
||||||
|
echo "Interface: $interface, IPv4 Address: $inner_ipv6"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
log "start to collect system info !"
|
log "start to collect system info !"
|
||||||
@@ -307,6 +366,8 @@ tcpctrl=$(sysctl net.ipv4.tcp_congestion_control | awk -F ' ' '{print $3}')
|
|||||||
# todo
|
# todo
|
||||||
# StartIOTest
|
# StartIOTest
|
||||||
|
|
||||||
|
GetManagePort
|
||||||
|
|
||||||
GetIpv4Info
|
GetIpv4Info
|
||||||
|
|
||||||
Check_Virtualization
|
Check_Virtualization
|
||||||
@@ -318,16 +379,18 @@ if [[ $(cat /etc/hostname | cut -d"-" -f 3 | grep -c '^[0-9][0-9]') -gt 0 ]]; th
|
|||||||
else
|
else
|
||||||
machineNumber=99
|
machineNumber=99
|
||||||
fi
|
fi
|
||||||
|
agentServerInfoFile="/octopus-agent/octopus-agent.conf "
|
||||||
|
|
||||||
#cat >/etc/environment.d/octopus-agent.conf <<EOF
|
#cat >/etc/environment.d/octopus-agent.conf <<EOF
|
||||||
cat >/octopus-agent/octopus-agent.conf <<EOF
|
cat >"$agentServerInfoFile"<<EOF
|
||||||
serverName: ${city}-${hostArch}-${machineNumber}
|
serverName: ${city}-${hostArch}-${machineNumber}
|
||||||
serverIpPbV4: $public_ipv4
|
serverIpPbV4: $public_ipv4
|
||||||
serverIpInV4:
|
serverIpInV4: $inner_ipv4
|
||||||
serverIpPbV6: $public_ipv6
|
serverIpPbV6: $public_ipv6
|
||||||
serverIpInV6:
|
serverIpInV6: $inner_ipv6
|
||||||
location: "$city $region $country"
|
location: "$city $region $country"
|
||||||
provider: $org
|
provider: $org
|
||||||
managePort: $(netstat -ntulp | grep sshd | grep -w tcp | awk '{print$4}' | cut -d":" -f2)
|
managePort: $managePort
|
||||||
cpuCore: "$cores @ $freq MHz"
|
cpuCore: "$cores @ $freq MHz"
|
||||||
cpuBrand: "$cpuName"
|
cpuBrand: "$cpuName"
|
||||||
memoryTotal: $tram
|
memoryTotal: $tram
|
||||||
@@ -340,8 +403,8 @@ tcpControl: $tcpctrl
|
|||||||
virtualization: $virt
|
virtualization: $virt
|
||||||
ioSpeed: "$ioavg MB/s"
|
ioSpeed: "$ioavg MB/s"
|
||||||
machineId: $(cat /etc/machine-id)
|
machineId: $(cat /etc/machine-id)
|
||||||
agentVersion: $(ls /octopus-agent | grep "octopus-agent" | cut -d "-" -f4-)
|
agentVersion: $(ls /octopus-agent | grep "octopus-agent_" | cut -d "_" -f4-)
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
log "agent server info has collect complete!"
|
log "agent server info has collect complete!"
|
||||||
log "file is => /octopus-agent/octopus-agent.conf"
|
log "file is => $agentServerInfoFile"
|
||||||
|
|||||||
Reference in New Issue
Block a user