Linux中常见问题(磁盘 定时任务)

第1章 linux无法上网

1) 第一步,先ping域名.

ping www.baidu.com

2)再ping一个公网ip ,

ping 223.5.5.5/223.6.6.6/114.114.114.114

[root@znix /]# ping 223.5.5.5

PING 223.5.5.5 (223.5.5.5) 56(84) bytes of data.

64 bytes from 223.5.5.5: icmp_seq=1 ttl=128 time=42.8 ms

2) ping 默认的网关

[root@znix ~]# route -n

Kernel IP routing table

Destination     Gateway         Genmask         Flags Metric Ref    Use Iface

10.0.0.0        0.0.0.0         255.255.255.0   U     0      0        0 eth0

169.254.0.0     0.0.0.0         255.255.0.0     U     1002   0        0 eth0

0.0.0.0         10.0.0.2        0.0.0.0         UG    0      0        0 eth0

第2章 系统的负载/cpu/内存太高了

1) 使用top 命令查看哪个进程占用cpu/内存多.

[root@znix /]# top

top - 15:29:37 up 4 days, 23:18,  4 users,  load average: 0.00, 0.00, 0.00

Tasks:  92 total,   1 running,  91 sleeping,   0 stopped,   0 zombie

Cpu(s):  0.3%us,  0.3%sy,  0.0%ni, 99.3%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st

Mem:    485984k total,   215144k used,   270840k free,   117300k buffers

Swap:   786428k total,     8664k used,   777764k free,    20700k cached

   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                               

 16949 root      20   0  102m 4628 3572 S  0.0  1.0   0:00.14 sshd                                                                   

 17064 root      20   0  102m 4608 3568 S  0.0  0.9   0:00.06 sshd                                                                   

 16812 root      20   0  102m 2604 2400 S  0.0  0.5   0:00.84 sshd

2) 找出对应程序的pid号码

a) 找到占用率较高的程序

16949 root      20   0  102m 4628 3572 S  0.0  1.0   0:00.14 sshd  

3) strace -p  进程的pid号码

a) 查看现在这个进程正在做什么事情.

[root@znix /]# strace -p 16949

Process 16949 attached

select(10, [3 5 9], [], NULL, NULL

第3章 定时任务

3.1 每分钟显示当前系统的日期 年-月-日_小时 ,把这个时间追加到 /tmp/date.log

3.1.1 .先运行命令

运行命令进行测试,确定命令可以执行.

[root@znix ~]# date +%F_%H >> /tmp/date.log

[root@znix ~]# cat /tmp/date.log

2017-09-08_09

3.1.2 命令放入脚本中

[root@znix scripts]# cat /server/scripts/date.sh

date +%F_%H:%M >> /tmp/date.log

3.1.3 测试脚本

[root@znix scripts]# /bin/sh /server/scripts/date.sh

[root@znix scripts]# tail -1 /tmp/date.log

2017-09-08_09:43

3.1.4 写到定时任务

[root@znix scripts]# crontab -l |tail -2

#print time to file by hou 20170908

* * * * * /bin/sh /server/scripts/date.sh  >/dev/null 2>&1

3.1.5 查看你定时任务的执行日历

[root@znix scripts]# tail -2 /var/log/cron

Sep  8 09:53:41 znix crontab[16396]: (root) LIST (root)

Sep  8 09:54:01 znix CROND[16400]: (root) CMD (/bin/sh /server/scripts/date.sh  >/dev/null 2>&1)

3.1.6 检查结果

[root@znix ~]# cat /tmp/date.log

2017-09-08_09

3.2 命令中的sh与bash

[root@znix ~]# ll /bin/sh /bin/bash

-rwxr-xr-x. 1 root root 942200 Mar 23 08:15 /bin/bash

lrwxrwxrwx. 1 root root      4 Aug 10 18:34 /bin/sh -> bash

第4章 磁盘满了之邮件服务

4.1 系统中的邮件服务

centos 6.x 为postfix

centos 5.x 为sendmail

4.2 关闭系统邮件服务

[root@znix ~]# /etc/init.d/postfix

Usage: /etc/init.d/postfix {start|stop|restart|reload|abort|flush|check|status|condrestart}

[root@znix ~]# /etc/init.d/postfix stop

Shutting down postfix:                                     [  OK  ]

4.2.1 关闭邮件服务后,系统的油价会放入/var/spool/postfix/maildrop/

[root@znix ~]# ls /var/spool/postfix/maildrop/ |wc -l

12

4.3 [企业案例] 如果定时任务规则结尾不加>/dev/null 2>&1或者追加到文件中>>/tmp/oldboy 2>&1,很容易导致硬盘inode空间被占满,从而系统服务不正常。

定时任务中-命令或脚本结果(正确及错误)定向到黑洞(>/dev/null 2>&1)或追加到文件中 >>/tmp/oldboy.txt 2>&1.

实例4-1 情况一:

邮件服务关闭 没有定向到空,会导致 /var/spool/postfix/maildrop/ 中有许多小文件

造成磁盘满了,即inode满了.

解决办法:将邮件服务打开就会释放inode.

[root@znix /]# /etc/init.d/postfix start

Starting postfix:                                          [  OK  ]

[root@znix /]# chkconfig |grep post

postfix        0:off   1:off   2:on    3:on    4:on    5:on    6:off

实例4-2 情况二:

邮件服务开启/var/spool/cron/root会变大,发的邮件都会存到文件中,时间长了会将

解决办法:定向到空即可

 >/dev/null 2>&1

4.4 两种输出重定向

>/dev/null  2>&1

把正确的和错误的都放在 /dev/null(黑洞,一去不复返)

>>/tmp/oldboy.txt   2>&1

把正确的和错误的都放在/tmp/oldboy.txt

4.5 书写定时任务要将内容输出重定向

如果定时任务规则结尾不加>/dev/null 2>&1或者追加到文件中>>/tmp/oldboy 2>&1,很容易导致硬盘inode空间被占满,从而系统服务不正常。

4.6 创建和删除大量小文件的方法

4.6.1 删除小文件的方法

1)大量的小文件

[root@znix tmp]# ls |xargs rm

2)删除文件所在的目录 (权限、所有者、属组)

3)临时开启邮件服务 (只对/var/spool/postfix/maildrop 这个目录下的小文件)

4.6.2 创建小文件的方法

[root@znix tmp]# echo {1..400000}|xargs touch

[root@znix tmp]# ll -hd  tmp/

drwxr-xr-x 2 root root 8.4M Sep  8 10:59 tmp/

4.7 管道与|xargs 区别:

| 传递的是文本

|xargs 后面的命令会任务传递过来的是文件

4.8 定时任务的位置

1.在用户的定时任务中,默认存放在当前用户的家目录下

2.系统的定时任务存放在根下

第5章 练习题--定时任务

5.1 在定时任务中的环境变量

定时任务中,只能识别两个位置的变量,使用其他位置命令的时候可以使用绝对路径,也可以添加环境变量.

/usr/bin

/bin

添加环境变量,直接写在定时任务的开始即可.可以将自己使用到的命令位置都添加上.

export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

5.2 每分钟显示当前的系统的ip地址还有系统日期date +%F 追加到文件中/tmp/ip.log

5.2.1 先测试一下命令

保证命令是执行没有错误的.

[root@znix /]# date +%F

2017-09-08

[root@znix /]# /sbin/ifconfig  eth0 |awk -F "[ :]+" 'NR==2 {print $4}'

10.0.0.201

5.2.2 将命令放入脚本

[root@znix ~]# cat /server/scripts/ip.sh

date +%F

/sbin/ifconfig  eth0 |awk -F "[ :]+" 'NR==2 {print $4}'

5.2.3 书写定时任务

[root@znix ~]# crontab -l |tail -2

#print ip & date

* * * * * /bin/sh /server/scripts/ip.sh  >/tmp/ip.sh 2>&1

5.2.4 检查执行结果

[root@znix tmp]# tail -f /tmp/ip.log

2017-09-08

10.0.0.201

5.3 每隔 2 个小时将/etc/services 文件打包备份到/tmp下(最每次备份成不同的备份包)。

5.3.1 测试命令是否正确

[root@znix ~]# cd / && /bin/tar zcf /tmp/ser_`date +%F_%H`.tar.gz  etc/services

[root@znix /]# ll tmp/ser_2017-09-08_1*

-rw-r--r-- 1 root root 127314 Sep  8 16:15 tmp/ser_2017-09-08_16.tar.gz

5.3.2 写入脚本中

[root@znix ~]# cat /server/scripts/ser.sh

cd / && /bin/tar zcf /tmp/ser_`date +%F_%H`.tar.gz  etc/services

5.3.3 测试脚本

[root@znix /]# sh /server/scripts/ser.sh

[root@znix /]# ll tmp/ser_2017-09-08_1*

-rw-r--r-- 1 root root 127314 Sep  8 16:17 tmp/ser_2017-09-08_16.tar.gz

5.3.4 写入定时任务

[root@znix ~]# crontab -l |tail -2

##dabao /etc/services

00 */2 * * * /bin/sh /server/scripts/ser.sh >/dev/null 2>&1

5.3.5 检查结果

[root@znix /]# ll tmp/ser_2017-09-08_1*

-rw-r--r-- 1 root root 127314 Sep  8 11:59 tmp/ser_2017-09-08_11.tar.gz

-rw-r--r-- 1 root root 127314 Sep  8 12:11 tmp/ser_2017-09-08_12.tar.gz

-rw-r--r-- 1 root root 127314 Sep  8 16:17 tmp/ser_2017-09-08_16.tar.gz

5.4 每天晚上 12 点,打包站点目录/var/www/html  备份到/data 目录下(最好每次备份按时间生成不同的备份包)

5.4.1 测试命令

[root@znix /]# cd / && tar zcf /data/www_`date +%F`.tar.gz  var/www/html

[root@znix /]#  ll /data/www*

-rw-r--r-- 1 root root 117 Sep  8 16:21 /data/www_2017-09-08.tar.gz

5.4.2 写入测试脚本

[root@znix /]# cat /server/scripts/www.sh

cd / && tar zcf /data/www_`date +%F`.tar.gz  var/www/html

[root@znix /]#  ll /data/www*

-rw-r--r-- 1 root root 117 Sep  8 16:21 /data/www_2017-09-08.tar.gz

5.4.3 写入定时任务

[root@znix /]# crontab -l |tail -2

####dabao tar

00 00 * * * /bin/sh /server/scripts/www.sh >/dev/null 2>&1

5.4.4 检查执行结果

[root@znix /]# ll /data/www*

-rw-r--r-- 1 root root 117 Sep  8 16:28 /data/www_2017-09-08.tar.gz

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏cs

linux学习六

网络服务 常用网络服务器软件 服务类型 软件名称 服务类型 软件名称 NFS 服务 NFS DNS服务 DNS Web服务 Apache Ma...

2689
来自专栏云计算教程系列

如何在CentOS 7上将BIND配置为专用网络DNS服务器

管理服务器配置和基础架构的一个重要部分包括通过设置适当的域名系统(DNS),维护一种通过名称查找网络接口和IP地址的简便方法。使用完全限定的域名(FQDN)而不...

170
来自专栏liuchengxu

使用 Shell 脚本进行 Hadoop Spark 集群的批量安装

虽然有一些自动化安装的工具,但是功能越多,越专业的工具,可能也需要越高的学习成本,而我们并非专业运维,但是又必须做这些事情的话,不妨选择用 Shell 脚本来完...

621
来自专栏程序员与猫

MongoDB安装使用

标签: MongoDB 参考链接:Windows上安装MongoDB教程 1. 官方下载 MongoDB提供了可用于32位和64位系统的预编译二进制包,你可以从...

1875
来自专栏Spark学习技巧

Hadoop伪分布式集群安装部署

一、 准备环境 1, 安装简介 Java-- jdk-8u121-linux-x64.tar.gz Hadoop--hadoop-2.7.4.tar.gz (...

2075
来自专栏鬼谷君

hbase分布式集群搭建

1133
来自专栏应用案例

docker搭建私有仓库

序言 黄金指,一不小心就弄出一个故障。。。好可怕好可怕,我的小心脏。。。我的小心眼。。。 我这么信任你,你居然欺骗我。。。。****,这么大的坑,填不满啊。。。...

3677
来自专栏大数据和云计算技术

hadoop运行环境搭建

森哥/洋哥hadoop系列,非常适合初学者: Hive 元数据表结构详解 HDFS学习:HDFS机架感知与副本放置策略 Yarn【label-based sch...

34511
来自专栏破晓之歌

Redis安装和初步使用 原

获取安装包:https://github.com/MSOpenTech/redis

892
来自专栏landv

centos查看系统/硬件信息及运维常用命令

[root@yan-001 ~] # uname -a # 查看内核/操作系统/CPU信息的linux系统信息命令

1022

扫码关注云+社区