rpm和yum常用命令选项总结

=======rpm命令的使用总结======

安装: 

rpm {-i|–install} [install-options] PACKAGE_FILE …

    -v: verbose

    -vv: more verbose

    -h: 以#显示程序包管理执行进度; 每个#表示2%的进度

    eg:rpm -ivh package

    [install-option]

        –test 测试安装, 但不真正执行安装, dry run模式

        –nodeps 忽略安装关系

        –replacepkgs 重新替换安装

        –nosignature 不检查来源合法性

        –nodigest 不检查包完整性

        –noscript 不执行程序包脚本片段

            %pre 安装前 –nopre

            %post 安装后 –nopost

            %preun 卸载前 –nopreun

            %postun 卸载后 –nopostun

升级:

rpm {-U|–upgrade} [install-options] PACKAGE_FILE …

rpm {-F|–freshen} [install-options] PACKAGE_FILE …

    upgrade: 安装有旧版, 则升级, 如果不存在旧版, 则安装

    freshen: 安装有旧版, 则升级, 如果不存在旧版, 不执行操作

    eg: rpm -Uvh PACKAGE

    eg: rpm -Fvh PACKAGE

        –oldpackage 降级

        –force 

    注意: 1. 不要对内核进行升级操作; Linux支持多内核版本并存, 因此, 对

            直接安装新版内核

          2. 如果源程序包的配置文件安装后曾被修改, 升级时, 新版本提供的同一个

            配置文件不会直接覆盖老版本的配置文件, 而把新版本的文件重命名(FILENAME.rpmnew)后保留

查询:

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

    [select-options]

        -a: 所有包

        -f: 查询指定的文件由哪个程序包生成

        -g: 查询指定包组的程序包

        -whatprovides CAPABILITY

            查询指定的CAPABILITY由哪个PACKAGE提供

            Query all packages that provide the CAPABILITY capability

        –whatrequires CAPABILITY

            查询指定的CAPABILITY别谁所依赖

            Query all packages that require CAPABILITY for proper functioning.

        -p, –package PACKAGE_FILE

            查询未安装的程序包

    [query-options]

        –changelog

            查询更新日志

        -c, –configfiles

            查询配置文件

        –conflicts

            与谁冲突

        -d, –docfiles

            查询程序的文档, 包括帮助文档

        -i, –info

            输出程序信息

        -l, –list

            列出程序安装完成后生成的所有文件

        –scripts

            列出程序包所有脚本

        –triggers, –triggerscripts

            触发器脚本

        -R, –requires

            查询指定的程序包所依赖的CAPABILITY

        –provides

            列出指定程序包所提供的CAPABILITY

==========yum常用命令的总结===========

yum [options] [command] [package …]

    yum repolist:显示仓库列表

        all 显示所有仓库列表

    list显示程序包

        all

        glob_exp1

        avaiable

        updates

        installed

    install PACKAGE1 PACKAGE2 …

    check-update 检查升级

    remove|erase PACKAGE 卸载

            会吧依赖于PACKAGE的包全部卸载

    info PACKAGE 查看包信息

    provides|whatprovides PACKAGE 查看指定的文件或文件时由哪个程序包提供

    clean 清理本地缓存

    makecache 构建缓存

    search STRING 模糊搜索程序包

    reinstall PACKAGE重新安装

    downgrade PACKAGE 降级安装

    deplist显示包的依赖关系

    version 自行man

    history 查看yum进行过的事务

        history summary查看历史事务摘要

        history list 列出事务

        history stats 统计

    loacalinstall 可以解决依赖关系的本地程序包安装, 建议直接使用install

    包组相关命令:

        * groupinstall group1 [group2] […]

            安装

        * groupupdate group1 [group2] […]

            更新

        * grouplist [hidden] [groupwildcard] […]

            列出

        * groupremove group1 [group2] […]

            移除

        * groupinfo group1 […]

            查询信息

=============yum仓库的创建及repo文件的制作===============

yum仓库的创建:

    1. 准备材料: N个rpm包,比如我把CENTOS7安装镜像中的Packages目录复制到了/root/mydata/yum.sr/中;

[root@localhost ~]# ls ./mydata.d/yum.sr/Packages/ | wc -l
3577    <--有3577个package

    2. 使用createrepo命令创建yum仓库:

[root@localhost ~]# createrepo -o /root/mydata.d/yum.sr/ /root/mydata.d/yum.sr/Packages/
    # -o选项用于指定repodata生成的位置,最后一个参数是rpm包们所在的位置。
Spawning worker 0 with 894 pkgs
Spawning worker 1 with 894 pkgs
Spawning worker 2 with 894 pkgs
Spawning worker 3 with 894 pkgs
Workers Finished
Saving Primary metadata
Saving file lists metadata
Saving other metadata
Generating sqlite DBs
Sqlite DBs complete
[root@localhost ~]# ls /root/mydata.d/yum.sr/
Packages  repodata
    # repodata为新生成的目录

    注:若电脑上没有createrepo命令,请使用yum install createrepo自行安装。

    3. 创建yum repo文件,并使用vim编辑:

[local]    <--指定yum源名;
name=my rpm base from local    <--可以理解为yum源描述;
baseurl=file:///root/mydata.d/yum.sr/    <--指定URL或使用“file://”指定本地路径,注意“/”的数量;
gpgcheck=0    <--不验证来源及package的完整性(因为是本地自己的文件);
enabled=1    <--启用此yum源;
--------------以上是vim编辑的内容---------------
[root@localhost yum.repos.d]# vim CentOS-My.repo 
[root@localhost yum.repos.d]# yum clean all
    # 清除yum缓存
Loaded plugins: fastestmirror, langpacks
Cleaning repos: base cdrom extras local updates
Cleaning up everything
Cleaning up list of fastest mirrors
[root@localhost yum.repos.d]# yum repolist
    # 重建yum缓存
Loaded plugins: fastestmirror, langpacks
base                                                                       | 3.6 kB  00:00:00     
cdrom                                                                      | 3.6 kB  00:00:00     
extras                                                                     | 3.4 kB  00:00:00     
local                                                                      | 2.9 kB  00:00:00     
updates                                                                    | 3.4 kB  00:00:00     
(1/7): cdrom/group_gz                                                      | 154 kB  00:00:00     
(2/7): local/primary_db                                                    | 2.7 MB  00:00:00     
(3/7): cdrom/primary_db                                                    | 2.7 MB  00:00:00     
(4/7): base/7/x86_64/primary_db                                            | 5.1 MB  00:00:00     
(5/7): extras/7/x86_64/primary_db                                          | 120 kB  00:00:01     
(6/7): base/7/x86_64/group_gz                                              | 154 kB  00:00:01     
(7/7): updates/7/x86_64/primary_db                                         | 4.7 MB  00:00:03     
Determining fastest mirrors
 * base: mirrors.btte.net
 * extras: mirrors.aliyun.com
 * updates: mirrors.sina.cn
repo id                                    repo name                                        status
base/7/x86_64                              CentOS-7 - Base                                  8,652
cdrom                                      my rpm base from cdrom                           3,576
extras/7/x86_64                            CentOS-7 - Extras                                  285
local                                      my rpm base from local                           3,576
updates/7/x86_64                           CentOS-7 - Updates                               1,726
repolist: 17,815
    # “local” yum源创建成功,且其与cdrom一致,因为local的pakages源于cdrom。
[root@localhost yum.repos.d]#

===========编译安装=========

前提要有开发环境,最起码gcc应该装上;

安装方法见下面;

以编译安装Apache为例:

[root@localhost ~]# wget http://mirror.bit.edu.cn/apache/httpd/httpd-2.4.17.tar.bz2
...下载过程省略...

文件会下载到你的当前目录。

解压缩下载到的文件:

[root@localhost ~]# ls
anaconda-ks.cfg  httpd-2.4.17.tar.bz2  mydata.d  pingpc.sh  rc2.d.sh
    # httpd-2.4.17.tar.bz2为下载到的文件;
[root@localhost ~]# tar -jxf httpd-2.4.17.tar.bz2 
    # 解压缩文件
[root@localhost ~]# ls
anaconda-ks.cfg  httpd-2.4.17  httpd-2.4.17.tar.bz2  mydata.d  pingpc.sh  rc2.d.sh
    # httpd-2.4.17 为解压后的目录

然后运行解压目录下的configure文件,但是configure文件可能会提示错误,大多是因为缺少某个程序,根据命令查找,安装即可,比如:

[root@localhost httpd-2.4.17]# yum search pcre
Loaded plugins: fastestmirror, langpacks
Loading mirror speeds from cached hostfile
 * base: mirrors.btte.net
 * extras: mirrors.aliyun.com
 * updates: mirrors.sina.cn
======================================= N/S matched: pcre ========================================
pcre-devel.i686 : Development files for pcre
pcre-devel.x86_64 : Development files for pcre
pcre-static.i686 : Static library for pcre
pcre-static.x86_64 : Static library for pcre
pcre-tools.x86_64 : Auxiliary utilities for pcre
pcre.i686 : Perl-compatible regular expression library
pcre.x86_64 : Perl-compatible regular expression library
  Name and summary matches only, use "search all" for everything.
[root@localhost httpd-2.4.17]# yum install pcre

然后再执行configure文件;

执行make命令;

执行make install命令;

正常情况下到此即为安装完成。

原创文章,作者:Jacen,如若转载,请注明出处:http://www.178linux.com/9809

(0)
上一篇 2015-12-15 22:55
下一篇 2015-12-15 22:56

相关推荐

  • Linux学习 Grep详则。

    grep 功能说明:查找文件里符合条件的字符串。 语  法:grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][–help][范本样式][文件或目录&…

    Linux干货 2017-07-24
  • Apache通过mod_proxy模块连接Tomcat并使用Memcached+MSM做Tomcat会话保持

    一 实验目的 本实验使用Apache的mod_proxy模块连接Tomcat, Nginx在前端做负载均衡,并使用Memcahced+MSM的方式保持Tomcat的会话,实现会话共享。 二 实验拓扑 说明:为测试方便,Memcached与Tomcat安装在同一机器中,正式环境应该安装在不同机器中。 三 实验环境 主机 IP 安装组件 node1 192.16…

    Linux干货 2017-01-17
  • week5

    1、显示当前系统上root、fedora或user1用户的默认shell; useradd fedora useradd user1 egrep "^(root|fedora|user1)" /etc/passwd | cut -d: -f1,7 2、找出/e…

    Linux干货 2016-11-24
  • Windows与linux分区的区别:

        对于我们普通人来讲,分区就是我们看到的“我的电脑”下面的C盘、D盘、E盘······,每个分区都有自己的区域,无法使用别的分区的空间,这样可以起到保护分区中文件的作用。其实,这样很容易理解。可是,对于linux初学者来讲,因为使用习惯了windows,到了linux下面,一下子很难转换过来。  &nb…

    2017-07-16
  • 大话命令之–ss

    大话命令之—ss ss是Socket Statistics的缩写。顾名思义,ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容。 优势: (1)显示更多更详细的有关TCP和连接状态的信息,(2)比netstat更快速更高效。 1 格式 格式:ss    [option]… &nbs…

    Linux干货 2017-05-15
  • HA专题: corosync+pacemaker实现nginx高可用

    HA专题: corosync+pacemaker实现nginx高可用 前言 实验介绍 实验拓扑 实验环境 实验步骤 准备工作 安装HA集群组件 安装nginx和配置nfs 使用crmsh配置集群资源 测试 总结 前言 这几天都会学习高可用集群, 也会将其中的一些实验写出来分享给大家, 这个专题估计会写5篇左右, p.s: 写博客很累的 实验介绍 这次的实验比…

    Linux干货 2016-04-11

评论列表(1条)

  • stanley
    stanley 2015-12-15 22:56

    格式上再优化些就可以置顶了