面向过程语言 开发的时候 需要 一步一步 执行
做一件事情,排出个步骤,第一步干什么,第二步干什么,如果出现情况A,做什么处理,如果出现了情况B,做什么处理
问题规模小,可以步骤化,按部就班处理
以指令为中心,数据服务于指令
C,shell
面向对象语言 开发的 时候 将 任务 当成一个整体
将编程看成是一个事物,对外界来说,事物是直接使用的,不用关心事物内部的情况。而编程就是设置事物能够完成功能。
一种认识世界、分析世界的方法论。将万事万物抽象为各种对象
类是抽象的概念,是万事万物的抽象,是一类事物的共同特征的集合
对象是类的具象,是一个实体
问题规模大,复杂系统
以数据为中心,指令服务于数据
java,python,golang等 云 go k8个字母s 平台
三种处理逻辑
顺序执行:程序按从上到下顺序执行
选择执行:程序执行过程中,根据条件的不同,进行选择不同分支继续执行
循环执行:程序执行过程中需要重复执行多次某段语句(已知次数 已知条件 死循环)
Linux 系统中的 Shell 是一个特殊的应用程序,它介于操作系统内核与用户之间,充当 了一个“命令解释器”的角色,负责接收用户输入的操作指令(命令)并进行解释,将需要执 行的操作传递给内核执行,并输出执行结果。 常见的 Shell 解释器程序有很多种,使用不同的 Shell 时,其内部指令、命令行提示符 等方面会存在一些区别。通过/etc/shells 文件可以了解当前系统所支持的 Shell 脚本种类。
查看本机的shell信息
linux中常见的shell
bash:基于gun的框架下发展的shell
csh:类似c语言的shell
tcsh:整合了csh提供了更多功能
sh:已经被bash替换
nologin:让用户无法登录
bash (/bin/bash)是目前大多数Linux 版本采用的默认shell
shell脚本用途
将简单的命令组合完成复杂的工作,自动化执行命令,提高工作效率
减少手工命令的重复输入,一定程度上避免人为错误
将软件或应用的安装及配置实现标准化
用于实现日常性的,重复性的运维工作,如:文件打包压缩备份,监控系统运行状态并实现告警等
就是将命令按顺序一一列出,最后自动执行
执行需要权限,也可以直接使用路径
脚本其实不复杂,通用脚本环境改变后依然可以使用的脚本
构成
脚本申明(解释器):第一行开头“#!/bin/bash”,表示此行以下的代码语句是通过/bin/bash程序来解释执行。#!/bin/bash为默认的解释器还有其他类型的解释器,#!/bin/python #!/bin/expect
注释信息:以#开头的语句表示为注释信息 # 注 释
可执行语句:比如echo命令用于输出“ ”之间的字符串
脚本执行逻辑
顺序执行:程序按从上到下顺序执行
选择执行:程序执行过程中,根据条件的不同,进行选择不同分支继续执行
循环执行:程序执行过程中需要重复执行多次某段语句
指定路径去执行 ./执行(需要有执行权限)
指定shell解释器去执行(不需要权限)
source 脚本名,将脚本叫入到全局运行可以补齐(会影响当前环境,一般不用)
命令错误(默认后续的命令还会继续执行,用bash -n 无法检查出来 ,可以使用 bash -x 进行观察)
2.语法错误 (会导致后续的命令不继续执行,可以用bash -n 检查错误,提示的出错行数不一定是准确的)
3.逻辑错误 (只能使用 bash -x 进行)
bash -n 脚本名称 (不在当前目录下加绝对路径) 检查语法错误 bash -x 脚本名称 (不在当前目录下加绝对路径) 逻辑错误
| 类型 | 设备文件 | 文件描述号 |
|---|---|---|
| 标准输入 | /dev/stdin | 0 |
| 标准输出 | /dev/stdout | 1 |
| 标准错误输出 | /dev/stderr | 2 |
交互式硬件设备
标准输入:从该设备接收用户输入的数据
标准输出:通过该设备向用户输出数据
标准错误:通过该设备报告执行出错信息
重定向的意思就是 ,不输出到默认设备上,输出到你指定的位置
| 输出类型 | 操作符 | 作用 |
|---|---|---|
| 重定向输入 | < | 从指定的文件读取数据,而不是从键盘输入 |
| 重定向输出 | 1> | 将输出结果保存到指定的文件(覆盖原有内容) |
| 追加输入 | >> | 将输出结果追加到指定的文件尾部 |
| 标准错误输出 | 2> | 将错误信息保存到指定的文件(覆盖原有内容 |
| 错误追加 | 2>> | 标准错误输出结果追加到指定的文件尾部 |
| 混合输出 | &>无论对错都可以重定向 | 将标准输出、标准错误的内容保存到同一个文件中 |
将左侧的命令输出结果,作为右侧命令的输入(处理对象)可以 叠加使用
管道符常见命令特殊符号
${}:调用命令执行的结果
‘ ’:强引用 ,不识别变量,本来含义
“ ”:弱引用,识别变量
{ }:规定变量的范围
自定义变量:由用户自己定义,修改和使用
预定义变量:Bash中内置的一类变量 shell 不能修改 规定好的变量 放在那里让你使用
环境变量:由系统维护,用于设置工作环境 当前目录 当前主机名啊 $PATH
只读变量:只可以读取不可以更改 只能不能修改 常量
位置变量:通过命令行给脚本传递参数
脚本补充命令
set -e
—— 在脚本的前面输入该命令,一旦出错立即停止运行
set -u
—— 变量不存在不让执行
| (管道符)
—— 将第一个命令的结果当做后一个命令的处理对象
|xargs
—— 将上一个命令的结果翻译成标准输出结果作为下一个命令的处理对象
echo $?
—— 结果显示为 0 则正确,反之,错误
read
—— 用来提示用户输入信息,实现简单的交互过程
—— read -p :设置提示信息
read -t :输入等待时间(单位默认为秒)
变量名=变量值
三种表示方式:
name=‘root’
name=“$user”
name=COMMAND或者name=$(COMMAND)
变量赋值实际应用
1.赋值时使用双引号(" ")可以直接调用变量(双引号可以识别变量)
2.赋值时使用单引号(' ')变量$只会被认为是字符$ 不会调用变量 (单引号不识别 变量)
3.赋值时使用(``反撇在tab上面)命令替换,提取命令执行后的输出结 果 和$( ) 用法相同
4.{}可以分隔变量值({} 可以确定变量的范围,`` $() 调用命令执行的结果)
变量名+=追加值
从键盘输入的内容变成变量
默认情况下,新定义的变量只在当前的shell环境中有效,因此称为局部变量,当进入子程序或新的shell环境中,局部变量将无法再起作用。
可以通过内部命令export将指定的变量为全局变量,使用户定义的变量在所子shell环境中可以继续使用
可以使用pstree 查看shell的环境
输入bash进入子shell
ctrl+D组合exit 退出子shell
expr 变量1 运算符 变量2 【运算符 变量3】
由系统提前创建,用来设置用户的工作环境
可以使用env查看环境变量
需要记住的常用环境变量
环境变量:
可以使子进程(包括孙子进程)继承父进程的变量,但是无法让父进程使用子进程的变量
一旦子进程修改从父进程继承的变量,将会新的值传递给孙子进程
一般只在系统配置文件中使用,在脚本中较少使用
配置文件位置在
/etc/profile如果修改此文件会作用于所有用户
~/.bash_profile 用户独立的配置文件,修改这个文件只作用于当前用户
可以用来长期变更或设置环境变量
[root@localhost ~]# vim /etc/profile .....................省略到行末添加 export PATH=$PATH:/root source立即生效或 . [root@localhost opt]# source /etc/profile
修改系统默认的命令数 [root@localhost opt]# echo $HISTSIZE 1000 [root@localhost opt]# vim /root/.bash_profile export HISTSIZE=200 [root@localhost opt]# source /root/.bash_profile [root@localhost opt]# echo $HISTSIZE 200
变量值不允许修改(重新赋值)的情况
无法使用 unset删除
最快方法重启
位置变量也称为位置参数,使用$1、$2、$3、…、$9 表示
echo "$1" 位置1 echo "$2" 位置2 echo "${10}" 位置10 echo "$10" 位置1和0 echo "$*" 将所有项当成一个值 echo "$@" 所有项 echo "$0" 脚本自身 echo "$#" 后面参数的个数
两位数需要大括号 为了防止出错统一用大括号
bash 帮你定义好了 拿来用就可以了,你不需要知道为什么,记住
$*:表示所有位置参数的内容看成一个整体返回 返回所有
$@:表示所有位置参数的内容分割成n份,每份作为一个独立的个体返回 返回所有
$?:表示前一条命令执行后的返回状态,返回值为 0 表示执行正确,返回任何非 0值均表示执行出现异常
$#:表示命令行中位置参数的总个数
$0:表示当前执行的脚本或程序的名称 当前脚本的名字
$$:当前bash的进程id
$!: 后台任务最后一个id