wanggang 发表于 2005-3-9 20:28:48

菜鸟问题!这是什么?

我在SHELL里有一个提示,告诉我:You have new mail in /var/spool/mail/root里,然后我用#cat /var/spool/mail/root命令,显示的内容如下(部分):
   --------------------- Cron Begin ------------------------

**Unmatched Entries**
Feb6 19:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb6 20:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb6 21:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb6 22:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb6 23:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb7 00:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb7 11:36:47 dhcp-4316-36 crond: (CRON) STARTUP (fork ok)
Feb7 12:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb7 13:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)
Feb 15 11:18:31 dhcp-4316-36 crond: (CRON) STARTUP (fork ok)
Feb 15 12:01:00 dhcp-4316-36 CROND: (root) CMD (run-parts /etc/cron.hourly)

---------------------- Cron End -------------------------



------------------ Disk Space --------------------

Filesystem            SizeUsed Avail Use% Mounted on
/dev/hdg6             5.3G2.0G3.1G39% /
none                  125M   0125M   0% /dev/shm


###################### LogWatch End #########################

From root@dhcp-4316-36Mon Feb 21 00:04:52 2005
Return-Path: <root@dhcp-4316-36>
Received: from dhcp-4316-36 (localhost.localdomain )
      by dhcp-4316-36 (8.12.8/8.12.8) with ESMTP id j1KG4pPW002996
      for <root@dhcp-4316-36>; Mon, 21 Feb 2005 00:04:51 +0800
Received: (from root@localhost)
      by dhcp-4316-36 (8.12.8/8.12.8/Submit) id j1KG4pjZ002993
      for root; Mon, 21 Feb 2005 00:04:51 +0800
Date: Mon, 21 Feb 2005 00:04:51 +0800
From: root <root@dhcp-4316-36>
Message-Id: <200502201604.j1KG4pjZ002993@dhcp-4316-36>
To: root@dhcp-4316-36
Subject: LogWatch for dhcp-4316-36


################### LogWatch 4.3.1 (01/13/03) ####################
       Processing Initiated: Mon Feb 21 00:04:49 2005
       Date Range Processed: yesterday
   Detail Level of Output: 0
          Logfiles for Host: dhcp-4316-36
################################################################

请问,这些是什么意思?
谢谢!!!

zhy2111314 发表于 2005-3-9 21:35:10

系统邮件吧!

wanggang 发表于 2005-3-9 23:15:12

那主要告诉我什么呢?
我从中能学到些什么呢?
再次感谢!

zhy2111314 发表于 2005-3-10 07:35:20

.......然后我用#cat /var/spool/mail/root命令......
首先上述命令应该是显示/var/spool/mail/root下的所有文件.
下面列出来的好象是不合法(匹配)的登录(**Unmatched Entries**)
然后是了解cron(定时执行指令)命令,看下面......

zhy2111314 发表于 2005-3-10 07:38:02

cron

定時執行指令 ( cron ):

    crontab [*/Minute] [*/Hour] [*/Day] [*/Month] [*(/DayOfWeek)?] Command

      Minute: 分鐘,1 ~ 59
      Hour : 小時,0 ~ 23
      Day : 日期,1 ~ 31
      Month : 月份,1 ~ 12 或 jan、feb...
      DayOfWeek? : 0(星期日)~ 6(星期六),或 mon、tue...
      Command : 所要執行的指令,中間以 ; 來分隔多個指令。

 

      -e : 編輯 /var/spool/cron/crontabs/UserName 這一個檔案。以 # 開頭代表註解。
      -l : 列出 /var/spool/cron/crontabs/UserName 這一個檔案的內容。
      -d : 刪除使用者的工作排程。
      -r : 刪除使用者的工作排程檔。

 

      Minute,Houre,Day,Month,DayOfWeek? 為條件式,需要符合所有條件的那個時刻指令才會執行。
      用 * 來代表略過這一個條件。
      如果同一個欄位有多個條件,中間要用 , 分開。
      如果是指連續一段時間,中間則以 - 分開。
      如果要每隔固定時間執行,則使用 /#,指每隔 # 時刻執行。

 

crontab 的指令,預設是以 /bin/sh 為直譯器,而以使用者的家目錄為工作目錄。然而使用者可以用 HOME、SHELL、PATH 的變數改變執行時的直譯器、預設執行目錄與路徑。也可以透過設定 MAILTO 設定執行後的紀錄要以電子郵件記送到何處。

# use /bin/sh to run commands, no matter what /etc/passwd says
SHELL=/bin/sh
# mail any output to `paul', no matter whose crontab this is
MAILTO=paul
#
# run five minutes after midnight, every day
5 0 * * *       $HOME/bin/daily.job >> $HOME/tmp/out 2>&1
# run at 2:15pm on the first of every month -- output mailed to paul
15 14 1 * *   $HOME/bin/monthly
# run at 10 pm on weekdays, annoy Joe
0 22 * * 1-5    mail -s "It's 10pm" joe%Joe,%%Where are your kids?%
23 0-23/2 * * * echo "run 23 minutes after midn, 2am, 4am ..., everyday"
5 4 * * sun   echo "run at 5 after 4 every sunday"

    root 可以用 -u user name 來編輯其它使用者的 crontab 設定。

crontab -u UserName -e

 

    在開機時,rc 檔會載入 crond 這一個 Daemon,
    它會定時去讀取這個檔案,並依其內容執行指令。
    而指令的執行結果(標準輸出/錯誤輸出,stdout/stderr)會以郵件方式寄給系統管理者,
    即 /etc/aliases 檔案中的 root : UserName 。

 

    也可以先將指令儲存成檔案,然後使用

crontab FileName

    來將要執行的指令寫入 /var/spool/cron/crontabs/UserName 這一個檔案中。

zhy2111314 发表于 2005-3-10 07:43:17

cron 是linux的内置服务,但它不自动起来,可以用以下的方法启动、关闭这个服务:

/sbin/service crond start //启动服务
/sbin/service crond stop //关闭服务
/sbin/service crond restart //重启服务
/sbin/service crond reload //重新载入配置
你也可以将这个服务在系统启动的时候也自动启动:

在/etc/rc.d/rc.local这个脚本的末尾加上:
/sbin/service crond start

现在cron这个服务已经在进程里面了,我们就可以用这个服务了,cron服务提供以下几种接口供大家使用:

1.直接用crontab命令编辑
cron服务提供crontab命令来设定cron服务的,以下是这个命令的一些参数与说明:

crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数
crontab -l //列出某个用户cron服务的详细内容
crontab -r //删除没个用户的cron服务
crontab -e //编辑某个用户的cron服务

比如说root查看自己的cron设置:

crontab -u root -l
再例如,root想删除fred的cron设置:

crontab -u fred -r
在编辑cron服务时,编辑的内容有一些格式和约定,输入:

crontab -u root -e
进入vi编辑模式,编辑的内容一定要符合下面的格式:

*/1 * * * * ls >> /tmp/ls.txt
这个格式的前一部分是对时间的设定,后面一部分是要执行的命令,如果要执行的命令太多,可以把这些命令写到一个脚本里面,然后在这里直接调用这个脚本就可以了,调用的时候记得写出命令的完整路径。时间的设定我们有一定的约定,前面五个*号代表五个数字,数字的取值范围和含义如下:

分钟 (0-59)
小時 (0-23)
日期 (1-31)
月份 (1-12)
星期 (0-6)//0代表星期天
除了数字还有几个个特殊的符号就是"*"、"/"和"-"、",",*代表所有的取值范围内的数字,"/"代表每的意思,"*/5"表示每5个单位,"-"代表从某个数字到某个数字,","分开几个离散的数字。以下举几个例子说明问题:

每天早上6点
0 6 * * * echo "Good morning." >> /tmp/test.txt //注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。

每两个小时
0 */2 * * * echo "Have a break now." >> /tmp/test.txt

晚上11点到早上8点之间每两个小时,早上八点
0 23-7/2,8 * * * echo "Have a good dream:)" >> /tmp/test.txt

每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点
0 11 4 * 1-3 command line

1月1日早上4点
0 4 1 1 * command line
每次编辑完某个用户的cron设置后,cron自动在/var/spool/cron下生成一个与此用户同名的文件,此用户的cron信息都记录在这个文件中,这个文件是不可以直接编辑的,只可以用crontab -e 来编辑。cron启动后每过一份钟读一次这个文件,检查是否要执行里面的命令。因此此文件修改后不需要重新启动cron服务。

2.编辑/etc/crontab 文件配置cron
cron 服务每分钟不仅要读一次/var/spool/cron内的所有文件,还需要读一次/etc/crontab,因此我们配置这个文件也能运用cron服务做一些事情。用crontab配置是针对某个用户的,而编辑/etc/crontab是针对系统的任务。此文件的文件格式是:

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root //如果出现错误,或者有数据输出,数据作为邮件发给这个帐号
HOME=/
# run-parts
01 * * * * root run-parts /etc/cron.hourly //每个小时去执行一遍/etc/cron.hourly内的脚本
02 4 * * * root run-parts /etc/cron.daily //每天去执行一遍/etc/cron.daily内的脚本
22 4 * * 0 root run-parts /etc/cron.weekly //每星期去执行一遍/etc/cron.weekly内的脚本
42 4 1 * * root run-parts /etc/cron.monthly //每个月去执行一遍/etc/cron.monthly内的脚本
使用者 运行的路径
大家注意"run-parts"这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名了。

zhy2111314 发表于 2005-3-10 07:52:56

相信楼主看了上面这些,再看一下自己的/etc/crontab,应该差不多明白了吧:)

zhy2111314 发表于 2005-3-10 17:52:06

还可以参照
http://www.linuxfans.org/nuke/modules.php?name=Forums&file=viewtopic&t=107769
进一步学习!:)

wanggang 发表于 2005-3-18 16:58:19

Thanks!
页: [1]
查看完整版本: 菜鸟问题!这是什么?