程序包管理: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

相关推荐

  • N26-博客作业-week2

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。   cp:copy 复制文件和路径 cp [OPTION]… [-T] SOURCE DEST cp [OPTION]… SOURCE… DIRECTORY cp [OPTION]… -t DIRECTORY SOURCE&…

    Linux干货 2017-02-12
  • 用户与组

    一、用户与组的概念 1、Linux多用户,多任务的特性    Linux是多用户多任务操作系统,多用户多任务就是可在系统上建多个用户,多个用户可同一时间同一个系统互不影执行的响各自不同的任务。例如linux服务器上有root、www、ftp,四个用户。同一时间内,root用户在查看系统日志,管理维护系统,www用户在修改自己的网页程序,f…

    Linux干货 2016-10-25
  • 马哥教育21期网络班—第15周课程+练习

    2、删除/boot/grub/grub.conf文件中所有行的行首的空白字符; sed 's@^[[:space:]]\+@@' /boot/grub/grub.conf 3、删除/etc/fstab文件中所有以#开头,后跟至少一个空白字符的行的行首的#和空白字符; sed 's@^#[[:spac…

    Linux干货 2016-11-14
  • 磁盘分区管理

    进行磁盘分区之前首先要了解什么是磁盘分区:         磁盘分区是在磁盘上划分几个逻辑部分,盘片一旦划分成数个分区,不同类的目录与文件可以存储进不同的分区。越多分区,也就有更多不同的地方,可以将文件的性质区分得更细,按照更为细分的性质,存储在不同的地方以管理文件;但太多分区就…

    2017-08-21
  • N22-love cat 17周博客作业第2部分-构建一个LVS-DR模型的高性能集群

    题目: 搭建一个LVS-DR模型的高性能集群,并实现以下功能:       (1)、wordpress程序通过nfs共享给个个realserver;       (2)、后端realserver中的nginx和php分离; 第17周   第2部分 网…

    Linux干货 2016-08-15
  • 马哥教育网络班22期第4周课程作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@MyCloudServer ~]# cp /etc/skel/ /home/tuser1  [root@MyCloudServer ~]# c…

    Linux干货 2016-09-19