Re: cron job question (for checking kernel updates)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 10/02/2013 02:27 PM, Ranjan Maitra issued this missive:
On Wed, 2 Oct 2013 13:34:36 -0700 Rick Stevens <ricks@xxxxxxxxxxxxxx>
wrote:

On 10/02/2013 01:06 PM, Ranjan Maitra issued this missive:
On Wed, 2 Oct 2013 09:26:32 -0700 Rick Stevens <ricks@xxxxxxxxxxxxxx>
wrote:

On 10/02/2013 08:10 AM, Ranjan Maitra issued this missive:
Hi,

I have a cron job running which yum updates all my machines once a day.
All of these work fine.

I also have a cron job which checks for kernel updates every hour and
sends me a message if an updated kernel has been installed. Here is the
relevant script:

--- begin file called check-kernel.sh in my scripts/yum directory---

#!/bin/bash

latestkernel=$(rpm -q kernel |tail -n1|sed -e 's/kernel-//')

#echo "$latestkernel"

if uname -a | grep -qv "$latestkernel"; then
notify-send "Kernel UPDATE on ${HOSTNAME}: Running Kernel is $(uname
-r) but lat est installed rpm is ${latestkernel}; REBOOT required"
fi;


--- end file called check-kernel.sh ---

(A bit wordy, I know.)

I have verified that this is executable and works from the commandline
without any errors.

I have the following set up via crontab -e:

0,15,30,45 * * * * nice -n 19 $HOME/.xplanet/download_xplanet_cloudmap
5 * * * * nice -n 19 $HOME/scripts/yum/check-kernel.sh

The first line downloads cloudmaps for use with xplanet and works just
fine (or appears to) and has done so for aeons.

However, nothing happens (or appears to) for the second line.

What is wrong here?

The most common problem I've seen is that cron jobs typically have very
limited paths and the executables you're running (notify-send, uname)
may not be in the path the cronjob has. For giggles, do "echo $PATH" as
the user the cronjob will run as. Then build a cron job that echos
cron's concept of the path:

	#!/bin/bash
	echo $PATH >/tmp/pathecho.txt

and have cron run that once as the same user. Look at the data in
/tmp/pathecho.txt and I'll bet you'll find its far more restricted than
that of an interactive shell.

I tried this: here is what I got --

$ echo $PATH
/bin:/usr/bin:/usr/local/bin:/usr/local/sbin:/usr/sbin:/home/user/bin

$ cat /tmp/pathecho.txt
/usr/bin:/bin

Clearly more restrictive as you suggest.

However, what I do not understand is why this does not "work" though. I
do not understand because notify-send is in /usr/bin as well as in /bin:

$ which notify-send
notify-send is /bin/notify-send
notify-send is /usr/bin/notify-send

Both appear to be in the path. So where is the problem?

I will also try the suggestions in the references in Matthew Miller's
response now.

You could try adding a "set -x" after the shebang line:

	#!/bin/bash
	set -x

That tells bash to print out every expansion. Then change your cron
entry to have a ">/tmp/test.txt 2>&1" at the end:

	5 * * * * nice -n 19 $HOME/scripts/yum/check-kernel.sh >/tmp/test.txt 2>&1

Let the script run, then examine the /tmp/test.txt file to see what bash
doesn't like. Don't forget to remove the "set -x" from the script and
the ">... 2>&1" stuff from the crontab entry when you're done. Odds are
it's a path issue or something that isn't expanding as you think it
would because it's not an interactive shell running the script.
-----------------------------------------------------------------

Here is what I get:

$ more /tmp/test.txt
++ tail -n1
++ rpm -q kernel
++ sed -e s/kernel-//
+ latestkernel=3.11.2-201.fc19.i686
+ grep -qv 3.11.2-201.fc19.i686
+ uname -a
++ uname -r
+ notify-send 'Kernel UPDATE on subarnarekha.stat.iastate.edu: Running
Kernel is 3.11.1-200.fc19.i686 but latest installed rpm is
3.11.2-201.fc19.i686; REBOOT r equired'


I also tried explicitly putting in /usr/bin/notify-send (hardcoding it
in) to the original code, but no effect.

Ok, so it looks like there's nothing wrong in the script so you can remove the "set -x" from the script and the ">/tmp/test.txt 2>&1" from
the crontab.

My guess is that the cron doesn't know that there is a GUI running and
so notify-send doesn't know where to send the message. I've seen some
stuff regarding this in one of the Ubuntu forums. Have a look at this:

http://askubuntu.com/questions/298608/notify-send-doesnt-work-from-crontab

In particular, look at the second and third answers (from danatela and krlmlr) and combine them (from danatela's answer to find who's logged
in on the GUI and krlmlr's answer to set the DBUS_SESSION_BUS_ADDRESS
for that user).
----------------------------------------------------------------------
- Rick Stevens, Systems Engineer, AllDigital    ricks@xxxxxxxxxxxxxx -
- AIM/Skype: therps2        ICQ: 22643734            Yahoo: origrps2 -
-                                                                    -
-           "I understand Windows 2000 has a Y2K problem."           -
----------------------------------------------------------------------
--
users mailing list
users@xxxxxxxxxxxxxxxxxxxxxxx
To unsubscribe or change subscription options:
https://admin.fedoraproject.org/mailman/listinfo/users
Fedora Code of Conduct: http://fedoraproject.org/code-of-conduct
Guidelines: http://fedoraproject.org/wiki/Mailing_list_guidelines
Have a question? Ask away: http://ask.fedoraproject.org




[Index of Archives]     [Older Fedora Users]     [Fedora Announce]     [Fedora Package Announce]     [EPEL Announce]     [EPEL Devel]     [Fedora Magazine]     [Fedora Summer Coding]     [Fedora Laptop]     [Fedora Cloud]     [Fedora Advisory Board]     [Fedora Education]     [Fedora Security]     [Fedora Scitech]     [Fedora Robotics]     [Fedora Infrastructure]     [Fedora Websites]     [Anaconda Devel]     [Fedora Devel Java]     [Fedora Desktop]     [Fedora Fonts]     [Fedora Marketing]     [Fedora Management Tools]     [Fedora Mentors]     [Fedora Package Review]     [Fedora R Devel]     [Fedora PHP Devel]     [Kickstart]     [Fedora Music]     [Fedora Packaging]     [Fedora SELinux]     [Fedora Legal]     [Fedora Kernel]     [Fedora OCaml]     [Coolkey]     [Virtualization Tools]     [ET Management Tools]     [Yum Users]     [Yosemite News]     [Gnome Users]     [KDE Users]     [Fedora Art]     [Fedora Docs]     [Fedora Sparc]     [Libvirt Users]     [Fedora ARM]

  Powered by Linux