Linux 基础知识(五)

一、每12小时备份并压缩/etc/目录到/back目录中,保存文件名格式为,etc-年-月-日-时-分.tar.gz)

crontab -e
*12/*** /usr/bin/tar -czf `date +%F-%H-%M`-etc.tar.gz /etc/

 
 
二、rpm包管理功能总结以及实例应用演示
rpm命令:rpm [OPTIONS] [PACKAGE_FILE]
安装:-i, --install
升级:-U, --update, -F, --freshen
卸载:-e, --erase
查询:-q, --query
校验:-V, --verify
数据库维护:--builddb, --initdb

    安装:
        rpm {-i|--install} [install-options] PACKAGE_FILE ...

            rpm  -ivh  PACKAGE_FILE ...

            GENERAL OPTIONS:
                -v:verbose,详细信息
                -vv:更详细的输出

            [install-options]:
                -h:hash marks输出进度条;每个#表示2%的进度;
                --test:测试安装,检查并报告依赖关系及冲突消息等;
                --nodeps:忽略依赖关系;不建议;
                --replacepkgs:重新安装

                注意:rpm可以自带脚本;
                    四类:--noscripts
                        preinstall:安装过程开始之前运行的脚本,%pre , --nopre
                        postinstall:安装过程完成之后运行的脚本,%post , --nopost
                        preuninstall:卸载过程真正开始执行之前运行的脚本,%preun, --nopreun 
                        postuninstall:卸载过程完成之后运行的脚本,%postun , --nopostun

                --nosignature:不检查包签名信息,不检查来源合法性;
                --nodigest:不检查包完整性信息;

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

            -U:升级或安装;
            -F:升级

            rpm  -Uvh PACKAGE_FILE ...
            rpm  -Fvh PACKAGE_FILE ...

                --oldpackage:降级;
                --force:强制升级;

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

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

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

    查询:
            -a, --all:查询所有已经安装过的包;
            -f  FILE:查询指定的文件由哪个程序包安装生成;

            -p, --package PACKAGE_FILE:用于实现对未安装的程序包执行查询操作;

            --whatprovides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供;
            --whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖;

        [query-options]
            --changelog:查询rpm包的changlog;
            -l, --list:程序安装生成的所有文件列表;
            -i, --info:程序包相关的信息,版本号、大小、所属的包组,等;
            -c, --configfiles:查询指定的程序包提供的配置文件;
            -d, --docfiles:查询指定的程序包提供的文档;
            --provides:列出指定的程序包提供的所有的CAPABILITY;
            -R, --requires:查询指定的程序包的依赖关系;
            --scripts:查看程序包自带的脚本片断;

        用法:
            -qi  PACKAGE, -qf FILE, -qc PACKAGE, -ql PACKAGE, -qd PACKAGE
            -qpi  PACKAGE_FILE, -qpl PACKAGE_FILE, -qpc PACKAGE_FILE, ...

    校验:
        rpm {-V|--verify} [select-options] [verify-options] 

        S file Size differs
        M Mode differs (includes permissions and file type)
        5 digest (formerly MD5 sum) differs
        D Device major/minor number mismatch
        L readLink(2) path mismatch
        U User ownership differs
        G Group ownership differs
        T mTime differs
        P caPabilities differ

包来源合法性验正和完整性验正:
    来源合法性验正:
    完整性验正:

    获取并导入信任的包制作者的密钥:
        对于CentOS发行版来说:rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

    验正:
        (1) 安装此组织签名的程序时,会自动执行验正;
        (2) 手动验正:rpm -K PACKAGE_FILE

数据库重建:
    rpm管理器数据库路径:/var/lib/rpm/
        查询操作:通过此处的数据库进行;

    获取帮助:
        CentOS 6:man rpm
        CentOS 7:man rpmdb

        rpm {--initdb|--rebuilddb} [--dbpath DIRECTORY] [--root DIRECTORY]
            --initdb:初始化数据库,当前无任何数据库可实始化创建一个新的;当前有时不执行任何操作;
            --rebuilddb:重新构建,通过读取当前系统上所有已经安装过的程序包进行重新创建;

 
 
三、写一个脚本实现以下菜单给用户
(1) disk:show disk info 信息
(2) mem:show memory info 信息
(3) cpu:show cpu info 信息
(*) quit
 

#!/bin/bash
echo '(1) disk: show disk info'
echo '(2) mem: show memory info'
echo '(3) cpu: show cpu info'
echo '(*) quit'
read -p "Your chioce: " chioce

if [[ "$chioce" == "1" ]]; then
        fdisk -l /dev/sd[a-z]
elif [[ "$chioce" == "2" ]]; then
        free -h
elif [[ "$chioce" == "3" ]]; then
        lscpu
elif [[ "$chioce" == "*" ]]; then
        exit 0
else
        echo "Unknow chioce."
        exit 0
fi

 
四、sed用法总结并结合实例演示
语法
sed [-hnV][-e<script>][-f<script文件>][文本文件]

常用选项:
-n∶使用安静(silent)模式。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e∶直接在指令列模式上进行 sed 的动作编辑;
-f∶直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed 动作;
-r∶sed 的动作支援的是延伸型正规表示法的语法。
常用命令:
d:删除;
p:显示模式空间中的内容;
a \text:在行后面追加文本“text”,支持使用\n实现多行追加;
i \text:在行前面插入文本“text”,支持使用\n实现多行插入;
c \text:把匹配到的行替换为此处指定的文本“text”;
w /PATH/TO/SOMEFILE:保存模式空间匹配到的行至指定的文件中;
r /PATH/FROM/SOMEFILE:读取指定文件的内容至当前文件被模式匹配到的行后面;文件合并;
=:为模式匹配到的行打印行号;
!:条件取反;
地址定界!编辑命令;
s///:查找替换,其分隔符可自行指定,常用的有s@@@, s###等;
替换标记:
g:全局替换;
w /PATH/TO/SOMEFILE:将替换成功的结果保存至指定文件中;
p:显示替换成功的行;

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

示例
sed 's/123/456/g' 替换全部123为456
sed 's/123/456/1' 替换每行第一个123为456
sed 's/123/456/2' 替换每行第二个123为456
 
显示除前3行内容
sed -n '1,3!p' /etc/passwd
 
显示第3行及之后3行
sed -n '3,+3p' /etc/passwd
 
文件第一行插入###
sed '1i####' /etc/passwd >a.txtbr/> 
文件未追加@@@
sed '$a@@@' /etc/passwd >a.txt
 
文件第3行替换$$$
sed '3c$$$' /etc/passwd >a.txt
 
文件2~4行复制文件尾
sed '2,4H;$G' /etc/passwd >a.txt
sed '2,4H;$G' 111 >333
 
删空白行
sed '/^$/d' /etc/passwd >a.txt
 
fstab 包含xfs 写入新文件
sed '/xfs/w 111' /etc/fstab
 
sed -n 'n;p' FILE:显示偶数行;
 
sed '1!G;h;$!d' FILE:逆序显示文件的内容;
 
sed ’$!d' FILE:取出最后一行;
 
sed '$!N;$!D' FILE:取出文件后两行;
 
sed '/^$/d;G' FILE:删除原有的所有空白行,而后为所有的非空白行后添加一个空白行;
 
sed 'n;d' FILE:显示奇数行;
 
sed 'G' FILE:在原有的每行后方添加一个空白行;
 
五、用bash实现统计访问日志文件中状态码大于等于400的IP数量并排序


sed -n -r '/\<40[0-9]\>/p' /var/log/httpd/access_log|awk '{print $1}' |sort|uniq -c 

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

  
 创建目录复制安装包
 

mkdir -pv /localrepo
cp /data/www/centos7/Packages/curl-7.29.0-51.el7.x86_64.rpm /localrepo/
cp /data/www/centos7/Packages/ftp-0.17-67.el7.x86_64.rpm /localrepo/
cp /data/www/centos7/Packages/openssh-7.4p1-16.el7.x86_64.rpm /localrepo/
cp /data/www/centos7/Packages/wget-1.14-18.el7.x86_64.rpm /localrepo/
cp /data/www/centos7/Packages/tcpdump-4.9.2-3.el7.x86_64.rpm /localrepo/

 
创建yum仓库

yum install createrepo
creatrepo /localrepo/

 
配置仓库

vim /etc/yum.repos.d/local.repo
[localrepo]
name=localrepo
baseurl=file:///localrepo
enabled=1  
gpgcheck=0 

 
显示仓库

yum repolist                   
Loaded plugins: fastestmirror, langpacks
Loading mirror speeds from cached hostfile
 * base: mirrors.aliyun.com
 * extras: mirrors.aliyun.com
 * updates: mirrors.aliyun.com
localrepo                                                                                                   | 2.9 kB  00:00:00     
localrepo/primary_db                                                                                        | 6.0 kB  00:00:00     
repo id                                        repo name                                                                     status
base/7/x86_64                                  CentOS-7 - Base - mirrors.aliyun.com                                          10,019
epel/x86_64                                    Extra Packages for Enterprise Linux 7 - x86_64                                12,874
extras/7/x86_64                                CentOS-7 - Extras - mirrors.aliyun.com                                           321
localrepo                                      localrepo                                                                          5
updates/7/x86_64                               CentOS-7 - Updates - mirrors.aliyun.com    

 
安装软件

yum install -y ftp openssh curl wget tcpdump

猜你喜欢

转载自blog.51cto.com/14074807/2346259