【Shell1】shell语法,ssh/build/scp/upgrade,环境变量,自动升级bmc

news2024/9/24 13:24:47

文章目录

  • 1.shell语法:shell是用C语言编写的程序,是用户使用Linux的桥梁,硬件>内核(os)>shell>文件系统
    • 1.1 变量:readonly定义只读变量,unset删除变量
    • 1.2 函数:shell脚本传递的参数中包含空格,应使用单引号或双引号将该参数括起来,以便于脚本将这个参数作为整体来接收。if [ -n str1 ] 当字符串的长度大于0时为真(字符串非空)
    • 1.3 运算:算术、关系、布尔、逻辑、字符串、文件运算
    • 1.4 流程控制:if、for、while、case
  • 2.ssh_tool:sed -i 's/\r//g' 文件(删除从txt复制来代码的换行符)
  • 3.build_bmc:To go back to default recipes: devtool reset linux-aspeed , devtool reset u-boot
    • 3.1 环境变量:用bash调用脚本的时候会创建一个和自己一模一样的shell子进程执行这个外部命令。这个子进程中设置了自己的运行的环境变量,此时父进程的环境变量并没有改变。bash test.sh == ./test.sh。
  • 4.scp_image:不用管STRING1
  • 5.bmc_upgrade:断电重启才从主启,当前永远mtd4
  • 6.自动升级bmc:AC ON物理上电


1.shell语法:shell是用C语言编写的程序,是用户使用Linux的桥梁,硬件>内核(os)>shell>文件系统

1.1 变量:readonly定义只读变量,unset删除变量

在这里插入图片描述
在这里插入图片描述
如果字符串中有空格,必须需要使用引号(str=hello world会报错)。
在这里插入图片描述
在这里插入图片描述
获取字符串长度:echo ${#str}expr length “${str}”
截取字符串:echo ${str:1:4}:显示字符串第1到第4个字符。
echo ${str:4}:从左边第4个字符开始,一直到结束。
echo ${str:0-6:3}:从倒数第6个字符开始的3个字符。
echo ${str:0-6}:从倒数第6个字符开始,一直到结束。

file=/dir1/dir2/dir3/my.file.txt
${file#*/}:删掉第一个 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt     / 可换成 .#*.
${file##*/}:删掉最后一个 / 及其左边的字符串:my.file.txt
${file%/*}:删掉最后一个 / 及其右边的字符串:/dir1/dir2/dir3
${file%%/*}:删掉第一个 / 及其右边的字符串:(空值)

在这里插入图片描述
在这里插入图片描述

#!/bin/bash
for i in `ifconfig | grep -o ^[a-z0-9.]*`
do
	name=$i 
	echo $name
	ipaddr=$(ifconfig $i|sed -n 2p|awk '{ print $2 }'|tr -d 'addr:')  # -d删除
	echo http://$1:8080/api/slave -d '{"slave":"'$2${name}'","ip":"'${ipaddr}'"}'
done

在这里插入图片描述
如下截取 = 号左边即第一个。
在这里插入图片描述

"-d")
    shift
    case ${1} in
        "lc1" | "lc2" | "cmm" | "fb1" | "fb2")
            ;;
        *)
            usage
            ;;
    esac
    dev=${1}
    led_devie=${dev%[^a-zA-Z]}    # lc
    if [ "$1" != "cmm" ];then
        index=${dev/*[a-zA-Z]/}   # 1
    fi
    ;;

设置别名,printf,重定向,exit,until,shift,basename/dirname
在这里插入图片描述
不添加引号,转义将不被执行,如下转义。
在这里插入图片描述
command > /dev/null 2>&1不在屏幕上显示输出结果错误。/dev/null 是一个特殊文件,写入到它的内容都会被丢弃,从该文件读取内容,什么也读不到。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# a.sh
a()
{
    return 1
}
if ! a ; then
   echo "111"
fi

$ ./a.sh 
111
# shift.sh
until [ $# -eq 0 ]
do
echo "第一个参数为: $1 参数个数为: $#"
shift
done

$./shift.sh 1 2 3 4    
第一个参数为: 1 参数个数为: 4
第一个参数为: 2 参数个数为: 3
第一个参数为: 3 参数个数为: 2
第一个参数为: 4 参数个数为: 1
# shift1.sh
sum=0
until [ $# -eq 0 ]
do
sum=`expr $sum + $1`
shift
done
echo "sum is: $sum"

$./shift1.sh 10 20 15
结果显示:45
basename /usr/local/nginx/conf/nginx.conf
nginx.conf
basename -s .conf /usr/local/nginx/conf/nginx.conf
nginx

dirname //
/
dirname /a/b/
/a 
dirname a
.
dirname a/b
a

realpath $path : 返回$path的绝对路径,路径不存在会报错,文件不存在不会报错

declare与let:let命令和双小括号 (( )) 的用法是类似的,它们都是用来对整数进行运算,不能对小数(浮点数)或字符串运算。
在这里插入图片描述
在这里插入图片描述
整型运算如上同如下。
在这里插入图片描述
在这里插入图片描述
test:用于检查某个条件是否成立,它可以进行数值、字符、文件三个方面的测试
在这里插入图片描述

1.2 函数:shell脚本传递的参数中包含空格,应使用单引号或双引号将该参数括起来,以便于脚本将这个参数作为整体来接收。if [ -n str1 ] 当字符串的长度大于0时为真(字符串非空)

在这里插入图片描述
在这里插入图片描述

1.3 运算:算术、关系、布尔、逻辑、字符串、文件运算

算术:
在这里插入图片描述
关系:
在这里插入图片描述
在这里插入图片描述
布尔:
在这里插入图片描述
逻辑:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
文件测试运算:
在这里插入图片描述
在这里插入图片描述

1.4 流程控制:if、for、while、case

if:
在这里插入图片描述
for:
在这里插入图片描述
while:
在这里插入图片描述
until:
在这里插入图片描述
case:
在这里插入图片描述
break与continue:
在这里插入图片描述

2.ssh_tool:sed -i ‘s/\r//g’ 文件(删除从txt复制来代码的换行符)

#!/usr/bin/expect
# b文件,llength等是expect中专属的,和ftp那些命令一样
# obmc-server:~$ whereis expect
# expect: /usr/bin/expect /usr/share/man/man1/expect.1.gz
puts "$argv0"

set arg_leng [llength $argv]
puts "$arg_leng" 

set argv_0   [lindex  $argv 0]
puts "$argv_0"

# @obmc-server:~/test$ ./b w
# ./b
# 1
# w
#!/usr/bin/expect
# 如上一行必须加且必须在第一行
if { [llength $argv] < 1} {
    puts "Usage:"
    puts "$argv0 raspberr ttyUSBx <pi2 0>"  # ssh-tool.sh pi2 0
    puts "$argv0 raspberr <pi1> <pi2> <pi3>"  # ssh-tool.sh pi1
    puts "$argv0 project_name <hollywood> <s3ip-bmc> <s3ip-bsp>"    # ssh-tool.sh hollywood
    # puts "$argv0 raspberrNUM ttyUSBx [force]"     # ssh-tool.sh pi1 0 force
    # puts "force if other used tty will kill process,杀串口进程"
    exit 1
}

set arg_leng [llength $argv  ]
set argv_0   [lindex  $argv 0]
set ttyUSBx  [lindex  $argv 1]
# set force    [lindex $argv 2]
set timeout 20
# set pi3_ip [exec sh -c {curl -s http://10.75.92.228:8080/api/help | python -m json.tool |grep -i "pi3" |cut -d '"' -f 4}]
set pi3_ip 10.75.159.104
set local_file ./tmp/deploy/images/obmc-cl/flash-obmc-cl
set passwderror 0

#11111111111111111111111111111111111111111111111111111111111111111111111111
if { $argv_0 == "pi1" } {
    set passwd 123456
    spawn ssh pi@$pi1_ip
}
if { $argv_0 == "pi2" } {
    set passwd 123456
    spawn ssh pi@$pi2_ip
}
if { $argv_0 == "pi3" } {
    set passwd 123456
    spawn ssh pi@$pi3_ip
}
if { $argv_0 == "hollywood" } {
    set passwd 0penBmc
    spawn ssh-keygen -f "/home_a/yu/.ssh/known_hosts" -R $hollywood_ip
    spawn ssh root@$hollywood_ip
}
if { $argv_0 == "docker" } {
    set passwd 1
    spawn ssh cit@10.75.159.16
    expect {
        "*yes/no*" {
            send "yes\r"
            exp_continue
        }
        "*assword:*" {
            if { $passwderror == 1 } {
            puts "passwd is error"
            exit 2
            }
            set timeout 1000
            set passwderror 1
            send "$passwd\r"
            sleep 0.2
            send "sudo su\r"
            sleep 0.2
            send "$passwd\r"
            sleep 0.2
            send "docker exec -it 16d93b0d2026 bash\r"
            sleep 0.2
            send "zsh\r"
            sleep 0.2
            send "ls\r"
            sleep 0.2
            send "cd\r"
            interact
        }
    }
}

#11111111111111111111111111111111111111111111111111111111111111111111111111
expect {
    "*yes/no*" {
        send "yes\r"
        exp_continue  # 该项被匹配后,还能继续匹配该expect判断语句内的其他项
    }
    "*assword:*" {
        if { $passwderror == 1 } {
        puts "passwd is error"
        exit 2
        }
        set timeout 1000
        set passwderror 1
        send "$passwd\r"
        if { $arg_leng == 1} {
            interact   # 执行完成后保持交互状态,把控制权交给控制台,这个时候便可以手动操作。
            # 如果没有该命令,命令完成后即退出。
        }
        if { $arg_leng == 2} {
            exp_continue  
        }
    }
    "*pi@raspberrypi*" {
        send " picocom -b 115200 /dev/ttyUSB$ttyUSBx\r"
        exp_continue
    }
    "*FATAL: cannot lock*" {
        # if { $force == "force" } {
        #     puts "you can kill process and try again"
        #     exit 1
        # }
        send " ps -ef |grep -i ttyUSB$ttyUSBx\r "
        interact
    }
    "*FATAL: cannot open*" {
        puts "!!!   ########################################   !!!"
        puts "!!!no ttyUSB$ttyUSBx"
        exit 1
    }
    "*Terminal ready*" {
        interact
    }
}

3.build_bmc:To go back to default recipes: devtool reset linux-aspeed , devtool reset u-boot

#!/bin/bash

# downloads() {
#     echo "buildpath: [$buildpath]"
#     build_exist=$(grep "DL_DIR" $buildpath/conf/local.conf)
#     echo "buildexist: [$build_exist]"
#     if [ ! -n "$build_exist" ]; then
#         echo "DL_DIR ?= \"/home_a/y/usr/local/downloads\"" >> "conf/local.conf"
#     fi
# }

# buildplatform() {
#     source openbmc-init-build-env meta-huaqin/meta-$1 build-$1
#     buildpath=$(pwd)
#     downloads
#     bitbake $1-image
#     rm -rf conf/local.conf
# }

usage() {
    echo "Usage: build an openbmc image"
    echo "    $(basename $0) <platform>"
    echo "    $(basename $0) <platform> <feature>"
    echo "    $(basename $0) <platform> <clean>"
    echo "    $(basename $0) <platform> <clean> <feature>"
    echo
    echo "Examples:"
    echo "    $(basename $0) kestrel"
    echo "    $(basename $0) kestrel ipmid"
    echo "    $(basename $0) kestrel clean"
    echo "    $(basename $0) kestrel clean ipmid"
}
# if [ $# -eq 1 ]; then
    # buildplatform $1
if [ $# -eq 1 ]; then
    source ./setup $1;
    echo "DL_DIR ?= \"/home_a/y/usr/local/downloads_ocp\"" >> "conf/local.conf"   # openbmc-hollywood-master/build/conf/local.conf 或 meta-huaqin/meta-xs9880-8c/conf/local.conf.sample
    bitbake  obmc-phosphor-image 
elif [ $# -ge 2 ]; then
    case $2 in
    "clean")
        source ./setup $1;
        echo "DL_DIR ?= \"/home_a/y/usr/local/downloads_ocp\"" >> "conf/local.conf"
        bitbake  obmc-phosphor-image -c cleanall obmc-phosphor-image
    ;;
    "u-boot")
	    # source openbmc-init-build-env meta-huaqin/meta-$1 build-$1 && buildpath=$(pwd); downloads; bitbake u-boot
    ;;
    "linux-aspeed")
	    # source openbmc-init-build-env meta-huaqin/meta-$1 build-$1 && buildpath=$(pwd); downloads; bitbake linux-aspeed
    ;;
    *)
	    source openbmc-init-build-env meta-huaqin/meta-$1 build-$1 && buildpath=$(pwd); downloads; bitbake $2
    ;;
    esac
else
    usage
fi
exit 0
# build目录下获取源码:devtool modify linux-aspeed ,devtool modify u-boot   
# This will create local Linux package under /workspace/sources/linux-aspeed for development
chmod 777 /home_a/y/app/bin/(usr/local/bin/)build_bmc

~$ vi .bash_profile
export PATH=/home_a/y/app/bin:$PATH

~$ vi .bashrc
alias gr='grep -nr'

3.1 环境变量:用bash调用脚本的时候会创建一个和自己一模一样的shell子进程执行这个外部命令。这个子进程中设置了自己的运行的环境变量,此时父进程的环境变量并没有改变。bash test.sh == ./test.sh。

用source来执行脚本的时候,不会创建子进程,而是在父进程中直接执行,所以当需要程序修改当前shell本身的环境变量的时候,用source命令。source test.sh == . test.sh。如下记住ebe从大到小。
在这里插入图片描述
上面就是改变linux的env的三种方法,每个用户env都不一样,env中HOME为用户主目录。
在这里插入图片描述
export在命令行单独输入是临时的(export…,env可查到多出了刚export的,但用户登出再登录,env查看没有刚export的)。但在.bash_profile中都含有export,用户一登录就执行.bash_profile,所以env中含有这些环境变量,这样export可视为永久。
在这里插入图片描述
所有可执行程序都要PATH指定,如ls,pwd(也是可执行程序)不加./(./是在当前目录执行),因为在冒号分隔(冒号不是连接)的几个目录下找。sqlplus命令行命令在/oracle/bin中。
在这里插入图片描述
在这里插入图片描述
ls这个可执行程序就是在bin目录下,上面PATH已指定。如下若未改为英文显示:未找到命令(中文)。
在这里插入图片描述
如下必须在用户主目录/oracle,才能vi .bash_profile。
在这里插入图片描述
在这里插入图片描述
如下对所有用户有效。
在这里插入图片描述
/etc/profile 是文件(里面有不建议在这文件里修改的英文说明), /etc/profile.d/ 是目录(如下新建.sh文件创建全局环境变量)。
在这里插入图片描述
如下在sss.sh中写入下行。/etc/profile这个文件中有这么一段shell:for i in /etc/profile.d/*.sh;,会在每次启动时自动加载profile.d目录中每个配置。
在这里插入图片描述
不想要什么变量直接删除 /etc/profile.d/ 下对应的shell 脚本即可,当用户重新登录shell如下或source /etc/profile 时会触发。
在这里插入图片描述

4.scp_image:不用管STRING1

#!/usr/bin/expect 

if { [llength $argv] < 2} { 
    puts "Usage:" 
    puts "$argv0 <Image path> IP" 
    puts "$argv0 <Image path> IP <path>" 
    exit 1 
}

set timeout 20 
set Local_File [lindex $argv 0] 
set IP [lindex $argv 1]
set STRING 0 
spawn ssh-keygen -f "/home_a/y/.ssh/known_hosts" -R $IP

proc myscpfunc { STRING1 } {
    set passwd 0penBmc
    set passwderror 0 
    expect { 
        "*assword:*" { 
            if { $passwderror == 1 } { 
            puts "passwd is error" 
            exit 2 
            } 
            set timeout 1000 
            set passwderror 1 
            send "$passwd\r" 
            exp_continue 
        } 
        "yes/no" { 
            send "yes\r" 
            exp_continue 
        } 
        timeout { 
            puts "connect is timeout" 
            exit 3 
        }
    }
}

if { [llength $argv] == 2} { 
    if {[regexp -nocase "obmc-phosphor-image" $Local_File]} {
        spawn scp $Local_File root@$IP:/tmp/images
        myscpfunc $STRING
        spawn scp /home_a/y/bak/bmc_upgrade root@$IP:~/
        myscpfunc $STRING
    } else {
        spawn scp $Local_File /home_a/y/bak/bmc_upgrade root@$IP:~/
        myscpfunc $STRING
    }
}

if { [llength $argv] == 3} { 
    set path [lindex $argv 2]
    spawn scp $Local_File  root@$IP:$path
    myscpfunc $STRING
} 

在这里插入图片描述

5.bmc_upgrade:断电重启才从主启,当前永远mtd4

if [ $# -lt 1 ];then
   echo "Usage: `basename $0`+<1;2;all>"
   echo "1   : flash0"
   echo "2   : flash0ro"
   echo "all : flash0 & flash0ro"
   echo "ocp : update ocpbmc image"
   exit 255
fi
cat /proc/mtd |grep -i "flash0\""
cat /proc/mtd |grep -i "flash0ro"

F0_string=$(cat /proc/mtd |grep -i flash0\" |cut -b 1-4)
F1_string=$(cat /proc/mtd |grep -i flash0ro |cut -b 1-4)
if [ "$F1_string" = "" ]; then
    F1_string=$(cat /proc/mtd |grep -i flash1 |cut -b 1-4)
fi

if [ $1 == "1" ]; then
    source /usr/local/bin/openbmc-utils.sh
    echo "Update /dev/$F0_string"
    flashcp  ./flash-* /dev/$F0_string
elif [ $1 == "2" ]; then
    source /usr/local/bin/openbmc-utils.sh
    echo "Update /dev/$F1_string"
    flashcp ./flash-* /dev/$F1_string
elif [ $1 == "all" ]; then
    source /usr/local/bin/openbmc-utils.sh
    echo "Update /dev/$F0_string & /dev/$F1_string"
    echo "First  : Update /dev/$F0_string"
    flashcp ./flash-* /dev/$F0_string
    echo "Second : Update /dev/$F1_string"
    flashcp ./flash-* /dev/$F1_string
elif [ $1 == "ocp" ]; then
    Image_ID=$(ls /tmp/images/)
    if [ ${#Image_ID} -eq 8 ];then
      echo "IMAGE ID = ${Image_ID}"
    else
      echo "IMAGE ID = ${Image_ID}"
      echo "Error-----multiple image"
      exit 255
    fi
    echo "busctl set-property xyz.openbmc_project.Software.BMC.Updater /xyz/openbmc_project/software/$Image_ID xyz.openbmc_project.Software.Activation RequestedActivation s xyz.openbmc_project.Software.Activation.RequestedActivations.Active"
    busctl set-property xyz.openbmc_project.Software.BMC.Updater /xyz/openbmc_project/software/$Image_ID xyz.openbmc_project.Software.Activation RequestedActivation s xyz.openbmc_project.Software.Activation.RequestedActivations.Active
    sleep 3
    echo "busctl get-property xyz.openbmc_project.Software.BMC.Updater /xyz/openbmc_project/software/$Image_ID xyz.openbmc_project.Software.Activation Activation" 
    busctl get-property xyz.openbmc_project.Software.BMC.Updater /xyz/openbmc_project/software/$Image_ID xyz.openbmc_project.Software.Activation Activation
    sleep 1
fi

if [ $? == "0" ];then
  echo "Update Over"
  echo "reboot now !!!!"
  reboot
else
  echo "Update fail !!!!"
fi

6.自动升级bmc:AC ON物理上电

在这里插入图片描述

#!/bin/sh
#shellcheck disable=SC1091
. /usr/local/bin/openbmc-utils.sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin

BMC_VERSION=/var/log/automatic_upgrade/version/bmc_version #主备版本都和这个比较,而不是主备互相比较
BMC_FW=/var/log/automatic_upgrade/fw/flash-xs9880-8c
BMC_WTD2_COUNT=/var/log/wtd_count
BMC_FW_UPDATE_COUNT=/var/log/bmc_update_count
FW_UPDATE_TIMES=8

check_file_ok() {
    if [ ! -f "$BMC_WTD2_COUNT" ]; then   #这行if是:假如不存在文件
        echo 0 > $BMC_WTD2_COUNT   #创建文件并写0
    fi
    if [ ! -f "$BMC_FW_UPDATE_COUNT" ]; then
        echo 0 > $BMC_FW_UPDATE_COUNT
    fi
    if [ ! -f "$BMC_VERSION" ] || [ ! -f "$BMC_FW" ]; then
        echo "$BMC_VERSION or $BMC_FW file does not exist"
        exit 255
    fi
}

check_fw_update_count() {
    bmc_fw_update_cont=$(cat "$BMC_FW_UPDATE_COUNT")
    if [ "$FW_UPDATE_TIMES" -lt "$bmc_fw_update_cont" ]; then
        logger -p user.err "$0 update bmc times exceeded"
        exit 255
    fi
}

check_wtd2_count() {
    if [ "$wdt2_timeout_count" -eq 0 ]; then
        echo 0 > $BMC_WTD2_COUNT
    fi
}

#11111111111111111111111111111111111111111111111111111111111111111111111111111
update_bmc_fw() {
    if [ "$1" = "current" ]; then
        flashcp $BMC_FW /dev/mtd4
    elif [ "$1" = "other" ]; then
        flashcp $BMC_FW /dev/mtd9
    fi
}

change_bmc_boot() {
    if [ "Master"x = "$bmc_boot"x ]; then 
        bmc_boot_info.sh reset slave
    else
        bmc_boot_info.sh reset master
    fi
}

get_bmc_version() {
    if [ "$1" = "other" ]; then
        bmc_version=$(version_dump --pingpong | awk -F ": " '{print $2}')
    elif [ "$1" = "current" ]; then
        bmc_version=$(version_dump bmc | awk -F ": " '{print $2}')
    fi
    echo "$bmc_version"
}

#1111111111111111111111111111111111111111111111111111111111111111111111111111111
update_bmc_fw_update_count() {
    index=$(cat "$BMC_FW_UPDATE_COUNT")
    index=$((index+1))
    echo $index > $BMC_FW_UPDATE_COUNT
}

update_wdt2_timeout_count() {
    echo "$wdt2_timeout_count" > $BMC_WTD2_COUNT
}

clean_bmc_fw_update_count() {
    echo 0 > $BMC_FW_UPDATE_COUNT
}

#111111111111111111111111111111111111111111111111111111111111111111111111111111
main() {
    check_file_ok
    bmc_boot_info=$(bmc_boot_info.sh)
    bmc_boot=$(echo $bmc_boot_info |awk -F " " '{print $10}')
    wdt2_timeout_count=$(echo $bmc_boot_info |awk -F " " '{print $4}')

    bmc_base_version=$(cat "$BMC_VERSION")
    bmc_wtd2_count=$(cat "$BMC_WTD2_COUNT")

    current_version=$(get_bmc_version current)
    other_version=$(get_bmc_version other)
    check_wtd2_count
    check_fw_update_count

    echo "$current_version" 
    echo "$other_version"
    echo "$bmc_wtd2_count"
    echo "$wdt2_timeout_count"

    if [ "$bmc_wtd2_count"x = "$wdt2_timeout_count"x ]; then   # N(No) WTD没有增加
        if [ "$bmc_base_version"x = "$current_version"x ]; then   # 文件版本和当前版本一致
            if [ "$bmc_base_version"x = "$other_version"x ]; then   # 文件版本和对面版本一致
                echo "all same"
                clean_bmc_fw_update_count
            else    # 文件版本和当前版本一致,但不和对面版本一致 【只有非当前版本一致】
                echo "only other not same"
                update_bmc_fw_update_count
                update_bmc_fw other
            fi
        else  # 文件版本和当前版本不一致
            if [ "$bmc_base_version"x = "$other_version"x ]; then  # 【只有当前BMC版本不一致】
                echo "only current not same"
                change_bmc_boot
            else   # 【两块BMC版本都不一致】
                echo "all not same"
                update_bmc_fw_update_count
                update_bmc_fw other
                change_bmc_boot
            fi
        fi

    else #Y WTD增加了
        update_wdt2_timeout_count
        if [ "$bmc_base_version"x = "$current_version"x ]; then  #【当前BMC版本一致】
            echo "current same"
            update_bmc_fw_update_count
            update_bmc_fw other
        else  # 【当前BMC版本不一致】
            echo "current not same"
            update_bmc_fw_update_count
            update_bmc_fw other
            change_bmc_boot
        fi
    fi
}
main

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

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

相关文章

app逆向篇之安卓模拟器环境搭建

前言 本教程适配:安卓7以上的安卓模拟器(包括雷电9等安卓9的模拟器&#xff09; 准备工具 雷电模拟器面具debug版LSPosed 正式步骤 安装雷电模拟器&#xff0c;这里怎么安装就不需要说了吧安装好雷电模拟器之后应该能够在桌面上看到两个图标&#xff0c;如下&#xff1a; …

分页和mmap

文章目录一、内存分页1、基本概念2、分页机制下&#xff0c;虚拟地址和物理地址是如何映射的&#xff1f;3、快表(TLB)二、mmap基本原理和分类一、内存分页 1、基本概念 CPU并不是直接访问物理内存地址&#xff0c;而是通过虚拟地址空间来间接的访问物理内存地址。 页&#x…

CSS ~ 从入门到入坑。

CSS ~ 从入门到入坑。 文章目录CSS ~ 从入门到入坑。what。css 三种实现方式。选择器。id 选择器 > class 选择器 > 标签选择器。标签选择器。类选择器。id 选择器。层次选择器。后代选择器。子选择器。相邻兄弟选择器。通用选择器。结构伪类选择器。属性选择器。字体风格…

OpenAI ChatGPT模型训练

打开VSCode 新建一个工作目录 使用pip install --upgrade openai 配置环境变量&#xff1a; OPENAI_API_KEY<你的open ai key> windows配置:(需要重启) setx OPENAI_API_KEY "你的open ai key" 准备训练数据集文件&#xff1a; 格式如下&#xff1a; 放到工作目…

NSSROUND#8[Basic]

文章目录一、[NSSRound#8 Basic]MyDoor二、[NSSRound#8 Basic]Upload_gogoggo三、[NSSRound#8 Basic]MyPage四、[NSSRound#8 Basic]ez_node一、[NSSRound#8 Basic]MyDoor <?php error_reporting(0);if (isset($_GET[N_S.S])) {eval($_GET[N_S.S]); }if(!isset($_GET[file])…

如何备考系统集成项目管理工程师?

首先了解考试信息&#xff0c;做好备考计划&#xff0c;准备好备考资料等~现在网上也有很多的视频教程&#xff0c;跟着一起学习&#xff0c;大概一周的时间就能过完。如果时间紧张&#xff0c;可以直接抓重点章节真题的复习。考试重点诺&#xff0c;重点章节标红了的&#xff…

NSACE高级WEB安全专家

目录信息收集基本信息收集域名注册信息收集子域名信息收集IP查询系统鉴定端口扫描搜索引擎信息收集 信息收集包括基本信息收集和搜索引擎收集 基本信息收集 基本信息收集方式如下&#xff1a; 域名注册信息查询&#xff1a;例如www.baidu.com 的注册信息&#xff0c;包含注…

vue3的核心知识点合集

Vue3 中文文档(新) Vue.js - 渐进式 JavaScript 框架 | Vue.js vue3的优点&#xff1a; 首次渲染更快diff 算法更快内存占用更少打包体积更小更好的 Typescript 支持Composition API 组合 API首先理解一下vite 构建工具&#xff1a; vite是一种新型前端构建工具&#xff0c;…

解答vue组件中一级组件可不可以作二级组件这个疑惑

引子 大家请看如下情况&#xff0c;我需要做一个项目&#xff0c;首页上的“产品介绍”部分同样也是导航导向的一部分&#xff1a; 首页中的部分&#xff1a; 导航栏导向的部分&#xff1a; 这里我要表达的是&#xff0c;组件Case在导航栏中属于一级路由&#xff0c;而在首…

解决idea出现的java.lang.OutOfMemoryError: Java heap space的问题

文章目录1. 复现问题2. 分析问题3. 解决问题4. 补充解决java.lang.OutOfMemoryError: PermGen space问题1. 复现问题 今天使用idea开发时&#xff0c;突然报出如下错误&#xff1a; Exception in thread "main" java.lang.OutOfMemoryError: Java heap spaceat org.…

【测试开发】web 自动化测试 --- selenium4

目录1. 什么是自动化为什么要做自动化2. 为什么选择selenium作为我使用的web自动化工具3. 什么是驱动&#xff1f;驱动的工作原理是什么5. 第一个自动化程序演示6. selenium基本语法6.1 定位元素的方法6.2 操作页面元素6.3 等待6.4 信息打印获取当前页面句柄&#xff0c;窗口切…

vue脚手架安装详细

一、vue脚手架安装命令npm i -g vue/cli 或 yarn global add vue/cli安装上面的工具&#xff0c;安装后运行 vue --version &#xff0c;如果看到版本号&#xff0c;说明安装成功或 vue -V工具安装好之后&#xff0c;就可以安装带有webpack配置的vue项目了。创建项目之前&#…

基于java的学生成绩管理系统 完整代码 毕业设计

完整项目代码&#xff1a;https://download.csdn.net/download/qq_38735017/87382417下面是程序界面的详情&#xff1a;分享不易 谢谢&#xff01;主界面首先是开始界面&#xff0c;功能选择窗口&#xff0c;包含 5 个功能按钮清除数据功能清空数据库数据&#xff08;若出现 bu…

问题状态(Conditioning of a problem)

Conditioning of a problem该博客是学习《Numerical Linear Algebra with Applications Using MATLAB》的一些总结&#xff0c;仅供学习使用。 通常即使使用一个稳定的算法来解决一个问题&#xff0c;该问题对数据中小的改变或扰动仍然是敏感的。这些扰动可能来自舍入误差(roun…

Python与Arcgis 获取图像信息

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 这里实现一个很简单的功能,批量的获取图像的相关信息,如影像格式、y分辨率等等,并将这些信息写入到一个csv文件中,同时也会为每个图像生成相应的矩形掩模面。 二、实现代码 在真正执行代码之前,我们首先配置一…

PAT——1111 对称日

央视新闻发了一条微博&#xff0c;指出 2020 年有个罕见的“对称日”&#xff0c;即 2020 年 2 月 2 日&#xff0c;按照 年年年年月月日日 格式组成的字符串 20200202 是完全对称的。 给定任意一个日期&#xff0c;本题就请你写程序判断一下&#xff0c;这是不是一个对称日&a…

DDD 参考工程架构

1 背景 不同团队落地DDD所采取的应用架构风格可能不同&#xff0c;并没有统一的、标准的DDD工程架构。有些团队可能遵循经典的DDD四层架构&#xff0c;或改进的DDD四层架构&#xff0c;有些团队可能综合考虑分层架构、整洁架构、六边形架构等多种架构风格&#xff0c;有些在实…

【JUC并发编程】ArrayBlockingQueue和LinkedBlockingQueue源码2分钟看完

文章目录1、BlockingQueue1&#xff09;接口方法2&#xff09;阻塞队列分类2、ArrayBlockingQueue1&#xff09;构造函数2&#xff09;put()入队3&#xff09;take()出队3、LinkedBlockingQueue1&#xff09;构造函数2&#xff09;put()入队3&#xff09;take()出队1、Blocking…

Android Dalvik虚拟机 对象创建内存分配流程

前言 本篇文章介绍我们在日常开发使用Java时new对象的时&#xff0c;Dalvik在堆上的内存分配是如何分配的。内存又和gc相关&#xff0c;下篇文章会分析Dalvik的gc流程。 Dalvik内存管理 内存碎片问题其实是一个通用的问题&#xff0c;不单止Dalvik虚拟机在Java堆为对象分配内…

Python中的类和对象(7)

1.私有变量 在大多数面向对象的编程语言中&#xff0c;都存在着私有变量&#xff08;private variable&#xff09;的概念&#xff0c;所谓私有变量&#xff0c;就是指通过某种手段&#xff0c;使得对象中的属性或方法无法被外部所访问。 Python 对于私有变量的实现是引入了一…