yum -y list java* 缓存加载不了_rpm和yum的使用,程序包编译安装以及编译apache过程中出现的问题...

一、rpm包管理

用法:

rpm [选项...]
查询/验证软件包选项:
-a, --all 查询/验证所有软件包
-f, --file 查询/验证文件属于的软件包
-g, --group 查询/验证组中的软件包
-p, --package 查询/验证一个软件包
--pkgid query/verify package(s) with package identifier
--hdrid query/verify package(s) with header identifier
--triggeredby query the package(s) triggered by the package
--whatrequires query/verify the package(s) which require a dependency
--whatprovides 查询/验证提供相关依赖的软件包
--nomanifest 不把非软件包文件作为清单处理

查询选项(用 -q 或 --query):
-c, --configfiles 列出所有配置文件
-d, --docfiles 列出所有程序文档
-L, --licensefiles list all license files
--dump 转储基本文件信息
-l, --list 列出软件包中的文件
--queryformat=QUERYFORMAT 使用这种格式打印信息
-s, --state 显示列出文件的状态

验证选项(用 -V 或 --verify):
--nofiledigest 不验证文件摘要
--nofiles 不验证软件包中文件
--nodeps 不验证包依赖
--noscript 不执行验证脚本

安装/升级/擦除选项:
--allfiles 安装全部文件,包含配置文件,否则配置文件会被跳过。
--allmatches 移除所有符合 的软件包(如果
被指定未多个软件包,常常会导致错误出现)
--badreloc 对不可重定位的软件包重新分配文件位置
-e, --erase=+ 清除 (卸载) 软件包
--excludedocs 不安装程序文档
--excludepath= 略过以 开头的文件
--force --replacepkgs --replacefiles 的缩写
-F, --freshen=+ 如果软件包已经安装,升级软件包
-h, --hash (和 -v 一起使用效果更好),以#显示程序包管理
执行进度;每个#表示2%的进度
--ignorearch 不验证软件包架构
--ignoreos 不验证软件包操作系统
--ignoresize 在安装前不检查磁盘空间
-i, --install 安装软件包
--justdb 更新数据库,但不修改文件系统
--nodeps 不验证软件包依赖
--nofiledigest 不验证文件摘要
--nocontexts 不安装文件的安全上下文
--noorder 不对软件包安装重新排序以满足依赖关系
--noscripts 不执行软件包脚本
--notriggers 不执行本软件包触发的任何脚本
--nocollections 请不要执行任何动作集
--oldpackage 更新到软件包的旧版本(带 --force
自动完成这一功能)
--percent 安装软件包时打印百分比
--prefix=
如果可重定位,便把软件包重定位到
--relocate== 将文件从 重定位到
--replacefiles 忽略软件包之间的冲突的文件
--replacepkgs 如果软件包已经有了,重新安装软件包
--test 不真正安装,只是判断下是否能安装
-U, --upgrade=+ 升级软件包
所有 rpm 模式和可执行文件的通用选项:
-D, --define=“MACRO EXPR” 定义值为 EXPR 的 MACRO
--undefine=MACRO undefine MACRO
-E, --eval=“EXPR” 打印 EXPR 的宏展开
--macros= 从文件 <...> 读取宏,不使用默认文件
--nodigest 不校验软件包的摘要
--nosignature 不验证软件包签名
--rcfile= 从文件 <...> 读取宏,不使用默认文件
-r, --root=ROOT 使用 ROOT 作为顶级目录 (default: "/")
--dbpath=DIRECTORY 使用 DIRECTORY 目录中的数据库
--querytags 显示已知的查询标签
--showrc 显示最终的 rpmrc 和宏配置
--quiet 提供更少的详细信息输出
-v, --verbose 提供更多的详细信息输出
--version 打印使用的 rpm 版本号
最常用到的选项是:rpm -ivh PACKAGE_FILE

最常见rpm包的地方就是我们的centos安装光盘,这里我挂载一个安装光盘并进入到其中

5656ddc52f8bb9f308ac8350983b896c.png

aaac90e3d9de023f72e73ea3ba82acc6.png

其中的Packages文件夹中就存放这非常多的rpm包

440bbb6496dbebc51c7313814e3e759b.png

b48a17343041d44f0a35af45fb47408c.png

我们先导入光盘中的公钥,这样可以保证rpm包的合法性

d570339660143e763309006fa95ad5da.png

再新建数据库,方便rpm包的安装

e54373167e08dfd79807aba7b08d89ef.png

安装一个rmp包试试

a0a8f472caf5a0e17bc1e5892030fa97.png

因为包与包之间存在依赖性,所以必须手动解决依赖性或忽略依赖性,这是rpm工具的弱点,所以有了yum作为rpm的补充,后面会降到yum,这里我们忽略依赖性安装

0164666190c4da17dd543538a9c42258.png

将刚才安装的包卸载掉,选项为-e

2e50a21d6c4b34e104ad5110b0e6168d.png

二、yum源管理

yum是对rpm的补充,因为rpm工具无法自动解决安装包的依赖问题,而yum很好的解决了这个问题

yum源的配置文件:

/etc/yum.conf:为所有仓库提供公共配置
/etc/yum.repos.d/*.repo:为仓库的指向提供配置

/etc/yum.repos.d/*.repo仓库指向的定义:

[repositoryID]
name=Some name for this repository
baseurl=url://path/to/repository/
enabled={1|0}
gpgcheck={1|0}
gpgkey=URL
enablegroups={1|0}
failovermethod={roundrobin|priority}
默认为:roundrobin,意为随机挑选;
cost=
默认为1000

yum的repo配置文件中可用的变量:

$releasever: 当前OS的发行版的主版本号;
$arch: 平台;
$basearch:基础平台;
$YUM0-$YUM9

国内常用yum源url:

http://mirrors.aliyun.com/

http://mirrors.sohu.com/

http://mirrors.163.com/

yum的命令行选项:

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

yum的子命令:

显示仓库列表:
repolist [all|enabled|disabled]

显示程序包:
list
# yum list [all | glob_exp1] [glob_exp2] [...]
# yum list {available|installed|updates} [glob_exp1] [...]

安装、重新安装程序包:
install package1 [package2] [...]

reinstall package1 [package2] [...] (重新安装)

升级、降级程序包:
update [package1] [package2] [...]

downgrade package1 [package2] [...] (降级)

检查可用升级:
check-update

卸载程序包:
remove | erase package1 [package2] [...]

查看程序包information:
info [...]

查看指定的特性(可以是某文件)是由哪个程序包所提供:
provides | whatprovides feature1 [feature2] [...]

清理本地缓存:
clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]

构建缓存:
makecache

搜索:
search string1 [string2] [...]
以指定的关键字搜索程序包名及summary信息;

查看指定包所依赖的capabilities:
deplist package1 [package2] [...]

查看yum事务历史:
history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]

安装及升级本地程序包:
* localinstall rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use install)
* localupdate rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use update)

包组管理的相关命令:
* groupinstall group1 [group2] [...]
* groupupdate group1 [group2] [...]
* grouplist [hidden] [groupwildcard] [...]
* groupremove group1 [group2] [...]
* groupinfo group1 [...]

1、配置本地yum源

进入/etc/yum.repos.d中

81e1fe8231c70a4210a9e56339b3c841.png

将系统自带的网络yum重命名以免使用,用mv重命名

mv CentOS-Base.repo CentOS-Base.repo.bak

471fb7ea14e760f74f82757b00c0d265.png

将系统光盘挂载到/media/cdrom中

b687b997d41c7a16ac5a8befcbf34b58.png

打开CentOS-Media.repo,在baseurl中加入/media/cdrom

fce9536cb7a195b8aa15bc3f870f416a.png

enabled=1表示启用

用yum install安装一个没安装过的软件试试

2、配置阿里云yum源

在/etc/yum.repos.d中创建一个repo文件,这里我创建的是aliyun.repo

670d2ef02c128bfb7f85d1767be1207c.png

文件中的内容是

2371b356f8ad55f838cf67083b258f0f.png

[Centos7-ailiyun.com]
name=Centos-$releasever-$basearch
baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch
enabled=1
gpgcheck=0
[updates-ailiyun.com]
name=Centos-$releasever-$basearch-updates
baseurl=http://mirrors.aliyun.com/centos/$releasever/updates/$basearch
enabled=1
gpgcheck=0

其中变量$releasever获取的是版本号,$basearch获取的是系统架构(如x86_64)

enabled=1表示启用,gpgcheck=0表示不进行校验

创建完之后构建本地缓存数据库,yum makecache

5edd78e742fc0a2603f250f9c8cdb37e.png

安装一个未安装的软件试试,比如centos7系统中没有ifconfig,我们yum install net-tools.x86_64

256587dd8571ac0ea6669c1ec4fbbc44.png

f972becd9c4bf9cfdd0ad3970a02c866.png

这里可以很明显的看到yum会自动帮你解决依赖关系

3、配置epel源

直接在上面的aliyun.repo中添加一个epel仓库

818ee03e5a09dc6b056ade0f30e8c8e9.png

添加完成之后记得构建缓存

dd1e03495d766185cb8080307bea3f6b.png

三、程序包的编译安装

1、开源源码获取站点

www.Github.com

www.apache.org

2、编译C源代码

前提:提供开发工具及开发环境

开发工具:make, gcc等

开发环境:开发库,头文件

glibc:标准库

通过“包组”提供开发组件

CentOS 6: "Development Tools", "Server Platform Development",

第一步:configure脚本

选项:指定安装位置、指定启用的特性

--help: 获取其支持使用的选项

选项分类:

安装路径设定:
--prefix=/PATH/TO/SOMEWHERE: 指定默认安装位置;默认为/usr/local/
--sysconfdir=/PATH/TO/SOMEWHERE:配置文件安装位置;
System types:
Optional Features: 可选特性
--disable-FEATURE
--enable-FEATURE[=ARG]
Optional Packages: 可选包
--with-PACKAGE[=ARG]
--without-PACKAGE

第二步:

make

第三步:

make install

3、安装并编译httpd-2.4

安装包组提供开发组件

8e850e72e8371c256c95e92ad120a200.png

通过wget下载一个httpd-2.4的源码至本地并解压

ff1cf9f509d07c70cfdf0ad292315999.png

0a69ac181c73db83faf5d955a86d6168.png

指定安装位置和配置文件路径

e0d66a27eaa266f64f65906d24ed94e0.png

报错因为为没找到APR包,那么我们去官网下一个编译安装

74ceba53f0a35f558222c7eb7913b191.png

390317c8eab91c626fe61c01d6dceeae.png

37745953e6c2a95a16cd3450c86a18da.png

5e636cde73204c0412460ddeb4f9ef60.png

make

68a05d327cd3e4a48c8e685fde6a877c.png

make install

4b78a4b394e455e4f31df99b0515a4cd.png

安装完APR后我们回到httpd下继续刚才的编译安装

4ee3686825d1908de5493cb95c4047bb.png

5549cb2cba866f2c5c7b0095271c3961.png

再次报错,缺少APR-util包,按照刚才安装APR包的方法安装

523cd6d0d0ca30bc91de2efc2e9c79fb.png

0ca80f8f10d4acb74d532148b8f0cc61.png

2c55d878c4e4b4dfe9fabf582d61fec9.png

68ec675fdce7a98462ec9431aab13a3d.png

这里需要指明之前APR安装的位置

3df44401c242c7deebcaabad2614bb54.png

安装完APR-util之后,再次安装httpd

f17f35a4e8afc42045e9a0034b3a3ac3.png

编译时注意指明apr或者apr-util的安装位置

4a8c404073f7281efed377a093ad03ac.png

73a77c6fe071e36a1c2b280057012b84.png

再次出错缺少pcre-config,还是按照前面的方法安装编译pcre-config

237782040c59a423761296722dbee9a0.png

04be43f2936728159d6f229fd09df1c0.png

2cc59f0c2bd4d2640a9909dd60f09a72.png

安装完pcre-config后编译httpd还是提示错误,需要安装pcre-devel

8adc9895783162af3f11dbb30a05f7b7.png

这里我们就用yum源安装了

33b985a33bc22706271cbd72e511ab2e.png

再次编译httpd

7a852d303b21cd34ab2c5d7dc3391f72.png

b3b045ad5422546bb8d6762476a81b0b.png

ccf3d044d2630608f82c2e454fcbe13c.png

这次成功了,继续执行make和make install

ca8dd2830f47c4c05f8e7f69ae848f56.png

eea108e4b303ce25a42d3613b14ba638.png

完成后打开httpd服务试试

77c9d2d0ff1e6bed53433ab33a96d063.png

98f6f966bb5610509c79989bda6eb838.png

3da57711505a80c60259c214b5220f99.png

这里需要注意的是,如果网页打不开请关闭selinux.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值