现在的位置: 首页 > 综合 > 正文

linux 基础学习之三:bash shell初识 下

2013年04月29日 ⁄ 综合 ⁄ 共 2373字 ⁄ 字号 评论关闭

5、变量键盘读取、数组与宣告: read, array, declare

read:用于读取键盘输入的变量,常用在shell script的编写当中,下面先看基本功能:

[root@linux ~]# read [-pt] variable
参数:
-p :后面可以接提示字符!
-t :后面可以接等待的『秒数!』这个比较有趣~不会一直等待使用者啦!

范例一:让使用者由键盘输入一内容,将该内容变成 atest 变量
[root@linux ~]# read atest
This is a test
[root@linux ~]# echo $atest
This is a test

范例二:提示使用者 30 秒内输入自己的大名,将该输入字符串做成 named 变量
[root@linux ~]# read -p "Please keyin your name: " -t 30 named
Please keyin your name: VBird Tsai
[root@linux ~]# echo $named
VBird Tsai

read 之后不加任何参数,直接加上变量名称,那么底下就会主动出现一个空白行,等待您输入。 如果加上 -t 后面接秒数之后,例如上面的范例当中,那么 30 秒之内没有任何动作时, 该指令就会自动略过了~如果是加上 -p ,嘿嘿!后面就会有比较多可以用的提示字符给我们参考! 在指令的下达里面,比较美观啦! ^_^

declare / typeset:一样的功能,就是在宣告变量的属性。
如果使用 declare 后面并没有接任何参数, 那么 bash 就会主动的将所有的变量名称与内容通通叫出来,就好像使用 set 一样啦! 那么 declare 还有什么语法呢?看看先:
[root@linux ~]# declare [-aixr] variable
参数:
-a :将后面的 variable 定义成为数组 (array)
-i :将后面接的 variable 定义成为整数数字 (integer)
-x :用法与 export 一样,就是将后面的 variable 变成环境变量;
-r :将一个 variable 的变量设定成为 readonly ,该变量不可被更改内容,也不能 unset

范例一:让变量 sum 进行 100+300+50 的加总结果
[root@linux ~]# sum=100+300+50
[root@linux ~]# echo $sum
100+300+50                                        <==咦!怎么没有帮我计算加总?因为这是文字型态的变量属性啊!

[root@linux ~]# declare -i sum=100+300+50
[root@linux ~]# echo $sum
450                      <==这下好了。。。

范例二:将 sum 变成环境变量
[root@linux ~]# declare -x sum
范例三:让 sum 变成只读属性,不可更动!
[root@linux ~]# declare -r sum
[root@linux ~]# sum=tesgting
-bash: sum: readonly variable             <==老天爷~不能改这个变数了!
declare 也是个很有用的功能~尤其是当我们需要使用到底下的数组功能时, 他也可以帮我们宣告数组的属性喔!不过,老话一句,数组也是在 shell script 比较常用的啦!
6、与档案系统及程序的限制关系: ulimit
想象一个状况:我的 Linux 主机里面同时登入了十个人,这十个人不知怎么搞的, 同时开启了 100 个档案,每个档案的大小约 10MBytes ,请问一下, 我的 Linux 主机的内存要有多大才够? 10*100*10 = 10000MBytes ~~ 老天爷,这样,系统不挂点才有鬼哩!为了要预防这个情况的发生,所以, 我们的 bash 是可以『限制使用者的某些系统资源』的,包括可以开启的档案数量, 可以使用的 CPU 时间,可以使用的内存总量等等。如何设定?用 ulimit 吧!
[root@linux ~]# ulimit [-SHacdflmnpstuv] [配额]
参数:
          -H :hard limit ,严格的设定,必定不能超过设定的值;
          -S :soft limit ,警告的设定,可以超过这个设定值,但是会有警告讯息,并且,还是无法超过 hard limit 的喔!也就是说,假设我的 soft limit为 80 , hard limit 为 100 ,那么我的某个资源可以用到 90 ,可以超过 80 ,还是无法超过 100 ,而且在 80~90 之间,会有警告讯息的意思。
        -a :列出所有的限制额度;
        -c :可建立的最大核心档案容量 (core files)
        -d :程序数据可使用的最大容量
         -f :此 shell 可以建立的最大档案容量 (一般可能设定为 2GB)单位为 Kbytes
         -l :可用于锁定 (lock) 的内存量
         -p :可用以管线处理 (pipe) 的数量
         -t :可使用的最大 CPU 时间 (单位为秒)
        -u :单一使用者可以使用的最大程序(process)数量。
范例一:列出所有的限制数据
[root@linux ~]# ulimit -a
范例二:限制使用者仅能建立 1MBytes 以下的容量的档案
[root@linux ~]# ulimit -f 1024
还记得我们在 Linux 磁盘档案系统 里面提到过,单一 filesystem 能够支持的单一档案大小与 block 的大小有关。例如 block size 为 1024 byte 时,单一档案可达 16GB 的容量。但是,我们可以用 ulimit 来限制使用者可以建立的档案大小喔! 利用 ulimit -f 就可以来设定了!例如上面的范例二,要注意单位喔!单位是 Kbytes。 若改天你一直无法建立一个大容量的档案,记得瞧一瞧 ulimit 的信息喔!( 不过,要注意的是,一般身份使用者如果以 ulimit
设定了 -f 的档案大小, 那么他『只能减小档案大小,不能增加档案大小喔!』)

抱歉!评论已关闭.