2019-05-27

1、每12小时备份并压缩/etc/目录至/backup目录中,保存文件名称格式为"etc-年-月-日-时-分.tar.gz"

mkdir /backup
crontab -e
1 */12 * * * /bin/tar -zcf /backup/etc-$(date +\%F-\%H-\%M) /etc &>/dev/null
crontab中的用户命令中需要使用%时,需要进行转义

2、rpm包管理功能总结以及实例应用演示。

安装

rpm{-i|--install} [install-options] PAKCKAGE_FILE1...

-h:hash,以#来表示安装进度,每个#表示2%的进度
-v,--verbose:显示安装过程中的详细信息
-vv:更详细信息
--test:不执行真正的安装过程,检查并报告依赖关系及冲突消息等
--nodeps:忽略依赖关系,能成功安装,但未必能成功运行
--replacepkgs:覆盖安装,重新安装并覆盖原有的文件
--force:强制安装

安装时常用的组合:-ivh,-ivvh

升级

rpm{-U | --upgrade}[install-options] PACKAGE_FILE...
-U:升级或安装
rpm{-F|--freshen} [install-options]PCKAGE_FILE...
-F:升级

--test:不执行真正的安装过程,检查并报告依赖关系及冲突消息等
--nodeps:忽略依赖关系,能成功安装,但未必能成功运行
--oldpackage:降级到旧版本

常用组合:-Uvh,-Fvh
注意:1)不要对内核做升级操作;Linux支持多内核版本并存,因此,直接安装新版本内核
2)如果某原程序包的配置文件安装后曾被修改过,升级时,新版本的程序提供的同一个配置文件不会覆盖原有版本的配置文件,而是把新版本的配置文件重命名(FILENAME.rpmnew)后提供

卸载

rpm {-e|--erase}[--allmatches][--nodeps][--noscripts][--test]PACKAGE_NAME...

--nodeps:忽略依赖关系
--test:测试卸载;dry-run模式
--allmatches:卸载所有匹配指定名称的程序包的各版本

注意:如果程序包的配置文件安装后曾被修改,卸载时,此文件通常不会被删除,而是被重命名(FILENAME.rpmsave)后留存

查询

rpm {-q|--query}[select-options][query-options]

[select-options]
-a,--all:查询所有已经安装过的包
-f FILE:查询指定的文件由哪个程序包安装生成
-p,--package PACKAGE_FILE:用于实现对未安装的程序包执行查询操作
--whatprovides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供
--whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖
[query-options]
--changelog:查看某包制作时随版本变化的changlog信息;
-l,--list:某包安装生成的所有文件列表
-i,--info:程序包简要说明信息,版本号,大小,所属的包组等
-c,--configfiles:查询指定的程序包提供的配置文件
-d,--docfiles:查询指定的程序包提供的文档
--provides:列出指定的程序包提供的所有CAPABILITY
-R,--requires:查询指定的程序包的依赖关系
--scripts:查看程序包安装或卸载时执行脚本

脚本有四类:--noscripts
preinstall:安装过程开始之前运行的脚本,%pre,--nopre
postinstall:安装过程完成之后运行脚本,%post,--nopost
preunistall:卸载过程开始执行之前运行的脚本,%preun.--nopreun
postuninstall:卸载过程完成之后运行的脚本,%ppostun,--nopostun

校验

rpm {-V|--verify}[select-options][verify-options]

常见用法:rpm -V PACKAGE_NAME
当没有输出结果时表示软件包完整,当有相应的结果输出表明对应的内容有修改:
S :(file Size differs )文件的容量大小是否被改变
M: (Mode differs) 文件的类型或文件属性(rwx)是否被改变
5: (MD5 sum differs)MD5这一种指纹密码的内容已经不同
D: (Device major/minor number mismatch)设备的主/次代码已经改变
L: (readLink(2) path mismatch)Link路径已改变
U: (User ownership differs)属主已改变
G :(Group ownership differs)属组已改变
T :(mTime differs)文件修改时间已改变
P: caPabilities differ

验证光盘中程序包的来源及完整性:
导入合法KEY文件:rpm --import /path/to/RPM-GPG-KEY-FILE
[select-options]
-a,--all:查询所有已经安装过的包
-f FILE:查询指定的文件由哪个程序包安装生成
-p,--package PACKAGE_FILE:用于实现对未安装的程序包执行查询操作
--whatprovides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供
--whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖
[query-options]
--changelog:查看某包制作时随版本变化的changlog信息;
-l,--list:某包安装生成的所有文件列表
-i,--info:程序包简要说明信息,版本号,大小,所属的包组等
-c,--configfiles:查询指定的程序包提供的配置文件
-d,--docfiles:查询指定的程序包提供的文档
--provides:列出指定的程序包提供的所有CAPABILITY
-R,--requires:查询指定的程序包的依赖关系
--scripts:查看程序包安装或卸载时执行脚本
>>>> 脚本有四类:--noscripts
preinstall:安装过程开始之前运行的脚本,%pre,--nopre
postinstall:安装过程完成之后运行脚本,%post,--nopost
preunistall:卸载过程开始执行之前运行的脚本,%preun.--nopreun
postuninstall:卸载过程完成之后运行的脚本,%ppostun,--nopostun

>校验
>>rpm {-V|--verify}[select-options][verify-options]
>>> 常见用法:rpm -V PACKAGE_NAME
当没有输出结果时表示软件包完整,当有相应的结果输出表明对应的内容有修改:
S :(file Size differs )文件的容量大小是否被改变
M: (Mode differs) 文件的类型或文件属性(rwx)是否被改变
5: (MD5 sum differs)MD5这一种指纹密码的内容已经不同
D: (Device major/minor number mismatch)设备的主/次代码已经改变
L: (readLink(2) path mismatch)Link路径已改变
U: (User ownership differs)属主已改变
G :(Group ownership differs)属组已改变
T :(mTime differs)文件修改时间已改变
P: caPabilities differ
>>>>验证光盘中程序包的来源及完整性:
导入合法KEY文件:rpm --import /path/to/RPM-GPG-KEY-FILE
验证:rpm{ -k|--checksig} PACKAGE_FILE
构建数据库
rpm{--initdb|--rebuilddb} [-v][--depath DIRECTORY]
--initdb:初始化数据库,当前无任何数据库可开始化创建一个新的;当前有时不执行任何操作
--rebuilddb:重建构造,通过读取当前系统上所有已安装过的程序包进行创建

示例

     rpm -ivh /tmp/htop-1.0.3-1.el6.x86_64.rpm 
      rpm -e htop
      rpm -qpi /tmp/htop-1.0.3-1.el6.x86_64.rpm
          warning: /tmp/htop-1.0.3-1.el6.x86_64.rpm: Header V3        
          Name        : htop                         Relocations: (not relocatable)
          Version     : 1.0.3                             Vendor: Fedora Project
          Release     : 1.el6                         Build Date: Sat 31 Oct 2015       03:26:54 AM CST
        Install Date: (not installed)               Build Host: buildvm-22.phx2.fedoraproject.org
        Group       : Applications/System           Source RPM: htop-1.0.3-1.el6.src.rpm
        Size        : 182737                           License: GPL+
        Signature   : RSA/8, Sun 01 Nov 2015 12:06:31 PM CST, Key ID 3b49df2a0608b895
        Packager    : Fedora Project
        URL         : http://hisham.hm/htop/
        Summary     : Interactive process viewer
        Description :
        htop is an interactive text-mode process viewer for Linux, similar to
        top(1).
  rpm -ql htop

3、yum的配置和使用总结以及yum私有仓库的创建。

yum的配置

1)主配置文件:/etc/yum.conf 为各仓库指向提供公共配置文件

cachedir=/var/cache/yum/$basearch/$releasever  #yum下载的RPM包的缓存目录 
keepcache=0  #缓存是否保存,1保存,0不保存
debuglevel=2   #调试级别(0-10),默认为2
logfile=/var/log/yum.log    #yum的日志文件所在的位置
exactarch=1    #在更新的时候,是否允许更新不同版本的RPM包
obsoletes=1      #这是一个update的参数,具体请参阅yum(8),简单的说就是相当于upgrade,允许更新陈旧的RPM包。 
gpgcheck=1     #是否检查GPG(GNU Private Guard),一种密钥方式签名。
plugins=1      #是否允许使用插件,默认是0不允许
installonly_limit=5     #允许保留多少个内核包
bugtracker_url=http://bugs.centos.org/set_project.php? project_id=19&ref=http://bugs.centos.org/bug_report_page.php?    category=yum        
distroverpkg=centos-release   

2)各仓库的定义:/etc/yum.repos.d/*.repo

[fasttrack] #[repositoryid]用于唯一标识repository指向,其必须唯一
name=CentOS-6 - fasttrack #当前仓库描述信息
mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=fasttrack&infra=$infra      
baseurl=http://mirror.centos.org/centos/$releasever/fasttrack/$basearch/
#指明repository的访问路径;URL支持的类型:
      #ftp服务:ftp://SERVER/PATH/TO/REPOSITORY
      #http服务:http://SERVER/PATH/TO/REPOSITORY
    ` #本地目录:file:///PATH/TO/REPOSTIROY
gpgcheck=1 #是否对程序包做校验
enabled=0    #此仓库是否可被使用
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 #指明当前gpgkey文件路径
cost= #指明当前repository的访问开销,默认为1000

使用

  • install package1 [package2] [...]
    * update [package1] [package2] [...]
    * update-to [package1] [package2] [...]
    * check-update
    * upgrade [package1] [package2] [...]
    * upgrade-to [package1] [package2] [...]
    * distribution-synchronization [package1] [package2] [...]
    * remove | erase package1 [package2] [...]
    * list [...]
    * info [...]
    * provides | whatprovides feature1 [feature2] [...]
    * clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
    * makecache
    * groupinstall group1 [group2] [...]
    * groupupdate group1 [group2] [...]
    * grouplist [hidden] [groupwildcard] [...]
    * groupremove group1 [group2] [...]
    * groupinfo group1 [...]
    * search string1 [string2] [...]
    * shell [filename]
    * resolvedep dep1 [dep2] [...]
    * localinstall rpmfile1 [rpmfile2] [...]
    (maintained for legacy reasons only - use install)
    * localupdate rpmfile1 [rpmfile2] [...]
    (maintained for legacy reasons only - use update)
    * reinstall package1 [package2] [...]
    * downgrade package1 [package2] [...]
    * deplist package1 [package2] [...]
    * repolist [all|enabled|disabled]
    * version [ all | installed | available | group-* | nogroups* | grouplist | groupinfo ]
    * history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|roll-
    back|new|sync|stats]
    * load-transaction [txfile]
    * check
    * help [command]

仓库管理

yum repolist:列出已经配置的所有可用仓库
yum repolist [all|enabled|disabled]

yum缓存管理

yum clean:清理缓存
clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
yum makecache:创建缓存,自动连接至每一个可用仓库

程序包安装

yum install package1 [package2] [...]

重新安装(覆盖安装)

yum reinstall package1 [package2] [...]

程序包升级

yum update [package1] [package2] [...]

程序包降级

yum downgrade package1 [package2] [...]

检查可用升级

yum check-update

程序包卸载

yum remove package1 [package2] [...]

查询

查看指定的特性(可以是某文件)是由哪个程序包所提供
provides | whatprovides feature1 [feature2] [...]
查看程序包information
info [...]
在包名和sumary信息中搜索指定的关键字:
search string1 [string2] [...]

安装及升级本地程序包

yum localinstall rpmfile1 [rpmfile2] [...]
yum localupdate rpmfile1 [rpmfile2] [...]

包组管理

安装:yum groupinstall group1 [group2] [...]
升级:yum groupupdate group1 [group2] [...]
列表:yum grouplist [hidden] [groupwildcard] [...]
卸载:yum groupremove group1 [group2] [...]
显示指定包组详情:yum groupinfo group1 [...]

注意:也可直接用install 、remove或update来管理包组,需要在组名前加@符号,如yum install@"Server Platform Development"

yum的命令选项

--nogpgcheck:禁止进行gpg check;
-y:自动回答为“yes”
-q:静默模式
--disablerepo=repoidglob:临时禁用此处指定的repo
--enablerepo=repoidglob:临时启用此处指定的repo
--noplugins:禁用所有插件

yum私有仓库的创建

1.安装createrepo程序包
2.确定repository输出方式
1)本地输出:提供一个放置rpm包的本地路径
file形式
2)网络输出:提供一个文件服务器,配置好ftp服务或http服务
ftp服务:
安装程序包:vsftpd
文件存放路径:/var/ftp/pub
启动服务:service vsftpd start
http服务:
安装程序包:httpd
文件存放路径:/var/www/html
程序包降级
>>>yum downgrade package1 [package2] [...]

>>检查可用升级
>>>yum check-update

>>程序包卸载
>>>yum remove package1 [package2] [...]

>>查询
>>>查看指定的特性(可以是某文件)是由哪个程序包所提供
provides | whatprovides feature1 [feature2] [...]
查看程序包information
info [...]
在包名和sumary信息中搜索指定的关键字:
search string1 [string2] [...]

>>安装及升级本地程序包
>>>yum localinstall rpmfile1 [rpmfile2] [...]
yum localupdate rpmfile1 [rpmfile2] [...]

>>包组管理
>>>安装:yum groupinstall group1 [group2] [...]
升级:yum groupupdate group1 [group2] [...]
列表:yum grouplist [hidden] [groupwildcard] [...]
卸载:yum groupremove group1 [group2] [...]
显示指定包组详情:yum groupinfo group1 [...]
>>>>注意:也可直接用install 、remove或update来管理包组,需要在组名前加@符号,如yum install@"Server Platform Development"

>>yum的命令选项
>>>--nogpgcheck:禁止进行gpg check;
-y:自动回答为“yes”
-q:静默模式
--disablerepo=repoidglob:临时禁用此处指定的repo
--enablerepo=repoidglob:临时启用此处指定的repo
--noplugins:禁用所有插件


>yum私有仓库的创建
>>1.安装createrepo程序包
2.确定repository输出方式
1)本地输出:提供一个放置rpm包的本地路径
file形式
2)网络输出:提供一个文件服务器,配置好ftp服务或http服务
ftp服务:
安装程序包:vsftpd
文件存放路径:/var/ftp/pub
启动服务:service vsftpd start
http服务:
安装程序包:httpd
文件存放路径:/var/www/html
启动服务:service httpd start
注意:确保关闭防火墙服务
3)在准备好的目录中放置rpm程序包
yum remove package1 [package2] [...]

>>查询
>>>查看指定的特性(可以是某文件)是由哪个程序包所提供
provides | whatprovides feature1 [feature2] [...]
查看程序包information
info [...]
在包名和sumary信息中搜索指定的关键字:
search string1 [string2] [...]

>>安装及升级本地程序包
>>>yum localinstall rpmfile1 [rpmfile2] [...]
yum localupdate rpmfile1 [rpmfile2] [...]

>>包组管理
>>>安装:yum groupinstall group1 [group2] [...]
升级:yum groupupdate group1 [group2] [...]
列表:yum grouplist [hidden] [groupwildcard] [...]
卸载:yum groupremove group1 [group2] [...]
显示指定包组详情:yum groupinfo group1 [...]
>>>>注意:也可直接用install 、remove或update来管理包组,需要在组名前加@符号,如yum install@"Server Platform Development"

>>yum的命令选项
>>>--nogpgcheck:禁止进行gpg check;
-y:自动回答为“yes”
-q:静默模式
--disablerepo=repoidglob:临时禁用此处指定的repo
--enablerepo=repoidglob:临时启用此处指定的repo
--noplugins:禁用所有插件


>yum私有仓库的创建
>>1.安装createrepo程序包
2.确定repository输出方式
1)本地输出:提供一个放置rpm包的本地路径
file形式
2)网络输出:提供一个文件服务器,配置好ftp服务或http服务
ftp服务:
安装程序包:vsftpd
文件存放路径:/var/ftp/pub
启动服务:service vsftpd start
http服务:
安装程序包:httpd
文件存放路径:/var/www/html
启动服务:service httpd start
注意:确保关闭防火墙服务
3)在准备好的目录中放置rpm程序包
4)对此目录执crearerepo命令即可

4、写一个脚本实现列出以下菜单给用户:

(1)disk:show disk info信息

(2)mem: show memory info信息

(3)cpu: show cpu info信息

(*)quit

     #!/bin/bash
     #
    cat << EOF
    disk)show disks info
    mem)show memory info
    cpu)show cpu info
    *)QUIT
    EOF 

5、sed用法总结并结合实例演示

sed [OPTION]... ‘script’ [input-file]...[actions]

OPTION(常用选项)

-n:不输出模式空间中的内容至屏幕
-e script,--expression=script:多点编辑
-f /PATH/TO/SED_SCRIPT_FILE
每行一个编辑命令:
-r,--regexp-extended:支持使用扩展正则表达式
-i[SUFFIX],--in-place[-SUFFIX]:直接编辑原文件

‘script'(地址定界编辑命令)

地址定界
(1)空地址:对全文进行处理;
(2)单地址:
#:指定行
/pattern/:被此模式所匹配到的每一行
(3)地址范围
#,#:
#,+#:
#,/part1/
/paer1/,/part2/
$:最后一行
(4)步进:~
1~2:所有奇数行
2~2:所有偶数行

编辑命令
d:删除
p:显示模式空间中的内容;
a \test:在行后面追加文本“test”,支持使用\n实现多行追加
i \test:在行前面插入文本"test",支持使用\n实现多行插入
c \test:把匹配到的行替换为此处指定的文本“test”
w /PATH/TO/SOMEFILE:保存模式空间匹配到的行至指定的文件中
r /PATH/FROM/SOMEFILE:读取指定文件的内容至当前文件被模式匹配到的行后面;文件合并
=:为模式匹配到的行打印行号
!:条件取反

高级编辑命令
h:把模式空间中的内容覆盖至保持空间中;
H:把模式空间中的内容追加至保持空间中;
g: 把保持空间中的内容覆盖至模式空间中;
G :把保持空间中的内容追加至模式空间中;
x:把模式空间中的内容和保持空间中的内容互换
n:覆盖读取匹配到的行的下一行至模式空间中
N:追加读取匹配到的行的下一行至模式空间中
d:删除模式空间中的行
D:删除多行模式空间中的所有行

示例
输出一个绝对路径给sed命令,取出其目录,其行为类似于dirname
echo "/var/log/messeges/" | sed -r 's@[^/]+/?@@' 删除原有的所有空白行,而后为所有的非空白行后添加一个空白行 sed '/^/d;G' FILE

6、 用bash实现统计访问日志文件中状态码大于等于400的IP数量并排序

sed -n -r '/<40[0-9]>/p' /var/log/httpd/access_log | cut -d" " -f1 | sort | uniq -c

7、 使用自制的yum源安装ftp、openssh、curl、wget、tcpdump等软件包

 mkdir /tmp/test
createrepo /tmp/test
 vim /etc/yum.repos.d/CentOS-Test.repo
 [TEST]
name=CentOS-7-TEST
baseurl=file:///tmp/test
gpcheck=0
enabled=1
cost=100
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容