QQ登录

只需一步,快速开始

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 765|回复: 8

菜鸟问题!这是什么?

[复制链接]
发表于 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**
Feb  6 19:01:00 dhcp-4316-36 CROND[4111]: (root) CMD (run-parts /etc/cron.hourly)
Feb  6 20:01:00 dhcp-4316-36 CROND[4155]: (root) CMD (run-parts /etc/cron.hourly)
Feb  6 21:01:00 dhcp-4316-36 CROND[4206]: (root) CMD (run-parts /etc/cron.hourly)
Feb  6 22:01:00 dhcp-4316-36 CROND[4303]: (root) CMD (run-parts /etc/cron.hourly)
Feb  6 23:01:00 dhcp-4316-36 CROND[4310]: (root) CMD (run-parts /etc/cron.hourly)
Feb  7 00:01:00 dhcp-4316-36 CROND[4437]: (root) CMD (run-parts /etc/cron.hourly)
Feb  7 11:36:47 dhcp-4316-36 crond[2279]: (CRON) STARTUP (fork ok)
Feb  7 12:01:00 dhcp-4316-36 CROND[2657]: (root) CMD (run-parts /etc/cron.hourly)
Feb  7 13:01:00 dhcp-4316-36 CROND[3053]: (root) CMD (run-parts /etc/cron.hourly)
Feb 15 11:18:31 dhcp-4316-36 crond[2282]: (CRON) STARTUP (fork ok)
Feb 15 12:01:00 dhcp-4316-36 CROND[2720]: (root) CMD (run-parts /etc/cron.hourly)

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



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

Filesystem            Size  Used Avail Use% Mounted on
/dev/hdg6             5.3G  2.0G  3.1G  39% /
none                  125M     0  125M   0% /dev/shm


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

From root@dhcp-4316-36  Mon Feb 21 00:04:52 2005
Return-Path: <root@dhcp-4316-36>
Received: from dhcp-4316-36 (localhost.localdomain [127.0.0.1])
        by dhcp-4316-36 (8.12.8/8.12. 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
################################################################

请问,这些是什么意思?
谢谢!!!
发表于 2005-3-9 21:35:10 | 显示全部楼层
系统邮件吧!
回复

使用道具 举报

 楼主| 发表于 2005-3-9 23:15:12 | 显示全部楼层
那主要告诉我什么呢?
我从中能学到些什么呢?
再次感谢!
回复

使用道具 举报

发表于 2005-3-10 07:35:20 | 显示全部楼层
.......然后我用#cat /var/spool/mail/root命令......

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

使用道具 举报

发表于 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 這一個檔案中。
回复

使用道具 举报

发表于 2005-3-10 07:43:17 | 显示全部楼层
cron 是linux的内置服务,但它不自动起来,可以用以下的方法启动、关闭这个服务:
[code:1]
/sbin/service crond start //启动服务
/sbin/service crond stop //关闭服务
/sbin/service crond restart //重启服务
/sbin/service crond reload //重新载入配置[/code:1]
你也可以将这个服务在系统启动的时候也自动启动:
[code:1]
在/etc/rc.d/rc.local这个脚本的末尾加上:
/sbin/service crond start[/code:1]

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

1.直接用crontab命令编辑
cron服务提供crontab命令来设定cron服务的,以下是这个命令的一些参数与说明:
[code:1]
crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数
crontab -l //列出某个用户cron服务的详细内容
crontab -r //删除没个用户的cron服务
crontab -e //编辑某个用户的cron服务[/code:1]

比如说root查看自己的cron设置:
[code:1]
crontab -u root -l[/code:1]
再例如,root想删除fred的cron设置:
[code:1]
crontab -u fred -r[/code:1]
在编辑cron服务时,编辑的内容有一些格式和约定,输入:
[code:1]
crontab -u root -e[/code:1]
进入vi编辑模式,编辑的内容一定要符合下面的格式:
[code:1]
*/1 * * * * ls >> /tmp/ls.txt[/code:1]
这个格式的前一部分是对时间的设定,后面一部分是要执行的命令,如果要执行的命令太多,可以把这些命令写到一个脚本里面,然后在这里直接调用这个脚本就可以了,调用的时候记得写出命令的完整路径。时间的设定我们有一定的约定,前面五个*号代表五个数字,数字的取值范围和含义如下:
[code:1]
分钟 (0-59)
小時 (0-23)
日期 (1-31)
月份 (1-12)
星期 (0-6)//0代表星期天[/code:1]
除了数字还有几个个特殊的符号就是"*"、"/"和"-"、",",*代表所有的取值范围内的数字,"/"代表每的意思,"*/5"表示每5个单位,"-"代表从某个数字到某个数字,","分开几个离散的数字。以下举几个例子说明问题:
[code:1]
每天早上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[/code:1]
每次编辑完某个用户的cron设置后,cron自动在/var/spool/cron下生成一个与此用户同名的文件,此用户的cron信息都记录在这个文件中,这个文件是不可以直接编辑的,只可以用crontab -e 来编辑。cron启动后每过一份钟读一次这个文件,检查是否要执行里面的命令。因此此文件修改后不需要重新启动cron服务。

2.编辑/etc/crontab 文件配置cron
cron 服务每分钟不仅要读一次/var/spool/cron内的所有文件,还需要读一次/etc/crontab,因此我们配置这个文件也能运用cron服务做一些事情。用crontab配置是针对某个用户的,而编辑/etc/crontab是针对系统的任务。此文件的文件格式是:
[code:1]
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内的脚本
使用者 运行的路径[/code:1]
大家注意"run-parts"这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名了。
回复

使用道具 举报

发表于 2005-3-10 07:52:56 | 显示全部楼层
相信楼主看了上面这些,再看一下自己的/etc/crontab,应该差不多明白了吧
回复

使用道具 举报

发表于 2005-3-10 17:52:06 | 显示全部楼层
还可以参照
http://www.linuxfans.org/nuke/modules.php?name=Forums&file=viewtopic&t=107769
进一步学习!
回复

使用道具 举报

 楼主| 发表于 2005-3-18 16:58:19 | 显示全部楼层
Thanks!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

GMT+8, 2024-10-3 07:26 , Processed in 0.041920 second(s), 15 queries .

© 2021 Powered by Discuz! X3.5.

快速回复 返回顶部 返回列表