软件包管理工具—yum命令总结

描述:

YUM: Yellowdog Update Modifier, rpm的前端程序,用来解决软件包相关依赖性,可以在多个库之间定位软件包,实现查询、安装、升级、删除等功能

说明:

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

文件服务器:

ftp://

http://

file:///

yum客户端配置文件:

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

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

仓库指向的定义:

[repositoryID]

name=Some name for this repository

baseurl=url://path/to/repository/

enabled={1|0}

gpgcheck={1|0}

gpgkey=URL

enablegroups={1|0}

failovermethod={roundrobin|priority}   默认为: roundrobin(随机挑选)

cost=    默认为1000

示例:

以教室服务器为yum源仓库的配置

[root@localhost yum.repos.d]# cat magedu.repo 
[base]
name=CentOS 7
baseurl=http://10.1.0.1/cobbler/ks_mirror/7/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
enabled=1

显示仓库列表:

repolist [all|enabled|disabled]

[root@localhost yum.repos.d]# yum repolist
repo id         repo name         status
!base          CentOS 7          9,007
cdrom        CentOS 7 cdrom        9,007

显示程序包:

# yum list [all | glob_exp1] [glob_exp2] […]

[root@localhost ~]# yum list tree      列出tree命令的程序包的信息
Available Packages
tree.x86_64   1.6.0-10.el7    base

# yum list {available|installed|updates} [glob_exp1][…]

安装程序包:

install package1 [package2] […]

[root@localhost Packages]# yum -y install tree
Installed:
  tree.x86_64 0:1.6.0-10.el7        
Complete!

reinstall package1 [package2] […] (重新安装)

升级程序包:

update [package1] [package2] […]

downgrade package1 [package2] […] (降级)

检查可用升级:

check-update

卸载程序包:

remove | erase package1 [package2] […]

[root@localhost ~]# yum remove tree      删除tree命令程序包
Removed:
  tree.x86_64 0:1.6.0-10.el7
Complete!

查看程序包information:info […]

[root@localhost ~]# yum info tree     查询tree命令程序包的信息
Installed Packages
Name        : tree
Arch        : x86_64
Version     : 1.6.0
Release     : 10.el7
Size        : 87 k
Repo        : installed
From repo   : base

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

provides | whatprovides feature1 [feature2] […]

[root@localhost ~]# yum provides tree    查询tree命令程序包是由哪个程序包提供的

tree-1.6.0-10.el7.x86_64 : File system tree viewer

Repo        : base

清理本地缓存:

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]

yum history

yum history info 6

yum history undo 6

日志 : /var/log/yum.log

安装本地程序包:

localinstall rpmfile1 [rpmfile2] […](用install替代)

及升级本地程序包:

localupdate rpmfile1 [rpmfile2] […](用update替代)

包组管理的相关命令:

groupinstall group1 [group2] […]

groupupdate group1 [group2] […]

grouplist [hidden] [groupwildcard] […]

groupremove group1 [group2] […]

groupinfo group1 […]

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

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

# mount /dev/cdrom /media/cdrom

(2) 创建配置文件

[CentOS7]

name=

baseurl=

gpgcheck=

enabled=

示例:

使用本地光盘当作本地仓库

[cdrom]
name=CentOS 7 cdrom
baseurl=file:///mnt/cdrom
gpgcheck=0
enabled=1

yum的命令行选项:

–nogpgcheck:禁止进行gpg check

-y: 自动回答为“ yes”

-q:静默模式

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

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

–noplugins:禁用所有插件

yum仓库

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

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

$arch: 平台, i386,i486,i586,x86_64等

$basearch:基础平台; i386

$YUM0-$YUM9:自定义变量

实例:

http://server/centos/$releasever/$basearch/

http://server/centos/7/x86_64

http://server/centos/6/i384

创建yum仓库:

createrepo [options] <directory>

程序包编译

程序包编译安装:

Application-VERSION-release.src.rpm –> 安装后,使

用rpmbuild命令制作成二进制格式的rpm包,而后再安装

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

源代码组织格式:

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

C、 C++: make (项目管理器, configure –>Makefile.in –> makefile)

java: maven

编译安装

C代码编译安装三步骤:

1、 ./configure:

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

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

2、 make:根据makefile文件,构建应用程序

3、 make install:复制文件到相应路径

开发工具:

autoconf: 生成configure脚本

automake:生成Makefile.in

注意:安装前查看INSTALL, README

编译安装

开源程序源代码的获取:

官方自建站点:

apache.org (ASF)

mariadb.org

代码托管:

SourceForge.net

Github.com

code.google.com

c/c++编译器: gcc (GNU C Complier)

编译安装

编译C源代码:

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

开发工具: make, gcc等

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

glibc:标准库

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

CentOS 6: "Development Tools",

"Server Platform Development",

编译安装

第一步: configure脚本

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

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

选项分类:

安装路径设定:

–prefix=/PATH: 指定默认安装位置,默认为/usr/local/

–sysconfdir=/PATH:配置文件安装位置

System types:支持交叉编译

编译安装

Optional Features: 可选特性

–disable-FEATURE

–enable-FEATURE[=ARG]

Optional Packages: 可选包,

–with-PACKAGE[=ARG],依赖包

–without-PACKAGE,禁用依赖关系

第二步: make

第三步: make install

示例:源码编译安装http

1,下载 httpd 源码包到当前目录下

[root@localhost ~]# lftp 10.1.0.1
lftp 10.1.0.1:~> mget pub/Sources/sources/httpd/httpd-2.2.29.tar.bz2 
5625498 bytes transferred                                   
lftp 10.1.0.1:/> bye
[root@localhost ~]# ls
httpd-2.2.29.tar.bz2

2,解压缩 httpd 源码包到当前目录下

[root@localhost ~]# tar -xf httpd-2.2.29.tar.bz2 
[root@localhost ~]# ls
httpd-2.2.29    httpd-2.2.29.tar.bz2

3,运行configure脚本,指定默认安装路径和配置文件安装路径

[root@localhost ~]# cd httpd-2.2.29;ls
acinclude.m4  configure      include         Makefile.in    README-win32.txt
[root@localhost httpd-2.2.29]# file configure
configure: POSIX shell script, ASCII text executable, with very long lines
[root@localhost httpd-2.2.29]# ./configure --prefix=/usr/local/httpd2 --sysconfdir=/etc/httpd2

4,执行make命令

[root@localhost httpd-2.2.29]# make

5,执行make install

[root@localhost httpd-2.2.29]# make install

6,关闭防火墙

[root@localhost bin]# iptables -F

7,运行 apachectl 脚本

[root@localhost httpd-2.2.29]# cd /usr/local/httpd2/bin;ls
apachectl  apu-1-config  checkgid  envvars    htcacheclean  htdigest  httpd
[root@localhost bin]# file apachectl 
apachectl: POSIX shell script, ASCII text executable
[root@localhost bin]# ./apachectl start

8,查看 httpd 服务是否开启(80端口)

[root@localhost bin]# netstat -ant
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
       ESTABLISHED
tcp6       0      0 :::80                   :::*                    LISTEN

9,访问 httpd 服务

wKioL1e9SZqx80MyAAAfgcUZYOk902.png

编译安装后的配置:

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

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

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

[root@localhost profile.d]# vim apache.sh 
PATH=$PATH:/usr/local/httpd2/bin
[root@localhost profile.d]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/httpd2/bin

(2) 导入库文件路径

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

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

[root@localhost ~]# vim /etc/ld.so.conf.d/httpd2.conf

让系统重新生成缓存:

ldconfig [-v]

[root@localhost ~]# ldconfig -v

(3) 导入头文件

基于链接的方式实现:

ln -sv

[root@localhost httpd2]# ln -s /usr/local/httpd2/include/ /usr/include/http2
[root@localhost httpd2]# cd /usr/include/;ls
ctype.h  http2  netipx  shadow.h   utmp.h
[root@localhost include]# ll http2
lrwxrwxrwx. 1 root root 26 Aug 24 13:19 http2 -> /usr/local/httpd2/include/

(4) 导入帮助手册

编辑/etc/man.config|man_db.conf文件,添加一个MANPATH

[root@localhost ~]# vim /etc/man_db.conf 
MANDATORY_MANPATH       /usr/local/httpd2/man


总结:

1,yum命令是基于rpm命令的,若rpm命令没安装或者误删除,则yum命令也使用不了

2,yum命令可以解决软件间的依赖性问题

3,yum命令的使用是基于yum仓库的建立,在/etc/yum.repos.d目录下创建一个以*.repo 结尾的文件为yum源的仓库,最重要的为baseurl=路径,其路径必须为可访问或已存在系统上的,若不存在或不能访问,则使用yum命令时会出现找不到相应的软件包,无正确的信息输出到屏幕上;仓库文件若有多个,必须确保每个文件的baseurl=路径可以正常访问,则使用yum命令时会去找所有的仓库文件路径出现找不到相应的软件包,无正确的信息输出到屏幕上。

4,创建yum源仓库的文件格式:

  [repositoryID]

  name=Some name for this repository

  baseurl=url://path/to/repository/   (可指定多个路径)

  enabled={1|0}   (0表示禁用,1表示启用,默认启用)

  gpgcheck={1|0}   (0表示不检测,1表示检测)

  gpgkey=URL

  enablegroups={1|0}

  failovermethod={roundrobin|priority}

5,利用yum命令实现源代码安装的主要步骤:

  a,./configure:

   –prefix=/PATH: 指定默认安装位置,默认为/usr/local/

   –sysconfdir=/PATH:配置文件安装位置

  b,make:根据makefile文件,构建应用程序

  c,make install:复制文件到相应路径

6,常用选项:

 安装

yum install 全部安装

yum install package1 安装指定的安装包package1

yum groupinsall group1 安装程序组group1

 更新和升级

yum update 全部更新

yum update package1 更新指定程序包package1

yum check-update 检查可更新的程序

yum upgrade package1 升级指定程序包package1

yum groupupdate group1 升级程序组group1

 查找和显示

yum info package1 显示安装包信息package1

yum list 显示所有已经安装和可以安装的程序包

yum list package1 显示指定程序包安装情况package1

yum groupinfo group1 显示程序组group1信息yum search string 根据关键字string查找安装包

 删除程序

yum remove | erase package1 删除程序包package1

yum groupremove group1 删除程序组group1

yum deplist package1 查看程序package1依赖情况

 清除缓存

yum clean packages 清除缓存目录下的软件包

yum clean headers 清除缓存目录下的 headers

yum clean oldheaders 清除缓存目录下旧的 headers

yum clean, yum clean all (= yum clean packages; yum clean oldheaders) 清除缓存目录下的软件包及旧的headers


作业:

1,源码安装apache

1,下载 httpd 源码包到当前目录下

[root@localhost ~]# lftp 10.1.0.1
lftp 10.1.0.1:~> mget pub/Sources/sources/httpd/httpd-2.2.29.tar.bz2 
5625498 bytes transferred                                   
lftp 10.1.0.1:/> bye
[root@localhost ~]# ls
httpd-2.2.29.tar.bz2

2,解压缩 httpd 源码包到当前目录下

[root@localhost ~]# tar -xf httpd-2.2.29.tar.bz2 
[root@localhost ~]# ls
httpd-2.2.29    httpd-2.2.29.tar.bz2

3,运行configure脚本,指定默认安装路径和配置文件安装路径

[root@localhost ~]# cd httpd-2.2.29;ls
acinclude.m4  configure      include         Makefile.in    README-win32.txt
[root@localhost httpd-2.2.29]# file configure
configure: POSIX shell script, ASCII text executable, with very long lines
[root@localhost httpd-2.2.29]# ./configure --prefix=/usr/local/httpd2 --sysconfdir=/etc/httpd2

4,执行make命令

[root@localhost httpd-2.2.29]# make

5,执行make install

[root@localhost httpd-2.2.29]# make install

6,导入至PATH环境变量中

[root@localhost profile.d]# vim apache.sh 
PATH=$PATH:/usr/local/httpd2/bin
[root@localhost profile.d]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/httpd2/bin

7,导入库文件路径

[root@localhost ~]# vim /etc/ld.so.conf.d/httpd2.conf

8,让系统重新生成缓存

[root@localhost ~]# ldconfig -v

9,导入头文件

[root@localhost httpd2]# ln -s /usr/local/httpd2/include/ /usr/include/http2

[root@localhost httpd2]# cd /usr/include/;ls
ctype.h  http2  netipx  shadow.h   utmp.h
[root@localhost include]# ll http2
lrwxrwxrwx. 1 root root 26 Aug 24 13:19 http2 -> /usr/local/httpd2/include/

10,导入帮助手册

[root@localhost ~]# vim /etc/man_db.conf 
MANDATORY_MANPATH       /usr/local/httpd2/man

11,关闭防火墙

[root@localhost bin]# iptables -F

12,运行 apachectl 脚本

[root@localhost httpd-2.2.29]# cd /usr/local/httpd2/bin;ls
apachectl  apu-1-config  checkgid  envvars    htcacheclean  htdigest  httpd
[root@localhost bin]# file apachectl 
apachectl: POSIX shell script, ASCII text executable
[root@localhost bin]# ./apachectl start

13,查看 httpd 服务是否开启(80端口)

[root@localhost bin]# netstat -ant
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
       ESTABLISHED
tcp6       0      0 :::80                   :::*                    LISTEN

14,访问 httpd 服务

wKioL1e9SZqx80MyAAAfgcUZYOk902.png

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

(0)
pingskypingsky
上一篇 2016-08-29
下一篇 2016-08-29

相关推荐

  • man帮助

                                        正确使用 man帮助      在生产过程中,我们会遇到不同的技术故…

    2017-05-30
  • linux下小练习(2)

    1、编写脚本/bin/per.sh,判断当前用户对指定的参数文件,  是否不可读并且不可写                         2、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充 许…

    Linux干货 2016-08-15
  • 对修改提示符引起的一些问题的理解

    有一个练习:提示符修改过后永久保存,每次打开一个新的shell,提示符都为已设定好的格式,不会因为打开新的shell而不同。 在做这个练习的时候遇到了不少问题,通过不断bing,将起初很陌生的问题一点点的解决,得到了一些理解,因此将理解写下来。 提示符与变量PS1有关,PS1的值可以被修改或重新赋予。PS1的值变,则提示符也会变。通过搜索得到只要在/etc/…

    Linux干货 2017-07-15
  • 马哥linux 0728作业

    1,软链接和硬链接的区别 硬链接有以下特性 1)文件有相同的 inode 及 data block; 2)只能对已存在的文件进行创建; 3)不能交叉文件系统进行硬链接的创建; 4)不能对目录进行创建,只可对文件创建; 5)删除一个硬链接文件并不影响其他有相同 inode 号的文件。 而软链接有一下特性 1)软链接有自己的文件属性及权限等; 2)可对不存在的文…

    Linux干货 2016-08-04
  • 马哥教育网络班21期+第7周课程练习

    马哥教育网络班21期+第7周课程练习 创建一个10G分区,并格式为ext4文件系统;    a.要求block大小为2048,预留空间百分比为2,卷标为MYDATA,默认挂载属性包含acl;    b.挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不能更新文件的访问时间戳; #&…

    Linux干货 2016-08-22
  • 看了还想看—普通权限及umask

        权限在操作系统是尤为重要的,无论是windows和linux中,都少不了权限这么一说,权限的大小决定了你能操作些什么,在linux中,权限对目录和文件的意义是不同的,并且还有特殊权限。今天,我们就来说说一说权限在linux中的重要性以及权限操作命令。     权限:权限决…

    Linux干货 2016-08-03