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

linux shell 笔记——1

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

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

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

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...