YUM:yellow dog,Yellowdog Update Modifier

yum repository:yum repo

  存储了众多rpm包,以及包的相关的无数据文件(放置于特定目录下:repodata);

  文件服务:

    ftp://

    http://

    nfs://

    file://

yum客户端:

   配置文件:

    /etc/yum.conf  为所有仓库提供公共配置

    /etc/yum.conf.d/*.repo  为仓库的指向提供配置

  仓库指向的定义:

  [repositoryID]

  name=Some name for this repository

  baseurl=rul://path/to/repository

  enabled={1|0}

  gpgcheck={1|0}

  gpgkey=URL

  enablegroups={1|0}

  failovermethod={roundrobin|priority}

    默认为:roundrobin,意为随机挑选 ;

  cost=

    默认为1000

yum命令的用法:

  yum [options] [command] [package ...]

  command is one of:
  * install package1 [package2] [...]
  * update [package1] [package2] [...]
  * update-to [package1] [package2] [...]
  * check-update
  * upgrade [package1] [package2] [...]
  * upgrade-to [package1] [package2] [...]
  * distribution-synchronization [package1] [package2] [...]
  * remove | erase package1 [package2] [...]
  * list [...]
  * info [...]
  * provides | whatprovides feature1 [feature2] [...]
  * clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
  * makecache
  * groupinstall group1 [group2] [...]
  * groupupdate group1 [group2] [...]
  * grouplist [hidden] [groupwildcard] [...]
  * groupremove group1 [group2] [...]
  * groupinfo group1 [...]
  * search string1 [string2] [...]
  * shell [filename]
  * resolvedep dep1 [dep2] [...]
  * localinstall rpmfile1 [rpmfile2] [...]
    (maintained for legacy reasons only - use install)
  * localupdate rpmfile1 [rpmfile2] [...]
    (maintained for legacy reasons only - use update)
  * reinstall package1 [package2] [...]
  * downgrade package1 [package2] [...]
  * deplist package1 [package2] [...]
  * repolist [all|enabled|disabled]
  * version [ all | installed | available | group-* | nogroups* | grouplist | groupinfo ]
  * history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]
  * load-transaction [txfile]
  * check
  * help [command]

显示仓库列表:

  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] [...]  (降级)

  upgrade [package1] [package2] [...]  # 作用和update一样,已经废弃。

检查可用升级:

  check-update

卸载程序包:

  remove | erase package1 [package2] [...]

查看程序包information:

  info [...]

查看指定的特性(可以是某文件)是由哪个程序包所提供:

   provides | whatprovides feature1 [feature2] [...]

  注:rpm只能查询已安装程序包的信息,而yum可以查询某个功能由哪个程序包所提供。

清理本地缓存:

  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 [...]

如何使用光盘当作本地yum仓库:

  (1)挂载光盘至某目录,例如/media/cdrom

    # mount -r -t iso9660 /dev/cdrom   /media/cdrom

  (2)创建配置文件

  [CentOS7]

  name=

  baseurl=

  gpgcheck=

  enabled=

yum的命令行选项:

  --nogpgcheck:禁止进行gpg check;

  -y:自动回答为"yes"

  -q:静默模式;

  --disablerepo=repoidglob:临时禁用此处指定的repo;

  --enablerepo=repoidglob:临时启用此处指定的repo;

  --noplugins:禁用所有插件;

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

  $releasever:当前OS的发行版的主版本号;

  $arch:平台;

  $basearch:基础平台;

  $YUM0-$YUM9

  http://mirrors.magedu.com/centos/$releasever/$basearch/os

创建yum仓库:

  createrepo [options] <directory>

程序包编译安装:

  testapp-VERSION-release.src.rpm --> 安装后,使用rpmbuild命令制作二进制格式 的rpm包,而后再安装;

  源代码 --> 预处理 --> 编译(gcc) --> 汇编 --> 链接 --> 执行

  源代码组织格式:

    多文件:文件中的代码之间,很可能存在跨文件依赖关系;

    C、C++:make(configure --> Makefile.in --> makefile)

    jave:maven

    

    编译安装三步骤:

      ./configure

        (1)通过选项传递参数,指定启用特性、安装路径等;执行时会参考用户的指定以及Makefile.in文件生成makefile;

        (2)检查依赖到的外部环境;

      make

        根据makefile文件,构建应用程序;

      make install

    

    开发工具:

      autoconf:生成configure脚本

      automake:生成Makefile.in

    建议:安装前查看INSTALL,README

  开源程序源代码的获取:

    官方自建站点:

      apache.org(ASF)

      mariadb.org

      ...

    代码托管:

      SourceForge

      Github.com

      code.google.com

  c/c++:gcc (GUN C Complier)

  编译C源代码:

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

      开发工具:make,gcc等

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

        glibc:标准库

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

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

    第一步:configure脚本

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

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

        选项分类:

          安装路径设定:

            --prefix=/PATH/TO/SOMEWHERE:指定默认安装 位置;

            --sysconfdir=/PATH/TO/SOMEWHERE:配置文件安装 位置;

          system types:

          Optional Features:可选特性

            --disable-FEATURE

            --enable-FEATURE[=ARG]

          Optional Packages:可选包

            --with-PACKAGE[=ARG]

            --without-PACKAGE

    第二步:make

    第三步:make install

  安装后的配置:

    (1)导出二进制程序目录至PATH环境变量中;

      编辑文件/etc/profile.d/NAME.sh

        export PATH=/PATH/TO/BIN:$PATH

    (2)导出库文件路径

      编辑/etc/ld.so.conf.d/NAME.conf

        添加新的库文件所在目录至此文件中;

      让系统重新生成缓存:

        ldconfig [-v]

    (3)导出头文件

      基本链接的方式实现;

        ln -sv

    (4)导出帮助手册

      编辑/etc/man.config文件

        添加一个MANPATH

练习:

  1、yum的配置和使用;包括yum repository的创建;

  2、编译安装apache 2.2;启动此服务;

博客作业:程序包管理:rpm/yum/编译

Linux:Day10 程序包管理的更多相关文章

  1. Linux下程序包管理工具RPM

    实验环境: CentOS release 6.6 (Final)  一台 IP地址:172.16.249.230 RPM 是 Red Hat Package Manager 的缩写,本意是Red Ha ...

  2. Linux程序包管理之yum及源代码安装

    第十六章.Linux程序包管理之yum及源代码安装 目录 yum介绍 yum配置文件 yum的repo配置文件中可用的变量 yum命令的使用 使用光盘作为本地yum仓库 如何创建yum仓库 编译安装的 ...

  3. Linux程序包管理rpm与yum

    Linux程序包管理 Linux中软件的安装主要有两种形式:一种是直接下载源代码包自行编译后安装,另一种直接获取rpm软件包进行安装. 程序的组成部分: 二进制程序:程序的主体文件,比如我们运行一个l ...

  4. Linux:Day9(下) 程序包管理

    API:Application Programming Interface POSIX:Portable OS 程序源代码 --> 预处理 --> 编译 --> 汇编 --> ...

  5. linux基础之程序包管理(rpm,yum)

    一.rpm 安装:rpm { -i | --install } [ install-options ] PACKAGE_FILE... -v: 显示安装时的详细信息 -vv: 显示许多难以阅读的调试信 ...

  6. Linux 程序包管理-RPM

    程序简介:  POSIX(Portable Openratin System)跨平台系统:不同操作系统平台的标准C库(glibc)都是遵循POSIX规范的,这样基于标准库开发程序的源代码可以夸平台编译 ...

  7. Linux程序包管理初步-rpm的使用

    在Linux系统上,一般而言,对于程序包管理器来说分为三类: debian:dpt,dpkg;             (程序包后缀.deb) rhel:rpm (程序包后缀.rpm) suse:rp ...

  8. Linux 程序包管理-YUM

    前端工具YUM管理程序包:  rpm管理软件虽然方便,但是需要手工解决软件包的依赖关系:很多时候安装一个软件需要首先安装一个或多个(有时多达上百个)其它软件,手工解决很复杂:使用yum可以解决这个问题 ...

  9. 程序包管理rpm、yum与简单编译安装程序

    Linux程序包管理 Linux中软件的安装主要有两种形式:一种是直接下载源代码包自行编译后安装,另一种直接获取rpm软件包进行安装. 程序的组成部分: 二进制程序:程序的主体文件,比如我们运行一个l ...

随机推荐

  1. 使用codis-admin搭建codis集群

    目的 在Redis Codis 部署安装的文章中,介绍了通过fe在web上搭建codis的基本步骤和方法,也介绍了codis-admin的相关说明,为了更好的熟悉codis-admin的使用,本文将使 ...

  2. Scala(四) —— 集合

    一.List var x = List(1,2,3,4) //x:List[Int] = List(1, 2, 3, 4) var y = List("x","y&quo ...

  3. [转]Chrome 错误代码:ERR_UNSAFE_PORT

    本文转自:https://blog.csdn.net/testcs_dn/article/details/39186225 最近在用Nginx发布多个站点测试,使用了87.88端口, 88端口访问正常 ...

  4. VS项目发布到本地IIS

    一.项目介绍 ①web项目,开发工具Visual Studio,语言C# ②本地IIS,手机上或其他用户在和本地在同一个局域网(并不绝对是指同一个WIFI)内访问,同时要把防火墙关掉 ③IIS全名In ...

  5. C#把动态创建的多个控件中指定控件显示在最上层

    在创建多个控件后,有些控件会发生重叠,那么就需要在鼠标按下它时能显示在最上层,下面通过先将按下操作的控件删除然后再重建,就达到让它显示在最上层了 //控件按下 private void picture ...

  6. 37.QT-QTSingleApplication-程序只运行一个实例

    QTSingleApplication由Qt官方提供的,用于实现只启动一个实例,并在启动时可以向向另一个实例通信(依赖于QtNetwork模块) QTSingleApplication下载路径:链接: ...

  7. 数据结构(java版)学习笔记(三)——线性表之单链表

    单链表的优点: 长度不固定,可以任意增删. 单链表的缺点: 存储密度小,因为每个数据元素,都需要额外存储一个指向下一元素的指针(双链表则需要两个指针). 要访问特定元素,只能从链表头开始,遍历到该元素 ...

  8. python爬虫+数据可视化项目(关注、持续更新)

    python爬虫+数据可视化项目(一) 爬取目标:中国天气网(起始url:http://www.weather.com.cn/textFC/hb.shtml#) 爬取内容:全国实时温度最低的十个城市气 ...

  9. Android为TV端助力 UDP协议

    废话不多说.直接上代码! 一. 接收端 1.创建UDP连接 public void init() { try { //开关的作用 isRunning = true; DatagramSocket mU ...

  10. (办公)TOKEN

    token就是HTTP认证,输入正确的token,在放在Authorization header中发送给服务器,认证成功.,就可以正确的拿到接口数据. 举个例子: 第一步:  客户端发送http re ...