在shell脚本中,$$表示当前shell进程的进程ID(PID)。它是一个特殊变量,用于引用当前进程的ID。这个变量通常用于调试、日志记录、信号处理和进程间通信等场景。
$$
shell脚本中 '$' 与不同的符号搭配其表示的意义也会不同 特殊标志符 含义 $0 当前脚本的文件名 $n 传递给脚本或函数的参数。n 是一个数字,表示第几个参数。...例如,第一个参数是$1,第二个参数是$2 $# 传递给脚本或函数的参数个数 $* 传递给脚本或函数的所有参数 $@ 传递给脚本或函数的所有参数 $?...上个命令的退出状态 $$ 当前Shell进程ID $() 与 `(反引号) 一样用来命令替换使用 ${} 引用变量划分出边界 注释:$* 和 $@ 都表示传递给函数或脚本的所有参数,不被双引号(" "...)包含时,都以"$1" "$2" … "$n" 的形式输出所有参数。...但是当它们被双引号(" ")包含时,"$*" 会将所有的参数作为一个整体,以"$1 $2 … $n"的形式输出所有参数;"$@" 会将各个参数分开,以"$1" "$2" … "$n" 的形式输出所有参数
$1是传递给shell脚本的第一个命令行参数。另外,也被称为位置参数。例如,$0、1、3、4等等。比如如果你运行....$1 在Bash脚本的含义Create a shell script named demo-args.sh as follows:最快的理解方式是实际在Linux上创建一个测试文件,这里我们命名为 demo-args.sh...为新建的脚本文件新增可执行权限。...$1 in bash functions $1 在函数含义Create a new script called func-args.sh;创建一个名为func-args.sh的新脚本。.../func-args.sh filename我们在脚本中传入参数,结果正确执行:xander@xander:~$ .
概述 在shell中开启alias 实际操作 概述 众所周知,shell脚本使用的是非交互式方式,在非交互式模式下alias扩展功能默认是关闭的,此时虽然可以定义alias别名,但是shell不会将alias...别名扩展成对应的命令,而是将alias别名本身当作命令执行,如果shell内置命令和PATH中均没有与alias别名同名的命令,则shell会找不到指定的命令。...---- 在shell中开启alias 使用shell内置命令shopt命令来开启alias扩展选项。...默认是打开的,在非交互式模式下是关闭的,但可以用可shopt来将其开启 shopt -s expand_aliases ---- 实际操作 在我们的项目中某个模块的双机启动脚本(root用户下操作),...项目启动中会依赖一些环境变量,所以双机启动脚本中需要显式的引入.bash_profile文件。 所以我们将 开启alias的命令放在 .bash_profile中。
一、Shell脚本变量的含义 1、$#:表示执行脚本传入参数的个数 2、*:表示执行脚本传入参数的列表(不包括0) 3、$$:表示进程的id;Shell本身的PID(ProcessID,即脚本运行的当前...:Shell最后运行的后台Process的PID(后台运行的最后一个进程的 进程ID号) 5、@:表示执行脚本传入参数的所有个数(不包括0) 6、$0:表示执行的脚本名称 7、$1:表示第一个参数 8、...:表示脚本执行的状态,0表示正常,其他表示错误 二 $ *和 $@的差异 在shell中,KaTeX parse error: Can't use function '' in math mode at.../bin/sh MY_SHELL_PATH=`dirname $0` echo "print shell script location:" echo ${MY_SHELL_PATH} echo..."====================================" echo "enter shell script location:${MY_SHELL_PATH}" cd `dirname
在python脚本中执行shell命令的方法 最近在写python的一些脚本,之前使用python都是在django中使用,可能大部分内容都是偏向于后端开发方面的,最近在写一些脚本的时候,发现了...使用Python处理一个shell命令或者一个执行一个shell脚本,一般情况下,有下面三种方法,下面我们来看: 第一种方法是使用os.system的方法 os.system("cmd") 我们在当前目录下面创建一个...命令打印出来aaa.sql中的内容,然后下面出现的数字0代表上述命令执行成功;如果我们打印bbb.sql则返回值是256,表示执行中出现了问题。...,把脚本的执行结果和返回值进行保存,根据脚本执行的结果来确定最终的返回值: 1cmd = "/bin/sh /data/scripts/test.sh %s" % para 2status, res...] 7else: 8 result["result"] = false 9 result["message"] = res 10return Response(result) 如果脚本中是对数据库的一系列操作
Shell脚本在运维工作中是极其重要的,而数组在shell脚本里的运用无论是在循环或运算方面都是非常实用的一个环节。...下面是对shell脚本中数组方面一些操作在此进行记录,希望能帮助到有兴趣的朋友~ 1.数组定义 [root@bastion-IDC ~]# a=(1 2 3 4 5 6 7 8) [root@bastion-IDC...bastion-IDC ~]# echo ${a[*]} 1 3 4 5 6 7 8 [root@bastion-IDC ~]# echo ${#a[*]} 7 直接通过:unset 数组[下标] 可以清除相应的元素
Shell中的$0、$1、$2的含义 $0 就是你写的shell脚本本身的名字 $1 是你给你写的shell脚本传的第一个参数 $2 是你给你写的shell脚本传的第二个参数 例子 脚本 #!.../bin/bash echo $0 # 打印脚本文件名 case $1 in # start) echo $1 ;; # 第一个参数是start,打印第一个参数 stop) echo
方法一、使用输入重定向 逐行读取文件的最简单方法是在while循环中使用输入重定向。...变量为文本文件中的每行内容 Tips:可以将上面的脚本缩减为一行命令,如下: [root@localhost ~]# while read rows; do echo "Line contents are...- 使用echo显示输出内容,输出内容包括自定义的字符串和变量,$rows变量为文本文件中的每行内容 Tips:可以将上面的脚本缩减为一行命令,如下: [root@localhost ~]# cat mycontent.txt...|while read rows;do echo "Line contents are : $rows";done 方法三、使用传入的文件名作为参数 第三种方法将通过添加$1参数,执行脚本时,在脚本后面追加文本文件名称.../bin/bash cat mycontent.txt |awk '{print "Line contents are: "$0}' 运行结果: 总结 本文介绍了如何使用shell脚本逐行读取文件内容
一、在 Shell 脚本中调用另一个 Shell 脚本的三种方式 先来说一下主要以下有几种方式: fork: 如果脚本有执行权限的话,path/to/foo.sh。...1.2 exec exec 与 fork 不同,不需要新开一个子 Shell 来执行被调用的脚本. 被调用的脚本与父脚本在同一个 Shell 内执行。...这是 exec 和 source 的区别. 1.3 source 与 fork 的区别是不新开一个子 Shell 来执行被调用的脚本,而是在同一个 Shell 中执行....所以被调用的脚本中声明的变量和环境变量, 都可以在主脚本中进行获取和使用。...从pid值看,两者是在同一进程中运行的。
被调用的脚本与父脚本在同一个 Shell 内执行。但是使用 exec 调用一个新脚本以后, 父脚本中 exec 行之后的内容就不会再执行了。...这是 exec 和 source 的区别. source 与 fork 的区别是不新开一个子 Shell 来执行被调用的脚本,而是在同一个 Shell 中执行....所以被调用的脚本中声明的变量和环境变量, 都可以在主脚本中进行获取和使用。 其实从命名上可以感知到其中的细微区别,下面通过两个脚本来体会三种调用方式的不同: 第一个脚本,我们命名为 1.sh: #!...exec 在同一个 Shell 内执行,但是父脚本中 exec 行之后的内容就不会再执行了 source 在同一个 Shell 中执行,在被调用的脚本中声明的变量和环境变量, 都可以在主脚本中进行获取和使用...参考: 在shell脚本中调用另一个脚本的三种不同方法(fork, exec, source)
shell脚本介绍 ? shell脚本结构和执行 ? ? ? ? 开头需要加#!/bin/bash 因为有了#!.../bin/bash文件头所以需要给01.sh文件执行权限 [root@100xuni1 shell]# chmod a+x 01.sh ? ? ? ? 以#开头的行作为解释说明 ?...脚本的名字以.sh结尾,用于区分这是一个shell脚本 执行方法有两种 chmod +x 1.sh; ./1.sh bash 1.sh 查看脚本执行过程 bash -x 1.sh ?...查看脚本是否语法错误 bash -n 1.sh ? date命令用法 ? date命令是显示系统的当前的日期和时间,date在shll当中作用很大 ?...shell脚本中的变量 ?
在 OpenXML SDK 里面对于很多值,如字符串等的值,都包含一个 HasValue 属性。刚入门的小伙伴会认为这就是一个和可空类型一样的属性,表示这个属性是不是为空。...其实这句话只是对一半,其实这个属性表示的是在重新定义的字符串参数里面的属性是否为空 在 OpenXML SDK 里面给很多基础类型都是自己新定义的,如 SingleValue 和 StringValue...,而刚好在 OpenXML SDK 里面存在大量的类型都是可能为空的。...fontSize 是空,尝试获取他的属性将会炸掉 正确的做法是使用下面代码 if (fontSize !...= null) { } 那么这个 HasValue 的意思是什么?
文章目录 shell 脚本调试系列 概述 启用 verbose 调试模式 在 Shell 脚本中启用语法检查调试模式 通过修改脚本的首行来启用脚本检查 内置的 set 命令来在脚本中启用调试模式 shell...脚本调试系列 Linux 中启用 Shell 脚本的调试模式 在 Shell 脚本中执行语法检查调试模式 在 Shell 脚本中跟踪调试命令的执行 ---- 概述 ?...写完脚本后,建议在运行脚本之前先检查脚本中的语法,而不是查看它们的输出以确认它们是否正常工作。 在本系列的这一部分,我们将了解如何使用语法检查调试模式。...记住我们之前在本系列的 Linux 中启用 Shell 脚本的调试模式 中解释了不同的调试选项,在这里,我们将使用它们来执行脚本调试。...: $ chmod +x script.sh 我们可以执行脚本并显示它被 Shell 读取到的每一行: $ bash -v script.sh ---- 在 Shell 脚本中启用语法检查调试模式 回到我们主题的重点
/bin/bash #当判断$1为空时,($1)就是脚本的第一参数,当用户不给参数的时候,$1是空的时候,那么屏幕就会显 示脚本的用法是错误 if [ -z "$1" ];then #-n 的意思是不换行...,不回车,两个echo分别会用两个颜色显示,但最终会在同一行显示,因为第一个echo没有换行 echo -n "用法:脚本 " echo -e "3[35m域名或IP" exit fi #c...[ $a -lt $b ]; then echo "猜小了" else echo "猜大了" fi echo 示例1的脚本因为每次执行都会变为随机数,所以该脚本并未完善, 后续会进一步完善该脚本...总结 ● if的语法格式 需要非常熟悉if的语法格式,在编写任合具体脚本案例之前首先要熟悉掌握if的语法格式if开始fi结尾,当then和if在同一行的时候需要使用“;”分号 当不在同一行的时候可以直接输入...,就可以做一个else,在前面的条件都不能满足的情况下,就统一认为符合最后一种情况,执行最后一个命令 ● 判断用户输入的字串是否为空 判断用户输入的字串是否为空有效防止脚本异常 ● 检测主机连通性
前言: EOF是End Of File的缩写,表示自定义终止符。既然自定义,那么EOF就不是固定的,可以随意设置别名,意思是把内容当作标准输入传给程序,Linux中按Ctrl-d就代表EOF。 ...在Shell中我们通常将EOF与 << 结合使用,表示后续的输入作为子命令或子Shell的输入,直到遇到EOF为止,再返回到主调Shell。...回顾一下< <的用法,当shell看到< <的时候,它就会知道下一个词是一个分界符。在该分界符以后的内容都被当作输入,直到shell又看到该分界符(位于单独的一行)。...通过cat配合重定向能够生成文件并追加操作,在它之前先回顾几个特殊符号: < :输入重定向 > :输出重定向 >> :输出重定向,进行追加,不会覆盖之前内容 << :标准输入来自命令行的一对分隔号的中间内容...YES NULL address varchar(25) YES NULL name age address tom 23 china -在数据库中查看新增的数据
. $$ Shell本身的PID(ProcessID) 2. $! Shell最后运行的后台Process的PID 3. $? ...最后运行的命令的结束代码(返回值) 4. $- 使用Set命令设定的Flag一览 5. $* 所有参数列表。...如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。 .... $# 添加到Shell的参数个数 8. $0 Shell本身的文件名 9.$1~$n 添加到Shell的各参数值。$1是第1参数、$2是第2参数…。 ...二.脚本示例 [root@localhost ~]# cat mytest.sh #!
// shell脚本中$符号的意义 // 今天是远程办公的第4天,渐渐的找到了一点在家办公的节奏了,改了几个shell脚本,在改动过程中,发现还有一些知识点需要巩固,这里写出来,加深下印象。...关于$符号,大家肯定都不陌生,在shell脚本中,$的作用还是比较大多的,这里将所有的$组合都列出来,大家可以看下效果。 $组成的命令大概有下面几个: $0,$1...$?,$!...,$$,$*,$#,$@ 下面分别看看这些意思是什么: 1 $0,$1 $0和$1比较好理解,他们的意思,分别是脚本名称和脚本的第一个参数,我们举个例子来看: jwfyyzdembp:tmp jwfyyz...脚本后面设置了sleep 10的命令,脚本运行完会睡眠10s,脚本中打印出来了值60658,此时我们查看当前脚本的进程号,发现子进程的进程id是60658 4 $*和$@ 这两个放在一起,主要是因为他们都代表引用的所有参数...反应的是脚本中某个命令的进程号。
在命令行和脚本中都非常有用。...在命令行和脚本中都非常有用 用途 /dev/null 通常被用于丢弃不需要的输出流,或作为用于输入流的空文件,这些操作通常由重定向完成,任何你想丢弃的数据都可以写入其中 丢弃标准输出 在写shell脚本的时候...,只想通过命令的结果执行后面的逻辑,而不想命令执行过程中有一大堆中间结果输出,这时候可以把命令执行过程中的输入全部写入 /dev/null 现有 a.sh 脚本,它的功能是判断传入的系统命令是否存在,脚本内容如下...丢弃标准错误输出 在shell脚本中,删除一个文件的时候,需要先判断文件是否存在,然后才能执行删除操作,否则删除的时候会输出错误, 一般的删除文件脚本内容如下: #!...[tt@ecs-centos-7 dev_test]$ cat /dev/null > t.txt [tt@ecs-centos-7 dev_test]$ cat t.txt 日志的处理 在脚本中
本文中的部分脚本来源于网络,就不申明原创了,如果这些东西自己学会了,那就是属于自己的了。 求从1加到100的和 使用for循环求和: #!.../bin/bash i=1 sum=0 while [ $i -le 100 ];do let sum+=$i let i++ done echo "sum is:$sum" 求100以内的偶数之和...until [ $i -gt $j ];do echo -ne "$i*$j=$(($i*$j))\t" let i++ done echo let i=1 let j++ done 通过脚本判断用户是否登入系统
给很多刚接触Makefile的人: 1、Makefile中可以嵌入shell脚本,而且能像shell脚本中一样,各种命令、控制结构都可使用。 2、Makefile的主要结构是 ......只有在command位置的shell脚本才是有效的,也就是只有在“生成目标的规则处”写的shell脚本才是shell脚本,其它位置的shell都是无效的。...3、Makefile中的shell,不同的行在不同的进程中执行,不同的行直接不能传递变量,所以很多时候shell都尽量使用反斜杠()来把相关的内容串成一行。...4、Makefile变量和shell变量是两个不同的东西,并且为了避免Makefile变量和shell变量冲突,引用Makefile变量最好使用$(Makefile_Var),引用shell变量时最好使用...但如果在纯粹的shell编程中,纯shell脚本里可以使用$VAR来引用VAR这个变量。 收藏于 2012-08-08
领取专属 10元无门槛券
手把手带您无忧上云