Linux shell编程学习总结


主要内容:

  • shell编程
  • sed命令
  • awk命令
  • crontab定时器

什么是Shell?
Shell是用户与内核进行交互操作的一种接口,目前最流行的Shell称为bash Shell
Shell也是一门编程语言<解释型的编程语言>,即shell脚本
一个系统可以存在多个shell,可以通过cat /etc/shells命令查看系统中安装的shell,不同的shell可能支持的命令语法是不相同的


Shell脚本的执行方式?

第一种:输入脚本的绝对路径或相对路径
首先要赋予+x权限

/root/helloWorld.sh
./helloWorld.sh
或者,不用赋予+x权限,而用解释器解释执行
sh  helloworld.sh

第二种:bash或sh +脚本

    sh /root/helloWorld.shsh helloWorld.sh

第三种:在脚本的路径前再加”. “

    . /root/helloWorld.sh. ./helloWorld.sh

区别:第一种和第二种会新开一个bash,不同bash中的变量无法共享.


Shell中的变量?
Linux Shell中的变量分为“系统变量”和“用户自定义变量”,可以通过set命令查看那系统变量
系统变量:$HOME、$PWD、$SHELL、$USER等等

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


定义变量?
变量=值 (例如STR=abc)
等号两侧不能有空格
变量名称一般习惯为大写
双引号和单引号有区别,双引号仅将空格脱意,单引号会将所有特殊字符脱意

STR="hello world"
A=9

unset A撤销变量 A
readonly B=2 声明静态的变量 B=2 ,不能 unset
export 变量名 可把变量提升为全局环境变量,可供其他shell程序使用


将命令的返回值赋给变量?
A=ls -la ( ls与la用`符号包括在内(波浪线按键中的,编辑器问题会被转义))反引号,运行里面的命令,并把结果返回给变量A
A=$(ls -la) 等价于反引号


Shell中的特殊变量?
$? 表示上一个命令退出的状态
$$ 表示当前进程编号
$0 表示当前脚本名称
$n 表示n位置的输入参数(n代表数字,n>=1)
$# 表示参数的个数,常用于循环
$*和$@ 都表示参数列表


$*与@?@区别?* 和 @@都表示传递给函数或脚本的所有参数,不被双引号”“包含时,都以1 22…n 的形式输出所有参数
当它们被双引号” “包含时,”""∗"会将所有的参数作为一个整体,以"1 22…n”的形式输出所有参数;”@""@"会将各个参数分开,以"1” “2""2"…"n” 的形式输出所有参数


运算符?
格式 :expr m + n 或$((m+n)) 注意expr运算符间要有空格
例如计算(2 +3 )×4 的值
1 .分步计算

S=`expr 2 + 3` expr $S \* 4

2.一步完成计算

    expr `expr 2 + 3 ` \* 4echo `expr \`expr 2 + 3\` \* 4`
$(((2+3)*4))

案例:
[root@weijie aa]# echo $(((2+3)*4))
20


for循环?
第一种:

for N in 1 2 3
doecho $N
donefor N in 1 2 3; do echo $N; donefor N in {1..3}; do echo $N; done

第二种:

for ((i = 0; i <= 5; i++))
doecho "welcome $i times"
donefor ((i = 0; i <= 5; i++)); do echo "welcome $i times"; done

while循环?
第一种

while expression
do
command
…
done

第二种

i=1
while ((i<=3))
doecho $ilet i++
done

解释:let 是让i++执行的指令,let详解请参考 博客


case语句?
格式

case $1 in
start)echo "starting";;
stop)echo "stoping";;
*)echo "Usage: {start|stop} “
esac

read命令?
read -p(提示语句)-n(字符个数) -t(等
使用示例:这里写图片描述


if判断?

\#!/bin/bash
read -p "please input your name:" NAME
if [ $NAME = root ]thenecho "hello ${NAME},  welcome !"elif [ $NAME = itcast ]thenecho "hello ${NAME},  welcome !"elseecho "SB, get out here !"
fi

判断语句?
[ condition ] (注意condition前后要有空格)
#非空返回true,可使用$?验证(0为true,>1为false)
[ itcast ]

#空返回false
[ ]

[ condition ] && echo OK || echo notok//注意注意注意:中括号与condition两边有一个空格。
条件满足,执行前面的语句,否则反之。
案例:[root@weijie aa]# [ ] && echo ok || echo notOk
notOk

解析:shell编译后的结果为notOk,因为[ ]中为空格返回的值为1(shell中1表示条件与假与C++、java等语言不同)


常用判断条件?

= 字符串比较
-lt 小于
-le 小于等于
-eq 等于
-gt 大于
-ge 大于等于
-ne 不等于
案例:

[root@weijie aa]# [ 2 -lt 3 ]
[root@weijie aa]# echo $?
0

-r 有读的权限
-w 有写的权限
-x 有执行的权限
-f 文件存在并且是一个常规的文件
-s 文件存在且不为空
-d 文件存在并是一个目录
-b文件存在并且是一个块设备
-L 文件存在并且是一个链接
案例:
[root@weijie aa]# [ -r shells.sh ]
[root@weijie aa]# echo $?
0


Shell自定义函数?
语法

 [ function ] funname [()]
{action;[return int;]
}function start()  / function start / start()

注意
1.必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先预编译
2.函数返回值,只能通过$? 系统变量获得,可以显示加:return 返回,如果不加,将以最后一条命令运行结果,作为返回值。 return后跟数值n(0-255)
案例:

#!/bin/bash
function fsum()
{echo $1,$2;return $(($1+$2));
}
total=$?;
echo "第一次调用后的返回结果:"$total;
fsum 5 4;
total=$?;
echo $total;

结果:
0(表示上一条指令执行成功,也就是花括号中的代码块执行成功)
5 4(给函数传递两个参数,$1:表示获取第一个参数)
9(返回计算结果)


脚本调试?

sh -vx helloWorld.sh

或者在脚本中增加set -x
案例:

[root@weijie aa]# sh -vx shells.sh 
#!/bin/bash
function fsum()
{echo $1,$2;return $(($1+$2));
}
total=$?;
+ total=0
echo "第一次调用后的返回结果:"$total;
+ echo $'\347\254\254\344\270\200\346\254\241\350\260\203\347\224\250\345\220\216\347\232\204\350\277\224\345\233\236\347\273\223\346\236\234:0'
第一次调用后的返回结果:0
fsum 5 4;
+ fsum 5 4
+ echo 5,4
5,4
+ return 9
total=$?;
+ total=9
echo $total;
+ echo 9
9

sed命令?
sed全称是:Stream EDitor即流编辑器,是一个很好的文本处理工具,本身是一个管道命令,处理时,把当前处理的行存储在临时缓冲区中,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行。它是以行为单位进行处理,可以将数据行进行替换、删除、新增、选取等特定工作。


sed选项?
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-i :直接修改读取的文件内容,而不是输出到终端。


sed function?
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)
d :删除,因为是删除啊,所以 d 后面通常不接任何内容
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行)
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行
s :取代,可以直接进行取代的工作!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g


awk命令?
AWK是一种优良的文本处理工具。其名称得自于它的创始人 Alfred Aho 、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母,AWK 提供了极其强大的功能:可以进行样式装入、流控制、数学运算符、进程控制语句甚至于内置的变量和函数。它具备了一个完整的语言所应具有的几乎所有精美特性。实际上 AWK 的确拥有自己的语言:AWK 程序设计语言, 三位创建者已将它正式定义为“样式扫描和处理语言”。它允许您创建简短的程序,这些程序读取输入文件、为数据排序、处理数据、对输入执行计算以及生成报表,还有无数其他的功能。


awk命令格式?

awk 'pattern1 {action1} pattern2 {action2} ...' filename

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/509760.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flink ProcessFunction 介绍使用

目录 实现功能 代码 测试 问题 官网描述&#xff1a;https://ci.apache.org/projects/flink/flink-docs-release-1.10/zh/dev/stream/operators/process_function.html The ProcessFunction is a low-level stream processing operation, giving access to the basic build…

Flink keyby 数据倾斜问题处理

上一篇我们使用keyby后发现数据严重倾斜 https://datamining.blog.csdn.net/article/details/105316728 大概看下问题所在&#xff0c;大量数据在一个subtask中运行 这里我们使用两阶段keyby 解决该问题 之前的问题如下图所示 我们期望的是 但我们的需要根据key进行聚合统计&a…

java中正则表达式

package com.test;import java.util.Scanner;public class M1001{public static void main(String[] args) {String input null;Scanner sc new Scanner(System.in);while(sc.hasNext()){inputsc.nextLine();String regex "^1[3|4|5|7|8][0-9]{9}$";//为表达式模板…

读书-时间(反思)

每一天的时间都非常多&#xff0c;下班以后的时间&#xff0c;周末闲暇的时间&#xff0c;但是时间这么多&#xff0c;自己往往不知道该拿它来干什么&#xff0c;每天下完班以后&#xff0c;回到家&#xff0c;打开电脑&#xff0c;打开手机&#xff0c;首先看一看QQ&#xff0…

Kafka 优化参数 unclean.leader.election.enable

Kafka 某个节点挂掉&#xff0c;导致整个服务异常&#xff0c;为了保证服务容灾&#xff0c;可对下面几个参数进行调整 unclean.leader.election.enabletrue min.insync.replicas1 offsets.topic.replication.factor3 这三个配置什么意思呢? 依次来看一下&#xff1a; unclean…

linux中iptables对防火墙的操作

Iptables教程 1. iptables防火墙简介 Iptables也叫netfilter是Linux下自带的一款免费且优秀的基于包过滤的防火墙工具&#xff0c;它的功能十分强大&#xff0c;使用非常灵活&#xff0c;可以对流入、流出、流经服务器的数据包进行精细的控制。iptables是Linux2.4及2.6内核中…

读书--好书

说到好书&#xff0c;我觉得对于每一个人来说&#xff0c;都有自己人生中的一本好书&#xff0c;她的内容能够引起我们的共鸣&#xff0c;认识到自己的不足之处&#xff0c;并且能够指引我们如何去改变它&#xff0c;去战胜它&#xff0c;从而使自己获取进步&#xff0c;得到升…

Web Components入门不完全指北

目前流行的各类前端框架&#xff0c;不管是react, angular还是vue&#xff0c;都有一个共同点&#xff0c;那就是支持组件化开发&#xff0c;但事实上随着浏览器的发展&#xff0c;现在浏览器也原生支持组件式开发&#xff0c;本文将通过介绍Web Components 的三个主要概念&…

Flink 1.9 CDH 6.3 集成

目录 1.下载准备文件 2.felink csa jar包准备 3.将 Flink Parcel放入httpd目录下 4.配置CDH Flink Parcel 5.安装Flink 1.下载准备文件 https://archive.cloudera.com/csa/1.0.0.0/csd/FLINK-1.9.0-csa1.0.0.0-cdh6.3.0.jarhttps://archive.cloudera.com/csa/1.0.0.0/parc…

如何花两年时间面试一个人

http://blog.sina.com.cn/s/blog_4caedc7a0102dycr.html?tj1

ssh免密登陆机制示意图

ssh免密登陆机制示意图

CDH 6.x 安装 Phoenix 服务

最近有个新项目启动&#xff0c;版本升级到6.3&#xff0c;发现CDH6.2 版本已经支持Phoenix parcel安装 一、准备文件 下载 https://archive.cloudera.com/phoenix/6.2.0/csd/PHOENIX-1.0.jar 下载parcel #目录 https://archive.cloudera.com/phoenix/6.2.0/parcels/ #根据…

Kafka 集群数据备份 MirrorMaker 详解

什么是 MirrorMaker&#xff1f; MirrorMaker是Kafka附带的一个用于在Kafka集群之间制作镜像数据的工具。该工具主要动作就是从源集群中消费并生产到目标群集。 一个集群可以启动多个MirrorMaker配置到多个集群 运行 MirrorMaker方法 kafka-mirror-maker.sh --consumer.conf…

面试的态度

关于面试&#xff0c;如果到了面试现场&#xff0c;可能环境并不是自己所希望的那样&#xff0c;但是也不能消极对待&#xff0c;既然自己付出了时间来到这里&#xff0c; 公司对方也安排了时间给予你面试&#xff0c;不管是本着对自己的负责&#xff0c;还是对公司面试人员的…

域名服务的工作流程

域名服务的工作流程

Kafka 消费者组 Rebalance 详解

Rebalance作用 Rebalance 本质上是一种协议&#xff0c;主要作用是为了保证消费者组&#xff08;Consumer Group&#xff09;下的所有消费者&#xff08;Consumer&#xff09;消费的主体分区达成均衡。 比如&#xff1a;我们有10个分区&#xff0c;当我们有一个消费者时&…

C/C++程序员必须熟悉的开源库

作为一个经验丰富的Linux C/C程序员&#xff0c; 肯定亲手写过各种功能的代码&#xff0c; 比如封装过数据库访问的类&#xff0c; 封装过网络通信的类&#xff0c;封装过日志操作的类&#xff0c; 封装过文件访问的类&#xff0c; 封装过UI界面库等&#xff0c; 也在实际的项目…

CDH kafka JMX 启动

服务正常启动 telnet 127.0.0.1 9393 就可以,直接 telnet ip 9393 就不通 我们查看CDH broker_java_opts 配置项 原内容为 -server -XX:+UseG1GC -XX:MaxGCPauseMillis=20 -XX:InitiatingHeapOccupancyPercent=35 -XX:G1HeapRegionSize=16M -XX:MinMetaspaceFreeRatio=50 …