bash脚本学习笔记

一、扫盲

脚本文件是一种文本文件,其中包含了一系列的命令和指令,可以被操作系统解释器直接解释执行。脚本文件通常被用来完成特定的任务或执行重复性的操作。

脚本文件通常以某种编程语言的语法编写,例如 Bash、Python、Perl、Ruby 等等。它们可以在 Linux、Unix、macOS、Windows 等不同的操作系统上运行,嵌入式设备的操作系统中也经常使用脚本文件来完成各种任务。

脚本文件有很多用途,例如:

  • 自动化任务:通过编写脚本文件可以自动化一些重复性的任务,比如备份数据、部署软件、执行定时任务等等。
  • 执行系统管理任务:管理员可以通过编写脚本文件快速地管理系统,比如创建用户、修改权限、安装软件等等。
  • 编写辅助工具:脚本文件还可以被用作编写辅助工具,比如计算器、日历、单位转换器等等。

总之,脚本文件是一种非常强大的工具,可以使我们的工作更加高效和简单。

Bash 是 shell 的一种,而 shell 则是通用的 Unix/Linux 命令行解释器。因此,所有的 Bash 脚本都是 shell 脚本,但并不是所有的 shell 脚本都是 Bash 脚本。

二、bash脚本文件的编写语法格式

Bash 脚本文件是一种文本文件,其中包含了一系列的命令和指令,可以被 Bash 解释器直接解释执行。以下是 Bash 脚本编写的语法格式:

  1. shebang 行:每个 Bash 脚本文件都应该以 shebang 行开头,告诉系统要使用哪个解释器来解释执行脚本。示例:#!/bin/bash

  2. 注释:以 # 开头的行是注释,不会被解释器执行。注释可以用于描述代码的功能、提醒自己或其他人后续需要完成的工作等。

  3. 变量定义:在脚本中可以定义变量并使用它们。Bash 中的变量名必须以字母或下划线开头,不能以数字开头,变量名区分大小写。变量赋值可以使用等号(=),但是等号两侧不能有空格。示例:name="John"

  4. 函数定义:在脚本中可以定义函数并在脚本中进行调用。函数有名称、参数和代码块,调用函数时可以传递参数给函数。示例:

    function say_hello {
        echo "Hello, $1!"
    }
    
  5. 条件语句:可以使用 if、elif 和 else 关键字来编写条件语句。条件语句根据条件的真假来决定是否执行某段代码。示例:

    if [ "$name" == "John" ]; then
        echo "Your name is John"
    else
        echo "Your name is not John"
    fi
    
  6. 循环语句:可以使用 for 和 while 关键字来编写循环语句。循环语句可以重复执行某段代码块。示例:

    for i in {1..5}; do
        echo $i
    done
    
    while true; do
        echo "Hello, World!"
        sleep 1
    done
    
  7. 输入输出:可以使用 echo 命令输出信息到标准输出流,也可以使用 read 命令从标准输入流中读取用户输入。示例:

    echo "Enter your name:"
    read name
    echo "Hello, $name!"
    

以上是 Bash 脚本编写的基本语法格式,需要注意的是,每个语句都是以换行符结束的,如果一条语句太长,可以使用反斜杠(\)折行。同时,缩进不是必需的,但它可以使代码更易于阅读和理解。

补充:

  • Shebang行是指Bash脚本文件的第一行,它用来指定该脚本将要使用哪个解释器来执行。Shebang行以井号(#)和叹号(!)字符“#!”开头,后面紧跟着解释器的完整路径和名称。

    Shebang行不仅仅是用于Bash脚本文件,它还可以用于其他编程语言或解释器。

  • 在Bash脚本中,echo是一个用于向终端输出文本的命令。它可以接受一个或多个字符串作为参数,并将它们打印到标准输出(通常是终端窗口)上。

  • 在脚本中,$符号可以用于多种不同的用途,以下是其中一些最常见的用法:

    1. 变量引用:在Bash脚本中,$后跟一个变量名可以引用该变量的值。例如,如果变量foo的值为"hello",则echo $foo将输出"hello"。
    2. 命令替换:在Bash脚本中,$()或``可以将命令的输出插入到另一个命令或语句中。例如,echo $(ls)将输出当前目录中的所有文件和文件夹的列表。

三、获取linux内存、cpu、磁盘IO等信息脚本编写

https://mp.weixin.qq.com/s/lOVFgO4ZwJDXksitthdp5A

yikou.sh 代码如下:

#!/bin/bash
# 获取要监控的本地服务器IP地址
IP=`ifconfig | grep inet | grep -vE 'inet6|127.0.0.1' | awk '{print $2}'`
echo "IP地址:"$IP
 
# 获取cpu总核数
cpu_num=`grep -c "model name" /proc/cpuinfo`
echo "cpu总核数:"$cpu_num
 
# 1、获取CPU利用率
################################################
#us 用户空间占用CPU百分比
#sy 内核空间占用CPU百分比
#ni 用户进程空间内改变过优先级的进程占用CPU百分比
#id 空闲CPU百分比
#wa 等待输入输出的CPU时间百分比
#hi 硬件中断
#si 软件中断
#################################################
# 获取用户空间占用CPU百分比
cpu_user=`top -b -n 1 | grep Cpu | awk '{print $2}' | cut -f 1 -d "%"`
echo "用户空间占用CPU百分比:"$cpu_user
 
# 获取内核空间占用CPU百分比
cpu_system=`top -b -n 1 | grep Cpu | awk '{print $4}' | cut -f 1 -d "%"`
echo "内核空间占用CPU百分比:"$cpu_system
 
# 获取空闲CPU百分比
cpu_idle=`top -b -n 1 | grep Cpu | awk '{print $8}' | cut -f 1 -d "%"`
echo "空闲CPU百分比:"$cpu_idle
 
# 获取等待输入输出占CPU百分比
cpu_iowait=`top -b -n 1 | grep Cpu | awk '{print $10}' | cut -f 1 -d "%"`
echo "等待输入输出占CPU百分比:"$cpu_iowait
 
#2、获取CPU上下文切换和中断次数
# 获取CPU中断次数
cpu_interrupt=`vmstat -n 1 1 | sed -n 3p | awk '{print $11}'`
echo "CPU中断次数:"$cpu_interrupt
 
# 获取CPU上下文切换次数
cpu_context_switch=`vmstat -n 1 1 | sed -n 3p | awk '{print $12}'`
echo "CPU上下文切换次数:"$cpu_context_switch
 
#3、获取CPU负载信息
# 获取CPU15分钟前到现在的负载平均值
cpu_load_15min=`uptime | awk '{print $11}' | cut -f 1 -d ','`
echo "CPU 15分钟前到现在的负载平均值:"$cpu_load_15min
 
# 获取CPU5分钟前到现在的负载平均值
cpu_load_5min=`uptime | awk '{print $10}' | cut -f 1 -d ','`
echo "CPU 5分钟前到现在的负载平均值:"$cpu_load_5min
 
# 获取CPU1分钟前到现在的负载平均值
cpu_load_1min=`uptime | awk '{print $9}' | cut -f 1 -d ','`
echo "CPU 1分钟前到现在的负载平均值:"$cpu_load_1min
 
# 获取任务队列(就绪状态等待的进程数)
cpu_task_length=`vmstat -n 1 1 | sed -n 3p | awk '{print $1}'`
echo "CPU任务队列长度:"$cpu_task_length
 
#4、获取内存信息
# 获取物理内存总量
mem_total=`free | grep Mem | awk '{print $2}'`
echo "物理内存总量:"$mem_total
 
# 获取操作系统已使用内存总量
mem_sys_used=`free | grep Mem | awk '{print $3}'`
echo "已使用内存总量(操作系统):"$mem_sys_used
 
# 获取操作系统未使用内存总量
mem_sys_free=`free | grep Mem | awk '{print $4}'`
echo "剩余内存总量(操作系统):"$mem_sys_free
 
# 获取应用程序已使用的内存总量
mem_user_used=`free | sed -n 3p | awk '{print $3}'`
echo "已使用内存总量(应用程序):"$mem_user_used
 
# 获取应用程序未使用内存总量
mem_user_free=`free | sed -n 3p | awk '{print $4}'`
echo "剩余内存总量(应用程序):"$mem_user_free
 
 
# 获取交换分区总大小
mem_swap_total=`free | grep Swap | awk '{print $2}'`
echo "交换分区总大小:"$mem_swap_total
 
# 获取已使用交换分区大小
mem_swap_used=`free | grep Swap | awk '{print $3}'`
echo "已使用交换分区大小:"$mem_swap_used
 
# 获取剩余交换分区大小
mem_swap_free=`free | grep Swap | awk '{print $4}'`
echo "剩余交换分区大小:"$mem_swap_free
 

#5、获取磁盘I/O统计信息
echo "指定设备(/dev/sda)的统计信息"
# 每秒向设备发起的读请求次数
disk_sda_rs=`iostat -kx | grep sda| awk '{print $4}'`
echo "每秒向设备发起的读请求次数:"$disk_sda_rs
 
# 每秒向设备发起的写请求次数
disk_sda_ws=`iostat -kx | grep sda| awk '{print $5}'`
echo "每秒向设备发起的写请求次数:"$disk_sda_ws
 
# 向设备发起的I/O请求队列长度平均值
disk_sda_avgqu_sz=`iostat -kx | grep sda| awk '{print $9}'`
echo "向设备发起的I/O请求队列长度平均值"$disk_sda_avgqu_sz
 
# 每次向设备发起的I/O请求平均时间
disk_sda_await=`iostat -kx | grep sda| awk '{print $10}'`
echo "每次向设备发起的I/O请求平均时间:"$disk_sda_await
 
# 向设备发起的I/O服务时间均值
disk_sda_svctm=`iostat -kx | grep sda| awk '{print $11}'`
echo "向设备发起的I/O服务时间均值:"$disk_sda_svctm
 
# 向设备发起I/O请求的CPU时间百分占比
disk_sda_util=`iostat -kx | grep sda| awk '{print $12}'`
echo "向设备发起I/O请求的CPU时间百分占比:"$disk_sda_util
  • ifconfig:这个命令用于显示系统中网络接口的配置情况,包括网络接口名称、MAC地址、IP地址等信息。

    grep -vE 'inet6|127.0.0.1':使用 grep 命令去掉包含 “inet6”、“127.0.0.1” 的行,因为这些行分别表示 IPv6 地址和本地回环地址。

    -v 参数表示反向选择(invert match),即只显示不包含匹配模式的行,相当于进行匹配模式的取反操作。

    -E 参数表示使用扩展正则表达式(extended regular expression)进行匹配。扩展正则表达式支持更多的元字符和语法,例如 | 表示或,() 表示分组等。

    通常情况下,我们需要获取的 IP 地址是可以被外部访问的公网 IP 地址,而不是本地IP地址。因此,这行代码使用了 grep -vE 'inet6|127.0.0.1' 命令过滤掉了本地IP地址和IPv6地址,只返回非本地IP地址。这样就可以确保获得的 IP 地址是可以被外部网络访问的公网 IP 地址。

    awk '{print $2}':使用 awk 命令提取 IP 地址所在的列,也就是第二列,然后打印出来。

    awk 是一种文本处理工具,awk '{print $2}' 中的 $2 表示输出当前行(即 grep 命令过滤后的结果)中的第二个字段,这里的字段指的是按照空格或制表符分隔的一段文本。默认情况下,awk 会以空格或制表符为分隔符将每一行分成多个字段

  • grep 中的-c 参数让 grep 命令输出字符串匹配的行数(或者说计算匹配数量)。

  • top -b -n 1:执行top命令,以非交互方式显示系统进程信息,其中“-b”选项表示以批处理模式运行,不需要进行交互;“-n 1”选项表示只显示1次信息后就退出。

    grep Cpu:在top命令的输出中查找包含"Cpu"字符串的行。

    awk '{print $2}':对于每个包含"Cpu"字符串的行,使用awk命令取出第二个字段,即"Cpu"使用率的数值(例如,如果该行的内容为"Cpu(s): 1.2%us, 0.8%sy, 0.0%ni, 98.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st",则取出的数值为"1.2%us").

    cut -f 1 -d "%": 对于上一步得到的数值(如"1.2%us"),使用cut命令取出第1个字段(即去掉末尾的百分号)并赋值给变量cpu_user

    -f 1这个选项指定要提取的字段,这里是第一个字段。如果文本数据中以多个字符分隔字段,可以使用逗号分隔的数字列表指定多个字段(例如 -f 1,3)。

    -d "%"这个选项指定字段之间的分隔符,这里是 “%”。如果不指定分隔符,cut 命令默认使用制表符 \t 作为分隔符。

  • vmstat -n 1 1:这个命令会打印出当前系统的一些性能指标,每隔1秒更新一次,一共更新1次,然后就退出了。其中,-n只显示一次报头,而不是定期显示。,而只打印出实时值;1表示每隔1秒打印一次;第二个1表示只打印1次。

    sed -n 3p:这个命令会从vmstat的输出中取出第三行。因为vmstat的输出的前两行是表头,第三行才是我们需要的数据。-n 选项表示“安静模式”,即只输出经过sed处理的内容,而不是原始文本。3p 表示只打印出输入中的第3行。其中,数字3是行号,而p则表示打印。

  • uptime:这个命令用于显示系统当前的负载平均值

  • free:这个命令用于查看系统内存的使用情况。它会输出当前系统的空闲和已用内存量、缓冲区和缓存所占用的内存量等信息。

    grep Memfree命令的输出包含了多个内存相关的行,这里使用grep命令过滤出包含Mem关键字的行。这个关键字用于标识当前系统内存的使用情况。

运行结果:

在这里插入图片描述

四、利用cyclictest和GNUplot绘制延迟图的脚本

mklatencyplot.bash 代码如下:

#!/bin/bash

# 1. 运行 cyclictest
# /home/zhang/rt-tests-1.0/cyclictest -i 100 -p 50 -n -t -D 10m -h5000 -q --policy=fifo >output

# 2. 获取最大延迟时间
max=`grep "Max Latencies" output | tr " " "\n" | sort -n | tail -1 | sed s/^0*//`

# 3. Grep数据行,删除空行并创建一个公共字段分隔符
grep -v -e "^#" -e "^$" output | tr " " "\t" >histogram 

# 4. 设置内核的数量
cores=4

# 5. 为每个核创建包含延迟类别和频率值的两列数据集
for i in `seq 1 $cores`
do
  column=`expr $i + 1`
  cut -f1,$column histogram >histogram$i
done

# 6. 创建plot命令头
echo  "set title \"Latency plot\"\n\
set terminal png\n\
set xlabel \"Latency (us), max $max us\"\n\
set logscale y\n\
set xrange [0:5000]\n\
set yrange [0.8:*]\n\
set ylabel \"Number of latency samples\"\n\
set output \"plot.png\"\n\
plot \\" >plotcmd

# 7. 追加绘图命令数据引用
for i in `seq 1 $cores`
do
  if test $i != 1
  then
    echo -n ", " >>plotcmd
  fi
  cpuno=`expr $i - 1`
  if test $cpuno -lt 10
  then
    title=" CPU$cpuno"
   else
    title="CPU$cpuno"
  fi
  echo -n "\"histogram$i\" using 1:2 title \"$title\" with histeps" >>plotcmd
done

# 8. 执行plot命令
gnuplot -persist <plotcmd
  • |:管道符号,表示将上一条命令的输出作为下一条命令的输入

  • sort 命令按数字大小对每个最大延迟值进行排序, -n 参数表示将值视为数字进行排序。这种排序方式默认是从小到大排序的,如果需要按照从大到小的顺序对行进行排序,可以使用-r选项

  • sed是一种流编辑器,它用于对文件进行基本的文本转换和过滤操作。

    sed s/^0*//:该指令使用了正则表达式, s是替换命令 ,替换命令的语法格式为s/old/new/;^0* 匹配行首的所有零,^ 表示匹配行首,0* 表示匹配零个或多个连续的零

    需要注意的是,在使用该指令时,如果在正则表达式中使用了 ^,则需要将其放在引号或反斜杠中,以避免 shell 解释器将其解释为行首字符,从而导致错误。

    在正则表达式中,^(脱字符)表示匹配文本的开头位置。它可以用于多种情况下,例如:

    1. ^pattern:表示以pattern开始的字符串。例如,正则表达式^Hello将匹配以Hello开头的字符串。
    2. [^characters]:表示不属于characters中任何一个字符的单个字符。例如,正则表达式[^aeiou]将匹配不包含元音字母的单个字符。
    3. ^(pattern):表示将pattern作为整个字符串的组,并从第一个字符开始匹配该组。这种语法通常与后续的数量词一起使用。例如,正则表达式^(ab)+将匹配以连续出现的ab开头的字符串。

    需要注意的是,^在方括号外面和里面的含义是不同的

  • grep: 这是一个查找文件中匹配文本的命令

    -v: grep的一个选项,表示匹配不包含模式的行

    -e: grep的一个选项,表示后面跟随的是模式

    ^ 表示匹配行的开头,而 $ 表示匹配行的结尾。因此, ^$ 表示匹配既没有开头字符也没有结尾字符的行,也就是空行。

    tr: 这是一个字符转换命令,用于将文件中的一个字符转换为另一个字符

  • gnuplot工具官网:http://www.gnuplot.info/

    参数logscale默认以 10 为低

  • echo中的-n选项表示不在输出末尾添加换行符

  • Gnuplot命令中的with histeps表示使用直方图而不是条形图来绘制柱状图

    直方图通常用于表示连续型的数据,例如时间、长度或者重量等。直方图的矩形通常是连续的,没有空隙

    条形图可以很好地展示不同类别之间的数据分布情况,例如对比不同商品的销售量、对比不同城市的人口等。条形图的矩形之间通常是有间隔的

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

多线程-阻塞队列(超详细)

目录 1.阻塞队列是什么 生产者-消费者模型 2.标准库中的阻塞队列 ⽣产者-消费者模型 阻塞队列实现 1.阻塞队列是什么 阻塞队列&#xff08;Blocking Queue&#xff09;是一种特殊类型的队列&#xff0c;它在插入和删除元素时可以提供阻塞机制。阻塞队列能是⼀种线程安全的数…

769933-15-5,Biotin aniline,用来标记和检测细胞膜上的特定蛋白质

您好&#xff0c;欢迎来到新研之家 文章关键词&#xff1a;769933-15-5&#xff0c;Biotin aniline&#xff0c;生物素苯胺 一、基本信息 产品简介&#xff1a;Biotin aniline, also known as Biotin aniline, is a molecular probe with strong reactivity. Its uniqueness…

​(四)hive的搭建2

在&#xff08;三&#xff09;hive的搭建1中我们搭建好了hive环境&#xff0c;但是只能本地访问&#xff0c;在本节中配置Hive的访问方式。 1.元数据服务的方式 1.1 编辑hive-site.xml sudo vi hive-site.xml 在文件最后增加以下内容 <!– 指定存储元数据要连接的地址 –…

RTSP/Onvif协议视频平台EasyNVR激活码授权异常该如何解决

TSINGSEE青犀视频安防监控平台EasyNVR可支持设备通过RTSP/Onvif协议接入&#xff0c;并能对接入的视频流进行处理与多端分发&#xff0c;包括RTSP、RTMP、HTTP-FLV、WS-FLV、HLS、WebRTC等多种格式。在智慧安防等视频监控场景中&#xff0c;EasyNVR可提供视频实时监控直播、云端…

反物质(anti matter)和湮灭反应(Annihilation)浅读

反物质 反物质是正常物质的反状态。当正反物质相遇时&#xff0c;双方就会相互湮灭抵消&#xff0c;发生爆炸并产生巨大能量。 概念 正电子、负质子都是反粒子&#xff0c;它们跟通常所说的电子、质子相比较&#xff0c;电量相等但电性相反。科学家设想在宇宙中可能存在完全由…

自然语言nlp学习五

6-10 文本生成--介绍_哔哩哔哩_bilibili 在自然语言处理&#xff08;NLP, Natural Language Processing&#xff09;领域&#xff0c;“sequence”通常是指一个有序的数据集合&#xff0c;它由一系列元素按照特定顺序排列而成。这些元素可以是单词、字符、句子或其他文本单位。…

Web实战丨基于django+hitcount的网页计数器

文章目录 写在前面Django简介主要程序运行结果系列文章写在后面 写在前面 本期内容 基于djangohitcount的网页计数器 所需环境 pythonpycharm或vscodedjango 下载地址 https://download.csdn.net/download/m0_68111267/88795611 Django简介 Django 是一个开源的、基于 …

聊聊DoIP吧(一)

DoIP是啥? DoIP代表"Diagnostic over Internet Protocol",即互联网诊断协议。它是一种用于在车辆诊断中进行通信的网络协议。DoIP的目标是在现代汽车中实现高效的诊断和通信。通过使用互联网协议(IP)作为通信基础,DoIP使得诊断信息能够通过网络进行传输,从而提…

指针的学习1

目录 什么是指针&#xff1f; 野指针 造成野指针的原因&#xff1a; 如何避免野指针&#xff1f; 内存和指针 如何理解编址&#xff1f; 指针变量和地址 取地址操作符& 指针变量和解引用操作符 指针变量 如何拆解指针类型&#xff1f; 指针变量的大小 指针变量…

闲聊电脑(4)硬盘分区

夜深人静&#xff0c;万籁俱寂&#xff0c;老郭趴在电脑桌上打盹&#xff0c;桌子上的小黄鸭和桌子旁的冰箱又开始窃窃私语…… 小黄鸭&#xff1a;冰箱大哥&#xff0c;上次你说的那个“分区”和“格式化”是什么意思&#xff1f; 冰箱&#xff1a;分区么&#xff0c;就是分…

基于WordPress开发微信小程序1:搭建Wordpress

2年前&#xff0c;在知乎上提问&#xff1a;多数公司为什么宁愿自研也不用wordpress二次开发建站&#xff1f; - 知乎 (zhihu.com)&#xff0c;收到了&#xff0c;很多回答 自己打算做一下提升&#xff0c;便有了自己基于wordpress开发微信小程序的想法 项目定位 基于wordpre…

【机器学习】科学库使用手册第2篇:机器学习任务和工作流程(已分享,附代码)

本系列文章md笔记&#xff08;已分享&#xff09;主要讨论人工智能相关知识。主要内容包括&#xff0c;了解机器学习定义以及应用场景&#xff0c;掌握机器学习基础环境的安装和使用&#xff0c;掌握利用常用的科学计算库对数据进行展示、分析&#xff0c;学会使用jupyter note…

MATLAB知识点: 矩阵元素的修改和删除

​讲解视频&#xff1a;可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇&#xff08;数学建模清风主讲&#xff0c;适合零基础同学观看&#xff09;_哔哩哔哩_bilibili 节选自第3章 3.3.3 矩阵元素的修改和删除 我们可以直接利用等…

记录关于node接收上传文件formData踩的坑

1.vue2使用插件formidable实现接收文件&#xff0c;首先接口不可以使用任何中间件&#xff0c;否则form.parse()方法不执行。 const express require(express) const multipart require(connect-multiparty); const testController require(../controller/testController)/…

定义HarmonyOS IDL接口

HarmonyOS IDL简介 HarmonyOS Interface Definition Language&#xff08;简称HarmonyOS IDL&#xff09;是HarmonyOS的接口描述语言。HarmonyOS IDL与其他接口语言类似&#xff0c;通过HarmonyOS IDL定义客户端与服务端均认可的编程接口&#xff0c;可以实现在二者间的跨进程…

YOLOv5改进 | Neck篇 | 2024.1最新MFDS-DETR的HS-FPN改进特征融合层(轻量化Neck、全网独家首发)

一、本文介绍 本文给大家带来的改进机制是最近这几天最新发布的改进机制MFDS-DETR提出的一种HS-FPN结构,其是一种为白细胞检测设计的网络结构,主要用于解决白细胞数据集中的多尺度挑战。它的基本原理包括两个关键部分:特征选择模块和特征融合模块,在本文的下面均会有讲解,…

AJAX-认识URL

定义 概念&#xff1a;URL就是统一资源定位符&#xff0c;简称网址&#xff0c;用于访问网络上的资源 组成 协议 http协议&#xff1a;超文本传输协议&#xff0c;规定浏览器和服务器之间传输数据的格式&#xff1b;规定了浏览器发送及服务器返回内容的格式 协议范围&#xf…

flutter抓包绕过

lutter的证书校验 起因&#xff1a; 最近工作上让做个app的复测&#xff0c;把apk发我后&#xff0c;开始尝试挂代理抓包&#xff0c;结果发现抓不到 为是证书没弄好&#xff0c;想着前几天不是刚导入了吗&#xff08;雾&#xff09;。又重新导入了下还是不行。然后各种lsp模…

IDEA中的Run Dashboard

Run Dashboard是IntelliJ IDEA中的工具【也就是View中的Services】&#xff0c;提供一个可视化界面&#xff0c;用于管理控制应用程序的运行和调试过程。 在Run DashBoard中&#xff0c;可以看到所有的运行配置&#xff0c;以及每个配置的运行状态&#xff08;正在运行&#xf…

嵌入式—— IIC

目录 一、初识IIC 1. 介绍 2. 理解 二、IIC的简单拆分 1. 物理层 特点&#xff1a; 2. 协议层 &#xff08;1&#xff09;IIC基本读写过程 具体过程描述&#xff1a; &#xff08;2&#xff09;通信的起始和停止信号 &#xff08;3&#xff09;数据有效性 &#xf…