首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SHELL(bash)脚本编程六:执行流程

bash命令的执行分为四大步骤:输入、解析、扩展和执行。 本文将详述bash命令的一般处理过程: 如图所示 ? 输入 交互模式 在交互模式下,输入来自终端。...在将编辑缓冲区的内容交给bash之前,Readline会执行历史扩展(见这里),之后由bash负责将本条命令存储到历史列表并进入下一步骤。 非交互模式 在非交互模式下,输入一般来自文件。...执行 不同类型的命令,bash执行方式有所差异。...复合命令 bash中每种复合命令都使用一个C函数来实现,功能包括执行恰当的展开(如for循环中关键词in后面的单词),执行特定的命令,根据命令的返回值来变更执行流程等等。...7、执行完毕后,bash收集命令的返回值。 这些,就是bash执行命令的整个流程。

1.6K40
您找到你想要的搜索结果了吗?
是的
没有找到

Linux 审计Bash执行命令 存储归档

BASH 将关闭 终端会话时所运行的所有命令,并写入你的历史记录文件。...~/.bash_history 当你同时运行两个会话的时候,history 命令将单独显示当前的会话记录,而不会显示其他的历史会话记录。...如何查阅最后的“ n ”命令 默认情况下,history 命令显示我们执行的最后1000条命令。如果你只想列出“ n ”个命令,请使用以下命令。 例如,显示最近的10个历史记录,请运行以下命令。...10 按条件搜索历史命令 $ history | grep rm $ history | tail -2 清除历史 1.如果想要删除特定命令,请输入 :history -d 2.要清空全部历史记录,请执行...a” 3.5 使用 HISTCONTROL 强制 history 不记住特定的命令 可以在.bash_profile里配置 HISTCONTROL=ignorespace 然后执行具体命令(如ls)的时候面输入一个空格

6.9K10

(19)Bash多命令顺序执行与管道符

一、多命令执行符 多命令执行符 格式 作用 ; 命令1 ;命令2 多个命令顺序执行,命令之间没有任何逻辑联系,就算第一条报错,第二条也会执行 && 命令1 && 命令2 逻辑与:当命令1正确执行,则命令...2才会执行;当命令1执行不正确,则命令2不会执行 || 命令1 || 命令2 逻辑或:当命令1执行不正确,则命令2才会执行 当命令1正确执行,则命令2不会执行 1."...&&"逻辑与 例1:第一条命令正确执行,则会执行第二条命令;第一条命令报错,第二条命令则不再执行 ? 这样做有什么意义吗?...有,我们有些命令,需要前一条命令正确执行,第二条命令才可以执行,比如说软件包安装(如下),这样就可以自动安装了,不需要等待一条一条输入命令了 #....||"逻辑或 例1:第一条命令正确执行,第二条命令就不执行了;第一条命令报错,第二条命令才执行 ?

1.1K10

Bash shell中bash、sh、source及“.”点等五种执行方式的区别与联系

三、具体探讨这几种执行方式的区别与联系 bash、sh分别执行a.sh和b.sh [Geeklp@Geeklp-BashShell ~]$ bash a.sh My name is Geeklp .I.../a.sh bash: ./a.sh: 权限不够 这个点与执行脚本之间无空格,表示执行当前目录下的a.sh脚本,相当于~/a.sh。b.sh也是一样的结果,无需讨论。...(无空格)来执行脚本时需要给需要执行的脚本加上执行权限,否则无法执行。加了权限之后,执行效果与bash及sh一致,不继承变量。...四、结论 bash与sh在对于脚本执行来说,效果一致,不继承除了当前shell之外的变量值。在无空格“.”(相对路径)、绝对路径且有执行权限的脚本执行中,效果与bash及sh一致。...bash、sh、不带空格的点(相对路径)或绝对路径中,脚本是在子进程中执行的。在source及带空格的点中,脚本是在父进程中执行的,差别很大。

3.2K10

mysql存储过程执行_mysql存储过程不执行

实战mysql存储程序与定时器 存储过程定时器eventprocedure实战 需求:一个庞大的日志表,现每天做定时统计一天的总数,放另一个表中,方便查看,运营。...旧方案:用脚本写好程序,用linux的crontab定时执行。 本文重点,用mysql定时器定时执行存储程序。...执行这个语句之前要先 Sql代码 delimiter $$ 执行完成后再 Sql代码 delimiter ; 用show查看是否已经成功 Sql代码 show procedure status like...‘%%’; 第二步:开启mysql定时器 如果不是on,就执行 Sql代码 set global event_scheduler=1; 不需要重启mysql 会发现mysql多起了一个daemon进程...Enable表示系统将执行这个事件。Disable表示系统不执行该事件。

16.6K20

Mysql执行过程

Mysql 执行流程 大致流程描述: MySQL客户端通过协议将SQL语句发送给MySQL服务器。...如果无法命中缓存,就继续走到分析器的下一步,如果查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段 。 不过需要注意的是在mysql的8.0版本以后,缓存被官方删除掉了。...查询优化器 能够进入到优化器阶段表示sql是符合mysql的标准语义规则的并且可以执行的,此阶段主要是进行sql语句的优化,会根据执行计划进行最优的选择,匹配合适的索引,选择最佳的执行方案。...,mysql会计算各个执行方法的最佳时间,最终确定一条执行的sql交给最后的执行器 查询优化器是整个流程中重要的一环。...而update会采用两阶段提交的方式,记录都redolog中 查询执行计划,就是MySQL查询中的执行计划,比如是执行where语句还是from语句,最先执行的总是FROM操作,最后执行的是LIMIT操作

2.8K20

MySQL】语句执行分析

为了验证问题是否出在sql语句,所以用以下方法来分析: 查询SQL执行记录 explain 分析 MySQL 语句执行时间 下面会分别介绍三个方法的开启方法。...key_len 显示MySQL决定使用的键长度。如果键是NULL,则长度为NULL。 ref 显示使用哪个列或常数与key一起从表中选择行。 rows 显示MySQL认为它执行查询时必须检查的行数。...rows显示MySQL认为它执行查询时必须检查的行数。多行之间的数据相乘可以估算要处理的行数。filtered显示了通过条件过滤出的行数的百分比估计值。...MySQL 语句执行时间 show profile 以及show profiles语句可以显示当前会话过程中执行SQL语句的性能信息。...已经是开启状态 执行sql语句后进行分析 执行完后,输入 show profiles;复制代码 即可查看所有的sql的执行时间 ?

1.6K40
领券