yum更多用法及源码编译安装apache和当天作业

一、yum的更多用法

上篇文章介绍了yum的基础用法及yum源的基本配置,除此之外yum还有更多的用法,以下将继续介绍yum的使用方法。

1、yum-config-manager工具,该工具可以自动生成yum的repo文件,而不需要手动创建编写,使用方法如下:

用法:yum-config-manager [options] [section]

-add-repo:添加仓库

# 添加一个阿里云的yum仓库
yum-config-manager -add-repo=http://mirrors.aliyun.com/centos/7.2.1511/os/x86_64/

–enable:启用某个仓库

–disable:禁用某个仓库

#禁用名为base的仓库
[root@liang yum.repos.d]# yum-config-manager --disable base
#启用名为base的仓库
[root@liang yum.repos.d]# yum-config-manager --enable base

2、包组管理,有些程序的安装包不止一个,而是一组程序包,这时可以使用包组的相关命令。yum工具从3.4.2版本之后包组管理命令分开为两个,比如groups list、groups install,3.4.2之前版本的组管理命令是一个,比如grouplist、groupinstall。以下将以3.4.2之后版本为例介绍。

groups list:显示组包名称

[root@fengl bin]# yum groups list

groups install:安装组包

#安装名为"Basic Web Server"的组包
[root@fengl bin]# yum groups install "Basic Web Server"

groups remove:移除组包

#移除名为"Basic Web Server"的组包
[root@fengl bin]# yum groups remove "Basic Web Server"

groups info:显示组包信息,“+”表示要安装的包,“=”表示已安装的包

#显示名为"Basic Web Server"组包的详细信息
[root@fengl bin]# yum groups info "Basic Web Server"

groups update:更新包组

#更新名为"Basic Web Server"的组包
[root@fengl bin]# yum groups update "Basic Web Server"

在CentOS7中,包组的命令有多种方式,比如groups info ,也可以写成group info或者groupinfo

3、yum的repo配置文件中也可以使用变量,在有些复杂的环境中使用变量能够大大减少配置量。

$releasever:当前OS的发行版的版本号,例如CentOS6.6 x86_64,其主版本为6

$basearch:平台,如 i386,i486,i586,x86_64等

$YUM0-$YUM9:自定义变量

例如:baseurl=http://repo.magedu.com/centos/$releasever/$basearch 且当前系统版本为CentOS6.6 x86_64,则baseurl表示的路径为: http://repo.magedu.com/centos/6/x86_64

    

4、本地创建yum仓库,有时需要自己建立一个yum仓库,即需要创建repodata目录及其相关yum的索引xml文件等,创建时使用的命令为:createropo,用法如下:

用法:createrepo [options] <directory>

一般情况下直接使用createrepo命令加目录即可,比如我的rpm包程序都放在/test目录下,可以直接使用creatrepo命令创建yum仓库

#为/test目录下的rpm包创建仓库
[root@fengl testdir]# createrepo /test/
#创建完之后可以在/test目录下看到repodata目录,里面存放有相关的仓库信息
[root@fengl repodata]# ls
01a3b489a465bcac22a43492163df43451dc6ce47d27f66de289756b91635523-filelists.sqlite.bz2
401dc19bda88c82c403423fb835844d64345f7e95f5b9835888189c03834cc93-filelists.xml.gz
5dc1e6e73c84803f059bb3065e684e56adfc289a7e398946574d79dac6643945-primary.sqlite.bz2
6bf9672d0862e8ef8b8ff05a2fd0208a922b1f5978e6589d87944c88259cb670-other.xml.gz
7c36572015e075add2b38b900837bcdbb8a504130ddff49b2351a7fc0affa3d4-other.sqlite.bz2
dabe2ce5481d23de1f4f52bdcfee0f9af98316c9e0de2ce8123adeefa0dd08b9-primary.xml.gz
repomd.xml

如果/test目录下的rpm包有增加、删除或更新等变动时,需要更新源数据信息时,可以使用–update选项

[root@fengl /]# createrepo --update /test

二、源码编译安装

1、源码编译安装主要分为3个步骤:

(1)运行configure脚本,可以动过该脚本指定以下信息

    –prefix:指定默认安装路径

    –sysconfdir:指定配置文件安装路径

    –with-CAPABILITY:依赖的程序包

    –enable-FEATURE:启用某个特性

    –disable-FEATURE:禁用某个特性

(2)运行make命令,完成项目构建,即根据makefile文件,构建引用程序

(3)运行make install命令,完成安装,即复制文件到相应的路径

2、源码安装apache示例

第1步:先yum安装develpment tools

第2步:下载apache源码程序包,并解压

[root@fengl test]# tar -jxvf httpd-2.2.29.tar.bz2

第3步:进入解压后的程序包目录下,查看configure文件,并运行,指定安装路径等

[root@fengl httpd-2.2.29]# ./configure --prefix=/usr/local/http2 --sysconfdir=/etc/http2/

第4步:执行make命令,完成项目构建

[root@fengl httpd-2.2.29]# make

第5步:执行make install,完成安装,安装完成后会在指定么目录下生成相应的文件

[root@fengl httpd-2.2.29]# make install
# /etc/http2下的文件
[root@fengl http2]# ll
total 92
drwxr-xr-x. 2 root root  4096 Aug 24 23:01 extra
-rw-r--r--. 1 root root 13702 Aug 24 23:01 httpd.conf
-rw-r--r--. 1 root root 12958 Aug 24 23:01 magic
-rw-r--r--. 1 root root 53011 Aug 24 23:01 mime.types
drwxr-xr-x. 3 root root  4096 Aug 24 23:01 original
# /usr/local/http2下的文件
[root@fengl http2]# ll
total 56
drwxr-xr-x.  2 root root  4096 Aug 24 23:01 bin
drwxr-xr-x.  2 root root  4096 Aug 24 23:01 build
drwxr-xr-x.  2 root root  4096 Aug 24 23:01 cgi-bin
drwxr-xr-x.  3 root root  4096 Aug 24 23:01 error
drwxr-xr-x.  2 root root  4096 Aug 23  2014 htdocs
drwxr-xr-x.  3 root root  4096 Aug 24 23:01 icons
drwxr-xr-x.  2 root root  4096 Aug 24 23:01 include
drwxr-xr-x.  3 root root  4096 Aug 24 23:01 lib
drwxr-xr-x.  2 root root  4096 Aug 24 23:01 logs
drwxr-xr-x.  4 root root  4096 Aug 24 23:01 man
drwxr-xr-x. 14 root root 12288 Aug 23  2014 manual
drwxr-xr-x.  2 root root  4096 Aug 24 23:01 modules

第6步:将apache的man帮助文件添加到man的配置文件(/etc/man_db.conf)中

1.png

第7步:将apache服务中的/bin目录下的可执行命令添加到PATH变量中

#在/etc/profile.d/目录下创建http2.sh文件,并添加PATH变量
[root@fengl profile.d]# vim /etc/profile.d/http2.sh 
#查看添加的PATH变量
[root@fengl profile.d]# cat /etc/profile.d/http2.sh 
PATH=$PATH:/usr/local/http2/bin
#加载刚添加的变量
[root@fengl profile.d]# . http2.sh
#查看是否加载 
[root@fengl profile.d]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/http2/bin

第8步:启动apache服务

[root@fengl bin]# apachectl start

第9步:测试(需要更改防火墙设置)

2.png

三、当天作业

1、输入若干个数值存入数组中,采用冒泡算法进行升序或降序排序

[root@fengl bin]# cat sz.sh 
#!/bin/bash

declare -a arr
until echo ${arr[*]} | grep -E "^[[:digit:]' ']+$" &> /dev/null;
do
read -p "请输入一组数字,每个数字以空格隔开:" -a arr
done

up () {
local i=$[`echo ${#arr[*]}`-1]
while [ $i -ge 0 ] ;
do
    local n=$[i-1]
    while [ $n -ge 0 ] ;
    do
        if [[ ${arr[$i]} -lt ${arr[$n]} ]] ;then
            local x=${arr[$i]}
            local y=${arr[$n]}
            arr[$i]=$y
            arr[$n]=$x
        fi
        let n--
    done
    let i--
done
echo ${arr[*]}
}
down () {
local i=$[`echo ${#arr[*]}`-1]
while [ $i -ge 0 ] ;
do
        local n=$[i-1]
        while [ $n -ge 0 ] ;
        do
                if [[ ${arr[$i]} -gt ${arr[$n]} ]] ;then
                        local x=${arr[$i]}
                        local y=${arr[$n]}
                        arr[$i]=$y
                        arr[$n]=$x
                fi
                let n--
        done
        let i--
done
echo ${arr[*]}
}
echo "升序排列为:"
up
echo "降序排列为:"
down

3GIF.gif

原创文章,作者:苦涩咖啡,如若转载,请注明出处:http://www.178linux.com/39577

(0)
苦涩咖啡苦涩咖啡
上一篇 2016-08-24
下一篇 2016-08-24

相关推荐

  • net25-第12周作业

    1、请描述一次完整的http请求处理过程; – (1)客户端发送http请求– (2)服务端建立或处理连接,接受请求或拒绝请求– (3)接受请求:接受客户端对服务器某一资源的请求– (4)处理请求:对请求报文进行解析,获取客户端请求的资源及请求方法等相关信息– (5)访问资源:获取请求报文中请求的资…

    Linux干货 2017-05-15
  • N26-第十五周

    温故知新1、总结sed和awk的详细用法;sed stream EDitor 流编辑器,行级sed  [option] …’script’ [input-file]script 地址定界编辑命令常用选项-n 静默模式 ,不输出模式空间中的内容至屏幕-e script –expression …

    Linux干货 2017-08-24
  • HA专题: corosync+pacemaker实现nginx高可用

    HA专题: corosync+pacemaker实现nginx高可用 前言 实验介绍 实验拓扑 实验环境 实验步骤 准备工作 安装HA集群组件 安装nginx和配置nfs 使用crmsh配置集群资源 测试 总结 前言 这几天都会学习高可用集群, 也会将其中的一些实验写出来分享给大家, 这个专题估计会写5篇左右, p.s: 写博客很累的 实验介绍 这次的实验比…

    Linux干货 2016-04-11
  • N25-第十周

    1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) 一、内核空间详细过程如下: POST –> BootSequence(BIOS) –> Bootloader(MBR) –> kernel(ramdisk) –> rootfs(只读) –> /sbin/init(systemd) 1.POST:(pow…

    Linux干货 2017-05-30
  • 用户、组、权限管理练习

    用户、组管理练习 一、创建的内容:        1、组Rockets,Knicks,Cavaliers,他们的GID分别是501,540,530。    2、用户James(theBeard),Chris(CP3),Lebron(King),Carmelo(Melo),他们的uid分别是…

    Linux干货 2017-09-03