关于MySQL的Admin Ping Command永利国际网站

Dos命令之前更改的太简单,现在加入判断是否进入fasboot模式和判断Android镜像是否存在;代码已经尽量简化成这样,dos命令功能还是比较不好用的,用了一下午的时间。。。

一、基础概念

编程语言有低级语言和高级语言两类。
高级语言也有编译型和解释型的区分,编译型语言有C,C++,jave;解释型语言有shell,perl,python
shell脚本是一种包含声明或命令,并符合一定格式的文本文件
shell作为一种过程式解释型的编程语言,它的基本组织结构有:

数据存储:变量、数组
表达式
语句:if while case

shell脚本的格式有:

#!SHEBANG    
CONFIGURATION_VARIABLES     
FUNCTION_DEFINITIONS    
MAIN_CODE

shell脚本格式要求首行必须是shebang机制
,shebang也是指明文件调用的解释器类型

#!/bin/bash     
#!/usr/bin/python    
#!/usr/bin/perl      
  • 创建shell脚本

第一步:使用文本编辑器来创建文本文件

第一行必须包括shell 声明序列:#!    
    #!/bin/bash
添加注释
    注释以# 开头

第二步运行脚本:

给予执行权限,通过具体的文件路径指明文件执行。    
直接运行解释器,将脚本作为解释器程序的参数运行。
  • 脚本调试

检测脚本中的语法错误
    bash -n /path/to/some_script
调试分布执行
    bash -x /path/to/some_script
  • 执行脚本

      /root/danran.sh    绝对路径,可以作用于子进程
      .  /danran.sh   相对路径,可以作用于子进程
      bash /root/danran.sh   可以作用于子进
      source /root/danran.sh   不会打开子进程,仅仅作用于当前进程 
    

前言:

最近在线上诊断QPS飙升的过程中深入进行了下Admin Ping
Command的测试。此外,再一些国外文章中最近也读到了一些相关知识,所以写成一篇博文做一下总结。

  1 @echo off
  2 
  3 
  4 
  5 
  6 ::路径注意增加
  7 @set flashpath=Z:DT380LINUXandroidouttargetproductmsm8953_64
  8 @set Dynamic_library_Path=Z:msm8909outtargetproductmsm8909objlibsensors.msm8909.so
  9 @set Sensors_conf=Z:DT380LINUXandroidvendorqcomproprietarysensorsdspsreg_defaultssensor_def_qcomdev.conf
 10 @set boot_image=%flashpath%boot.img
 11 @set mbn_image=%flashpath%emmc_appsboot.mbn
 12 @set userdata_image=%flashpath%userdata.img
 13 @set system_image=%flashpath%system.img
 14 @set persist_image=%flashpath%persist.img
 15 @set ramdisk_image=%flashpath%ramdisk.img
 16 @set recover_image=%flashpath%recovery.img
 17 @set cache_image=%flashpath%cache.img
 18 @set Dynamic_library=%Dynamic_library_Path%
 19 @set Dynamic_library_Board_Path=/system/lib/
 20 
 21 ::初始化,下面便是判断是否有文件
 22 @set Image_Index=0
 23 @set Image_Current-path=0
 24 @set Image_Length=7
 25 @set Image[0]-path=%boot_image%
 26 @set Image[1]-path=%mbn_image%
 27 @set Image[2]-path=%system_image%
 28 @set Image[3]-path=%persist_image%
 29 @set Image[4]-path=%ramdisk_image%
 30 @set Image[5]-path=%recover_image%
 31 @set Image[6]-path=%cache_image%
 32 @set Image[7]-path=%Dynamic_library%
 33 ::初始化
 34 
 35 :LoopStart
 36 
 37 ::清空字符串
 38 @set Image_Current-path=0
 39 
 40 if %Image_Index% equ %Image_Length% goto BeginRun
 41 
 42 for /f "usebackq tokens=1,2,3 delims==-" %%a in (`set Image[%Image_Index%]`) do (
 43     set Image_Current-%%b=%%c
 44 )
 45 
 46 if exist %Image_Current-path% (
 47     @echo 该路径%Image_Current-path%存在......
 48     @echo.
 49 ) else (
 50     @echo %Image_Current-path%
 51     @echo 请确定该文件文件是否存在?如果不存在,请确定路径,打开脚本重新设置。10秒后关闭....
 52     @ping -n 10 127.0.0.1>nul
 53     exit
 54 )
 55 
 56 @set /a Image_Index=%Image_Index%+1
 57 
 58 goto LoopStart
 59 
 60 :BeginRun
 61 @echo 检查Android镜像文件已经完成,请继续下一步......
 62 @echo.
 63 
 64 @echo 0、同时烧录emmc_appsboot.mbn和boot.img
 65 @echo 1、烧录boot.img
 66 @echo 2、烧录aboot.img
 67 @echo 3、烧录persist.img
 68 @echo 4、烧录ramdisk.img
 69 @echo 5、烧录recovery.img
 70 @echo 6、烧录system.img
 71 @echo 7、烧录cache.img
 72 @echo 8、烧录所有镜像
 73 @echo 9、重新推进sensor.so
 74 ::@echo 10、烧录并更新adsp架构下的sensor文件
 75 
 76 @set /p option=请先设置路径后,再输入要烧录的选项:
 77 
 78 
 79 if "%option%" == "9" (
 80 adb root
 81 adb wait-for-device
 82 adb remount
 83 @echo 重新推进sensor........
 84 adb push %Dynamic_library% %Dynamic_library_Board_Path%
 85 adb reboot
 86 @echo 正在重启...... 5秒后关闭....
 87 @ping -n 5 127.0.0.1>nul
 88 
 89 exit
 90 )
 91 
 92 
 93 ::判断是否进入fastboot模式
 94 fastboot devices>1.txt
 95 set /p message=<1.txt
 96 del 1.txt
 97 if not defined message (
 98     echo 正处于adb mode模式.....
 99     adb wait-for-device
100     adb reboot-bootloader
101 ) else ( 
102     echo 正处于fastboot mode模式.....
103 )
104 
105 
106 @echo.
107 
108 if "%option%" == "0" (
109 @echo 同时烧录emmc_appsboot.mbn和boot.img........
110 fastboot flash boot %boot_image%
111 fastboot flash aboot %mbn_image%
112 )
113 
114 if "%option%" == "1" (
115 @echo 烧录boot.img........
116 fastboot flash boot %boot_image%
117 )
118 
119 if "%option%" == "2" (
120 @echo 烧录aboot.img........
121 fastboot flash aboot %mbn_image%
122 )
123 
124 if "%option%" == "3" (
125 @echo 烧录persist.img..........
126 fastboot flash persist %persist_image%
127 )
128 
129 if "%option%" == "4" (
130 @echo 烧录ramdisk.img..........
131 fastboot flash ramdisk %ramdisk_image%
132 )
133 
134 if "%option%" == "5" (
135 @echo 烧录recovery.img...........
136 fastboot flash recovery %recover_image%
137 )
138 
139 if "%option%" == "6" (
140 @echo 烧录system.img........
141 fastboot flash system %system_image%
142 )
143 
144 if "%option%" == "7" (
145 @echo 烧录cache.img...........
146 fastboot flash cache %cache_image%
147 )
148 
149 if "%option%" == "8" (
150 @echo 烧录所有镜像.............
151 fastboot flash boot %boot_image%
152 fastboot flash aboot %mbn_image%
153 fastboot flash persist %persist_image%
154 fastboot flash ramdisk %ramdisk_image%
155 fastboot flash recovery %recover_image%
156 fastboot flash system %system_image%
157 fastboot flash cache %cache_image%
158 fastboot flash userdata %userdata_image%
159 )
160 
161 
162 
163 
164 fastboot reboot
165 @echo 正在重启 请稍后......
166 adb wait-for-device
167 adb root
168 adb wait-for-device
169 
170 
171 @ping -n 5 127.0.0.1>nul
172 adb shell dmesg > kmesg.log
173 @echo kernel log已经导出.....
174 
175 
176 
177 @echo [烧录成功,暂停5秒自动关闭]
178 @ping -n 5 127.0.0.1>nul

二、变量: 命名的存储空间

数据的存储方式有:

字符:   
数值:整型,浮点型 

变量类型:
作用:

1、定义数据存储格式
2、定义参与的运算    
3、表示的数据范围

类型:

字符    
数值:整型,浮点数

编程语言的变量又有强类型和弱类型的区分

强类型:jave,C++
    变量不经过强制转换,它永远是这个数据类型,不允许隐式的类型转换,故需要定义数据类型
弱类型:bash
   变量会有隐式转换,故不需要指定数据类型,所有要存储的数据都当做字符进行,不支持浮点数

 

 

逻辑运算

与: 
    1 && 1 = 1    
    1 && 0 = 0   
    0 && 1 = 0
    0 && 0 = 0
或: 
    1 || 1 = 1
    1 || 0 = 1
    0 || 1 = 1
    0 || 0 = 0
非:
    !1 = 0
    !0 = 1
异或:相同为假,不同为真 
短路运算:
    短路与:
        第一个为0,结果必为0   
        第一个为1,第二个必须要参与运算
    短路或:
        第一个为1,结果必为1
        第一个为0,第二个必须参与运算

永利国际网站 1

1. 关于Admin Ping Command?

由于查阅官方文档中没有关于Admin Ping
Command的描述和介绍。因此,Google了很多页面,把大家的阐述做一个个人理解总结如下:

什么是Admin Ping Command(后文简称ping命令)? 

ping命令实际上是提供了一种轻度消耗命令接口,这种接口用于去判断一个持久连接是否存活,或者远端MySQL是否存活。

当远端MySQL
Server接收到这种特殊形式的命令后,不做更多的语法解析和执行计划优化,直接返回结果。

Admin Ping Command有什么用?

在运用链接池方法连接MySQL的时候,这个命令就显得非常有用。因为链接池再把一个空闲链接句柄给到客户端的时候并不知道这个链接是否仍然存活(即没有超时或者被Server
主动kill)。链接池需要用一个命令去判断并触发重连。而这时Ping
Command无疑是代价最小的。如果有同学自己用java代码去实现MySQL链接池的话,链接存活判断使用Admin
Ping Command是最佳选择。

怎么调用Admin Ping Command?

每个MySQL client/connector 实现Ping
Command的方式都不一样。Java的使用方法见:

Perl的使用方法简单的说就是 $dbh->ping();
详见:

 

 

三、bash中的变量的种类

根据变量的生效范围为标准:

本地变量:生效范围为当前shell进程,对当前shell之外的其他的shell进程无效,包括当前shell的子shell进程均无效;    
环境变量:生效范围为当前shell进程及其子进程;    
局部变量:生效范围为当前shell进程中某代码片段(通常指函数);  
位置变量:$1,$2,...来表示,用于让脚本在脚本代码中调用通过命令行传递给它的参数;    
特殊变量:$?,$0,$*,$@,$#,$$    

本地变量:

变量赋值:name=“value”
    可以使用单引号:
        value:
            (1)可以是直接赋值:name=“filename”
            (2)变量引用:name=“$username”
            (3)命令引用:name=`COMMAND`,name=$(COMMAND)
变量引用:$(name),$name
    "":弱引用,其中的变量引用会被替换为变量值;
    '':强引用,其中的变量引用不会被替换为变量值,而保持原字符串;
显示已定义的所有变量:
    set
撤销变量:
    unset name

环境变量:

变量声明、赋值
    export name=VALUE
    declare -x name=VALUE
变量引用:$name,$(name)
显示所有环境变量:
    export
    env
    printenv
    declear -x
撤销变量:
    unset name
bash中有很多内置的环境变量,PATH,SHELL,UID,HISTSIZE,PWD,OLD,HISTFILE,PS1,_
_:上一个命令的最后一个字符串

永利国际网站 2

  • 变量命名法则:

    1、不能使用程序中的保留字,如if、for
    2、只能使用数字、字母及下划线,且不能以数字开头
    3、最好见名知义

只读变量:

设置只读变量:
    readonly name
    declare -r name 
查看只读变量:
    readonly -p 

位置变量:

在脚本代码中调用通过命令行传递给脚本的参数:
    $1,$2,....:对应调用第1,第2....个参数,$10以上的应使用括号${10} ,${12}  
        shift [n] 调换位置,n不能大于参数的个数
    $0:调用命名本身
    $*:传递给脚本的所有参数,将所有参数作为一个整体字符传递
    $@:传递给脚本的所有参数,每一个参数独立传递,与$*只有在使用“”引起来时才有区别
    $#:传递给脚本的参数个数   
    set --:清空所有位置变量参数

特殊变量:$?,$0,$*,$@,$#,$$
    $?:返回状态码
    $$:返回当前进程的进程编号

永利国际网站 3

永利国际网站 4

image

永利国际网站 5

永利国际网站 6

永利国际网站 7

2. Admin Ping Command的性能优势测试

看了上面的介绍,大家一定有很多疑问。例如,用ping比用select
1到底快多少?如何在Server端监控?下文将通过实际测试一一分析。

如何在MySQL Server端观察到Admin Ping Command?

实际上MySQL有一个专门的计数器来统计ping命令。通过show global status like
‘Com_admin_commands’ 即可看到从Server启动后累计接收到的ping命令次数

Admin Ping Command的性能优势有多大?

下面通过一个简单的perl测试脚本,来观察常用的 select 1 和
ping命令之间的性能差距。脚本分别重复执行十万次ping和select
1,通过time比较两者之间的总执行时间的差距。脚本如下:

use strict;
use warnings;
use utf8;
use DBI;
use IO::Socket;
use FileHandle;


my $CONFIG_SERVER_IP  ='192.168.26.167';
my $CONFIG_SERVER_DB='test';
my $CONFIG_SERVER_PORT='3310';
my $CONFIG_SERVER_USER='root';
my $CONFIG_SERVER_PASS='password';
my $dbh = DBI->connect("DBI:mysql:$CONFIG_SERVER_DB;host=$CONFIG_SERVER_IP;port=$CONFIG_SERVER_PORT", $CONFIG_SERVER_USER, $CONFIG_SERVER_PASS,{RaiseError => 1}) || die "Could not connect to database: $DBI::errstr";


for(my $i=0;$i<100000;$i++){
    #my $result=$dbh->do('/* ping */select 1');
    my $result=$dbh->ping;
}

执行结果:

select 1:

real    0m5.968s
user    0m1.235s
sys    0m1.175s

real    0m6.003s
user    0m1.195s
sys    0m1.236s

real    0m6.155s
user    0m1.225s
sys    0m1.237s

Admin Ping:

real    0m3.426s
user    0m0.604s
sys    0m1.115s

real    0m3.483s
user    0m0.681s
sys    0m1.081s

real    0m3.467s
user    0m0.614s
sys    0m1.136s

取平均值后,

SELECT 1十万次执行时间: 6.03 秒

Admin PING十万次执行时间:3.45秒

可见后者性能整整高出 74%
,对于链接池这种对响应时间要求极高的实现来说,资源的节省相当可观。

 

参考资料:

 

 

 

 

 

 

 

 

四、bash的配置文件

按生效范围划分:存在两类
    全局配置:
        /etc/profile
            /etc/profile.d/*.sh
        /etc/bashrc    
    个人配置:
        ~/.bash_profile
        ~/.bashrc
按功能划分:存在两类
    profile类:为交互式登录的shell提供配置
        全局:/etc/profile,/etc/profile.d/*.sh
        个人:~/.bash_profile
        功用:
            (1)用于定义环境变量
            (2)运行命令和脚本

    bashrc类:为非交互式登录的shell提供配置
        全局:/etc/bashrc
        个人:~/.bashrc
        功用:
            (1)定义命令别名
            (2)定义本地变量
    修改文件后生效:
       1、重启shell进程
       2、source ~/.bashrc
          . ~/.bashrc  
bash退出任务
    保存在~/.bash_logout 文件中(用户)
    在退出登录shell 时运行
    用于
        创建自动备份
        清除临时文件

shell登录:
    交互式登录:
        直接通过终端输入账号密码;
        使用“su -UserName”或“su -l UserName”切换的用户
        读取文件的顺序:
            /etc/profile --> /etc/profile.d/*.sh --> ~/.bash_profile --> ~/.bashrc --> /etc/bashrc
    非交互式登录:
        su UserName
        图形界面下打开终端
        执行脚本
        文件读取顺序:
            ~/.bashrc --> /etc/bashrc --> /etc/profile.d/*.sh 
编辑配置文件定义的新配置的生效方式:
    (1)重新启动shell进程
    (2)使用source或.命令进程   

其中用到的相应内容有dos命令for循环的使用:

五、bash中进行算数运算

+,-,*,/,%,...
实现算数运算:
    (1)let var=算数表达式
        sum1=3;sum2=4;let sum=$sum1+sum2
    (2)var=$(算术表达式)
    (3)var=$((算术表达式))
    (4)var=$(expr arg1 arg2 arg3...) expr命令,参数之间用空格隔开 
        sum=$(expr $num1 * $num2)
            *在某些场景下需要转义
    (5)declare -i var = 数值
    (6)echo '算术表达式' | bc

bash有内置的随机数生成器:$RANDOM
    echo $[$RANDOM%60]  对60取模,即生成0-59之间的某个数
    echo $[$RANDOM%60+1]   取1-60之间的某数

永利国际网站 8

增强型赋值:
    +=,-=,*=,/=,%=
    count+=1  <==> count=count+1
自增,自减:
    let var+=1 <==> let var++
    let var-=1 <==> let var--

永利国际网站 9

练习:  

1、编写脚本sumid.sh,计算/etc/passwd文件中的第10个用户和第20个用户的id之和
    #! /bin/bash
    user10="`head -n $2 $1 | tail -n 1|cut -d: -f3`"
    user20="`head -n $3 $1 | tail -n 1|cut -d: -f3`"
    let sum=$user10+$user20
    echo "user id sum is $sum"

永利国际网站 10

2、编写脚本/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和  

    #!/bin/bash
    spaceline1=`grep "^[[:space:]]*$" $1 | wc -l`
    spaceline2=`grep "^[[:space:]]*$" $2 | wc -l`
    echo "The sum of space line:$[spaceline1+spaceline2]"

永利国际网站 11

3、生成脚本模板
    #!/bin/bash
    [ $# -gt 1 ] &&{ echo "the args is error";exit;}
    [ $# == 0 ] && read -s -p "please input script name: " name || name="$1"
    echo "#!/bin/bash
    # filename "$name"
    # author:danran 
    # time is `date +%F`" >"$name"
    chmod +x "$name"
    vim "$name"

4、编写脚本,统计/etc、/usr、/var目录中有多少个一级子目录和文件
    #!/bin/bash
    # danran
    # time is Mon Jun  5 13:09:12 CST 2017
    line1=`ls $1 | wc -l`
    line2=`ls $2 | wc -l`
    line3=`ls $3 | wc -l`
    let sum=$line1+$line2+$line3
    echo $sum

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website