rpm程序包管理器;
1.rpm命令行工具
2.yum工具;
rpm命令行工具;
功能;
1.将编译好的应用程序的各个组成文件打包成一个或多个程序包文件;
2.软件包的安装,卸载,升级,查询,校验及数据库管理功能
rpm程序包中文件的组成清单;
1.程序的文件
2.文件清单
3.软件安装或卸载时所运行的脚本文件;共分为四类
preinstall;在正式的安装操作开始之前所运行的脚本,A%pre
postinstall;在安装完成后所执行的脚本,%post
preuninstall;在正式卸载操作开始之前所运行的脚本,%preun
postuninstall;在卸载完成后所执行的脚本,%postun
rpm数据库(公共);
已经安装好的程序包名称及版本
/var/lib/rpm
获取程序包的途径;
1.系统的发行版的光盘
2.官方的文件服务器或镜像站点;
http://mirrors.aliyun.com
http://mirrors.sohu.com
http://mirrors.163.com
3.某个项目的官方站点;
4.第三方组织制作的rpm程序包站点
Fedora EPEL;红帽官方的社区组织,在镜像站点中也包含EPEL镜像
搜索引擎;
http://pkgs.org
http://rpmfind.net
http://pbone.net
5.自己制作
建议;获得程序包之后,实施完整性检查
来源合法性;
通过程序提供者的数字签名加密的数据,我们通过其公钥进行解密验证;
程序包完整性;
sha-1校验码
rpm和yum两个工具的使用
rpm命令行工具:
安装,卸载,升级(降级),查询,校验,认证,数据库维护
rpm命令的通用选项;
-v;显示安装例程的信息,仅仅显示安装软件名
-vv;显示非常详细的操作信息,
安装:
rpm {-i|--install} [install-options] PACKAGE_FILE ...
install-options
-h, --hash;用50个“#”来表示安装进度
--test;并不是真正的安装软件包,仅仅是测试是否在安装时能够正常完成,dry run模式;
--nodeps;忽略,因为依赖关系导致的安装错误,不建议使用
--replacefiles;在安装软件包时,软件包中的文件会直接将原来安装的文件替换
--replacepkgs;无需卸载软件包而重新安装
--noscripts;不运行任何脚本
--nopre
--nopost
--nosignature;不考虑软件包的来源是否合法
--nosdigest;不考虑软件包是否完整
安装例子;
(暂缺)
升级;
rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
如果选择被安装的程序包事先并未安装,则全新安装,如果已经安装了旧版本,则可以升级安装;
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
仅仅只能对已经安装的低版本的程序包进行升级安装
常用选项,与安装相同
--oldpackage;降级安装,用老版本的程序包替换新版本的程序包
--force;强制升级
注意;
1.强烈建议,不要对内核进行升级操作,linux可以支持多内核,可以直接安装新版本的内核,在启动界面可以手动更换
2.升级安装可能会带来文件的变化,因此,系统默认不会直接更改之前安装过的软件的配置文件,新程序包中的配置文件会被重命名,通常回事;FINENAME.rpmnew
卸载;
rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts]
[--notriggers] [--test] PACKAGE_NAME ...
--allmatches;卸载所有匹配指定名称的程序包的各个版本
--nodeps;卸载时忽略依赖关系,不建议使用
--test;测试卸载,dry run模式
查询;
rpm {-q|--query} [select-options] [query-options]
选项;
[select-options]
PACKGE_NAME;直接给出程序包名
-a,--all;查询所有已经安装的程序包名
~]# rpm -qa |grep mysq1
-f,--file FILE;查找指定的文件是由哪个程序包提供的
-p,--package PACKAGE_FILE;对还没有安装的程序包文件中执行查询操作
--whatprovides CAPABILITY;查询指定的CAPABILITY是由哪个程序包提供的
--whatrequires CAPABILITY;查询指定的CAPABILITY被哪个程序包所依赖
[query-options]
--changelog;查询rpm程序包的changelog
-c,--configfiles;查询指定程序包中有哪些是配置文件
-d,--docfiles;查询指定程序包中有哪些文档文件
-i,--info;查询程序包的相关信息,包括版本号,发行号,程序包大小,描述等
-l,--list;列表显示程序包安装会产生哪些文件
--provides;列出指定程序包所提供的所有的CAPABILITY;
-R,--requires;查询指定程序包的依赖关系
--scripts;查看程序包所携带的脚本的内容
具体使用方法;
-qf FILE
-qc|-ql|-qd|-qi PACKGE_NAME
-qpl|-qpc|-qpd|-qpi PACKGE_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
认证;
rpm --imper /PATH/TO/KEY_FILE
rpm -K /PATH/TO/PACKAGE_FILE
数据库管理;
数据库的初始化管理
/var/lib/rpm
rpm {--querytags|--showrc}
rpm ;
1.安装 -i
2.升级 -U/-F
3.卸载 -e
4.查询 -q [select-option] [query-option]
5.校验 -V
6.导入验证码,验证
7.数据库管理
linux程序包管理之二
程序包管理的前端工具;
centos系;yum. dnf
yum;
Yellowdog Updater Modified
Yellowdog是一款发行版linux,使用rpm作为默认的程序包管理工具
URL;yum定位软件仓库中程序包文件的主要标识方式;
scema;//[username@]hostname[:port][/PATH/TO/DOCUMENT][parameters][method]
yum是C/S结构的模型,其中服务器也称为软件仓库(yum repository),客户端需要书写URL以指定服务器及程序包路径
在服务器上。软件仓库其实就是一个目录,在目录中包含了程序包文件以及元数据文件;
元数据文件统一的存放于repodata的目录中;也可以是,repodata目录所在的路径即为软件仓库的路径;
createrepo命令;
createrepo - Create repomd (xml-rpm-metadata) repository
createrepo [options] <directory>
<directory>;存放程序包的目录
客户机的使用;
yum程序包
yum主配置文件;/etc/yum.conf
ini风格的配置信息模式;分段式配置内容
[repositoryid]
statements
注意;所有的配置语句,其生效的范围是从一个[]开始,到下一个[]结束
例如;
[repo1]
statements
[repo2]
statements
注意;
1.repositoryid必须全局唯一
2.repositoryid不能包括除了.和_之外的任何特殊字符,可以包含字母和数字,字母严格区分大小写机制;
/etc/yum.conf文件的内容
[main]
cachedir=/var/cache/yum/$basearch/$releasever
keepcache=0
debuglevel=2
logfile=/var/log/yum.log
exactarch=1
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
想要更加全面的信息,可以使用man 5 yum.conf获取;
# PUT YOUR REPOS HERE OR IN separate files named file.repo in /etc/yum.repos.d
用户自定义的repository的指向信息,可以写在主配置文件中,也可以将用户自定义的repository的指向信息,以.repo为文件后缀名,并且存放于/etc/yum.repos.d目录中;
主配置文件;
/etc/yum.conf
只提供yum仓库指向信息的公共配置内容;
注意;该文件一般情况下,不进行任何修改;
片段配置文件;
/etc/yum.repos.d/*.repo
每一个以.repo为后缀名的文件,即为一个仓库文件;这样的每个文件中可以配置指向一个或多个yum仓库
yum程序在查找yum仓库的时候,根据这些配置文件来查找的,每一次可能会找到多个yum仓库,从所有可以使用的仓库文件中查找最新版本的程序包并缓存到本地进行安装,升级等操作;
同类的多个仓库被称为镜像;只要有一个可用即可;
不同类的仓库也可以同时存在多个,yum可以同时使用这些仓库
.repo文件该如何定义;
[repositoryid]
name=Full name of repository
baseurl=schema://hostname/PATH/TO/REPOADTA
schema;
http[s].ftp.nfs;网络服务器指向
file;本地服务器指向
mirrorlist=mirror_url
enabled={0|1};0表示禁用此仓库指向,1表示启用,如果没有enabled语句,默认为启用状态;
gpgcheck={0|1};0标识不进行程序包认证,1表示认证;如果为1;需要指定认证所需要的公钥文件,需要使用gpgkey语句
gpgkey=schema;//hostname/PATH/TO/PUBLIC_KEY_FILE
例子;gpgkey=file:///etc/pki/rpm-gpg/rpm-gpg-key-centos-$releasever
failovermethod={roundrobin|priority}
故障倒换方法;
roundrobin;随机查找,默认的方法
priority;按照顺序一次选择
enablegroups={1|0}
cost=num,默认所有仓库的开销值都是1000;
一般的repo指向内容;
[repoid]
name=
#mirrorlist=
enbaled=1
gpgcheck=0
#gpgkey=
yum命令的方法;
yum - Yellowdog Updater Modified
yum [options] [command] [package ...]
[options];
-y, --assumeyes;对于yum执行过程中与用户交互的问题,全部以yes回答
-q, --quiet;安静模式;在yum执行过程中,没有任何信息输出到stdout
--enablerepo=repoidglob
--disablerepo=repoidglob
在yum执行过程中明确的规定启用或禁用某个repository指向,在使用了这样的选项之后,仓库指向文件只on个的enabled语句的作用将失效
--noplugins;
在某一次yum执行过程中,明确指出不使用任何插件
--nogpgcheck;
在某一次yum执行过程中,明确指出不验证程序包完整性,在仓库指向文件中的gpgcheck=1语句会失效
[command];
command is one of:
* install package1 [package2] [...]
安装程序包
注意;
1.如果只是给出程序包名称,yum搜索所有仓库,并找到最新版本缓存安装;
2.如果给出程序包的名称及版本,则查找安装指定版本的程序包;
3.如果给出的程序包是完整的程序包名,则只是查找某一个程序包;
4.程序包名称可以使用globbing,(* ? [] [^])
* update [package1] [package2] [...]
* update-to [package1] [package2] [...]
* update-minimal [package1] [package2] [...]
* check-update
* upgrade-to [package1] [package2] [...]
程序包升级或降级;
程序包不同版本之间的更迭;
* remove | erase package1 [package2] [...]
卸载程序包;
* list [...]
yum list LIST OPTIONS
LIST OPTIONS
all;显示所有的程序包;包括已经安装的和尚未安装但可用的;
注意;
anaconda;centos系统的安装器,在安装操作系统的时候一并安装的程序包;
installed;显示所有已经安装的程序包
available;显示所有尚未安装但可以安装的程序包
updates;显示所有可以升级更新的程序包
* info [...]
yum info LISI OPTIONS
LIST OPTIONS
all;显示所有的程序包,包括已经安装的和尚未安装但可用的
注意;
anaconda;centos系统的安装器,在安装操作系统的时候一并安装的程序包;
installed;显示所有已经安装的程序包
available;显示所有尚未安装但可以安装的程序包
updates;显示所有可以升级更新的程序包
* provides | whatprovides feature1 [feature2] [...]
查看指定的特性是由哪个程序包提供的
* clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
清理本地缓存信息
* makecache [fast]
构建缓存
* groupinstall group1 [group2] [...]
* groupupdate group1 [group2] [...]
* grouplist [hidden] [groupwildcard] [...]
* groupremove group1 [group2] [...]
* groupinfo group1 [...]
程序包组的管理命令;
* search string1 [string2] [...]
根据关键字进行匹配,默认情况下,搜索程序包名称及汇总信息,模糊搜索
* shell [filename]
给yum提供一个交互式命令的操作界面
* localinstall rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use install)
* localupdate rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use update)
实现本地程序包管理,即;不依赖于软件仓库,直接对rpm格式包文件进行操作;
这两个命令已经被停用,使用install取代
* reinstall package1 [package2] [...]
重新安装
* deplist package1 [package2] [...]
显示每个程序包所有的依赖关系
* repolist [all|enabled|disabled]
列表显示yum仓库的元数据信息
在没有给出后面的参数的时候,默认为enabled
* version [ all | installed | available | group-* | nogroups* | grouplist |
groupinfo ]
* history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]
查看yum事务的历史;
安装,升级,卸载等操作的时候,yum会开启事务
* load-transaction [txfile]
重新启动已经停止的事务
* check
* help [command]
centos7中yum命令;
程序包的管理命令;
* groups [...]
groups {install | remove |list | info | update}
别名;groupinstall groupremove grouplist groupoinfo groupudpate
* autoremove [packagel] [...]
自动卸载
* repoinfo [all|enabled|disabled]
常用的第三方yum仓库,Fedora EPEL
到官方站点或镜像站点中,下载epel
release程序包,并且使用rpm命令装至对应的linux发行版本,在/etc/yum.repos.d目录中,会多一个epel.repo的文件;更新repolist即可使用
要求linux虚拟机能够链接互联网
yum的repo配置文件中的变量;
$releasever;当前操作系统的发行版本的主版本号;
如;centos7.2-1511,其发行版本的主版本号是7
centos 6.7 其发行版本的主版本号是6
$basearch;当前计算机所使用的基础平台架构类型;
如;intel兼容机
i686
x86_64
apple计算机设备
ppc
ppc64
$arch;平台架构类型
$YUM0~$YUM9;yum内置由用户自定义的10个变量
为什么要用这些变量?
服务器(repository,仓库):必须能够提供所有的常用发行版本以及平台相关的程序包;但是服务器无法预测任何一个客户端具体的版本使用情况;
所以让用户自行选择
创建本地yum仓库;
createrepo /PATH/TO/PACKAGES
centos程序包管理器之编译安装
为什么要进行源代码编译安装?
1.对应的程序包并不能直接获取到;
2.已经编译好的二进制中,尚不包含我们所需要的功能;
3.已经编译好的二进制中,包含的功能太多,我们并不需要
源代码包有两种;
由程序员直接打包的源代码;name-VERSION.tar.gz
由第三方利用rpm工具制作的rpm源代码包,name-VERIONS-release.src.rpm
/usr/src/name-VERIONS
源代码的组织形式;
1.多文件组成
2.文件中的代码之间,甚至是不同文件的代码段之间都可能存在依赖关系
源代码的项目管理工具;
C/C++项目管理工具;make
java项目管理工具;maven
源代码 --> 预处理(预处理器,cpp) --> 编译(编译器,gcc) --> 汇编(汇编器) --> 链接(链接器) --> 用于执行操作的二进制文件
针对于每个需要编译的源代码文件;都肯会有一个或多个被他依赖的文件或他所依赖的文件,这样的信息会被保存到一个配置文件中,这个配置文件会告诉我们
1.调用哪个预处理器,如何进行预处理
2.调用哪个编译器,如何进行编译;
3.文件的编译顺序等等
这类文件一般是makefile,这样的makefile文件并不是实现存在的,也不是对所有用户的需求都一视同仁的;
程序员可以使用专用的工具,来对于所有的源代码文件进行内容分析和抽取,构建makefile文件,所有的makefile文件都有一个统一的模版————makefile.in
用户可以根据自己的需要,自行构建makefile文件,从而实现能够满足自己需求的编译过程
帮助用户生成makefile文件的通常是一个名为configure的脚本文件;
开发工具;
autoconf;帮助用户生成configure脚本
automake;帮助用户生成makefile.in的模版文件
建议;任何的源代码包,在解压缩之间,都会提供INSTALL或README的文档文件,我们在编译操作之前,最好先查阅此类文件的内容,以确定编译过程
开源程序的源代码的获取方法;
1.官方自检的站点;
apache.org(ASF)
mariadb.org
2.代码的托管站点
sourceforge
github
code.google.com
需要使用编译器;gcc(GNU C Complier)
开发环境的安装;
1.yum groups install “开发工具”
yum groups install “Development”
centos6;
yum groupinstall “Development Tools”“Server platform Development”
“desktop platform develoment”
2.yum install make automake autoconf gcc glibc qt ncurses
通常来讲,linux系统中的编译安装程序的三大步骤;
1.configure [options...]
2.make
3.make install
第一步;
./configure [options...] [VAR=VALUE]...
常用选项分类;
1.安装路径的设定;
--prefix=/PATH/TO/SOMEWHERE
指定默认的程序安装路径,如果不给该选项,默认路径/usr/local/
--sysconfdir=DIR
指定配置文件的安装路径
2.系统类型
3.可选特性:
--disable-FEATURE
在编译过程中禁用某种特性或功能
--enable-FEATURE[=ARG]
在编译过程中启用某个特性或功能
4.可选程序包:
--with-PACKAGE[=ARG]
在编译过程中,选择使用额外的程序包
--without-PACKAGE
在编译过程中,不使用额外的程序包
第二步:
make[-j] [#]
第三步:
make install
编译收尾工作:
/usr/local/apache2里面会包含bin, sbin, etc, lib, lib64, include, man, ...
1.导出二进制文件:
创建一个文件: /etc/profile.d/httpd.sh
export PATH=/usr/local/apache2/bin:/usr/local/apache2/sbin:$PATH
2.导出库文件:
创建一个文件:/etc/ld.so.conf.d/httpd.conf
/usr/local/apache2/lib64
ldconfig [-v]
3.导出头文件:
在/usr/include目录中,为编译安装的软件创建头文件的符号链接:
ln -sv /usr/local/apache2/include /usr/include/httpd
4.导出帮助文件:
CentOS6: /etc/man.config
新添加一行:MANPATH=/usr/local/apache2/man
CentOS7: /etc/man_db.conf
新添加一行:MANPATH_MAP=/usr/local/apache2/bin /usr/local/apache2/man
举例安装httpd-2.4.18
1.首先要解决开发工具环境
2.使用适合httpd-2.4.18版本的apr及apr-util工具;
安装apr工具;
安装apr-util工具;
3.需要安装pcre-deve1以满足httpd的正则表达式使用需求
yum -y install pcre-deve1
编译安装httpd
~]# tar xf httpd-2.4.18.tar.gz -C /usr/src
~]# cd /usr/src/httpd-2.4.18
~]# ./configure --with-apr=/usr/local/apr-1.5.2 --with-apr-util=/usr/local/apr-util-1.5.4
~]# make
~]# make install
收尾:
1.导出二进制文件:
vim /etc/profile.d/httpd.sh
export PATH=/usr/local/apache2/bin:$PATH
source /etc/profile.d/httpd.sh
2.导出库文件:
vim /etc/ld.so.conf.d/httpd-x86_64.conf
/usr/local/apache2/modules
ldconfig -v
3.导出头文件:
ln -sv /usr/local/apache2/include /usr/include/httpd
sed命令
vim的末行命令(ex末行命令);
sed;stream editor,流编辑器;按照行为单位,对一个或多个文件进行编辑处理;每一次sed都会处理给定文件中的一行内容
在sed处理文本时,将正在处理的当前行存储到临时的缓冲区中,称为“模式空间”用当前行去匹配给定的PATTERN,如果讷讷感匹配,则使用command编辑出来,如果不匹配,则默认输出至标准输出,然后继续处理下一行;直到文件的末尾。
默认情况下,sed的所有处理行为不会影响源文件的内容;
我们一般会使用sed命令来自动编辑一个或多个文件,简化对文件的循环操作;
sed命令;
sed - stream editor for filtering and transforming text
sed [OPTION]... ‘script’ [input-file]...
选项;
-n, --quiet, --silent;对于不能匹配模式的行,默认不输出到屏幕
-e--verify script, --expression=script;多条件编辑
-f script-file, --file=script-file;从指定的script-file中读取脚本
注意;script-file为一个能够定位到脚本的路径,最好为绝对路径
-i[SUFFIX], --in-place[=SUFFIX];原文件直接编辑操作
-r, --regexp-extended;使sed支持扩展正则表达式
script;
“Addsresse command”
Addsresse(地址定界)
1.空地址;对所有文件的所有行进行处理;
2.单地址;sed对于能够匹配该地址的那唯一一行进行处理;
num;表示行号
/pattern/:能够匹配该模式的所有行
3.地址范围;
addr1,addr2;从adde1开始到addr2结束的中间所有行;
first~step;从first标记的行号开始,以step所代表的数字为步长
addr1,+N;从addr1开始,包括addr1所在行,并继续向后计算N行
addr1,~N;从addr1开始,包括addr1所在行,向后计算addr1*N行
/pattern1/,/pattern2/;从被pattern1匹配的第一行开始计算。一直到被/pattern2/,匹配到的第一行结束
command(处理命令)
=;显示被模式所有空白行行号
例如:sed -n '/^$/=' /etc/grub2.cfg
a \text:在被模式匹配的行的后面追加text的内容,支持使用\n换行,从而实现多行追加;
i \text:在被模式匹配的行的前面插入text的内容,支持使用\n换行,从而实现多行插入;
c \text:将被模式匹配的行的修改为text的内容,支持使用\n换行,从而实现一行变多行;
d:在模式空间中删除被模式匹配的行;这样的行不能再进行标准输出;
注意:在使用d命令的时候,不宜使用-n选项;
p:显示模式空间中被模式匹配的行;
注意:在使用p命令的时候,通常会搭配-n选项;
w filepath:将模式空间中被模式匹配的行,另存到filepath文件中;
r filepath:将filepath文件的内容追加至模式空间中被模式匹配的行之后;
!Command:在模式空间中被模式匹配的行,不执行Command命令;相反,未被模式匹配的行,参会执行Command命令
s///:查找替换,分隔符可以任意更换,只要相同即可;
s@@@, s###, s,,,
s/pattern/text/[control]
s@/etc/fstab@/etc/mtab@
pattern:计划查找并替换的内容
text:要替换的结果
control:如何进行替换
g:行内全部替换
p:显示替换成功的行
w filepath:将替换成功的行另存到filepath文件中;
支持后向引用:
s/\(string\)/&/
s/\(string\)/\1/
高级编辑命令:
h: 把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g: 从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x: 把模式空间中的内容与保持空间中的内容进行互换
n: 读取匹配到的行的下一行覆盖至模式空间
N:追加匹配到的行的下一行至模式空间
d: 删除模式空间中的行
D:删除多行模式空间中的所有行
示例:
sed -n 'n;p' FILE
sed '1!G;h;$!d' FILE
sed '$!N;$!D' FILE
sed '$!d' FILE
sed ‘G’ FILE
sed ‘g’ FILE
sed ‘/^$/d;G’ FILE
sed 'n;d' FILE
sed -n '1!G;h;$p' FILE
grep:文本搜索
sed:文本编辑工具
awk:文件格式化工具