shell 脚本之数组 和 yum 【下】

shell 脚本之数组 和 yum 【下】

数组

 

变量:存储单个元素的内存空间  

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

数组名和索引 

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

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

      声明数组: declare -a ARRAY_NAME 

                 declare -A ARRAY_NAME: 关联数组

数组赋值

 数组元素的赋值: 

(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

引用数组

 引用数组元素:${ARRAY_NAME[INDEX]} 

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

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

${#ARRAY_NAME[*]} 

${#ARRAY_NAME[@]}  

示例:生成10个随机数保存于数组中,并找出其最大值和最小值 

#!/bin/bash 

declare -a rand 

declare -i max=0 

declare –i min=32767 

for i in {0..9}; do 

    rand[$i]=$RANDOM 

    echo ${rand[$i]} 

    [ ${rand[$i]} -gt $max ] && max=${rand[$i]} 

    [ ${rand[$i]} -lt $min ] && min=${rand[$i]} 

done 

echo "Max: $max  Min:$min"

编写脚本,定义一个数组,数组中的元素是/var/log目录下所有以 .log结尾的文件;要统计其下标为偶数的文件中的行数之和 

#!/bin/bash 

# declare -a files 

files=(/var/log/*.log) 

declare -i lines=0 

for i in $(seq 0 $[${#files[*]}-1]); do 

if [ $[$i%2] -eq 0 ];then 

    let lines+=$(wc -l ${files[$i]} | cut -d' ' -f1) 

fi 

done 

    echo "Lines: $lines."

数组数据处理

 引用数组中的元素: 

所有元素:

    ${ARRAY[@]}, ${ARRAY[*]} 

数组切片:

    ${ARRAY[@]:offset:number} 

offset: 

    要跳过的元素个数 

number: 

    要取出的元素个数 

取偏移量之后的所有元素 

    ${ARRAY[@]:offset}  

向数组中追加元素: 

    ARRAY[${#ARRAY[*]}]  

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

    unset ARRAY[INDEX]  

关联数组: 

    declare -A ARRAY_NAME 

注意:必须先声明,再调用 ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)

字符串处理

bash的字符串处理工具:  

字符串切片: 

${#var}:

    返回字符串变量var的长度 

${var:offset}:

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

${var:offset:number}:

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

${var: -lengh}:

    取字符串的最右侧几个字符 

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

${var:offset: -lengh}:

    从最左侧跳过offset字符,一直 取到字符串的最右侧lengh个字符之前

基于模式取子串: 

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

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

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

示例: 

    file="var/log/messages“ 

    ${file#*/}: log/messages 

    ${file##*/}: messages

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

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

示例 file="/var/log/messages" 

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

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

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

    ${url##*:} 80 

    ${url%%:*} http

查找替换: 

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

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

 查找并删除: 

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

     ${var//pattern}:所有 

     ${var/#pattern}:行首 

     ${var/%pattern}:行尾  

 字符大小写转换: 

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

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

变量赋值

${var:-value}:如果var为空或未设置,那么返回value;否 则,则返回var的值 ${var:+value}:如果var不空,则返回value,否则返回空值 ${var:=value}:如果var为空或未设置,那么返回value,并 将value赋值给var;否则,则返回var的值 ${var:?error_info}:如果var为空或未设置,那么在当前终 端打印error_info;否则,则返回var的值

 

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

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

    (2) 在脚本中source此文件即可

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

declare [选项] 变量名 

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

  -i 将变量定义为整型数 

  -a 将变量定义为数组 

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

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

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

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

  -l  

    将变量值转为小写字母 

    declare –l var=UPPER -u  

    将变量值转为大写字母 

    declare –u var=lower

间接变量引用

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

variable1=variable2 

variable2=value 

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

variable2的值为value,间接变量引用是指通过variable1获 得变量值value的行为

bash Shell提供了两种格式实现间接变量引用 

eval tempvar=\$$variable1 

     tempvar=${!variable1}  

示例: 

[root@server ~]# N=NAME 

[root@server ~]# NAME=45

[root@server ~]# N1=${!N} 

[root@server ~]# echo $N1 45

[root@server ~]# eval N2=\$$A 

[root@server ~]# echo $2 45

eval命令

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

示例: 

[root@server ~]# CMD=whoami 

[root@server ~]# echo  $CMD whoami 

[root@server ~]# eval $CMD 

               

创建临时文件

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

  mktemp [OPTION]… [TEMPLATE] TEMPLATE: filename.XXX X至少要出现三个 

  OPTION: 

  -d: 创建临时目录 

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

  示例: 

  #mktemp /tmp/test.XXX 

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

  #mktemp –tmpdir=/testdir test.XXXXXX

  安装复制文件

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 GROUP  

示例: 

install -m 700 -o wang -g admins file1 file2 

install –m –d /testdir/installdir 

bash如何展开命令行优先级

把命令行分成单个命令词 

展开别名 

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

展开波浪符声明(~) 

命令替换$() 和 “) 

再次把命令行分成命令词 

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

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

运行命令

bash的配置文件

按生效范围划分,存在两类:  

全局配置: 

  /etc/profile 

  /etc/profile.d/*.sh 

  /etc/bashrc  

个人配置: 

  ~/.bash_profile 

  ~/.bashrc

shell登录两种方式

 

交互式登录: 

  (1)直接通过终端输入账号密码登录; 

  (2)使用“su – UserName” 切换的用户 执行顺序: /etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc  

非交互式登录: 

  (1)su UserName 

  (2)图形界面下打开的终端 

  (3)执行脚本 执行顺序: ~/.bashrc –> /etc/bashrc –> /etc/profile.d/*.sh

Profile类

 按功能划分,存在两类: profiile类和bashrc类 

profile类:为交互式登录的shell提供配置 全局:/etc/profile, /etc/profile.d/*.sh 个人:~/.bash_profile 功用: (1) 用于定义环境变量 (2) 运行命令或脚本

bashrc类:为非交互式和交互式登录的shell提供配置 全局:/etc/bashrc 个人:~/.bashrc 

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

编辑配置文件生效

修改profile和bashrc文件后需生效 两种方法: 

  1重新启动shell进程 

  2 . 或source 

例: . ~/.bashrc

Bash 退出任务   

保存在~/.bash_logout文件中(用户)  

在退出登录shell时运行  

用于 

  创建自动备份 

  清除临时文件

yum 的仓库指向 和 编译安装 

 yum的命令行选项: 

     –nogpgcheck:禁止进行gpg check 

     -y: 自动回答为“yes” 

     -q:静默模式 

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

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

     –noplugins:禁用所有插件

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

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

  (2) 创建配置文件 

    [CentOS7] 

    name= 

    baseurl= 

    gpgcheck= 

    enabled=

程序包编译

 程序包编译安装: 

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

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

源代码组织格式: 

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

    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

准备:提供开发工具及开发环境 开发工具:make, gcc等 开发环境:开发库,头文件 glibc:标准库 实现:通过“包组”提供开发组件 

CentOS 6: 

    Development Tools 

    Server Platform Development 

CentOS 7: 

    Development Tools Development and Creative Workstati

第一步: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

安装后的配置: 

  (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

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

(0)
a1215276209a1215276209
上一篇 2016-08-24
下一篇 2016-08-24

相关推荐

  • linux下的打包与压缩

    linux压缩或解压缩工具有很多,除了已经很少有人使用的compress外,现在常用的还有tar,bzip2,xz 和gzip等,我们来说说它们的用法。 先来说bzip2。bunzip2和bzcat可以由bzip2指定选项来执行同样的结果,这里只介绍bzip2的用法。使用bzip2这个工具创建的文件以.bz2,.bz,.tbz,.tar.bz2或者…

    Linux干货 2017-04-16
  • 第八周

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态;      在线的主机使用绿色显示;      不在线的主使用红色显示; #!/bin/bash # for i in 172.16.250.{…

    Linux干货 2017-05-23
  • linux基础之用户管理

    介绍了一些基础命令,比如cut、head传输到管道时的使用,并通过详细的介绍、大量的习题完成了用户管理的相关知识

    Linux干货 2017-12-15
  • Linux运维学习历程-第一天-基础知识

    什么是Linux   Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。 为什么学Linux…

    Linux干货 2016-08-03
  • HAProxy

    LB Cluster: 四层:lvs, nginx(stream),haproxy(mode tcp) 七层:http: nginx(http, ngx_http_upstream_module), haproxy(mode http), httpd, ats, perlbal, pound… HAProxy 程序环境: 主程序:/usr/sbi…

    Linux干货 2017-07-03
  • 系统管理之程序包管理(一) rpm详解

    系统管理之程序包管理(1):     程序包管理是运维人员的基本工作素质之一。在操作系统上,不断的安装,卸载,配置应用程序包,让不同程序包运行提供不同的服务;利用某种工具完成某些操作的过程。这就要求运维工作人员熟悉安装,管理应用程序包。 在linux上,程序包主要有两种:tar,rpm包。 一、程序包概述: 系统接口   &nb…

    Linux干货 2016-08-21