健康检查脚本
nmap:扫描端口
while true
do
healthy=`curl B:httpPORT/healthy -i | grep HTTP/1.1 | tail -n 1 | awk '{print $2}'`
done
批量操作类型脚本(记录每一步日志)
将100个nginx:vn推送到harbor仓库192.168.0.100
根据镜像对比sha值,来判断是否为你想要的镜像
批量部署脚本
功能:在一台机器上可以对所有机器进行操作
原理:给机子进行免密登录
批量分发脚本
网络测试类型脚本
用一些手段去获取域内所有主机的信息
举例:假如有dhcp分配IP,想查看哪些IP被占用。
用数组记录IP地址池,再for循环这个数组,ping这个IP地址,如果不通就没有占用,同时需要并行执行,这样可以同时用多个进程去执行命令,大大提高效率。
批量文本处理类型脚本
Grep -r aaa 是显示文件名和里面的东西
并发:QPS 每秒访问次数,不管有多少请求在1s内访问
并行:同一时间内并行发生。
文档对比认证
变量
变量赋值:= 、for i in、read
变量在内存中的存储,会在内存中空出一块内存,用来存变量名称和值。
!a的用法
#a 获取字符串长度
fileformat=unix 文件输出格式
·长短匹配
#左匹配 %右(单)匹配 %%长匹配
/是做匹配转换的,将双杠中间的数转换为后面的数。
字符串的切片操作,从第几个开始切,切到第几位。
数组
${array[@]} 比较常见,代表取所有,*也指取所有。
·批量注释:#号或
<<comment
Comment
变量的作用域
局部变量local (只能在函数块中使用)、全局变量(在一个进程中可以使用)、环境变量(继承给子进程使用)
$# 传递的参数的个数
$* 参数列举出来
$$ 显示进程号 $?查看上一条消息的返回码
-a的优先级高于-o的优先级,多重判断需注意使用。
运算符
Shell中默认所有的字符都是字符串
IFS表示默认分隔符(尽量不用)
计数器:
用sum清零来延缓网络波动性。
case 常在部署软件时使用
文件测试描述符
-b file 检测文件是否是块设备文件,如果是,则返回 true。[-b $file]返回 false。
-c file 检测文件是否是字符设备文件,如果是,则返回 true。[-c $file]返回 false。
-d file 检测文件是否是目录,如果是,则返回 true。[-d $file]返回 false。
-f file 检测文件是否是普通文件(既不是目录,也不是设备文件),如果是,则返回 true。[-f $file]返回 true。
-g file 检测文件是否设置了 SGID 位,如果是,则返回 true。[-g $file]返回 false。
-k file 检测文件是否设置了粘着位(Sticky Bit),如果是,则返回 true。「-k $file]返回 false。
-p file 检测文件是否是有名管道,如果是,则返回 true。[-p $file]返回 false。
-u file 检测文件是否设置了 SUID 位,如果是,则返回 true。[-u $file]返回 false。
-r file 检测文件是否可读,如果是,则返回 true。[-r $file]返回 true。
-w file 检测文件是否可写,如果是,则返回 true。[-w $file]返回 true。
-x file 检测文件是否可执行,如果是,则返回 true。[-x $file]返回 true。
-s file 检测文件是否为空(文件大小是否大于0),不为空返回 true。[-s $file]返回 true。
文件描述符的范围0-255 文件流输入输出要有文件名fd来标识。
0是标准输出、1是标准正确输出、2是错误输出
只要有文件传输就会有文件流,有文件流输出输出必有描述符。
资源分配的最小单位是进程,
当CPU上下文切换,也是进程切换。
进程和线程的区别:
有没有分配共享出来的资源
执行环境与资源:进程是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配的基本单位1。每个进程都有自己独立的地址空间、文件描述符等资源23。而线程是进程内的一个执行单元,共享进程的地址空间和资源,如内存空间、文件等。
通信与切换开销:进程之间的通信需要通过显式的机制,如管道、消息队列和共享内存等来实现,因此通信开销相对较大。而线程之间可以直接读写进程共享的数据,通信更加方便和快捷3。同样,由于线程共享进程的资源,创建、销毁和切换线程的开销相对较小,而进程由于具有独立的资源,其创建、销毁和切换的开销相对较大。
并发性与独立性:进程是独立的执行单元,具有自己的调度算法,在并发条件下更加稳定可靠。而线程共享进程的资源,线程之间的调度和同步比较复杂,对并发条件的处理需要更多的注意。
管理与安全:进程的管理相对复杂,需要操作系统的支持。而线程的创建和销毁相对简单,可以更灵活地进行管理3。另外,进程间的地址空间隔离使得不同进程的数据互不影响,因此更加安全可靠。线程间则需要考虑共享数据的安全性和避免竞争条件。
总结来说,进程和线程在执行环境、资源、通信、切换开销、并发性、独立性、管理以及安全性等方面都存在显著的区别。了解这些区别对于编写高效、安全和可靠的程序至关重要。
内核态(发生在ring0级别的内核调用),凡是和硬件直接相关的都是内核态、用户态(发生在ring3级别的内核调用),在硬件上被软件一层层赋予的大概是用户态
Ring0是系统的开关机、严格的资源访问;ring3是用户开的一些进程。
从用户态到内存态在内存上是消耗资源的。像网卡、网络等这种和硬件直接相关的都是内核态;在硬件上做一层层的软件处理的大概率是用户态。
生产者、消费者问题
一个生产者、一个消费者,中间有缓存空间。生产者和消费者不用直接联系,只需连接中间的缓存空间即可。
异步:请求管道、完成管道,记录着客户端是谁,客户的请求资源是谁,返回的资源是谁
一般情况下,在做生产者和消费者时,当其中一个消费者去访问的时候,会涉及到一个加锁问题lock,会直接将你的读写权限锁掉,将其他进程对你中间管道读写权限锁掉,其他过来读是无权限的
在整个生产者、消费者流程中若有某个节点数据填满,而导致整个服务流程无法进行,那么就叫死锁。
互斥锁:解决多个进程对同一个进程改变的问题。互斥锁用来保护共享资源,确保在任意时刻只有一个线程能够访问共享资源,从而避免数据竞争和不一致性问题。
扩展
高可用:遇事不决,冗余部署
对象:是抽象出来的一种属性,类如果被赋值,就被称为对象
总结
脚本练习
1.随机n个元素的数组(n>10),输出相邻4位元素大于20的元素数组集合
#!/bin/bash
n=20
random_array=()
for ((i=0; i<$n; i++)); do
random_num=$((RANDOM % 101)) # 生成0-100的随机数
random_array+=($random_num)
done
echo "原始数组:"
for element in "${random_array[@]}"; do
echo $element
done
for ((i=0; i<${#random_array[@]}-3; i++)); do
# 计算当前四个元素之和
sum=$((random_array[i] + random_array[i+1] + random_array[i+2] + random_array[i+3]))
if ((sum > 20)); then
echo "元素集合: ${random_array[i]} ${random_array[i+1]} ${random_array[i+2]} ${random_array[i+3]}"
fi
done
2.健康检查脚本
3. 镜像批量拉改推脚本,sha值比对
给脚本执行权chmod +x 3.sh
./3.sh
4.批量命令,分发脚本
创建一个包含服务器列表的文件(例如servers.txt),每行一个服务器的IP地址或主机名
5.网络探测脚本,主机ip,端口
6.文本校对替换脚本
7. nginx日志根据时间统计人数,访问量,单人访问次数,并发数
8.跨主机实现的一个生产者消费者模型
使用流程控制语句结合组织8个功能