程序包管理:rpm , yum ,与编译

1.RPM,Redhat Package Manager。是Redhat和CentOS等Linux系统上常见的软件安装工具。

软件安装:

常见选项

-i                #install,安装
-v                #详细信息
-vv               #更加详细的信息
-h                #显示进度条,一个#表示2%
--test            #测试安装,但不是真正执行安装,dry run 模式
--nodeps          #忽略依赖关系
--replacepkgs     #重新安装
--nodigest        #不检查完整性
--nosignature     #不检验来源

软件升级:

rpm {U|--upgrade} [install-options] package_file...
rpm {F|--freshen} [install-options] package_file...
    upgrade            #系统已经安装了旧版程序的,则升级;没有安装过程序的,则安装。
    freshen            #系统已经安装了旧版程序的,则升级;没有安装过程序的,不安装。
    --oldpackage       #降级
    --force            #强制升级

软件卸载:

-e               #earse,卸载

rpm.png

rpm安装的常见选项配搭是ivh。加上v和h是为了更加美观,和能够看安装状况。

但是我们可以看见rpm在卸载和安装的时候,有时候会由于依赖关系而安装失败。

而且这些依赖关系要安装软件的人手动解决,如果依赖关系真是费时费力。

所以在安装软件的时候,可以选择自动解决依赖关系的yum。

软件查询 Query

rpm {-q|--query} [select-option] [query-option]
一般选项:
-a            #列出所有系统安装了的包
-f            #根据文件查询指定文件是由哪一个包 安装而来
-p            #查询未安装的包所提供的文件

[query-option]#特定选项
-i            #information,查看包的介绍信息
-c            #configfile,查看提供的配置文件
-d            #doc,程序软件提供的帮助文档类文件
-l            #查看指定程序包安装后生成的所有文件
-R            #查询指定程序包所依赖的CAPABILITY
--scripts     #查看程序包所带的四种脚本
--provides    #列出程序包所提供的功能(capability)

常见组合: qf、qi、qc

qf_qi_qc.png

我们可以通过-qf选项来查找出命令 是由什么包安装而来。

接着,我们也可以使用命令引用,把-qf输出的包名输出,再给-qi来查询包的详细信息

而-qc和-qd选项则可以只输出这个包中的配置文件,和帮助文档。

qRequire.png

-R选项,则是Require的缩写。具体是列出包所依赖的功能(capability),具体也就是一些模块或者其他的软件。

大概是用来解决依赖关系,但是后来的yum由于可以通过repodata文件来自动分析,所以现在一般很少用。

--provide.png

而–provides选项则用来输出这个包提供了一些什么模块,或者功能(capability)。

由于coreutils提供的是一些主要的常用软件,所以能看见提供了很多命令。

假如我们查询的是一个没有安装过的包,也就是特定路径下的rpm包,要使用-i,-c,-d,则需要配合-p选项。如,-qpi

qpi.png

2.yum文件包管理     Yellowdog Update Modifier

yum安装软件的优势

yum会从yum源中获取文件列表和依赖关系。

每一次创建cache的时候都会请求文件列表的校验码,来识别软件包是否有更新(repodata.xml)

配置文件

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

yum repository:yum repo    yum仓库

储存了众多rpm包,以及包的相关的元数据文件。而yum的配置文件*.repo必须指向repodata目录中repodata.xml所在的地方。

列出当前系统中所有资源库:

yum repolist

yum repolist.png

如何自己手动指定一个yum源?

在/etc/yum.repos.d/创建一个以repo结尾的文件就可以!

假如已经自带的Base文件已经失效,可以在/etc/yum.repos.d/下面随便创建一个文件夹。

然后把原有的repo都复制到里面去,那么系统自带的仓库就都读不到了。

repo.png

repo文件的格式。

这里最主要的是baseurl这个地址,因为这个地址指向服务器repodata文件。

其次name字段则是在初始化仓库的时候显示的名字。

当gpgcheck为0的时候,gpgkey也就不用添加也可以了。

而且enable的默认选项是1,0则表示不启用。

repofile.png

我们可以初始化之后列出的仓库多了一个Mirror_aliyun

看到配置文件的中括号里的内容对应repoid,name字段则对应repo name。

为了提高通用性,repo提供一些变量$basearch以$releasever,

分别表示系统架构以及发行版本,也就是CentOS7的7,以及x86_64.

完成了yum源的配置之后,我们就可以查看或者安装软件了。

yum info.png

yum的info子命令,类似于rpm -qi,同样输出包的信息。

yum install httpd.png

执行yum install httpd

自动解决软件包之间的依赖关系

3.编译安装(CentOS6上)

前期的准备;

首先要安装编译的环境

yum groupinstall "Development Tools" "Desktop Platform Development"

然后要获得源码包,可以通过wget等方式下载到源码包。

然后解压得到的压缩包,并且切换到源码的目录里面

编译的三大步骤:

(1) ./configure      

            #这个脚本主要用于检查各种指定特性所依赖的外部文件

            #配合各种选项,可以启用特性和调整软件的安装路径等。

示例:编译httpd2.2

./configure --prefix=/usr/local/apache --sysconf=/etc/httpd2.2 --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --enable-modules=most --enable-mpms-shared=all --with-mpm=prefork

./configure检查期间,假如报错,可能是一些依赖的devel包没有装。

装上特性所依赖的包之后,再执行一次./configure脚本也是没有问题的。

configure.png

       

(2)make

    在./configure文件检查没有问题之后,执行make。就会自动地编译。

make1.png

make2.png

(3)make install

make install命令实际上是把已经编译好的软件复制到对应位置的一个命令。

所以在三大步骤里面,问题最多的是第一步./configure。

makeinstall.png

编译好之后。

  1. 把软件添加到PATH变量的路径中:修改/etc/profile.d/httpd.sh

    添加一行:PATH=程序二进制执行文件所在的目录:$PATH

    如,PATH=/usr/local/apache/bin:$PATH

    那样重新开机之后,系统用户初始化环境的时候就会能在PATH中读到二进制的文件,而不用每次都是用完全的路径。

  2. 添加二进制执行文件所依赖的库文件 到 需要加载的库中

    系统能顺利找到了二进制文件之后,我们还要让系统能顺利找到二进制执行文件所需要的库

  所以我们要在/etc/ld.so.conf.d/目录下创建一个与软件同名的conf文件

    如,/etc/ld.so.conf.d/httpd.conf

  然后再往里面添加一行库所在的目录/usr/local/apache/lib,并使用ldconfig来重新生成缓存

3.导入include头文件

可以选择复制,或者做软连接的方式,把include目录下的文件都复制到/usr/include目录下

include.png

4.导出帮助手册

最后我们编辑一下/etc/man.conf文件,在里面添加一个MANPATH条目

manpath.png

  

最后重新登录一下之后,我们就可以使用apachectl start命令来启动httpd,并使用ss命令查看使用状况

ss-tnl.png

使用浏览器直接访问ip的时候,运行成功。

work.png

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

(0)
菠菜菠菜
上一篇 2016-03-25
下一篇 2016-03-26

相关推荐

  • 2016-08-10作业

    1、编写脚本/root/bin/systeminfo.sh, 显示当前主机系统信息,包括主机名,IPv4 地址,操作系统版本,内核版本,CPU 型号,内存大小,硬盘大小。 #!/bin/bash echo "hostname is `hostname`" echo "IPv4 is `ifconfig | sed -n &#03…

    Linux干货 2016-08-15
  • DNS-BIND

    1.实验环境 服务器类型 域名 IP 主DNS服务器 test.com. 192.5.24.101 从DNS服务器 192.5.24.102 子DNS服务器 ops.test.com. 192.5.24.201 备注:所有服务器需保持时间同步。 2.正向解析区域(192.5.24.101) 1)  安装bind 2)  编辑主配置文件,修…

    2017-05-31
  • date(时间),timedatectl(时区),cal(日历)的用法

    date+%F 显示日期,   显示格式如 2017-07-15+%T 显示时间    显示格式如 15:00:15+%Y 显示年      显示格式如 2017+%m 月 +%d 日+%H 时+%M 分+%S 秒+%s 从linux初始到现在经历了多少秒+%w 显示数字形式的星期+%a …

    Linux干货 2017-07-14
  • Linux进程管理和计划任务

    进程管理篇 进程概念 内核的功用:进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能等 Process: 运行中的程序的一个副本,是被载入内存的一个指令集合     进程ID(Process ID,PID)号码被用来标记各个进程     UID、GID、和SELinux语…

    Linux干货 2016-09-17
  • 20160803普通权限与特殊权限及umask

    权限     任何一个可执行程序文件能不能启动为进程,取决发起者对程序文件是否拥有执行权限.即权限决定用户对文件或者目录的使用范围.在Linux系统中,root的权限是最高的,可操作的权限最大,通常情况下root账号只用于管理系统的重要信息,并不做日常维护工作,所以正确设定用户的权限对系统的安全性尤为重要. 普通权限: 文件目录只针对三类…

    Linux干货 2016-08-04
  • vim的基本使用

    前言:     Vim是一个类似于Vi的著名的功能强大、高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特性。VIM是自由软件。    Vim普遍被推崇为类Vi编辑器中最好的一个,事实上真正的劲敌来自Emacs的不同变体。1999 年Emacs被选为Linuxworld文本…

    Linux干货 2017-07-30