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

相关推荐

  • bash 基础特性1

    bash 基础特性 命令模式 systemctl set-default multi-user.target 图形模式 systemctl set-default graphical.target   # rmdir [OPTION]…DIRECTORY…-p:删除某录后,如果其父目录为空,则一并删除之-v:显示过程# mk…

    Linux干货 2017-06-01
  • 第三周作业

    1、列出当前系统上所有已登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 ~]# who | cut -d ' ' -f 1 | sort -u 2、取出最后登录到当前系统的用户的相关信息。 ~]# la…

    Linux干货 2016-12-19
  • 脚本

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;     #!/bin/bash     #     sum=0 &n…

    Linux干货 2016-12-23
  • 马哥教育网络班22期+第3周课程练习 忍者乱太郎喻成

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。  who|awk '{print $1}'|uniq 2、取出最后登录到当前系统的用户的相关信息。 题目不是很清晰我估计是题目想要的是 last -1   cat /etc/pa…

    Linux干货 2016-09-06
  • awk入门应用

    awk概述使用语法常用命令选项相关输出命令print item1,item2,…printf FORMAT,item1,item2,….相关格式符相关修饰符相关内建变量相关内置函数相关操作符相关模式相关控制语句及示例if(condition) statementsif(condition){statements} else {statements}while…

    Linux干货 2016-12-04
  • linux系统文件的元数据

    linux系统文件的元数据 什么是元数据 文件的数据分两种: 一种元数据,既属性数据:metadata 一种就是数据本身:data 如何查看元数据: stat stat命令用于显示文件的状态信息 [root@localhost ~]# stat /tmp/mylinux File: ‘/tmp/mylinux’ Size: 143 Blocks: 0 IO …

    Linux干货 2018-03-11