文档章节

linux shell 编程 11 特殊符号 & 以及和他的恩怨

QH_C
 QH_C
发布于 2015/11/17 22:43
字数 1019
阅读 17
收藏 0

这篇文章中主要说说这四个符号: &、&& 、$!、$$ 四个符号。

符号解释:

&&: 逻辑关系 与

& : 在后台运行进程

$! : 是最后运行的后台Process的PID

$$:是脚本运行的当前进程ID号

为什么要在这里说这些符号那,有三个不是在之前已经学习过了吗,原因有一、获取程序的pid

下面我们就看看 这几个符号:

在之前的文章中获取pid 的方式就是如下两种

1、如果是使用ps 命令来查看pid 则: ps -ef |  grep -v 'grep' | grep  'java' | awk '{print $2}'

这个命令就是获取java 这个程序的pid,因为使用ps 命令第一列输出的是user  第二列输出的是 pid 所以就这样我们能获取这个程序的pid

2、如果是按照端口号来查看pid的则: netstat -anp | grep  8080 | awk '{print $7}'  | awk '{split($0,b,"/");print b[1]}'

这个命令就是获取8080 这个端口号的程序的pid ,因为使用netstat  输出的列数的第七列有程序名称和pid 而他们之间是使用“/” 来隔开的,所以使用了 awk 编程命令的split 来获取数组 在获取数组中的值,这样就获得了pid


3、但总是感觉这种方式有点不舒服,感觉代码写的很死,不健壮如果输出的列有变化则就获取不到了。所以我们可以这种方式来试试,那就是 $! 和 & ,通过上面的介绍我们也知道,$! 就是最后运行的process的pid 而 & 是表示在后台执行进程,这样我们就可以使用一个命令来获取程序的pid了

4、简单实例,获取pid

#!/bin/bash
java hello  & echo $! >/usr/src/run.pid

这个脚本很简单,就是运行hello这个java程序, 之后的应该能猜到了,就是获取运行 这个java 的进程pid 在将他重定向到run.pid 这个目录下。

获取这个文件中pid  : $(cat  /usr/src/run.pid)  或使用反引号 ` cat /usr/src/run.pid`

这样我们就能从这个文件中读取之前保存的pid了,获取之后我们可以使用: ps -p $pid | grep 'name' 来获取这个程序是否执行的信息。


5、附上正式脚本

#!/bin/bash

basepath=/www/homepage

PATH=$PATH:$HOME/bin:/usr/local/mysql/lib/mysql/

JAVA_HOME=/usr/java/jdk
ANT_HOME=/usr/java/ant
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:/usr/local/resin/lib/jsdk23.jar
PATH=$JAVA_HOME/bin:$ANT_HOME/bin:$PATH
export JAVA_HOME CLASSPATH ANT_HOME PATH

LANG=zh_CN
export LANG
cd $basepath/WebRoot/WEB-INF/classes
PID=`cat /www/homepage/1minute.pid`
content=`ps -p $PID -f |grep DumpFileByMultThread`
if [ "$content" != "" ]; then
        kill -9 $PID
        echo "$PID is killed"
fi
java -classpath .:$basepath/WebRoot/WEB-INF/lib/commons-httpclient-3.0.jar:$basepath/WebRoot/WEB-INF/lib/log4j-1.2.11.jar:$basepath/WebRoot/WEB-INF/lib/commons-logging-1.0.4.jar:$basepath/WebRoot/WEB-INF/lib/commons-codec-1.3.jar:$basepath/WebRoot/WEB-INF/lib/commons-net-1.4.1.jar:$basepath/WebRoot/WEB-INF/lib/jakarta-oro.jar com.soufun.fetch.DumpFileByMultThread $basepath/src/com/soufun/fetch/1minute.txt & echo $! > /www/homepage/1minute.pid
~

注: 这里有个问题 &$! > filenae  这个写在java启动脚本中没问题,但是写在启动tomcat的脚本中不报错 但是获取的那个pid 压根就找不到对应的进程。

上面脚本中主要的地方分析如下:

(1)、使用反引号`` 或者 $() 来执行命令 cat   /www/homepage/1minute.pdi 从这个文件中获取pid

(2)、使用  ps -p $pid -f | grem "name"  获取指定pid下的指定的进程名称的进程信息。注意这里不加 -f 的话就获取不到进程名称,-f 是全名称展示

(3)、如果进程存在则可以获取相关信息,如果不存在则获取不到信息,信息为空

(4)、如果信息不为空的,说明进程在执行, 使用kill  -9  $pid 强制杀死进程以及子进程


6、 附带四个符号:

>、>!、>> 、 < 、这四个符号

>               输出重定向到一个文件或设备 覆盖原来的文件
>!              输出重定向到一个文件或设备 强制覆盖原来的文件
>>             输出重定向到一个文件或设备 追加原来的文件
<               输入重定向到一个程序


© 著作权归作者所有

共有 人打赏支持
QH_C
粉丝 1
博文 75
码字总数 69153
作品 0
朝阳
程序员
私信 提问
Day24 shell环境变量

管道符和作业控制 管道符:| 用于将前一个指令的输出作为后一个指令的输入。 作业控制:主要用于命令进程的控制 CTR+Z:暂停当前运行的进程 fg:命令恢复(前台),加数字能够指定恢复的进程;...

杉下
06/30
0
0
8.10 shell特殊符号cut命令 8.11 sort_wc_uniq命令 8.12 tee

五周第五次课 8.10 shell特殊符号cut命令 8.11 sortwcuniq命令 8.12 teetrsplit命令 8.13 shell特殊符号下 8.10 shell特殊符号cut命令 cut命令 8.11 sortwcuniq命令 sort-wc-uniq命令 特殊符...

wb_rambo123
01/12
0
0
[原创]Bash中的test,[,[[ 有什么区别

在Bash中,test, [, [[ 都可以用来对一个布尔表达式进行求值,比如: 一般情况下,三者的效果是一样的,但细节上存在差别 在大多数的Shell中, test和[ 是等价的(除了个别比较古老的Bourne Shel...

mj4738
2011/11/25
0
0
五周五次课

8.10 shell特殊符号cut命令 8.11 sortwcuniq命令 8.12 teetrsplit命令 8.13 shell特殊符号下 相关测验题目:http://ask.apelearn.com/question/5437 扩展 1. source exec 区别 http://alsww......

河图再现
01/12
0
0
22.Shell特殊符号和cut,sort,wc,uniq,tee,tr,split命令

五周第五次课(1月12日) 8.10 shell特殊符号cut命令 8.11 sortwcuniq命令 8.12 teetrsplit命令 8.13 shell特殊符号下 相关测验题目:http://ask.apelearn.com/question/5437 扩展 source e...

Xavi2017
01/14
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Mariadb二进制包安装,Apache安装

安装mariadb 下载二进制包并解压 [root@test-a src]# wget https://downloads.mariadb.com/MariaDB/mariadb-10.2.6/bintar-linux-glibc_214-x86_64/mariadb-10.2.6-linux-glibc_214-x86_64.t......

野雪球
今天
3
0
ConcurrentHashMap 高并发性的实现机制

ConcurrentHashMap 的结构分析 为了更好的理解 ConcurrentHashMap 高并发的具体实现,让我们先探索它的结构模型。 ConcurrentHashMap 类中包含两个静态内部类 HashEntry 和 Segment。HashEnt...

TonyStarkSir
今天
3
0
大数据教程(7.4)HDFS的java客户端API(流处理方式)

博主上一篇博客分享了namenode和datanode的工作原理,本章节将继前面的HDFS的java客户端简单API后深度讲述HDFS流处理API。 场景:博主前面的文章介绍过HDFS上存的大文件会成不同的块存储在不...

em_aaron
昨天
4
0
聊聊storm的window trigger

序 本文主要研究一下storm的window trigger WindowTridentProcessor.prepare storm-core-1.2.2-sources.jar!/org/apache/storm/trident/windowing/WindowTridentProcessor.java public v......

go4it
昨天
7
0
CentOS 生产环境配置

初始配置 对于一般配置来说,不需要安装 epel-release 仓库,本文主要在于希望跟随 RHEL 的配置流程,紧跟红帽公司对于服务器的配置说明。 # yum update 安装 centos-release-scl # yum ins...

clin003
昨天
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部