百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

linux shell 笔记——1

liuian 2025-05-23 18:31 35 浏览

shell的格式开头

#!/bin/bash 或者 #!/bin/sh 开头

系统变量:HOME、HOME、HOME、PWD、SHELL、SHELL、SHELL、USER ,PATH等等比方:echo $HOME 等等..

输出

echo $HOME
test="1234566"

截取字符串

${变量名:起始:长度}

echo $test 等价于 echo ${test}

1) 定义变量:变量=值

2)显示当前 shell 中所有变量:set

3)撤销变量:unset 变量

4) 声明静态变量:readonly 变量,注意:不能 unset

https://baijiahao.baidu.com/s?id=1701686693229076458&wfr=spider&for=pc

定义变量的规则

1) 变量名称可以由字母、数字和下划线组成,但是不能以数字开头。

2) 等号两侧不能有空格3) 变量名称一般习惯为大写

将命令的返回值赋给变量(重点)

1)A=`ls -la` 反引号,运行里面的命令,并把结果返回给变量 A2)A=$(ls -la) 等价于反引号

设置环境变量的基本语法:

export 变量名=变量值 (功能描述:将 shell 变量输出为环境变量)

source 配置文件(功能描述:让修改后的配置信息立即生效)

echo $变量名(功能描述:查询环境变量的值)

运算 :

方式1: expr $val oparator $var2

方式2:aa= $(( $val oparator $var2 ))

方式2必须要赋值,否则报错



grep解析 :

pid=`ps -ef|grep run.jar|grep -v grep|awk '{print $2}' `

grep -v grep 是干啥的呢 ?很简单 ,为了去除包含grep的进程行 ,避免影响最终数据的正确性 。



ps -ef|grep gogs

isTester.com 1883 1844 0 13:55 pts/0 00:00:00 grep gogs

git 6583 1 0 2018 ? 01:25:46 ./gogs web

加上grep -v grep ,就只剩下1行记录 。

[isTester.com@iZ94b31ttqsZ]~# ps -ef|grep gogs | grep -v grep

git 6583 1 0 2018 ? 01:25:46 ./gogs web


grep -v 意为不包括;上述语句的意思是查找除了grep下的所有信息






$2:表示第二个字段

print $2 : 打印第二个字段

awk '{print $2}' $fileName : 一行一行的读取指定的文件, 以空格作为分隔符,打印第二个字段


比如有个文件是testAWK.txt,文件内容如下:

11 22 33 44

55 66 77 88

执行 awk '{print $2}' testAWK.txt

结果:

22

66




ps -ef|grep gogs | grep -v grep | wc -l

wc -l 统计行数





if解析


#如果 pid变量的长度为0,则为真

if[ -z "$pid"] then

return 1


else

return 0


fi



#$? 是上一个程序执行是否成功的标志,如果执行成功则$? 为0,否则 不为0

is_exist #执行函数

if[ $? -eq "0" ] then

return 1


else

return 0

fi




Shell 数组元素个数${#array[@]}

数组的所有元素${array[*]}

字符串长度${#str}

数组下标集合${!array[@]} 如:0 1 2 3




################### 第1种 #######################

for i in ${array[@]}

#也可以写成for element in ${array[*]}

do

echo $i

done



################## 第2种 ########################

array=($(ls)) #注意多一个括号

for i in ${array[*]}

do

echo $i ;

done


################## 第3种 ########################

array=($(ls)) #注意多一个括号

for i in ${array[*]}

do

echo $i ;

done



################## 第4种 ########################

array=$(ls) #注意少一个括号

for i in $array do


echo $i;

done;


################## 第5种 ########################

for i in "${!array[@]}" ; do

echo ${array[i]};

done;


find

1. 在/root下查找文件更新日是在距现在时刻二天以内的文件

# find /root/ -mtime -2

2. 在/root下查找文件更新日是在距现在时刻二天以上的文件

# find /root/ -mtime +2

3.在/root下查找文件更新日是在距现在时刻一天以上二天以内的文件

# find /root/ -mtime 2



exec命令

ls与find结合使用

find ./ -name "UserServic*Impl*" -exec ls -l {} \;

语法:find pathname -option [-print ] [ -exec | -ok command ] {} \;



exec 文件重定向

shell的exec内建命令并不启用新的shell,而是用要执行的命令替换当前的shell进程,并将老进程的环境清理掉,而且exec命令后的其他命令不再执行


#!/bin/bash

2

3 echo "hello mysql"

4 exec echo " hello oracle"

5 echo "hello db2"


第5行代码将不执行,因为线程已终止



文件描述符

https://blog.csdn.net/weixin_55972781/article/details/118254368

inux默认文件描述符:

每打开一个shell就会打开默认的三个文件描述符描0,1,2分别代表【标准输入】和【标准输出】及【标准错误输出】

linux每一个打开文件都会关联一个文件描述符,需要的时候我们可以使用exec命令指定一个大于3的数字作为文件


1)# exec 3</tmp/1.txt //以“只读方式”打开/tmp/1.txt,文件描述符对应为3

2)# exec 3>/tmp/1.txt //以“只写方式”打开/tmp/1.txt,文件描述符对应为3

3)# exec 3<>/tmp/1.txt //以“读写方式”打开/tmp/1.txt,文件描述符对应为3

4)# exec 3<&- //关闭文件描述符3


脚本测试


#脚本测试

#!/bin/bash
exec 4>&1 #用4记录标准输出
exec 1>/tmp/abc #重定向标准输出
echo "123"
echo "456"
exec 1>&4 #恢复标准输出
exec 4>&- #关闭4

(运行此脚本,脚本中的echo输出会输出到/tmp/abc文件中,脚本第二行用4>&1 是为了记录标准输出的文件描述符便于执行完毕后恢复标准输出,

恢复标准输出也可以用exec 1>/dev/tty)

#注:

echo "hello" >&4 向文件描述符中输入内容只使用 > 不能用 >> ,此时的 > 不会清空文件,

是否清空文件需要在exec命令关联文件描述符到文件的时候区别使用 > 或 >>

#例如下脚本:

#!/bin/bash
exec 4>/tmp/abc
echo "123" >&4
echo "456" >&4
exec 4>&-

则每次执行完脚本后/tmp/abc文件内容都是123\n456,若把第二行换成exec 4>>/tmp/abc则会追加进去(文件的清空操作是在exec命令的操作时进行的)

sed用法

sed -i "s/原字符串/新字符串/g" `grep 原字符串 -rl 所在目录`

for f in $(find * | grep opt-boot.sh); do sed -i "s#/home/spring-boot#/home/cater/spring-java#g" $f; done



查看目录下文件个数

当前目录下

ls -l | grep "^-"| wc -l

查看指定目录下的文件个数

ls -l specified_dir | grep "^-"| wc -l

递归查找

ls -lR | grep "^-"| wc -l


ls -l :长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等)


grep "^-" 表示-开头的,这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d

wc -l 统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于

一行信息对应一个文件,所以也就是文件的个数



如:

drwxr-xr-x 2 cater cater 12288 May 19 16:26 lib

-rw-rw-r-- 1 cater cater 250656 Jun 14 11:04 log.out

-rw-rw-r-- 1 cater cater 1955683 Jun 14 11:07 member-shopper-system-1.0.jar




demo1

https://blog.csdn.net/qq_38686676/article/details/124814424

1.编写一个shell脚本,它把第二个位置参数及其以后的各个参数指定的文件拷贝到第一个位置参数指定的目录中。

#!/bin/bash


dir=$1

shift #将位置参数移动一位(即原先的第二个位置参数现在变成了第一个位置参数,依次类推)

while [ $1 ]
do
file=$1
cp $file $dir
shift
done

ls $dir





echo $0 # 当前脚本的文件名(间接运行时还包括绝对路径)。

echo $n # 传递给脚本或函数的参数。n 是一个数字,表示第几个参数。例如,第一个参数是 $1 。

echo $# # 传递给脚本或函数的参数个数。

echo $* # 传递给脚本或函数的所有参数。

echo $@ # 传递给脚本或函数的所有参数。被双引号 (" ") 包含时,与 $* 不同,下面将会讲到。

echo $? # 上个命令的退出状态,或函数的返回值。

echo $ # 当前 Shell 进程 ID。对于 Shell 脚本,就是这些脚本所在的进程 ID。

echo $_ # 上一个命令的最后一个参数

echo $! # 后台运行的最后一个进程的 ID 号



递归问题:

$? 所能传递的最大值是255 解决这个问题的方法有两种,一种是利用全局变量,另外一种则是利用其他方式进行周转(例如标准输

入输出设备echo实现也可以

return

只能返回数字,不能返回字符串

相关推荐

2023年最新微信小程序抓包教程(微信小程序 抓包)

声明:本公众号大部分文章来自作者日常学习笔记,部分文章经作者授权及其他公众号白名单转载。未经授权严禁转载。如需转载,请联系开百。请不要利用文章中的相关技术从事非法测试。由此产生的任何不良后果与文...

测试人员必看的软件测试面试文档(软件测试面试怎么说)

前言又到了毕业季,我们将会迎来许多需要面试的小伙伴,在这里呢笔者给从事软件测试的小伙伴准备了一份顶级的面试文档。1、什么是bug?bug由哪些字段(要素)组成?1)将在电脑系统或程序中,隐藏着的...

复活,视频号一键下载,有手就会,长期更新(2023-12-21)

视频号下载的话题,也算是流量密码了。但也是比较麻烦的问题,频频失效不说,使用方法也难以入手。今天,奶酪就来讲讲视频号下载的新方案,更关键的是,它们有手就会有用,最后一个方法万能。实测2023-12-...

新款HTTP代理抓包工具Proxyman(界面美观、功能强大)

不论是普通的前后端开发人员,还是做爬虫、逆向的爬虫工程师和安全逆向工程,必不可少会使用的一种工具就是HTTP抓包工具。说到抓包工具,脱口而出的肯定是浏览器F12开发者调试界面、Charles(青花瓷)...

使用Charles工具对手机进行HTTPS抓包

本次用到的工具:Charles、雷电模拟器。比较常用的抓包工具有fiddler和Charles,今天讲Charles如何对手机端的HTTS包进行抓包。fiddler抓包工具不做讲解,网上有很多fidd...

苹果手机下载 TikTok 旧版本安装包教程

目前苹果手机能在国内免拔卡使用的TikTok版本只有21.1.0版本,而AppStore是高于21.1.0版本,本次教程就是解决如何下载TikTok旧版本安装包。前期准备准备美区...

【0基础学爬虫】爬虫基础之抓包工具的使用

大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...

防止应用调试分析IP被扫描加固实战教程

防止应用调试分析IP被扫描加固实战教程一、概述在当今数字化时代,应用程序的安全性已成为开发者关注的焦点。特别是在应用调试过程中,保护应用的网络安全显得尤为重要。为了防止应用调试过程中IP被扫描和潜在的...

一文了解 Telerik Test Studio 测试神器

1.简介TelerikTestStudio(以下称TestStudio)是一个易于使用的自动化测试工具,可用于Web、WPF应用的界面功能测试,也可以用于API测试,以及负载和性能测试。Te...

HLS实战之Wireshark抓包分析(wireshark抓包总结)

0.引言Wireshark(前称Ethereal)是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。Wireshark使用WinPCAP作为接口,直接...

信息安全之HTTPS协议详解(加密方式、证书原理、中间人攻击 )

HTTPS协议详解(加密方式、证书原理、中间人攻击)HTTPS协议的加密方式有哪些?HTTPS证书的原理是什么?如何防止中间人攻击?一:HTTPS基本介绍:1.HTTPS是什么:HTTPS也是一个...

Fiddler 怎么抓取手机APP:抖音、小程序、小红书数据接口

使用Fiddler抓取移动应用程序(APP)的数据接口需要进行以下步骤:首先,确保手机与计算机连接在同一网络下。在计算机上安装Fiddler工具,并打开它。将手机的代理设置为Fiddler代理。具体方...

python爬虫教程:教你通过 Fiddler 进行手机抓包

今天要说说怎么在我们的手机抓包有时候我们想对请求的数据或者响应的数据进行篡改怎么做呢?我们经常在用的手机手机里面的数据怎么对它抓包呢?那么...接下来就是学习python的正确姿势我们要用到一款强...

Fiddler入门教程全家桶,建议收藏

学习Fiddler工具之前,我们先了解一下Fiddler工具的特点,Fiddler能做什么?如何使用Fidder捕获数据包、修改请求、模拟客户端向服务端发送请求、实施越权的安全性测试等相关知识。本章节...

fiddler如何抓取https请求实现手机抓包(100%成功解决)

一、HTTP协议和HTTPS协议。(1)HTTPS协议=HTTP协议+SSL协议,默认端口:443(2)HTTP协议(HyperTextTransferProtocol):超文本传输协议。默认...