select基本用法和软件包管理

一、select语句

    select语句在脚本中用于创建菜单,按数字顺序排列的菜单项显示在标准输出上,并用PS3提示符,等待用户输入。用户输入菜单中的某个数字,执行相应的命令,并被保存在内置变量REPLY中。

用法:

    select NAME [in WORDS … ;] do COMMANDS; done

注意:

    select默认无限循环,因此,要配合break或ctrl+c退出循环,或配合exit退出脚本。

blob.png

    select可以与case配合使用

blob.png

二、rpm

    rpm(RedHat Package Manager)类似于windows中的“添加/删除程序功能”,rpm执行安装包分为二进制包和源代码包,其中二进制包可以直接安装在程序中,,而源代码包将会由rpm自动编译、安装。源代码包一般以src.rpm作为后缀。

    安装:

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

            -v    详细显示

            -vv    更加详细显示

            -h    用#显示程序包执行进度

    

            [install-options] 

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

                –nodeps:忽略依赖关系 

                –replacepkgs | replacefiles 

                –nosignature: 不检查来源合法性 

                –nodigest:不检查包完整性 

                –noscipts:不执行程序包脚本片断 

                    %pre: 安装前脚本; –nopre 

                    %post: 安装后脚本; –nopost 

                    %preun: 卸载前脚本; –nopreun 

                    %postun: 卸载后脚本; –nopostun

    升级

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

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

            upgrade:安装有旧版程序包,则“升级”如果不存在旧版程序包,则“安装” 

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

            rpm -Uvh PACKAGE_FILE … 

            rpm -Fvh PACKAGE_FILE … 

                –oldpackage:降级 

                –force: 强行升级

注意: 

(1) 不要对内核做升级操作;Linux支持多内核版本并存,因此 ,对直接安装新版本内核 

(2) 如果原程序包的配置文件安装后曾被修改,升级时,新版本 的提供的同一个配置文件并不会直接覆盖老版本的配置文件,而 把新版本的文件重命名(FILENAME.rpmnew)后保留

    包查询

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

    

        [select-options] 

            -a: 所有包 

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

            -p rpmfile:针对尚未安装的程序包文件做查询操作; 

            –whatprovides CAPABILITY:查询指定的CAPABILITY 由哪个包所提供 

            –whatrequires CAPABILITY:查询指定的CAPABILITY被 哪个包所依赖 

    

        rpm2cpio 包文件|cpio –itv 预览包内文件

    

        rpm2cpio 包文件|cpio –id  “*.conf” 释放包内文件

    

        [query-options] 

            –changelog:查询rpm包的changelog 

            -c: 查询程序的配置文件 

            -d: 查询程序的文档 

            -i: information 

            -l: 查看指定的程序包安装后生成的所有文件; 

            –scripts:程序包自带的脚本片断 

            -R: 查询指定的程序包所依赖的CAPABILITY; 

            –provides: 列出指定程序包所提供的CAPABILITY;

    

    卸载: 

    

        rpm {-e|–erase} [–allmatches] [–nodeps] [-noscripts] [–notriggers] [–test] PACKAGE_NAME …

    

    包校验

    

        rpm {-V|–verify} [select-options] [verify-options] 

            S file Size differs 

            M Mode differs (includes permissions and file type) 

            5 digest (formerly MD5 sum) differs 

            D Device major/minor number mismatch 

            L readLink(2) path mismatch 

            U User ownership differs 

            G Group ownership differs 

            T mTime differs 

            P capabilities differ

        

        包来源合法性验正及完整性验正: 

            完整性验正:SHA256 

            来源合法性验正:RSA

        公钥加密: 

            对称加密:加密、解密使用同一密钥; 

            非对称加密:密钥是成对儿的 

                public key: 公钥,公开所有人 

                secret key: 私钥, 不能公开 

        导入所需要公钥: 

            rpm  -K|checksig rpmfile 检查包的完整性和签名 

            rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 

            CentOS 7发行版光盘提供:RPM-GPG-KEY-CentOS-7 rpm -qa gpg-pubkey*

    

    rpm数据库

        数据库重建

            /var/lib/rpm    

        rpm {–initdb|–rebuilddb} 

            initdb: 初始化 如果事先不存在数据库,则新建之 否则,不执行任何操作 

            rebuilddb:重建 无论当前存在与否,直接重新创建数据库

三、yum的配置

    yum(Yellow dog Updater,Modifid)是linux中shell前端的软件包管理器,基于rpm包管理,能够从指定的服务器自动下载rpm包并且安装,可以自动处理依赖性关系,并且依次安装所有以来的软体包。yum提供了查找、安装、删除某一个、一组甚至全部软件包的命令。

yum客户端配置文件

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

/etc/yun.repos.d/*.repo:为仓库的指向提供配置

仓库指向定义:

    [repositoryID]    软件源名称

    namee=Some name for this repository    仓库名称

    baseurl=url://path/to/repository/    源镜像地址

    enabled={1|0}    是否启用源

    gpgcheck={1|0}    是否进行gpg的校验下载的rpm包

    gpgkey=URL    用于定义gpg校验的密钥

    enablegroups={1|0}

    failovermethod={roundrobin|priority}

        默认为:roundrobin,意为随机挑选镜像服务器中的地址;

            priorty,表示顺序选择地址 

    cost=    默认为1000 

blob.png

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

(2)
zhanghuanyuzhanghuanyu
上一篇 2016-08-21 20:45
下一篇 2016-08-21 20:45

相关推荐

  • 马哥教育网络班22期第一周课程练习1-未闻花名

    一、cpu架构 计算机体系结构: 运算器、控制器(cpu还包含寄存器)、存储器(内存)、输入设备(键盘、硬盘等)、输出设备(显示器、硬盘等) cpu组成: 核心部件:运算器(加法器)、控制器()、寄存器(由于数据总线复用,为cpu保存现场,过程数据记录)。 辅助部件:一、二、三级缓存:弥合CPU和内存速率不匹配。频率控制器? 地址总线:内存寻址。 数据总线:…

    Linux干货 2016-08-15
  • 对inode的初步理解

    1.什么是inode?     inode中文译作”索引节点“,是linux操作系统中的一种数据结构,用来存储文件的元数据信息。在linux系统中每个文件都会分配一个inode,我们也可以把inode看作指针,它永远指向文件的具体存储位置。 2.inode中包含了什么信息? * inode 编号 * 用来识别文件类型,以及用于 …

    2017-07-18
  • 网络班N27 第四周作业

    1、 复制/etc/skel目录为/home/tuserl,要求/home/tuserl及其内部文件的属组和其他用户均没有任何访问权限。 [root@ ~]# cp -r /etc/skel /home/tuserl [root@ ~]# chmod -Rv 700 /home/tuserl/ mode of ‘/home/tuserl/’ changed …

    Linux干货 2017-08-19
  • 第四周作业新

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

    2017-02-20
  • 马哥教育网络班22期+第一周课程练习

        操作系统:centos 7.2  64位 计算机组成及功能。 计算机组成: 由存储器、运算器、控制器、输入设备、输出设备组成。 功能: 存储器:用来存放计算程序及参与运算的各种数据;例如:硬盘、内存 运算器:负责数据的算术运算和逻辑运算即数据的加工处理 控制器:负责对程序规定的控制信息进行分析,控制并…

    Linux干货 2016-08-15
  • TCP详解

    TCP协议详解   TCP/IP协议不是TCP和IP这两个协议的合称,而是指因特网整个使用TCP/IP协议的协议集合。他取代了OSI七层模型,成为事实上的应用于实际的模型。 TCP/IP协议与OSI协议的关系如下:   各层的作用如下: TCP特性: 工作在传输层面向连接协议 全双工协议 半关闭 错误检查 将数据打包成段,排序 确认机制 …

    2017-09-02

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-22 10:35

    文章对rpm工具的常见用法和选项总结的很精细,也很用心,对于rpm包管理工具而言,其最重要的是查询选项,这也是最丰富的地方,需要多加练习熟练掌握。