rpm包的功能:将编译好的应用程序的各组成文件打包成一个或者多个程序包文件,从而方便的实现程序包的安装、升级、卸载和查询等功能。
组织格式:(1)程序包的清单文件(即安装或者卸载时需要运行的脚本),每个程序包都单独实现
(2)数据库:/usr/lib/rpm/目录下,主要是提供程序包的名称和版本、包与包的依赖关系、软件功能说明以及安装生成各文件路径及校验信息等
获取程序包的途径:
(1)系统的发行版的光盘或者官方的文件服务器或者镜像站点,主要有http://mirrors.aliyun.com;http://mirrors.suhu.com ; http://mirrors.163.com
(2)项目的官方站点:如http.apache.org ; www.zabix.org
(3)第三方组织,如epel或者搜索工具(pkgs.org 、 rpmfind.net 、rpm.pbone.net)
(4)自己制作的rpm包
rpm程序包管理
Centos系统上rpm命令管理程序包(安装、升级、卸载、查询和校验以及数据库维护)
安装
格式:rpm [OPTIONS] [Package_file]
-i | --install :安装
[install-options] :-v:显示安装过程中的详细信息
-h:以#显示进度条
--test:测试安装,不真正安装,仅报告依赖信息和冲突信息
--nodeps:忽略依赖关系
--replacepkgs:覆盖安装
--force:强制安装
常用组合选项:-ivh;-ivvh(显示更加详细的信息)
演示:安装zsh程序包
~]# rpm -ivh zsh-5.0.2-7.e17.x86_64.rpm
升级
rpm {-U | --update }[install options] PACKAGE_FILE
-U :升级或安装
rpm {-F | --freshen }[install options] PACKAGE_FILE
-F:升级
组合使用:-Uvh;-Fvh
[install options] :
--test:测试安装,不真正安装,仅报告依赖信息和冲突信息
--nodeps:忽略依赖关系
--oldpackages:降级到旧版本
注意:(1)不要对内核执行升级,linux允许多个内核共存,因此可以直接安装多个不同版本的内核
(2)如果程序包的配置文件安装之后曾被修改,升级时,新版本的文件不会覆盖老版本的配置文件,而是把新版本的配置文件重命名后保存(加后缀.rpmnew)
卸载:移除已经安装的程序包
rpm {-e |--erase} [OPTIONS] PACKAGE_FILE
--allmatches:若一个程序包同时安装多个版本,则一次性卸载
--nodeps:忽略依赖关系
--test:测试卸载
查询:查看某包是否已经安装,以及检查安装的所有的包,还可以查询某包的具体信息
用法:rpm {-q | --query} [selece-options] [query-options]
[selece-options] :挑选选项
rpm -q PACKAGE_NAME:查询指定的包是否已经安装以及其版本
rpm -qa :查询已经安装的程序包
rpm -qf /PATH/TO/SMEFILE :查询某文件是由哪个安装包生成
rpm -qpi:查询尚未安装的程序包的相关信息
--whatprovides CAPABILITY :查询制定的CAPABBILITY是由哪个安装包生成
--whatrequires CAPABILITY:查询制定的CAPABBILITY是被哪个安装包所依赖
[query-options] :查询选项
(1)--change:查询某rpm包的修改日志
如:~]# rpm -q --change bash
(2)-l | --list :列出某安装包生成的文件列表
如:~]# rpm -ql bash
(3)-i :查询某包的简要说明信息
如:rpm -qi bash
(4)-c:查询某包安装完成后生成的所有配置文件
如:~]#rpm -qc bash
(5)-d:查询指定程序包提供的帮助文档
如:~]#rpm -qd bash
(6)--provides:列出指定程序包提供的CAPABILITY;--whatprovides:查询bash能力由哪个程序包提供
如:~]#rpm -q --provides bash ; ~]#rpm -q --whatprovides bash
(7)--requires:查询某包依赖的CABABILITY
如:rpm -q --requires bash
(8)--scripts:查询某包安装或卸载时的执行脚本(脚本由4类)
如:rpm -q --scripts bash
四类脚本:preinstall:安装过程开始之前执行的脚本
postinstall:安装过程完成之后执行的脚本
preuninstall:卸载之前执行的脚本
postuninstall:卸载过程完成之后执行的脚本
示例:
[root@192 ~]# rpm -qi bash #########查询bash的简要说明信息
Name : bash
Version : 4.2.46
Release : 30.el7
Architecture: x86_64
Install Date: 2019年07月28日 星期二 21时34分37秒
Group : System Environment/Shells
Size : 3667709
License : GPLv3+
Signature : RSA/SHA256, 2018年04月25日 星期三 18时54分19秒, Key ID 24c6a8a7f4a80eb5
Source RPM : bash-4.2.46-30.el7.src.rpm
Build Date : 2018年04月11日 星期三 08时55分22秒
Build Host : x86-01.bsys.centos.org
Relocations : (not relocatable)
Packager : CentOS BuildSystem <http://bugs.centos.org>
Vendor : CentOS
URL : http://www.gnu.org/software/bash
Summary : The GNU Bourne Again shell
Description :
The GNU Bourne Again shell (Bash) is a shell or command language
interpreter that is compatible with the Bourne shell (sh). Bash
incorporates useful features from the Korn shell (ksh) and the C shell
(csh). Most sh scripts can be run by bash without modification.
[root@192 ~]# rpm -qc httpd ###########查询httpd包安装之后生成的配置文件
/etc/httpd/conf.d/autoindex.conf
/etc/httpd/conf.d/userdir.conf
/etc/httpd/conf.d/welcome.conf
/etc/httpd/conf.modules.d/00-base.conf
/etc/httpd/conf.modules.d/00-dav.conf
/etc/httpd/conf.modules.d/00-lua.conf
/etc/httpd/conf.modules.d/00-mpm.conf
/etc/httpd/conf.modules.d/00-proxy.conf
/etc/httpd/conf.modules.d/00-systemd.conf
/etc/httpd/conf.modules.d/01-cgi.conf
/etc/httpd/conf/httpd.conf
/etc/httpd/conf/magic
/etc/logrotate.d/httpd
/etc/sysconfig/htcacheclean
/etc/sysconfig/httpd
校验:查询安装之后生成的文件是否发生了改变
格式:rpm {-V | verify} [select-option] [verify-option]
[root@192 ~]# rpm -V httpd
3、yum的配置和使用总结以及yum私有仓库的创建。
YUM: Yellowdog Update Modifier,完成RHEL系列前端自动解决依赖关系安装工具,依赖rpm存在
YUM配置文件路径
/etc/yum.conf:为所有yum仓库提供公共配置
/etc/yum.repos.d
/etc/yum.conf 主配置定义
[root@zabbix-mysql ~]# cat /etc/yum.conf
[main] # 通用主配置段
cachedir=/var/cache/yum/x86_64/$releasever # 缓存文件文件路径
keepcache=1 # 缓存到本地的文件是否保存
debuglevel=2 # 调试级别
logfile=/var/log/yum.log # 安装的日志文件
exactarch=1 # 精确严格的平台 release 匹配
obsoletes=1
gpgcheck=1 # 检测来源合法性和完整性
plugins=1 # 支持插件机制
installonly_limit=5 同时安装多少程序包
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php?category=yum
distroverpkg=centos-release #当前发行版本号从哪儿获取
[root@zabbix-mysql ~]# ll /var/cache/yum/x86_64/7
total 28
drwxr-xr-x 4 root root 4096 May 21 23:09 aliyun
drwxr-xr-x 4 root root 4096 Nov 21 18:50 base
drwxr-xr-x 4 root root 4096 Apr 16 2018 centos7-yum
drwxr-xr-x 4 root root 4096 Nov 21 18:50 extras
drwxr-xr-x 4 root root 132 Nov 20 2018 mysql57-community
drwxr-xr-x 4 root root 132 Nov 20 2018 mysql-connectors-community
drwxr-xr-x 4 root root 132 Nov 20 2018 mysql-tools-community
-rw-r--r-- 1 root root 183 May 21 23:09 timedhosts
-rw-r--r-- 1 root root 0 May 21 23:09 timedhosts.txt
drwxr-xr-x 4 root root 4096 Nov 21 18:50 updates
drwxr-xr-x 4 root root 4096 Nov 22 18:16 zabbix
drwxr-xr-x 4 root root 73 Nov 22 18:16 zabbix-non-supported
[root@zabbix-mysql ~]# tail /var/log/yum.log
Feb 14 17:33:08 Installed: apr-util-1.5.2-6.el7.x86_64
Feb 14 17:33:08 Installed: httpd-tools-2.4.6-88.el7.centos.x86_64
Mar 28 09:52:05 Installed: 2:nmap-ncat-6.40-16.el7.x86_64
Apr 08 10:55:19 Installed: libcgroup-0.41-20.el7.x86_64
Apr 08 10:55:19 Installed: libcgroup-tools-0.41-20.el7.x86_64
Apr 08 16:00:21 Updated: 14:libpcap-1.5.3-11.el7.x86_64
Apr 08 16:00:21 Installed: 14:tcpdump-4.9.2-3.el7.x86_64
Apr 28 21:52:15 Installed: iotop-0.6-4.el7.noarch
May 08 18:03:45 Installed: sysstat-10.1.5-17.el7.x86_64
May 21 23:09:34 Installed: 2:nmap-6.40-16.el7.x86_64
**yum仓库(*.repo)配置文件定义**
[root@zabbix-mysql yum.repos.d]# cat aliyun.repo
[aliyun] # 仓库ID
name=aliyun
baseurl=http://mirrors.aliyun.com/centos/7/os/x86_64 # yum 仓库指定的访问路径(阿里源)
enabled=1 # 启用此仓库
gpgcheck=0 # 检查完整性和来源合法性
YUM 常用命令
- yum repolist 显示仓库列表
- yum list 显示程序包
- yum search 模糊查找程序包
- yum install 安装程序包
- yum remove 卸载程序包
- yum update [package1] [package2] [...] 升级操作
- yum downgrade package1 [package2] [...] 降级操作
- yum info [package1] [package2] [...] 查看程序包简要信息
- yum provides | whatprovides feature1 [feature2] [...] 查看指定的特性(可以是某文件)是由哪个程序包所提供
- yum clean <packages | metadata | expire-cache | rpmdb | plugins | all > 清理本地缓存
// 查看yum仓库
[root@zabbix-mysql yum.repos.d]
创建私有 yum 仓库
-
第一种:使用发行光盘作为yum仓库
mkdir /mnt/cdrom
mount /dev/sr0 /mnt/cdrom
mkdir /etc/yum.repos.d/bak
mv /etc/yum.repos.d/* /etc/yum.repos.d/bak/
#vi /etc/yum.repos.d/mybase.repo
[mybase]
name=LocalYum
baseurl=file:///mnt/cdrom
gpgcheck=0
enabled=1
-
第二种,使用本地或网络rpm包手动创建
- 第一步:安装
createrepo
- 第二步:确定repository输出方式:有两种,本地输出与网络输出。
本地输出:提供一个放置rpm包的本地路径
网络输出 :提供一个文件服务器,配置好ftp服务或http服务(注意防火墙要开放对应端口)
? ftp服务:
? 安装程序包:vsftpd
? 文件存放路径:/var/ftp/pub
启动服务:service vsftpd start
http服务:
? 安装程序包:httpd
? 文件存放路径:/var/ftp/pub
? 启动服务:service httpd start
- 第三步:把rpm 程序包文件放入准备好的目录中,可以从光盘复制rpm 包过去。
- 第四步:对此目录运行
createrepo
命令即可,到此就完成了本地仓库的创建。
- 测试所创建的yum 仓库是否可用
-
在/etc/yum.repos.d/ 目录下创建一个以repo结尾的文件,示例如下:
[root@localhost yum.repos.d]# yum info createrepo //查看已安装的createrepo信息
[root@localhost yum.repos.d]# mkdir -p /yumtest/Packages
[root@localhost yum.repos.d]# cp /media/cdrom/Packages/* /yumtest/Packages/ //下载所需要的所有文件到本地某个路径
[root@localhost yum.repos.d]# createrepo /yumtest/ //创建关联关系,完成后生成repodata
root@localhost yum.repos.d]# cat Local.repo //配置yum源文件
[Local]
name=Local Yum
baseurl=file:///yumtest/
#baseurl=http://<repo_host>/Packages //当为http网络输出时,用此配置。<repo_host>仓库主机IP,Packages为http发布目录下的软件包目录
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
enabled=1
[root@localhost yum.repos.d]# yum repolist //查看配置好的yum仓库
(2)mem: show memory info信息
[root@etcd03 tmp]# cat test1.sh
#!/bin/bash
read -p "Your choice:" choice
case $choice in
disk)
fdisk -l;;
mem)
cat /proc/meminfo;;
cpu)
lscpu;;
*)
exit;;
esac
5、sed用法总结并结合实例演示
常用选项
-n:不输出模式空间中的内容至屏幕;
-e script, --expression=script:多点编辑;
-f /PATH/TO/SED_SCRIPT_FILE : 每行一个编辑命令;
-r, --regexp-extended:支持使用扩展正则表达式;
-i[SUFFIX], --in-place[=SUFFIX]:直接编辑原文件 ;
1)空地址:什么都不填写时,表示对全文进行处理
2)单地址
#,
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:显示替换成功的行;
sed -i ‘s/text/replace/g‘ file
#/3g标记替换第3次出现后的匹配:
echo "thisthisthisthisthis" | sed ‘s/this/THIS/3g‘
thisthisTHISTHISTHIS
#通过正则表达式\w\+匹配每一个单词,然后用[&]替换它。&对应于之前所匹配到的单词。
echo "this is an example" | sed ‘s/\w\+/[&]/g‘
[this] [is] [an] [example]
echo "sever EIGHT" | sed
6、 用bash实现统计访问日志文件中状态码大于等于400的IP数量并排序
#!/bin/bash
nginx_log=‘/usr/local/nginx/logs/host.access.log‘
code_400_count=$(awk ‘($9 >= 400) {print $1}‘ ${nginx_log} | sort -rn | uniq -c)
echo $code_400_count
7、 使用自制的yum源安装ftp、openssh、curl、wget、tcpdump等软件包
**关闭其它非自制yum源,设置*.repo文件中相应的enabled=0**
yum install -y ftp --enablerepo=Local Yum
yum install -y openssh --enablerepo=Local Yum
yum install -y curl --enablerepo=Local Yum
yum install -y wget --enablerepo=Local Yum
yum install -y tcpdump --enablerepo=Local Yum