Linux系统程序包的管理-Yum及编译安装

      Yum 是通过分析RPM的标头数据后,根据各软件的依赖关系制作出有依赖关系时的的解决方案,然后可以自动处理软件的依赖性问题,以解决软件安装或移除与升级的问题。

      由于发行版必须要先释放软件,然后将软件放置于yum服务器上面,以提供用户端用来安装与升级。因此,我们想要使用yum的功能时,必须要先找到适合的yum server才行。事实上,CentOS在释放软件的时候已经制作好了yum源,只要能够连上Internet,就可以使用yum。在这里,向大家介绍一下yum本地仓库的配置。

      制作本地yum源有两种方式:第一种直接使用光盘镜像,不过此方法只适用于本机;第二种创建本地yum仓库,使用http或ftp等方式向外部yum repository。

第一种:如何使用光盘作为yum repository

      1、先将光盘挂载到指定位置,例如:创建/media/cdrom这个目录用来作为挂载点,mount /dev/sr0 /media/cdrom。在这里要提一下/misc/cd这个特殊的目录,cd到这个目录下,光盘会自动挂载的该目录下。在CentOS6中已经默认安装此功能,而7中我们需要安装autofs:

Linux系统程序包的管理-Yum及编译安装 #安装autofs

Linux系统程序包的管理-Yum及编译安装 #启用autofs服务

Linux系统程序包的管理-Yum及编译安装 #将其设置为开机自启

通过df我们可以看到光盘的挂载情况

 Linux系统程序包的管理-Yum及编译安装

      2、在/etc/yum.repos.d/目录下创建.repo为后缀名的配置文件,基本内容如下所示(因为CentOS在释放软件的时候已经制作好了yum源,在这里我们可以将/etc/yum.repos.d/下的所有文件进行备份,然后将其删除):

Linux系统程序包的管理-Yum及编译安装

第二种:创建本地yum仓库

      如果你作为一个企业的管理人员,为了方便公司内部网络中的服务器安装软件,同时也节省网络带宽,此时可以在公司内部创建一个yum仓库。此处以CentOS6为例(CentOS7步骤与6基本相同):

ftp服务:

  1、首先安装并启用vsftpd服务

       yum -y install vsftpd 安装vsftpd

       service vsftpd start 启用vsftpd服务 (在7中 用 systemctl start vsftpd)

       chkconfig vsftpd start 将其添加至开机启动项(在7中用systemctl enable vsftpd)

       iptables -F  清空防火墙规则

       service iptables stop (在7中用systemctl  stop  iptables)

       chkconfig iptables off 不将防火墙开机自启(在7中用systemctl disable firewalld.service)

  2、打开ftp服务器的目录:cd  /var/ftp/pub/

  3、创建一个app目录用来存放rpm包:mkdir app

  4、安装createrepo工具:yum install createrepo

  5、复制rpm包到 app目录下:cp /misc/cd/Packages  /var/ftp/pub/app/

  6、创建rpm元数据存储库:createrepo  /var/ftp/pub/app/

  7、此时访问ftp://你的CentOS6的地址就可以了

 Linux系统程序包的管理-Yum及编译安装

http服务:

Linux系统程序包的管理-Yum及编译安装

因为httpd服务安装好会有一个欢迎界面,要不显示此页面可注释/etc/httpd/conf.d/welcome.conf 里的所有行

在这里要提一下,rpm包的存放位置在/var/www/html

以ftp服务为例创建yum库:

Linux系统程序包的管理-Yum及编译安装

 注意,ftp地址要到存在repodata的目录

yum命令的使用:

       yum [options] [command] [package…]

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

              list [available|installed|updates]
显示程序包

              install package1 [package2]
[…] 安装程序包

              reinstall package 重新安装

              update package  升级安装

              downgrade package 降级安装

              check-update 检查可用升级

              remove | erase package 卸载程序包

              info package 查看程序包的信息

              provides | whatprovides  feature1 … 查看指定的特性(可以是某文件)是由哪个包提供的

              clean all 清理本地缓存

       查看yum的历史:

              history [info|list|packages-list|packages-info]

       撤销对应的第#个历史中命令

              history undo #

       查看对应的第#个历史的信息

              history info #

       包组的管理:

              groupinstall group1(包组的名字中存在空格,要用” ”,在这里不区分大小写)    

              groupremove group1 卸载包组

grouplist  group1显示包组的列表

yum的命令行选项:

       –nogpgcheck:不进行gpg 检查

       -y:自动回答“yes”

       -q:静默模式

yum有一些内置变量,用于保存当前平台的相关信息:

       $releasever:当前的CentOS的版本

       $basearch:基础平台 例如i386(32位)、x86_64

如可在yum的配置文件中适当使用:

       例如:定义baseurl路径时 baseurl= http://172.18.0.1/fedora-epel/$releasever /$basearch /

                   其实际路径为http://172.18.0.1/fedora-epel/6/x86_64/

源代码编译安装程序

       源码安装首先依赖于环境的支持,即编译开发工具、以及各个被依赖到的程序包的开发组,另外还需要定制的编译参数来进行编译安装

       1、编译开发工具(包组)有:

              Development tools

              Server Platform Development

              Desktop Platform Development

              Debug Tools

       2、被依赖的程序包的开发组件:

              1)、编译安装被依赖的程序

              2)、安装相关程序的名称中包含devel的子包

       源代码程序中会将程序分隔保存在多个文件中,文件间或许存在依赖关系,因此,编译时可能需要按照特定次序进行编译;此时,一般会使用项目管理工具(通常也会称为构建工具GNU make)对其进行管理;构建工具会调用合适的编译器,并根据配置文件(Makefile)中定义的次序对源代码文件进行编译。需要注意的是:

       1、每个项目的程序员开发完成某版本后,会使用autoconf为程序代码生成一个脚本文件:configuer;其功能:此脚本会收集当前系统上的开发环境中所依赖的各组件的版本、特性等,并检查所依赖的环境是否能满足,最后会根据Makefile.in文件生成一个makefile文件;

       2、每个项目的开发员开发完成某个版本后,会使用automake为程序代码生成一个makefile模板文件,即Makefile.in

编译安装过程如下:

       1、运行configure脚本;

              Configure脚本的运用:

                     –help:查看帮助信息;

                     –prefix=/path/:指定默认安装路径

                     –sysconfdir=/path/ :指定配置文件的安装路径

                     –with/without-CAPABILITY : 依赖/不依赖的程序包

                     –enable/disable-FEATURE : 启用/禁用某个特性

 运行过程中会需要手动安装依赖包,将提示缺少的包后加上-devel 手动安装(yum)即可

       2、运行make命令,完成项目构建;

       3、运行make install命令,完成安装。

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

(0)
Immortals、zcyImmortals、zcy
上一篇 2017-05-02
下一篇 2017-05-02

相关推荐

  • CentOS下获取帮助

    CentOS中获取帮助 在使用和学习CentOS系统时,我们可能会遇上不熟悉的命令,需要获取帮助。在很多情况下,我们无法通过网络获取帮助,这个时候我们就需要自己通过查看系统帮助文档来解决问题。下面就来介绍获取帮助的方法: 1、 获取简单的帮助信息:whatis COMMAND   2、获取比较详细的命令帮助信息:help COMMAND;COMMA…

    2017-07-15
  • 正则表达式字符集

    POSIX Description ASCII Unicode Shorthand Java [:alnum:] Alphanumeric characters [a–zA–Z0–9] [\p{L}\p{Nl}  \p{Nd}] \p{Alnum} [:alpha:] Alphabetic characters …

    Linux干货 2017-07-07
  • Linux运维之基础拾遗

    博客具体内容请移步博客园: http://www.cnblogs.com/ITOps/p/6151766.html

    Linux干货 2016-12-09
  • N22-第十周作业

    第十周    1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情)    POST–>BootSequence(BOIS)–>BootLoader(MBR)–>Kernel(ramfs或者ramdisk)–&gt…

    Linux干货 2016-11-07
  • Linux学习总结&day07-正则表达式&文本处理工具

    第一部分、正则表达式     1、什么是正则表达式     正则表达式就是处理字符串的方法,它是以行为单位来进行字符串的处理行为,正则表达式通过一些特殊符号的辅助,可以让用户轻易的达到查找、删除、替换某特定字符串的处理程序。     正则表…

    Linux干货 2016-08-08
  • Cacti整合Zabbix监控

    前言: 由于公司现在很多业务都是使用cacti进行监控流量的,并且还有一些使用zabbix监控的项目,正好又有一个项目需要搭建Cacti+Zabbix进行综合监控,搭建完毕之后发现,Cacti较之以前有了不小的改进,所以就来写一写Cacti和Zabbix监控整合的文章,顺便说一下Cacti下的一些好用的插件。 环境: Centos 6.4 X86_64 Ca…

    Linux干货 2015-03-19