Linux 打开shell的过程;bash基本使用

登录到shell的过程

  1. linux系统在调用init初始化进程之前,主要是完成系统级别的一系列动作,此时,用户根本无法使用系统,因为系统根本没有让用户控制系统的途径!
  2. init之所以存在,其意义应该是增加linux的灵活性 和 标准性:变异的linux完全可以调用其他的init程序;有了统一的init入口后,可以机动的定义之后的调用动作。
  3. 一般的linux总是调用init作为pid=1的进程,它是所有进程的起点!
  4. init调用login进程,进行登陆验证
  5. login调用shell。shell有很多中,找个适合你自己的就行了
  6. shell才是用户和linux的交互接口。这个接口就是为了让用户高效、方便、灵活、强大的控制和使用liunx而存在的!如果是特殊的应用。login完全可以不调用shell!
  7. shell会调用一系列初始化文件:
  1. /etc/profile  --系统
  2. /etc/bashrc  --系统
  3. ~/.bash_profile  --user
  4. ~/.bashrc  --user
  5. ~/.bash_login  --user
  6. ~/.profle  --user
  7. ~/.bash_logout  --user logout

bash的基本用法

  • bash显示变量:echo $环境变量
  • bash设置变量:set 环境变量=值
  • bash倒出到系统变量:export 环境变量=值
  • bash以当前shell环境执行一个脚本,通常用于设置当前shell的环境变量:source【.】 脚本
  • bash解释输入的顺序:命令空白..参数..回车。命令的优先级:
  1. 别名
  2. bash的编程关键字
  3. 函数
  4. 内置命令
  5. 外部命令
  • bash的内置命令:help 获得内置命令的帮助
  • bash的内置命令:type 获得查询命令的类型
  • bash的内置命令:buildin、enable、command管理内、外命令是否生效
  • bash命令执行状态的返回变量:$?  通常:0.成功;127.命令未找到;>=128.程序错误终止
  • bash无条件执行多个命令:各命令以分号“;”分隔。执行的状态为最后一个命令的返回状态。如果想让多个命令的输出重定向到文件,需要把这些命令放到(命令1;命令2;  )> out.txt 内,最后的命令必须加空格
  • bash依赖条件执行多个命令:各命令以“&&”分隔,前边的执行成功才执行后边的
  • bash依赖条件执行多个命令:各命令以“||”分隔,前边的执行失败才执行后边的
  • bash后台执行命令:在命令后加上“&”。注意,如果该命令有屏幕输出就不好了,需要重定向到其他才不会影响前台的输入等
  • bash终止当前运行的程序的执行:ctrol+c 或 ctrol + \
  • bash将当前运行的程序放到后台以作业的形式运行:ctrol+z,注意这样实际上在后台上挂起的状态。$!变量获得最后放入后台的作业的进程pid
  • bash作业管理:  
  •  
    •  
      • ctrol+z  --后台挂起;  命令&  --后台运行
      • jobs  --列车所有后台作业。 -r 正在运行的 ;-s 挂起的;%n 作业号;%name 作业名 ;%?name 含有name的作业; %+ 当前作业;%% 当前作业;%-上一个作业
      • bg  --执行后台作业
      • fg  --将后台作业放到前台执行
      • stop  --挂起后台作业
      • stty tostop  --如果后台作业有终端输出,则挂起
      • kill  --终止后台作业
      • wait  --等待后台作业及其返回值
  • bash使用tab键自动完成命令 或 文件名
  • bash命令历史功能:默认放在~/bash_history下。history内置命令显示历史记录。fc命令可以查看、执行历史命令;“!!”可以执行最后历史命令;“!n” 执行指定行号的历史命令;“!name”执行以name开头的最后执行的历史命令


bash编程

一:变量

  1. declare 或 直接赋值 的局部变量:declare var1=20  或  var2='as   df\df'
  2. export的全局变量:var1=sdaf   export var1 或 export var2=vdsf3
  3. 位置变量:$1 ---- $n
  4. 特殊预定于变量:$0--当前进程的文件名   $$--当前进程的spid  $#--位置参数的个数   $!--后台最后执行的作业的作业号    $?--上一程序的执行状态  $@--全部位置参数--原样的参数列表   $*--全部位置参数--内部用单引号括起来的一个字符串  
  5. 其他预定于的环境变量:$UID  $PWD  $PATH...........
  6. 变量扩展:虽然 $vars可能会——变量和周围文本通过空白分隔了——正确的工作,但${vars}总能正确的工作
  7. unset:删除环境变量,不能删除只读的环境变量
  8. readonly var=值:定义只读的环境变量。注意:只读的意思是可以修改值,但不能unset环境变量
  9. 命令替换:反单引号方式`ls ` $(ls ) 方式

二:注释及魔数

  #  --行注释

  #!/bin/bash  --魔数

三:高级变量扩展:参数变量的替换

  1. ${v1-v2}  --如果v1没义或为空有定,v2替换v1,v1不会被更改  --定义默认值
  2. ${v1+v2}  --如果v1没义或为空有定,不做任何处理,否则v2替换v1,v1不会被更改  --强制使用默认值
  3. ${v1=v2}  --如果v1没义或为空有定,v2替换v1,v1被更改为v2。--注意因为更改v1,这种用法被能用于位置参数
  4. ${v1?v2}  --如果v1没义或为空有定,非交互模式下:类似于${v1-v2},但bash有标准错误输出;交互模式下:bash提示错误v1需要定义,提示内容为v2,并退出shell执行!
  5. ${var##*str}  --开头长变量截去
  6. ${var#*str}  --开头短变量截去
  7. ${var%%str*}  --末尾长变量截去
  8. ${var%str*}  --末尾短变量截去
  9. ${var/pattern}  --开头模式匹配删除。可以通过在pattern上加上“#、%”来明确指示是开头还是结尾删除
  10. ${var//pattern}  --模式匹配删除
  11. ${var/pattern/replace}  --模式匹配替换
  12. ${var//pattern/replace}  --模式匹配替换
  13. ${var:startpos:length}  --截取指定位置和长度的字符串,开始位置、长度均可省略,默认为0或1、到末尾

四:条件测试表达式

数值测试,复合模式下,可以使用c的语法和运算符

  • -eq 等于  --注意和字符串比较的 “=”类似
  • -ne 不等于  --注意和字符串比较的 “!=”类似
  • -gt 大于
  • -lt 小于
  • -ge 大于等于
  • -le 小于等于
  • ...
  • ...

字符串比较:注意双引号引用的使用

  • = 等于
  • ==通配符比较
  • != 不等于
  • >
  • <
  • -z字符串  字符串长度等于0
  • -n字符串  字符串长度大于0

文件测试

  • -e文件名  文件存在
  • -r文件名  文件存在且可读
  • -w文件名  文件存在且可写
  • -x文件名  文件存在且可执行
  • -s文件名  文件存在且至少有一个字符
  • -S文件名  文件存在且是套接字
  • -d目录名  文件存在且目录存在
  • -f文件名  文件存在且普通文件
  • -c文件名  文件存在且字符文件
  • -b文件名  文件存在且块文件
  • -p文件名  文件存在且是管道文件
  • -L|-h文件名  文件存在且是符号链接文件
  • -N文件名  文件自最后读取后发生修改
  • file1 -nt file2 file1 比 file2 文件新
  • file1 -ot file2 file1 比 file2 文件旧
  • file1 -ef file2 file1 是否是 file2 的硬连接

符合运算符

  • test express 内置命令测试 等同于 [express]  --不能屏蔽特殊字符如>、 <、 \、 (、) 等等
  • [express] 内置命令测试 等同于 test express   --不能屏蔽特殊字符如>、 <、 \、 (、) 等等
  • [[express]] 字符串复合运算符表达式,指出通配符比较。
  • ((express)) 算数复合运算符表达式 可以使用类似于c的语法
  • let express 算数运算赋值测试内置命令

五:数值计算表达式

  $((express))  或 $[express]

六:基本流程控制语句。这些语句的关键字必须放在不同的行

if 条件测试

then

命令

           elif [condition]

           then

             命令

else

命令

fi

for 变量 [in 列表]  --注意这里的“变量”是循环控制变量

do

若干命令

done

例子1:

for myfile in /etc/r*   /var/lo*  ${ORACLE_HOME}/*

do

  if [-d "$myfile"]

  then

    echo "$myfile is (dir)"

  else

    echo "$myfile is (file)"

  fi

done

例子2:

#! /bin/bash

for param in "$@"

do

  echo "$param"

done

while|until  --区别在于while当“若干命令1”最后执行的状态为真时执行循环,until反之

若干命令1

do

若干命令2

done

case string in

exp1)

  若干命令1

;;

exp2)

  若干命令2

;;

.........

*)

  其他命令

esac

          breake 和 continue

七:函数。函数实际上是一组程序,是shell脚本程序的一部分

  注意:bash的函数中定义的变量即是shell全局变量,所以必须注意变量的使用。可以通过在函数内定义的变量声明为local来避免对函数外部全局变量的影响!

functionname

  local var=值

  若干命令

函数的调用:functionname param1 param2 ...

shell将会自动将这些参数传给位置变量$1 $2 .... $# $*

 

八:命令分组

  (命令) --shell打开新的子shell进程调用命令

  {命令} --shell以管道的方式从自身的shell进程中运行命令

九:bash的执行和调试

  执行:bash 脚本文件 或 将脚本文件设置为可执行

  调试:bash 选项 脚本文件。常用的调试选项

  • -n  --读入命令但不执行
  • -u  --如果变量未设置,则认为程序错误
  • -v  --读入shell的输入行时显示出来
  • -x  --执行shell命令时,显示命令及其参数
  • 在shell程序内使用echo等内部命令输出变量及中间结果

十:bash中特殊的函数、语句、其他

dirname 和 basename 是字符串函数

标识不同进制的数值:base#数字符号  --如 八进制057、 16进制0x23a、2进制2#0101、30进制30#12b

原文地址:https://www.cnblogs.com/jinzhenshui/p/1417610.html