Difference between revisions of "Bash"

From Blue-IT.org Wiki

(Grep and Tail)
(notify-send)
Line 46: Line 46:
  
 
  #!/bin/bash
 
  #!/bin/bash
+
 
 
  notify_start() {
 
  notify_start() {
  
Line 77: Line 77:
 
   
 
   
 
  done
 
  done
 +
 +
 +
== Monitoring ==
 +
Sometimes you like to run a monitor in the background. Here an example for checking if a drive had an drive error.
 +
 +
#!/bin/bash
 +
 +
if ps x | grep -v grep | grep -v $$ | grep $0 | grep -v subl | grep -v vi
 +
then
 +
        echo "$0 already running. Exiting"
 +
        exit 1
 +
else
 +
 +
################################################
 +
# PUT YOUR CODE HERE
 +
# vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
 +
 +
  notify_start() {
 +
 +
      aplay /local/share/sounds/KDE_Critical_Error.wav
 +
   
 +
      notify-send  "Backup is is mounted." \
 +
                  -i /usr/share/icons/gnome/48x48/actions/document-open-recent.png \
 +
                  "Read and write support for you is working."
 +
  }
 +
 
 +
  notify_end() {
 +
 
 +
      aplay /local/share/sounds/KDE_Critical_Error.wav
 +
 +
      notify-send  "Backup Drive is not ready!" \
 +
                  -i /usr/share/icons/gnome/48x48/actions/stock-delete.png \
 +
                  "Resolve the problem and save your work"
 +
  }
 +
 +
while(true); do
 +
 +
message_head="SSD WRITE TEST:"
 +
message_time="date +%F_%Hh:%Ms:%Nms"
 +
error="ERROR:"
 +
 +
logger "${message_head} $(${message_time}) starting sync"
 +
 +
if sync
 +
then
 +
logger "${message_head} $(${message_time}) sync finished successfully."
 +
else
 +
logger "${message_head} $(${message_time}) ${error} while do sync."
 +
fi
 +
 +
sleep 2
 +
 +
 
 +
if touch ~/testfile
 +
  then
 +
logger "${message_head} $(${message_time}) touched testfile in home successfully."
 +
 +
  if rm ~/testfile
 +
then
 +
logger "${message_head} $(${message_time}) removed testfile in home successfully."
 +
else
 +
logger "${message_head} $(${message_time}) ${error} while removing tesfile in home."
 +
fi
 +
 +
  else
 +
logger "${message_head} $(${message_time}) ${error} while touching tesfile in home."
 +
 
 +
notify_end
 +
  fi
 +
 
 +
sleep 28
 +
 
 +
 +
done
 +
 +
# ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 +
################################################
 +
 
 +
fi
  
  
 
[[Category:Network]]
 
[[Category:Network]]
 
[[Category:Bash]]
 
[[Category:Bash]]

Revision as of 10:28, 9 January 2014

Environment

Put this in front of any script to avoid problems when running the script in other languages! The en_US locale should be avaiabel on all systems:

export LC_MESSAGES="en_US.UTF-8"
export LC_TYPE="en_US.UTF-8"
export LANGUAGE="en_US.UTF-8


Singleton

The singleton pattern is a very handy one. You can realise it in bash like this:

if ps x | grep -v grep | grep -v $$ | grep $0 | grep -v subl | grep -v vi
then
        echo "$0 already running. Exiting"
        exit 1
else

################################################
# PUT YOUR CODE HERE
# vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv

./run_me

# ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
################################################ 
 
fi

Grep

Grep a steam with tail, head

Sometimes you need not to filter a standard out only once, but with tail

tail -f -n 300 /var/log/syslog | stdbuf -o0 grep PATTERN

Graphical Tools

Sometimes you need to get out of yor script, give a message to your users - visually.

notify-send

See Ubuntu_Desktop#Notify_OSD

#!/bin/bash
 
notify_start() {
    aplay Critical_Error.wav
   
    notify-send   "Backup is is mounted." \
                -i /usr/share/icons/gnome/48x48/actions/document-open-recent.png \
                "Read and write support for you is working."
}

notify_end() {

    notify-send   "Backup Drive is not ready!" \
                -i /usr/share/icons/gnome/48x48/actions/stock-delete.png \
                "Resolve the problem and save your work"
}


while(true); do

	if touch /backup/testfile
	then
		rm /backup/testfile
		notify_start
	else
		notify_end
	fi

sleep 10

done


Monitoring

Sometimes you like to run a monitor in the background. Here an example for checking if a drive had an drive error.

#!/bin/bash

if ps x | grep -v grep | grep -v $$ | grep $0 | grep -v subl | grep -v vi
then
        echo "$0 already running. Exiting"
        exit 1
else

################################################
# PUT YOUR CODE HERE
# vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv

 notify_start() {

     aplay /local/share/sounds/KDE_Critical_Error.wav
    
     notify-send   "Backup is is mounted." \
                 -i /usr/share/icons/gnome/48x48/actions/document-open-recent.png \
                 "Read and write support for you is working."
 }
 
 notify_end() {
 
     aplay	/local/share/sounds/KDE_Critical_Error.wav

     notify-send   "Backup Drive is not ready!" \
                 -i /usr/share/icons/gnome/48x48/actions/stock-delete.png \
                 "Resolve the problem and save your work"
 }

while(true); do

	message_head="SSD WRITE TEST:"
	message_time="date +%F_%Hh:%Ms:%Nms"
	error="ERROR:"
	
	logger "${message_head} $(${message_time}) starting sync"

	if sync
	then
		logger "${message_head} $(${message_time}) sync finished successfully."
	else
		logger "${message_head} $(${message_time}) ${error} while do sync."
	fi

	sleep 2

 	
	if touch ~/testfile
 	then
		logger "${message_head} $(${message_time}) touched testfile in home successfully."

 		if rm ~/testfile 
		then 
			logger "${message_head} $(${message_time}) removed testfile in home successfully."
		else
			logger "${message_head} $(${message_time}) ${error} while removing tesfile in home."
		fi

 	else
		logger "${message_head} $(${message_time}) ${error} while touching tesfile in home."
 		
		notify_end
 	fi
 
sleep 28
 

done

# ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
################################################ 
 
fi