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 21:21
下一篇 2016-08-24 21:21

相关推荐

  • N26-第一周博客作业

    1、计算机的组成及功能     CPU: Central Processing Unit 运算与管理控制功能        包括:          &nbsp…

    Linux干货 2017-01-10
  • 终于成为马帮的成员了

    终于成为马帮的成员了

    Linux干货 2016-09-18
  • 初学Linux练习题

    1、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中 tr ‘a-z’ ‘A-Z’ < /etc/issue  > /tmp/issue.out 2、将当前系统登录用户的信息转换为大写后保存至/tmp/who.out文件中 3、一个linux用户给root发邮件…

    2017-11-19
  • M20-1正则表达式有话说

    1、找出ifconfig命令结果中本机的所有ipv4地址  [root@centos7 ~]# ifconfig |grep -E -o '(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-…

    Linux干货 2016-08-05
  • 学习笔记–权限管理

    文件系统的权限管理 1、Linux系统下每个目录或文件的权限对象主要分为:属主(u)、属组(g)、其他用户(o),针对每类访问对象都定义了三种权限:读(r)、写(w)、执行(x),这三种权限针对目录和文件的作用各不相同,以下将做详细说明: 对于文件来说: 读(r)权限:可以使用文本查看类工具读取文件内容 写(w)权限:可以修改文件内容,但不能删除文件本身 执…

    Linux干货 2016-08-05
  • 推倒一个二十来岁青壮年第一步

    首先:找到他家在哪里,了解他的生长环境 然后:调查他的信息,慢慢了解他,学会和他交流,学会控制他

    Linux干货 2016-09-21