mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-22 22:03:39 +03:00
B #4793: Rewrite VM disks monitoring
This commit is contained in:
parent
648fe67f15
commit
9baef5c8d6
@ -14,6 +14,11 @@
|
||||
# limitations under the License. #
|
||||
#--------------------------------------------------------------------------- #
|
||||
|
||||
require 'augeas'
|
||||
require 'base64'
|
||||
require 'zlib'
|
||||
require 'socket'
|
||||
|
||||
module OpenNebula
|
||||
|
||||
# Generic log function
|
||||
@ -92,4 +97,61 @@ module OpenNebula
|
||||
log "Executed \"#{command}\"."
|
||||
end
|
||||
|
||||
def self.send_to_monitor(msg_type, result, oid, data)
|
||||
# Read monitord.conf
|
||||
one_location = ENV['ONE_LOCATION']
|
||||
|
||||
if !one_location
|
||||
file_dir = '/etc/one/'
|
||||
else
|
||||
file_dir = one_location + '/etc/'
|
||||
end
|
||||
|
||||
file_name = 'monitord.conf'
|
||||
|
||||
aug = Augeas.create(:no_modl_autoload => true,
|
||||
:no_load => true,
|
||||
:root => file_dir,
|
||||
:loadpath => file_name)
|
||||
|
||||
aug.clear_transforms
|
||||
aug.transform(:lens => 'Oned.lns', :incl => file_name)
|
||||
aug.context = "/files/#{file_name}"
|
||||
aug.load
|
||||
|
||||
mon_address = aug.get('NETWORK/MONITOR_ADDRESS')
|
||||
mon_port = aug.get('NETWORK/PORT')
|
||||
mon_key = aug.get('NETWORK/PUBKEY').tr('"', '')
|
||||
|
||||
mon_address = "127.0.0.1" if mon_address.include? "auto"
|
||||
|
||||
# Encrypt
|
||||
if mon_key && !mon_key.empty?
|
||||
block_size = mon_key.n.num_bytes - 11
|
||||
|
||||
edata = ''
|
||||
index = 0
|
||||
|
||||
loop do
|
||||
break if index >= data.length
|
||||
|
||||
edata << mon_key.public_encrypt(data[index, block_size])
|
||||
|
||||
index += block_size
|
||||
end
|
||||
|
||||
data = edata
|
||||
end
|
||||
|
||||
# Send data
|
||||
zdata = Zlib::Deflate.deflate(data, Zlib::BEST_COMPRESSION)
|
||||
data64 = Base64.strict_encode64(zdata)
|
||||
|
||||
result = "SUCCESS" if result == "0" || result == 0
|
||||
|
||||
msg = "#{msg_type} #{result} #{oid} #{data64}"
|
||||
|
||||
socket_udp = UDPSocket.new()
|
||||
socket_udp.send(msg, 0, mon_address, mon_port)
|
||||
end
|
||||
end
|
||||
|
@ -1039,3 +1039,50 @@ function get_nic_information {
|
||||
OUTBOUND_PEAK_KB="${XPATH_ELEMENTS[j++]}"
|
||||
ORDER="${XPATH_ELEMENTS[j++]}"
|
||||
}
|
||||
|
||||
# Send message to monitor daemon
|
||||
# This function reads monitor network and encryption settings from monitord.conf,
|
||||
# packs and optionally encrypt the message and sends it to monitor daemon
|
||||
# Parameters
|
||||
# $1 Message type: MONITOR_VM, BEACON_HOST, MONITOR_HOST, SYSTEM_HOST, STATE_VM, LOG, ...
|
||||
# $2 Result of the operation:
|
||||
# 0 or "SUCCESS" means succesful monitoring
|
||||
# everything else is failure
|
||||
# $3 Object ID, use -1 if not relevant
|
||||
# $4 Message payload (the monitoring data)
|
||||
function send_to_monitor {
|
||||
msg_type="$1"
|
||||
msg_result="$2"
|
||||
msg_oid="$3"
|
||||
msg_payload="$4"
|
||||
|
||||
if [ "$msg_result" = "0" ]; then
|
||||
msg_result=SUCCESS
|
||||
fi
|
||||
|
||||
# Read monitord config
|
||||
if [ -z "${ONE_LOCATION}" ]; then
|
||||
mon_conf=/etc/one/monitord.conf
|
||||
else
|
||||
mon_conf=$ONE_LOCATION/etc/monitord.conf
|
||||
fi
|
||||
|
||||
mon_config=$(augtool -L -l $mon_conf ls /files/$mon_conf/NETWORK)
|
||||
mon_address=$(echo "$mon_config" | grep MONITOR_ADDRESS | awk '{print $3}')
|
||||
mon_port=$(echo "$mon_config" | grep PORT | awk '{print $3}')
|
||||
mon_key=$(echo "$mon_config" | grep PUBKEY | awk '{print $3}')
|
||||
|
||||
if [[ $mon_address == *"auto"* ]]; then
|
||||
mon_address="127.0.0.1"
|
||||
fi
|
||||
|
||||
# Send message
|
||||
# todo if mon_key is not empty do message encryption
|
||||
|
||||
payload_b64="$(echo $msg_payload | \
|
||||
ruby -e "require 'zlib'; puts Zlib::Deflate.deflate(STDIN.read)" | \
|
||||
base64 -w 0)"
|
||||
|
||||
echo "$msg_type $msg_result $msg_oid $payload_b64" |
|
||||
nc -u -w1 $mon_address $mon_port
|
||||
}
|
@ -155,7 +155,10 @@ void MonitorDriverProtocol::_beacon_host(message_t msg)
|
||||
NebulaLog::warn("MDP", "Error condition detected on beacon for host "
|
||||
+ to_string(msg->oid()) + ": " + msg->payload());
|
||||
|
||||
hm->error_monitor(msg->oid(), msg->payload());
|
||||
if (msg->oid() >= 0)
|
||||
{
|
||||
hm->error_monitor(msg->oid(), msg->payload());
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -75,49 +75,48 @@ echo "USED_MB=\$USED_MB"
|
||||
echo "FREE_MB=\$FREE_MB"
|
||||
echo "TOTAL_MB=\$TOTAL_MB"
|
||||
|
||||
if [ $MONITOR_VM_DISKS -eq 1 ]; then
|
||||
vms=\$(ls "$BASE_PATH" | grep '^[0-9]\+$')
|
||||
EOF
|
||||
)
|
||||
|
||||
monitor=""
|
||||
MONITOR_VM_SCRIPT=$(cat <<EOF
|
||||
|
||||
for vm in \$vms; do
|
||||
vmdir="${BASE_PATH}/\${vm}"
|
||||
disks=\$(ls "\$vmdir" 2>/dev/null | grep '^disk\.[0-9]\+$')
|
||||
vms=\$(ls "$BASE_PATH" | grep '^[0-9]\+$')
|
||||
|
||||
[ -z \$disks ] && continue
|
||||
monitor=""
|
||||
|
||||
vm_monitor=""
|
||||
for vm in \$vms; do
|
||||
vmdir="${BASE_PATH}/\${vm}"
|
||||
disks=\$(ls "\$vmdir" 2>/dev/null | grep '^disk\.[0-9]\+$')
|
||||
|
||||
for disk in \$disks; do
|
||||
disk_id="\$(echo "\$disk" | cut -d. -f2)"
|
||||
disk_size="\$(du -mL "\${vmdir}/\${disk}" 2>/dev/null | awk '{print \$1}')"
|
||||
snap_dir="\${vmdir}/\${disk}.snap"
|
||||
[ -z \$disks ] && continue
|
||||
|
||||
[ -z "\$disk_size" ] && continue
|
||||
vm_monitor=""
|
||||
|
||||
vm_monitor="\${vm_monitor} DISK_SIZE = [ ID=\${disk_id}, SIZE=\${disk_size}]"
|
||||
for disk in \$disks; do
|
||||
disk_id="\$(echo "\$disk" | cut -d. -f2)"
|
||||
disk_size="\$(du -mL "\${vmdir}/\${disk}" 2>/dev/null | awk '{print \$1}')"
|
||||
snap_dir="\${vmdir}/\${disk}.snap"
|
||||
|
||||
if [ -e "\$snap_dir" ]; then
|
||||
snaps="\$(ls "\$snap_dir" 2>/dev/null | grep '^[0-9]$')"
|
||||
[ -z "\$disk_size" ] && continue
|
||||
|
||||
for snap in \$snaps; do
|
||||
snap_size="\$(du -mL "\${snap_dir}/\${snap}" 2>/dev/null | awk '{print \$1}')"
|
||||
[ -z "\$snap_size" ] && continue
|
||||
vm_monitor="\${vm_monitor} DISK_SIZE = [ ID=\${disk_id}, SIZE=\${disk_size}]"
|
||||
|
||||
vm_monitor="\${vm_monitor}\nSNAPSHOT_SIZE = "\
|
||||
"[ ID=\${snap}, DISK_ID=\${disk_id}, SIZE=\${snap_size}]"
|
||||
done
|
||||
fi
|
||||
done
|
||||
if [ -e "\$snap_dir" ]; then
|
||||
snaps="\$(ls "\$snap_dir" 2>/dev/null | grep '^[0-9]$')"
|
||||
|
||||
vm_monitor_b64="\$(echo \$vm_monitor | base64 -w 0)"
|
||||
monitor="\${monitor}VM=[ID=\$vm,MONITOR=\"\$vm_monitor_b64\"] "
|
||||
for snap in \$snaps; do
|
||||
snap_size="\$(du -mL "\${snap_dir}/\${snap}" 2>/dev/null | awk '{print \$1}')"
|
||||
[ -z "\$snap_size" ] && continue
|
||||
|
||||
vm_monitor="\${vm_monitor}\nSNAPSHOT_SIZE = "\
|
||||
"[ ID=\${snap}, DISK_ID=\${disk_id}, SIZE=\${snap_size}]"
|
||||
done
|
||||
fi
|
||||
done
|
||||
|
||||
monitor_b64="\$(echo \$monitor | ruby -e "require 'zlib';\
|
||||
puts Zlib::Deflate.deflate(STDIN.read)" | base64 -w 0)"
|
||||
echo MONITOR_VM SUCCESS 0 \$monitor_b64 | nc -u -w0 127.0.0.1 4124
|
||||
fi
|
||||
vm_monitor_b64="\$(echo \$vm_monitor | base64 -w 0)"
|
||||
echo "VM=[ID=\$vm, MONITOR=\"\$vm_monitor_b64\"] "
|
||||
done
|
||||
|
||||
EOF
|
||||
)
|
||||
@ -125,16 +124,26 @@ EOF
|
||||
if [ -n "$BRIDGE_LIST" ]; then
|
||||
HOST=`get_destination_host`
|
||||
MONITOR_DATA=$(ssh_monitor_and_log "$HOST" "$MONITOR_SCRIPT" "Remote monitor script" 2>&1)
|
||||
MONITOR_STATUS=$?
|
||||
|
||||
if [ $MONITOR_VM_DISKS -eq 1 ]; then
|
||||
MONITOR_DATA_VMS=$(ssh_monitor_and_log "$HOST" "$MONITOR_VM_SCRIPT" "Remote VM disks monitor script" 2>&1)
|
||||
MONITOR_VMS_STATUS=$?
|
||||
fi
|
||||
else
|
||||
MONITOR_DATA=$(monitor_and_log "$MONITOR_SCRIPT" "Monitor script" 2>&1)
|
||||
MONITOR_STATUS=$?
|
||||
|
||||
if [ $MONITOR_VM_DISKS -eq 1 ]; then
|
||||
MONITOR_DATA_VMS=$(monitor_and_log "$MONITOR_VM_SCRIPT" "VM disks monitor script" 2>&1)
|
||||
MONITOR_VMS_STATUS=$?
|
||||
fi
|
||||
fi
|
||||
|
||||
MONITOR_STATUS=$?
|
||||
echo $MONITOR_DATA
|
||||
|
||||
if [ "$MONITOR_STATUS" = "0" ]; then
|
||||
echo "$MONITOR_DATA"
|
||||
exit 0
|
||||
else
|
||||
echo "$MONITOR_DATA"
|
||||
exit $MONITOR_STATUS
|
||||
if [ $MONITOR_VM_DISKS -eq 1 ]; then
|
||||
send_to_monitor MONITOR_VM $MONITOR_VMS_STATUS -1 "$MONITOR_DATA_VMS"
|
||||
fi
|
||||
|
||||
exit $MONITOR_STATUS
|
||||
|
Loading…
x
Reference in New Issue
Block a user