uptime
作用:查看系统相关信息
常用选项:
-V 查看版本
实例:
1
2
3
4
5
6
7
8
|
[root@jacken ~]
# uptime
13:38:20 up 4:22, 2
users
, load average: 0.54, 0.40, 0.20
[root@jacken ~]
# uptime -V
procps version 3.2.8
1、13:38:20 当前时间
2、4:22 系统已运行时间(单位时分)
3、2
users
当前在线用户
4、0.54, 0.40, 0.20 平均负载
|
何为系统负载呢?
系统平均负载被定义为在特定时间间隔内运行队列中的平均进程树。
seq
作用:输出整数
常用选项:
n 输出从1-n的整数
n m 输出从n到m的整数
n m p 从数字n开始,依次增加m,小于p
-s "分隔符" 以指定的分隔符分割,默认为回车
-w:输出同宽数列,不足的位数用0补齐。比如 seq -w 10 会输出 01、02..10
-f 分隔符%g 格式化输出,数字前边都会加一个分割符
实例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
[root@jacken ~]
# seq 2
1
2
[root@jacken ~]
# seq 2 4
2
3
4
[root@jacken ~]
# seq 2 4 13
2
6
10
[root@jacken ~]
#
[root@jacken ~]
# seq -s "+" 10
1+2+3+4+5+6+7+8+9+10
[root@jacken ~]
# seq -w 10 > 1
[root@jacken ~]
# seq -w 100 > 2
[root@jacken ~]
# head -5 1 2
==> 1 <==
01
02
03
04
05
==> 2 <==
001
002
003
004
005
[root@jacken ~]
#
[root@jacken ~]
# seq -f hi%g 3
hi1
hi2
hi3
[root@jacken ~]
# seq -f %4g 3
1
2
3
|
crontab
作用:周期性执行所需任务
常用选项:
-e 编辑
-u 指定用户名
-l 查看任务
-r 删除用户目前的crontab.
分 时 日 月 周 命令
需要启动crond服务
实例:
1
2
3
4
5
6
7
8
9
10
11
12
|
[root@jacken ~]
# crontab -e
crontab
: installing new
crontab
You have mail
in
/var/spool/mail/root
[root@jacken ~]
# /etc/init.d/crond restart
Starting crond: [ OK ]
[root@jacken ~]
# crontab -l
45 04 1,5,15 * *
/bin/ls
每个月的1、5、15号04时45分执行
ls
命令
[root@jacken ~]
# crontab -r
[root@jacken ~]
# crontab -l
no
crontab
for
root
[root@jacken ~]
#
|
每个用户的周期执行的文件路径 /var/spool/cron/用户
45 04 1,10,22 * * 每月1号、10号、22号的04:45分
10 1 * * 6,0 每周六、周日的01 : 10 (0表示星期天)
0,30 18-23 * * * 每天18 : 00至23 : 00之间每隔30分钟
* 23-7/1 * * * 晚上11点到早上7点之间,每隔一小时
当为凌晨的时候 时那一项必须写为0 而非24
crontab 调用date
需求:/var/www/html/是网站的发布目录,如何每天凌晨0点30对其进行自动备份
30 0 * * * /bin/tar -czf /backup/web_bak_$(date +\%Y\%m\%d).tar.gz /var/www/html > /dev/null 2>&1
同步网络时间可用echo
echo "*/1 * * * * /usr/sbin/ntpdate ntp.api.bz > /dev/null 2>&1 " > /var/spool/cron/root
at
作用:定时任务
注释:at命令依赖atd服务,需要启动/etc/init.d/atd服务。/etc/at.allow 与 /etc/at.deny 这两个文件来进行 at 的使用限制。加上这两个文件后, at 的工作情况是这样的:
先找寻 /etc/at.allow 这个文件,写在这个文件中的使用者才能使用 at ,没有在这个文件中的使用者则不能使用 at (即使没有写在 at.deny 当中);
如果 /etc/at.allow 不存在,就寻找 /etc/at.deny 这个文件,若写在这个 at.deny 的使用者则不能使用 at ,而没有在这个 at.deny文件中的使用者,就可以使用 at 命令了。
如果两个文件都不存在,那么只有 root 可以使用 at 这个命令。
常用选项:
-c NUMBER 查看未执行计划内容
at 5pm+3 days 3天后下午5点执行 Ctrl+D结束
at 17:20 tomorrow 明天17点20
atq查看系统没有执行工作的任务
atrm NUMBER 删除已设置的任务
实例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
[root@jacken ~]
# /etc/init.d/atd restart
Stopping atd: [ OK ]
Starting atd: [ OK ]
[root@jacken ~]
# date
Wed Mar 25 15:32:20 CST 2015
[root@jacken ~]
# at 15:33
at>
touch
/tmp/test
at> <EOT>
job 6 at 2015-03-25 15:33
[root@jacken ~]
# date
Wed Mar 25 15:33:11 CST 2015
[root@jacken ~]
# ls /tmp/
test
[root@jacken ~]
#
[root@jacken ~]
# atq
[root@jacken ~]
# at 17:20 tomorrow
at> \
cp
/etc/passwd
/tmp/
at> <EOT>
job 7 at 2015-03-26 17:20
[root@jacken ~]
# atq
7 2015-03-26 17:20 a root
[root@jacken ~]
# at -c 7 | tail
G_BROKEN_FILENAMES=1;
export
G_BROKEN_FILENAMES
OLDPWD=
/root
;
export
OLDPWD
cd
/root
|| {
echo
'Execution directory inaccessible'
>&2
exit
1
}
${SHELL:-
/bin/sh
} <<
'marcinDELIMITER301cdd1c'
\
cp
/etc/passwd
/tmp/
marcinDELIMITER301cdd1c
[root@jacken ~]
# atrm 7
[root@jacken ~]
# atq
[root@jacken ~]
#
|
rpm
作用:安装以*.rpm结尾的软件包。
常用选项:
-ivh 安装显示安装进度
-Uvh 升级软件包
-qpl 列出RPM包内的文件信息
-qf 查找指定文件属于哪个RPM软件包
-e 删除包
-q 查询包是否安装
-ql 查看软件安装后生成了哪些配置文件
--force 强制安装软件包
--nodeps 解决依赖性关系
注释:
[root@jacken ~]# mount /dev/cdrom /mnt
mount: block device /dev/sr0 is write-protected, mounting read-only
挂载本地光盘到/mnt
实例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
[root@jacken ~]
# cd /mnt/Packages/
[root@jacken Packages]
# ls | grep vsftpd
vsftpd-2.2.2-12.el6_5.1.x86_64.rpm
[root@jacken Packages]
# rpm -ivh vsftpd-2.2.2-12.el6_5.1.x86_64.rpm
warning: vsftpd-2.2.2-12.el6_5.1.x86_64.rpm: Header V3 RSA
/SHA1
Signature, key ID c105b9de: NOKEY
Preparing...
########################################### [100%]
1:vsftpd
########################################### [100%]
[root@jacken Packages]
# rpm -q vsftpd
vsftpd-2.2.2-12.el6_5.1.x86_64
[root@jacken Packages]
# rpm -qf /etc/vsftpd/vsftpd.conf
vsftpd-2.2.2-12.el6_5.1.x86_64
[root@jacken Packages]
# rpm -qpl /etc/vsftpd/vsftpd.conf
[root@jacken Packages]
# rpm -qpl vsftpd-2.2.2-12.el6_5.1.x86_64.rpm
warning: vsftpd-2.2.2-12.el6_5.1.x86_64.rpm: Header V3 RSA
/SHA1
Signature, key ID c105b9de: NOKEY
/etc/logrotate
.d
/vsftpd
/etc/pam
.d
/vsftpd
/etc/rc
.d
/init
.d
/vsftpd
/etc/vsftpd
....省略
....省略
/usr/share/man/man8/vsftpd
.8.gz
/var/ftp
/var/ftp/pub
[root@jacken Packages]
# rpm -e vsftpd
[root@jacken Packages]
# rpm -q vsftpd
package vsftpd is not installed
[root@jacken Packages]
#
[root@jacken ~]
# rpm -ql vsftpd
/etc/logrotate
.d
/vsftpd
/etc/pam
.d
/vsftpd
/etc/rc
.d
/init
.d
/vsftpd
/etc/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
|
yum
作用:从软件"仓库"中安装软件,解决依赖性。
常用选项:
-y 当安装过程提示选择全部为"yes"
-q 不显示安装的过程
yum install package1 安装指定的安装包package1
yum groupinsall group1 安装程序组group1
yum update package1 更新指定程序包package1
yum check-update 检查可更新的程序
yum upgrade package1 升级指定程序包package1
yum groupupdate group1 升级程序组group1
yum list package1 显示指定程序包安装情况package1
yum remove package1 删除程序包package1
yum groupremove group1 删除程序组group1
yum grouplist 列出所有程序组
yum clean all 清除缓存目录下的软件包及旧的headers
注释:
配置yum源,以本地光盘作为yum源为例。
[root@jacken ~]# mount /dev/cdrom /mnt
mount: block device /dev/sr0 is write-protected, mounting read-only
[root@jacken ~]# cd /etc/yum.repos.d/
[root@jacken yum.repos.d]# ls
server.repo
名称必须以.repo结尾
[root@jacken yum.repos.d]# cat server.repo
[base]
name=1
baseurl=file:///mnt
enabled=1
gpgcheck=0
[root@jacken yum.repos.d]#
本文转自Jacken_yang 51CTO博客,原文链接:http://blog.51cto.com/linuxnote/1624317,如需转载请自行联系原作者