码迷,mamicode.com
首页 > 编程语言 > 详细

bash数组和字符串处理、yum命令详解及编译安装

时间:2016-08-26 00:04:35      阅读:304      评论:0      收藏:0      [点我收藏+]

标签:数组、字符串处理、declare、yum、编译安装

8月22号主要内容:

一、bash中的数组

二、bash中字符串处理

三、高级变量及配置用户环境

四、yum详解

五、编译安装


一、bash中的数组

1、数组的组成和申明

(1) 数组:存储多个元素的连续的内存空间,相当于多个变量的 集合。

(2) 组成:数组名和索引

     索引:编号从0开始,属于数值索引

     注意:索引可支持使用自定义的格式,而不仅是数值格式 ,即为关联索引,bash4.0版本之后开始支持。 bash的数组支持稀疏格式(索引不连续)

(3) 申明数组:

        declare -a ARRAY_NAME

        declare -A ARRAY_NAME: 关联数组


2、数组的赋值

(1) 一次只赋值一个元素;

    ARRAY_NAME[INDEX]=VALUE

    weekdays[0]="Sunday"

    weekdays[4]="Thursday"

(2) 一次赋值全部元素:

    ARRAY_NAME=("VAL1" "VAL2" "VAL3" ...)

(3) 只赋值特定元素: ARRAY_NAME=([0]="VAL1" [3]="VAL2" ...)

(4) 交互式数组值对赋值 read -a ARRAY (输入多个数值即可同时给多个元素赋值)


3、引用数组
(1)引用数组元素:${ARRAY_NAME[INDEX]}

    注意:省略[INDEX]表示引用下标为0的元素

(2)数组的长度(数组中元素的个数):

    ${#ARRAY_NAME[*]}

    ${#ARRAY_NAME[@]}


4、数组数据处理
(1) 引用数组中的元素:

    所有元素:${ARRAY[@]}, ${ARRAY[*]}

    数组切片:${ARRAY[@]:offset:number}

        offset: 要跳过的元素个数

        number: 要取出的元素个数 取偏移量之后的所有元素 ${ARRAY[@]:offset}

(2) 向数组中追加元素:

    ARRAY[${#ARRAY[*]}]

(3) 删除数组中的某元素:导致稀疏格式

    unset ARRAY[INDEX]

(4) 关联数组:

    declare -A ARRAY_NAME 注意:必须先声明,再调用

    ARRAY_NAME=([idx_name1]=‘val1‘ [idx_name2]=‘val‘...)



二、bash中字符串处理

1、字符串切片:

(1) ${#var}:返回字符串变量var的长度

(2) ${var:offset}:返回字符串变量var中从第offset个字符后 (不包括第offset个字符)的字符开始,到最后的部分,offset 的取值在0 到 ${#var}-1 之间(bash4.2后,允许为负值)

(3) ${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为 number的部分

(4) ${var: -lengh}:取字符串的最右侧几个字符

        注意:冒号后必须有一空白字符

(5) ${var:offset: -lengh}:从最左侧跳过offset字符,一直取到字符串的最右侧lengh个字符之前


2、基于模式取子串:

(1) ${var#*word}:其中word可以是指定的任意字符

    功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的 所有字符

(2) ${var##*word}:同上,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容

    示例:取路径的基名

        file="var/log/messages" 

        ${file##*/}: messages

(3) ${var%word*}:其中word可以是指定的任意字符;

    功能:自右而左,查找var变量所存储的字符串中,第一 次出现的word, 删除字符串最后一个字符向左至第一次出现word字符之间的所有字符;

    示例:取路径的文件名

       file="var/log/messages"

       ${file%/*}: /var/log

(4) ${var%%word*}:同上,只不过删除字符串最右侧的字符向 左至最后一次出现word字符之间的所有字符;

    示例: 取url类型

        url=http://www.magedu.com:80

        ${url##*:} 80

        ${url%%:*} http


3、查找替换:
(1) ${var/pattern/substi}:查找var所表示的字符串中,第 一次被pattern所匹配到的字符串,以substi替换之

(2) ${var//pattern/substi}: 查找var所表示的字符串中, 所有能被pattern所匹配到的字符串,以substi替换之

(3) ${var/#pattern/substi}:查找var所表示的字符串中, 行首被pattern所匹配到的字符串,以substi替换之

(4) ${var/%pattern/substi}:查找var所表示的字符串中, 行尾被pattern所匹配到的字符串,以substi替换之


4、查找并删除:

(1) ${var/pattern}:查找var所表示的字符串中,删除第一 次被pattern所匹配到的字符串

(2) ${var//pattern}:所有

(3) ${var/#pattern}:行首

(4) ${var/%pattern}:行尾


5、字符大小写转换:

${var^^}:把var中的所有小写字母转换为大写

${var,,}:把var中的所有大写字母转换为小写



三、高级变量及配置用户环境

1、变量赋值新方法

(1) ${var:-value}:如果var为空或未设置,那么返回value;否 则,则返回var的值

(2) ${var:+value}:如果var不空,则返回value,否则返回空值

(3) ${var:=value}:如果var为空或未设置,那么返回value,并 将value赋值给var;否则,则返回var的值

(4) ${var:?error_info}:如果var为空或未设置,那么在当前终 端打印error_info;否则,则返回var的值

(5) 为脚本程序使用配置文件,实现变量赋值

     定义文本文件,每行定义“name=value”

     在脚本中source此文件即可


2、高级变量用法-有类型变量

(1) Shell变量一般是无类型的,但是bash Shell提供了declare和 typeset两个命令用于指定变量的类型,两个命令是等价的

(2) declare [选项] 变量名

    -r 将变量设置为只读属性

    -i 将变量定义为整型数

    -a 将变量定义为数组

    -A 将变量定义为关联数组

    -f 显示此脚本前定义过的所有函数名及其内容

    -F 仅显示此脚本前定义过的所有函数名

    -x 将变量声明为环境变量

    -l  将变量值(大写部分)转为小写字母 declare –l var=UPPER

    -u  将变量值转为大写字母 declare –u var=lower


3、间接变量引用

如果第一个变量的值是第二个变量的名字,从第一个变量引 用第二个变量的值就称为间接变量引用 variable1=variable2

variable2=value

variable1的值是variable2,而variable2又是变量名, variable2的值为value

间接变量引用是指通过variable1获得变量值value的行为(仅有上面两个步骤是做不到的)

bash Shell提供的两种格式(完成将value赋给tempvar):

    eval tempvar=\$$variable1

    tempvar=${!variable1}

注:eval命令将会首先扫描命令行进行所有的置换,然后再执行该命令(两步)。该命令适用于那些一次扫描无法实现其功能的 变量。该命令对变量进行两次扫描


4、创建临时文件

(1) mktemp命令:创建的临时文件可避免冲突

(2) mktemp [OPTION]... [TEMPLATE] TEMPLATE: filename.XXX X至少要出现三个

(3) OPTION: -d: 创建临时目录

                    -p DIR或--tmpdir=DIR:指明临时文件所存放目录位置

    示例:

     #mktemp /tmp/test.XXX

     #tmpdir=`mktemp –d /tmp/testdir.XXX`

     #mktemp --tmpdir=/testdir test.XXXXXX


5、安装复制文件(编译安装时使用较多)

install命令:

    install [OPTION]... [-T] SOURCE DEST 单文件

    install [OPTION]... SOURCE... DIRECTORY

    install [OPTION]... -t DIRECTORY SOURCE...

    install [OPTION]... -d DIRECTORY...创建空目录

    选项:

            -m MODE ,默认755

            -o OWNER

            -g GROU

6、bash如何展开命令行(识别顺序)

    把命令行分成单个命令词

    展开别名

    展开大括号种的声明({})

    展开波浪符声明(~)

    命令替换$() 和 ``)

    再次把命令行分成命令词

    展开文件通配(*、?、[abc]等等)

    准备I/0重导向(<、>)

    运行命令


7、bash的配置文件
(1) 按生效范围划分,存在两类:

全局配置:

    /etc/profile

    /etc/profile.d/*.sh

    /etc/bashrc

个人配置:

    ~/.bash_profile

    ~/.bashrc

(2) 按功能划分,存在两类: profiile类和bashrc类

    profile类:为交互式登录的shell提供配置

            全局:/etc/profile, /etc/profile.d/*.sh

            个人:~/.bash_profile

            功用: (1) 用于定义环境变量 (2) 运行命令或脚本

    bashrc类:为非交互式和交互式登录的shell提供配置

            全局:/etc/bashrc

            个人:~/.bashrc

            功用: (1) 定义命令别名和函数 (2) 定义本地变量

(3) 修改profile和bashrc文件后需生效

    两种方法:

        1.重新启动shell进程

        2. 或source 例: . ~/.bashrc



四、yum命令详解

1、yum简介:

(1) YUM: Yellowdog Update Modifier,rpm的前端程序,用来 解决软件包相关依赖性,可以在多个库之间定位软件包

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

(3) 文件服务器: ftp://         http://         file:///


2、yum配置文件

(1) yum客户端配置文件:

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

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

(2) 仓库指向的定义:

    [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

(3) 教学环境yum源

    教室里的yum源: http://10.1.0.1/cobbler/ks_mirror/CentOS-7x86_64/

    CentOS epel: http://10.1.0.1/fedora-epel/7/x86_64/

    

3、yum命令的用法:

     yum [options] [command] [package ...]

     [options]:

        --nogpgcheck:禁止进行gpg check

        -y: 自动回答为“yes”

        -q:静默模式

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

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

        --noplugins:禁用所有插件

    [command]:

        显示仓库列表

                yum repolist [all|enabled|disabled]

        显示程序包:

                yum list

                yum list [all | glob_exp1] [glob_exp2] [...]

                yum list {available|installed|updates} [glob_exp1] [...]

        安装程序包:

                yum install package1 [package2] [...]

                yum reinstall package1 [package2] [...]  (重新安装)

         升级程序包:

                yum update [package1] [package2] [...]

                yum downgrade package1 [package2] [...] (降级)

          检查可用升级:

                yum check-update

        卸载程序包:

                yum remove | erase package1 [package2] [...]

        查看程序包information:

                yum info [...]

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

                yum provides | whatprovides feature1 [feature2] [...]

        清理本地缓存:

                yum clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]

        构建缓存:

                yum makecache

         搜索:

                yum search string1 [string2] [...] 以指定的关键字搜索程序包名及summary信息

        查看指定包所依赖的capabilities:

                yum deplist package1 [package2] [...]

        查看yum事务历史:

                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

        包组管理的相关命令:

                yum groupinstall group1 [group2] [...]

                yum groupupdate group1 [group2] [...]

                yum grouplist [hidden] [groupwildcard] [...]

                yum groupremove group1 [group2] [...] yum groupinfo group1 [...]


4、使用光盘当作本地yum仓库:

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

            # mount  /dev/cdrom  /media/cdrom

     创建配置文件 [CentOS7]

            name=

            baseurl=

            gpgcheck=

            enabled=


5、创建yum仓库:

        createrepo [options] <directory>


注:三种搭建yum仓库的方法见本人博客链接:

    http://xiaomonkey.blog.51cto.com/11869371/1842218



五、编译安装详解

1、程序包编译安装

    Application-VERSION-release.src.rpm --> 安装后,使 用rpmbuild命令制作成二进制格式的rpm包,而后再安装

    源代码-->预处理-->编译-->汇编-->链接-->执行

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

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


2、C代码编译安装三步骤:

(1) ./configure:

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

       检查依赖到的外部环境,如依赖的软件包

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

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

注意:安装前查看INSTALL,README


3、开源程序源代码的获取:

    官方自建站点: apache.org (ASF:Apache Software Foundation)     mariadb.org ...

    代码托管: SourceForge.net     Github.com     code.google.com

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


4、编译安装(编译C源代码)

(1) 准备:提供开发工具及开发环境

        开发工具:make, gcc等

        开发环境:开发库,头文件 glibc:标准库

(2) 实现:通过“包组”提供开发组件

        CentOS 6:

            Development Tools

            Server Platform Development

        CentOS 7:

            Development Tools

            Development and Creative Workstation

(3) 第一步:configure脚本

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

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

        选项分类:

            安装路径设定:

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

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

                System types:支持交叉编译

            Optional Features: 可选特性

                --disable-FEATURE

                --enable-FEATURE[=ARG]

    第二步:make

    第三步:make install

(4) 安装后的配置

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

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

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

    2) 导入库文件路径

            编辑/etc/ld.so.conf.d/NAME.conf 添加新的库文件所在目录至此文件中

            让系统重新生成缓存: ldconfig [-v]

    (3) 导入头文件

            基于链接的方式实现: ln -sv

    (4) 导入帮助手册

            编辑/etc/man.config|man_db.conf文件

            添加一个MANPATH

本文出自 “笑猴子” 博客,请务必保留此出处http://xiaomonkey.blog.51cto.com/11869371/1842611

bash数组和字符串处理、yum命令详解及编译安装

标签:数组、字符串处理、declare、yum、编译安装

原文地址:http://xiaomonkey.blog.51cto.com/11869371/1842611

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!