精华内容
下载资源
问答
  • <p>I'm creating a web, where I want one part of it to look something like this: Some text, followed by an audio tag with path to the audio file and then an underline(not an underline to text, but ...
  • 如何制作一个linux 里好用的截屏脚本? 1 前期准备:xwininfo命令 xwininfo命令的功能是显示选中窗口的大小和坐标信息,如下所示,这里的关键信息便是我们选中窗口的坐标和宽度; user@user☆ :~$ xwininfo ...

    如何制作一个linux 里好用的截屏脚本?

    1 前期准备:xwininfo命令

    xwininfo命令的功能是显示选中窗口的大小和坐标信息,如下所示,这里的关键信息便是我们选中窗口的坐标和宽度;

    user@user☆ :~$ xwininfo 
    
    xwininfo: Please select the window about which you
              would like information by clicking the
              mouse in that window.
    
    xwininfo: Window id: 0x520000a "user@user: ~"
    
      Absolute upper-left X:  111
      Absolute upper-left Y:  297
      Relative upper-left X:  0
      Relative upper-left Y:  0
      Width: 732
      Height: 699
      Depth: 32
      Visual: 0x165
      Visual Class: TrueColor
      Border width: 0
      Class: InputOutput
      Colormap: 0x5200009 (not installed)
      Bit Gravity State: NorthWestGravity
      Window Gravity State: NorthWestGravity
      Backing Store State: NotUseful
      Save Under State: no
      Map State: IsViewable
      Override Redirect State: no
      Corners:  +111+297  -837+297  -837-54  +111-54
      -geometry 80x41+101-44
    
    

    2 前期准备:byzanz工具

    在这里插入图片描述

    byzanz是一个轻量级的截屏工具,可以用来生成清晰的gif动态效果图!

    我们记录几个重要的参数信息:

      -d, --duration=SECS     动画的时间 (默认:10 秒)
      -e, --exec=COMMAND      Command to execute and time
      --delay=SECS            开始之前的延时(默认:1 秒)
      -c, --cursor            录制鼠标光标
      -a, --audio             录音
      -x, --x=像素            要录制矩形的 X 坐标
      -y, --y=像素            要录制矩形的 Y 坐标
      -w, --width=像素        录制矩形的宽度
      -h, --height=像素       录制矩形的高度
      -v, --verbose           详细
      --display=显示          要使用的 X 显示
    

    3 制作脚本思路

    由上面讲解可知byzanz是一个非常不错的制作截屏的工具,但是有一个弊病,所有的截屏参数需要手动输入,否则使用的截屏就是全局截屏。为了让截屏更好用就必须搭配xwininfo,且要让xwininfo的数据能通过脚本自动传递给byzanz。

    所以思路很清晰,写一个脚本整合xwininfo和byzanz,让我们选择录屏的功能通过一个无参的窗口简单的完成!

    这里思路很简单,使用awk,通过字符串分割的方式,直接拿到x、y坐标、宽、高的字符串!

    var=$(xwininfo | awk -F ":" '/Absolute upper-left X/ || /Absolute upper-left Y/ ||  /Width/ || /Height/{print $2}')  
    

    拿到坐标和宽高后,剩下的工作就是把他们参数化,传递给byzanz-record,这里使用read命令,通过管道重定向结果到四个变量:

    read x y w h < <(echo $var)
    

    这里read有个值得注意的点,传入的参数采用的重定向符号如下:< <(echo $var);正常的百度你肯能都搜索不到这种小于号+下括号,本人也是根据shell脚本插件写出来的!

    个人认为可以将命令解释如下:

    • <(echo $var)表示将(echo $var)这个命令的输出作为重定向输入信号;
    • < 将随后输入信号再次重定向至read;

    4 制作脚本展示

    如图所示为本人编写的制作脚本,其中支持5、 10、20s的录制时间,并将只做好的gif存入本地Pictures目录:

    produce_gif()
    {
    var=$(xwininfo | awk -F ":" '/Absolute upper-left X/ || /Absolute upper-left Y/ ||
        /Width/ || /Height/{print $2}')
    echo "$var"
    set -e
    read -t 5 -p "do you want to screen shot the window and get a gif ?" ans1
    if [[ $ans1 == "yes" ]];then
        read x y w h < <(echo $var)
        byzanz-record -d $1 -x $x -y $y -w $w -h $h /home/user/Pictures/byzanz-user.gif
    fi
    set +e
    }
    
    
    usage()
    {
        cat <<EOF
        xwin-gif [options]
        [options]
            -d remove tem cache of byzanz
            -1 5s gif 
            -2 10s gif
    EOF
    
    }
    
    [ -z "$1" ] && usage && exit -1
    while getopts "12d" opt
    do
        case $opt in
            d)echo "delete byzanz cache:"
              ls -l /tmp/*byzanz*  
                ;;
            1)echo "start 5s gif!"
              produce_gif 5
            ;;
            2)echo "start 10s gif!"
              produce_gif 10
                ;;
             ?)echo "start default:20s gif!"
                 produce_gif 20
            ;;
        esac
    done
    

    5 小结

    制作一个好用的gif录屏工具脚本,实际上还是一个通过shell将xwininfo、byzanz以及awk和read结合使用的过程,通过awk识别窗口参数,read读取参数,最终完成了零输入和配置的gif制作脚本!

    这里值得学习一下的是read x y w h < <(echo $var)语句,我相信以后还有许多地方要用到它,特此记录!

    6 扩展:输入重定向

    Bash 支持的输出重定向符号总结如下

    符号 说明
    command <file 将 file 文件中的内容作为 command 的输入。
    command <<END 从标准输入(键盘)中读取数据,直到遇见分界符 END 才停止(分界符可以是任意的字符串,用户自己定义)。
    command file2 将 file1 作为 command 的输入,并将 command 的处理结果输出到 file2。

    下面我们简单用一下用法:

    fwd@fwd☆ :~/bin$ cat ding
    a
     b
     c
    
    fwd@fwd☆ :~/bin$ wc -l <ding
    4
    fwd@fwd☆ :~/bin$ wc -l <<end
    > d
    > s
    > end
    2
    fwd@fwd☆ :~/bin$ wc -l <ding >ding1
    fwd@fwd☆ :~/bin$ cat ding1
    4
    

    最后也不要忘记了新近学习的一种:

    fwd@fwd☆ :~/bin$ wc -l < <(cat ding)
    4
    
    

    最后的最后

    ps:如果你有关于< <()更好的解释,不吝赐教,谢谢了!

    展开全文
  • HowTo如何制作一个文字冒险游戏-里篇(2)逐条解析脚本文件-附件资源
  • (当然用外挂不是那么道义哈,呵呵),那我们就来看一下如何用python来制作一个外挂。。。。 我打开了4399小游戏网,点开了一个不知名的游戏,唔,做寿司的,有材料在一边,客人过来后说出他们的要求,你按照菜单...

    玩过电脑游戏的同学对于外挂肯定不陌生,但是你在用外挂的时候有没有想过如何做一个外挂呢?(当然用外挂不是那么道义哈,呵呵),那我们就来看一下如何用python来制作一个外挂。。。。

    我打开了4399小游戏网,点开了一个不知名的游戏,唔,做寿司的,有材料在一边,客人过来后说出他们的要求,你按照菜单做好端给他便好~ 为啥这么有难度?8种菜单记不清,点点就点错,鼠标还不好使肌肉劳损啥的伤不起啊……

    首先要声明,这里的游戏外挂的概念,和那些大型网游里的外挂可不同,不能自动打怪,不能喝药不能躲避GM…… 那做这个外挂有啥用?问的好,没用,除了可以浪费你一点时间,提高一下编程技术,增加一点点点点点点的做外挂的基础以外,毫无用处,如果您是以制作一个惊天地泣鬼神不开则已一开立刻超神的外挂为目标过来的话,恐怕要让您失望了,请及早绕道。我的目的很简单,就是自动玩这款小游戏而已。

    入门Python其实很容易,但是我们要去坚持学习,每一天坚持很困难,我相信很多人学了一个星期就放弃了,为什么呢?其实没有好的学习资料给你去学习,你们是很难坚持的,在学习Python的过程中有什么不懂得可以加我,从零基础开始到Python各领域的项目实战教程、开发工具与电子书籍,都有整理。与你分享企业当下对于python人才需求及学好python的高效技巧,每晚趣味讲解Python实战操作。V新:itz992 希望对你们有帮助

    工具的准备

    这篇文章需要您有Python基础,我不会讲解Python语法啥的~

    Python

    需要安装autopy和PIL以及pywin32包。

    autopy是一个自动化操作的python库,可以模拟一些鼠标、键盘事件,还能对屏幕进行访问,本来我想用win32api来模拟输入事件的,发现这个用起来比较简单,最厉害的是它是跨平台的,请搜索安装;而PIL那是大名鼎鼎了,Python图像处理的No.1,下面会说明用它来做什么;pywin32其实不是必须的,但是为了方便(鼠标它在自己动着呢,如何结束它呢),还是建议安装一下,哦对了,我是在win平台上做的,外挂大概只有windows用户需要吧?

    截屏和图像处理工具

    截屏是获取游戏图像以供分析游戏提示,其实没有专门的工具直接Print Screen粘贴到图像处理工具里也可以。我用的是PicPick,相当好用,而且个人用户是免费的;而图像处理则是为了获取各种信息的,我们要用它得到点菜图像后保存起来,供外挂分析判断。我用的是PhotoShop… 不要告诉Adobe,其实PicPick中自带的图像编辑器也足够了,只要能查看图像坐标和剪贴图片就好饿了,只不过我习惯PS了~

    编辑器

    这个我就不用说了吧,写代码得要个编辑器啊!俺用VIM,您若愿意用写字板也可以……

    原理分析

    外挂的历史啥的我不想说啦,有兴趣请谷歌或度娘(注:非技术问题尽可以百度)。

    看这个游戏,有8种菜,每种菜都有固定的做法,顾客一旦坐下来,头顶上就会有一个图片,看图片就知道他想要点什么菜,点击左边原料区域,然后点击一下……不知道叫什么,像个竹简一样的东西,菜就做完了,然后把做好的食物拖拽到客户面前就好了。

    顾客头上显示图片的位置是固定的,总共也只有四个位置,我们可以逐一分析,而原料的位置也是固定的,每种菜的做法更是清清楚楚,这样一来我们完全可以判断,程序可以很好的帮我们做出一份一份的佳肴并奉上,于是钱滚滚的来:)

    autopy介绍

    github上有一篇很不错的入门文章,虽然是英文但是很简单,不过我还是摘几个这次用得到的说明一下,以显示我很勤劳。

    移动鼠标

    import autopy
    autopy.mouse.move(100, 100) # 移动鼠标
    autopy.mouse.smooth_move(400, 400) # 平滑移动鼠标(上面那个是瞬间的)
    

    这个命令会让鼠标迅速移动到指定屏幕坐标,你知道什么是屏幕坐标的吧,左上角是(0,0),然后向右向下递增,所以1024×768屏幕的右下角坐标是……你猜对了,是(1023,767)。

    不过有些不幸的,如果你实际用一下这个命令,然后用autopy.mouse.get_pos()获得一下当前坐标,发现它并不在(100,100)上,而是更小一些,比如我的机器上是(97,99),和分辨率有关。这个移动是用户了和windows中mouse_event函数,若不清楚api的,知道这回事就好了,就是这个坐标不是很精确的。像我一样很好奇的,可以去读一下autopy的源码,我发现他计算绝对坐标算法有问题:

    point.x *= 0xFFFF / GetSystemMetrics(SM_CXSCREEN);
    

    这里先做除法再做乘法,学过一点计算方法的就应该知道对于整数运算,应该先乘再除的,否则就会产生比较大的误差,如果他写成:

    point.x = point.x * 0xffff / GetSystemMetrics(SM_CXSCREEN);
    

    就会准多了,虽然理论上会慢一点点,不过我也懒得改代码重新编译了,差几个像素,这里对我们影响不大~咱要吸取教训呀。

    点击鼠标

    import autopy
    autopy.mouse.click() # 单击
    autopy.mouse.toggle(True) # 按下左键
    autopy.mouse.toggle(False) # 松开左键
    

    这个比较简单,不过记得这里的操作都是非常非常快的,有可能游戏还没反应过来呢,你就完成了,于是失败了…… 所以必要的时候,请sleep一小会儿。

    键盘操作

    我们这次没用到键盘,所以我就不说了。

    怎么做?分析顾客头上的图像就可以,来,从获取图像开始吧~

    打开你钟爱的图像编辑器,开始丈量吧~ 我们得知道图像在屏幕的具体位置,可以用标尺量出来,本来直接量也是可以的,但是我这里使用了画面左上角的位置(也就是点1)来当做参考位置,这样一旦画面有变动,我们只需要修改一个点坐标就好了,否则每一个点都需要重新写一遍可不是一件快乐的事情。

    看最左边的顾客头像上面的图像,我们需要两个点才可确定这个范围,分别是图像的左上角和右下角,也就是点2和点3,。后面还有三个顾客的位置,只需要简单的加上一个增量就好了,for循环就是为此而生!

    同样的,我们原料的位置,“竹席”的位置等等,都可以用这种方法获得。注意获得的都是相对游戏画面左上角的相对位置。至于抓图的方法,PIL的ImageGrab就很好用,autopy也可以抓图,为什么不用,我下面就会说到。

    分析图像

    我们这个外挂里相当有难度的一个问题出现了,如何知道我们获得的图像到底是哪一个菜?对人眼……甚至狗眼来说,这都是一个相当easy的问题,“一看就知道”!对的,这就是人比机器高明的地方,我们做起来很简单的事情,电脑却傻傻分不清楚。

    autopy图像局限

    如果你看过autopy的api,会发现它有一个bitmap包,里面有find_bitmap方法,就是在一个大图像里寻找样品小图像的。聪明的你一定可以想到,我们可以截下整个游戏画面,然后准备所有的菜的小图像用这个方法一找就明白哪个菜被叫到了。确实,一开始我也有这样做的冲动,不过立刻就放弃了……这个方法查找图像,速度先不说,它有个条件是“精确匹配”,图像上有一个像素的RGB值差了1,它就查不出来了。我们知道flash是矢量绘图,它把一个点阵图片显示在屏幕上是经过了缩放的,这里变数就很大,理论上相同的输入相同的算法得出的结果肯定是一致的,但是因为绘图背景等的关系,总会有一点点的差距,就是这点差距使得这个美妙的函数不可使用了……

    好吧,不能用也是好事,否则我怎么引出我们高明的图像分析算法呢?

    相似图像查找原理

    相信你一定用过Google的“按图搜图”功能,如果没有,你就落伍啦,快去试试!当你输入一张图片时,它会把与这张图相似的图像都给你呈现出来,所以当你找到一张中意的图想做壁纸又觉得太小的时候,基本可以用这个方法找到合适的~

    我们就要利用和这个相似的原理来判断用户的点餐,当然我们的算法不可能和Google那般复杂,知乎上有一篇很不错的文章描述了这个问题,有兴趣的可以看看,我直接给出实现:

     def get_hash(self, img):
     image = img.resize((18, 13), Image.ANTIALIAS).convert("L")
     pixels = list(image.getdata())
     avg = sum(pixels) / len(pixels)
     return "".join(map(lambda p : "1" if p > avg else "0", pixels))
    

    因为这是类的一个方法,所以有个self参数,无视它。这里的img应该传入一个Image对象,可以使读入图像文件后的结果,也可以是截屏后的结果。而缩放的尺寸(18,13)是我根据实际情况定的,因为顾客头像上的菜的图像基本就是这个比例。事实证明这个比例还是挺重要的,因为我们的菜有点儿相似,如果比例不合适压缩后就失真了,容易误判(我之前就吃亏了)。

    得到一个图片的“指纹”后,我们就可以与标准的图片指纹比较,怎么比较呢,应该使用“汉明距离”,也就是两个字符串对应位置的不同字符的个数。实现也很简单……

     def hamming_dist(self, hash1, hash2):
     return sum(itertools.imap(operator.ne, hash1, hash2))
    

    好了,我们可以用准备好的标准图像,然后预先读取计算特征码存储起来,然后再截图与它们比较就好了,距离最小的那个就是对应的菜,代码如下:

     def order(self, i):
     l, t = self.left + i * self.step, self.top
     r, b = l + self.width, t + self.height
     hash2 = self.get_hash(ImageGrab.grab((l, t, r, b)))
     (mi, dist) = None, 50
     for i, hash1 in enumerate(self.maps):
     if hash1 is None:
     continue
     this_dist = self.hamming_dist(hash1, hash2)
     if this_dist < dist:
     mi = i
     dist = this_dist
     return mi
    

    这里有一个50的初始距离,如果截取图像与任何菜单相比都大于50,说明什么?说明现在那个位置的图像不是菜,也就是说顾客还没坐那位置上呢,或者我们把游戏最小化了(老板来了),这样处理很重要,免得它随意找一个最相近但又完全不搭边的菜进行处理。

    自动做菜

    这个问题很简单,我们只需要把菜单的原料记录在案,然后点击相应位置便可,我把它写成了一个类来调用:

    class Menu:
     def __init__(self):
     self.stuff_pos = []
     self.recipes = [None] * 8
     self.init_stuff()
     self.init_recipe()
     def init_stuff(self):
     for i in range(9):
     self.stuff_pos.append( (L + 102 + (i % 3) * 42, T + 303 + (i / 3) * 42) )
     def init_recipe(self):
     self.recipes[0] = (1, 2)
     self.recipes[1] = (0, 1, 2)
     self.recipes[2] = (5, 1, 2)
     self.recipes[3] = (3, 0, 1, 2)
     self.recipes[4] = (4, 1, 2)
     self.recipes[5] = (7, 1, 2)
     self.recipes[6] = (6, 1, 2)
     self.recipes[7] = (8, 1, 2)
     def click(self, i):
     autopy.mouse.move(self.stuff_pos[i][0] + 20, self.stuff_pos[i][1] + 20)
     autopy.mouse.click()
     def make(self, i):
     for x in self.recipes[i]:
     self.click(x)
     autopy.mouse.move(L + 315, T + 363)
     autopy.mouse.click()
    

    这是本外挂中最没技术含量的一个类了:)请原谅我没有写注释和doc,因为都很简单,相信你懂得。

    展开全文
  • ###利用 windows bat 脚本制作一个oracle 性能状态监控工具 ####choice /t 2 /d y /n &gt;nul 表示每隔2秒定时执行 @echo off :start sqlplus -S system/oracle@10.80.18.201/fiona @c:/1.sql choice /t 2 /...

    ###利用 windows bat 脚本制作一个oracle 性能状态监控工具

    ####choice /t 2 /d y /n >nul 表示每隔2秒定时执行

    @echo off

    :start
    sqlplus -S system/oracle@10.80.18.201/fiona @c:/1.sql

    choice /t 2 /d y /n >nul
    cls

    goto start

    ########################################c:/1.sql 文本内容##################

    ###########1.sql 查询数据库的脚本可以根据自己关注的点,自定义#####################

    set line 300 pagesize 20

    col dbro for a11
    col dbts for a8

    SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */ /*+ NO_MONITOR */
     *
      FROM (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             round(sum(value),2) taas
              from gv$sysmetric
             where metric_name = 'Database Time Per Sec'
               and group_id = 3),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             count(*) sess, count(distinct username) duser
              from gv$session
             where type <> 'BACKGROUND'
               and username is not null
               and SCHEMA# != 0),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             to_char(max(end_time), 'hh24:mi:ss') dbts, sum(value) spga
              from gv$sysmetric
             where metric_name = 'Total PGA Allocated'
               and group_id = 3),
           (select (sysdate - startup_time) * 86400 uptm from v$instance),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             SUM(VALUE) scpu, count(distinct inst_id) inst
              from gv$osstat
             where stat_name = 'NUM_CPUS'),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             SUM(VALUE) ssga
              from gv$sga),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             SUM(VALUE) prob
              from GV$DIAG_INFO
             where NAME = 'Active Problem Count'),
           (select sum(fra) reco
              from (select SPACE_USED / GREATEST(SPACE_LIMIT, 1) * 100 fra
                      from V$RECOVERY_FILE_DEST
                    union
                    select 0 fra from dual)),
           (select initcap(substr(sys_context('USERENV', 'DATABASE_ROLE'),
                                  -7,
                                  16)) dbro
              from dual),
           (select sum(ar) dgar
              from (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
                     sofar ar
                      from gv$recovery_progress
                     where type = 'Media Recovery'
                       and ITEM = 'Active Apply Rate'
                       and rownum = 1
                    union
                    select 0 ar from dual)),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             max(VALUE) pgag
              from gv$pgastat
             where name = 'aggregate PGA target parameter');

    SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */ /*+ NO_MONITOR */
    inid,
    round(hcpu,2) hcpu,
    round(sgfr,2) sgfr,
    round(utps,2) utps,
    round(ucps,2) ucps,
    round(saas,2) saas,
    round(mbps,2) mbps,
    round(ssrt,2) ssrt,
    round(iorl,2) iorl,
    round(load,2) load,
    round(upga,2) upga,
    round(aspq,2) aspq,
    round(dbcp,2) dbcp,
    round(dbwa,2) dbwa,
    round(iops,2) iops,
    round(asct,2) asct,
    round(isct,2) isct,
    round(cpas,2) cpas,
    round(ioas,2) ioas,
    round(waas,2) waas,
    round(dcpu,2) dcpu,
    round(ncpu,2) ncpu,
    round(logr,2) logr,
    round(phyr,2) phyr,
    round(phyw,2) phyw,
    round(temp,2) temp,
    round(dbtm,2) dbtm
      FROM (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             inst_id inid,
             sum(decode(metric_name, 'CPU Usage Per Sec', value, 0)) dcpu,
             sum(decode(metric_name, 'Host CPU Utilization (%)', value, 0)) hcpu,
             sum(decode(metric_name, 'I/O Megabytes per Second', value, 0)) mbps,
             sum(decode(metric_name, 'SQL Service Response Time', value, 0)) ssrt,
             sum(decode(metric_name,
                        'Average Synchronous Single-Block Read Latency',
                        value,
                        0)) iorl,
             sum(decode(metric_name, 'Current OS Load', value, 0)) load,
             sum(decode(metric_name, 'Active Parallel Sessions', value, 0)) aspq,
             sum(decode(metric_name, 'Database CPU Time Ratio', value, 0)) dbcp,
             sum(decode(metric_name, 'Database Wait Time Ratio', value, 0)) dbwa,
             sum(decode(metric_name, 'I/O Requests per Second', value, 0)) iops
              from gv$sysmetric
             where metric_name in
                   ('CPU Usage Per Sec', 'Host CPU Utilization (%)',
                    'I/O Megabytes per Second', 'SQL Service Response Time',
                    'Average Synchronous Single-Block Read Latency',
                    'Current OS Load', 'Active Parallel Sessions',
                    'Database CPU Time Ratio', 'Database Wait Time Ratio',
                    'I/O Requests per Second')
               and group_id = 2
             group by inst_id),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             inst_id id1,
             sum(decode(metric_name, 'Shared Pool Free %', value, 0)) sgfr,
             sum(decode(metric_name, 'User Transaction Per Sec', value, 0)) utps,
             sum(decode(metric_name, 'User Calls Per Sec', value, 0)) ucps,
             sum(decode(metric_name, 'Average Active Sessions', value, 0)) saas,
             sum(decode(metric_name, 'Total PGA Allocated', value, 0)) upga,
             sum(decode(metric_name, 'Logical Reads Per Sec', value, 0)) logr,
             sum(decode(metric_name, 'Physical Reads Per Sec', value, 0)) phyr,
             sum(decode(metric_name, 'Physical Writes Per Sec', value, 0)) phyw,
             sum(decode(metric_name, 'Temp Space Used', value, 0)) temp,
             sum(decode(metric_name, 'Database Time Per Sec', value, 0)) dbtm
              from gv$sysmetric
             where metric_name in
                   ('Shared Pool Free %', 'User Transaction Per Sec',
                    'User Calls Per Sec', 'Logical Reads Per Sec',
                    'Physical Reads Per Sec', 'Physical Writes Per Sec',
                    'Temp Space Used', 'Database Time Per Sec',
                    'Average Active Sessions', 'Total PGA Allocated')
               and group_id = 3
             group by inst_id),
           (SELECT id2,
                   sum(asct) asct,
                   sum(isct) isct,
                   sum(cpas) cpas,
                   sum(ioas) ioas,
                   sum(waas) waas
              FROM (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
                     inst_id id2,
                     sum(DECODE(status, 'ACTIVE', 1, 0)) asct,
                     count(*) isct,
                     sum(DECODE(status, 'ACTIVE', decode(WAIT_TIME, 0, 0, 1), 0)) cpas,
                     sum(DECODE(status,
                                'ACTIVE',
                                decode(wait_class, 'User I/O', 1, 0),
                                0)) ioas,
                     sum(DECODE(status,
                                'ACTIVE',
                                decode(WAIT_TIME,
                                       0,
                                       decode(wait_class, 'User I/O', 0, 1),
                                       0),
                                0)) waas
                      from gv$session
                     where type <> 'BACKGROUND'
                       and username is not null
                       and SCHEMA# != 0
                     group by inst_id
                    UNION ALL
                    SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
                     inst_id id2, 0 asct, 0 isct, 0 cpas, 0 ioas, 0 waas
                      from gv$instance)
             group by id2),
           (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
             inst_id id3, TO_NUMBER(VALUE) ncpu
              from gv$osstat
             where stat_name = 'NUM_CPUS')
     WHERE id1 = inid
       and id2 = inid
       and id3 = inid
       and ROWNUM <= 5
     ORDER BY dbtm desc;
     
     
     col event for a40
     col wclas for a10
     
    host echo "########TOP event######################################################"
    SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */ /*+ NO_MONITOR */
              event,
              totwa,
              twsec,
              round(avgms,2) as avgms,
              ROUND(RATIO_TO_REPORT(twsec) OVER() * 100) pctwa,
              wclas,
              evtid
               FROM (SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
                      SW.EVENT,
                      SUM(SE.TOTAL_WAITS) totwa,
                      SUM(SE.TIME_WAITED) / 100 twsec,
                      SUM(SE.TIME_WAITED) /
                      (GREATEST(SUM(SE.TOTAL_WAITS), 1) * 10) avgms,
                      SW.WAIT_CLASS wclas,
                      SW.EVENT# evtid
                       FROM GV$SESSION_WAIT_CLASS SE
                       JOIN GV$SESSION SW ON SE.INST_ID = SW.INST_ID
                                         AND SE.SID = SW.SID
                      WHERE SE.wait_class != 'Idle'
                        AND SW.wait_class != 'Idle'
                      GROUP BY SW.EVENT, SW.WAIT_CLASS, SW.EVENT#
                     HAVING SUM(SE.TOTAL_WAITS) > 0
                     UNION
                     SELECT /*+ OPT_PARAM('_optimizer_adaptive_plans','false') */
                      'DB CPU' event,
                      0 totwa,
                      SUM(VALUE) / 100 twsec,
                      0 avgms,
                      NULL wclas,
                      19 evtid
                       FROM GV$SESSTAT se
                       JOIN GV$SESSION s2 ON se.INST_ID = s2.INST_ID
                                         AND se.SID = s2.SID
                      WHERE se.STATISTIC# = 19
                        AND se.value > 0
                        AND s2.wait_class != 'Idle'
                      ORDER BY twsec desc)
              WHERE ROWNUM < 6; 


     exit

     

    展开全文
  • 常见的yum命令更是基于rpm命令之上的,接下来就让我简单介绍一下rpm命令,并用rpm命令简单开发一个刷取访问量的脚本程序。 rpm命令 rpm命令是RPM软件包的管理工具,rpm原本是Red Hat Linux发行版专门用来管理Linux...
  • #include <stdio.h> #include <stdlib.h>//system #include <string.h>//strcmp z int main() ... printf("分钟后开启暴击buff,喊声-大哥我错了-关闭暴击加成\n"); scanf("%s",...

    在学习c语言的过程中,用学习到的知识去写一些恶搞脚本也是比较有意思而且挺有收获的

    这里简单的分享一下自己所学到的简易版关机脚本的代码

    #include <stdio.h>
    #include <stdlib.h>//system函数需要用到的头文件
    #include <string.h>//strcmp函数需要用到的头文件
    
    
    
    int main()
    {
        char input[20] = { 0 };//存储数据
        system("shutdown -s -t 60");//关机指令,意思是60秒后关机,具体时间可以随意设置
    
     
     again:
         printf("喊声-大哥我错了-关闭关机指令\n");
         scanf("%s",input);
         if(strcmp(input,"大哥我错了") == 0)
         {
             system("shutdown -a");//停止关机
         }
         else
         {
             goto again;//重复操作
         }
         return 0;
    }

    效果展示: 

     

     

    展开全文
  • 作为一个文字冒险游戏,自然不能只有一条脚本,这时候,我们一般将写在文本文件中的内容全部加载,然后在逐条执行。 当一个角色说完话时,总要点击什么一下才能进行下一句。而在显示图片,播放声音,设置变量等时候...
  • 在近期的工作中,与合作伙伴搭建了一个POC的演示环境,演示环境得到了客户的肯定,但是客户提出了新的需求,就是要在服务器重启时,所有的...制作启动脚本需要明确两件事情,一是哪些程序需要启动,二是如何制作脚本
  • 请首先从工具文件夹中启动httpdownloader,并将其允许在您的病毒扫描程序中(它被检测为恶意软件,但不是恶意软件),然后将其关闭并运行其中一个脚本。 注意:下载后请关闭httpdownloader 运行其中一个bat文件...
  • 您单击一个表单按钮或单击一个链接,一两分钟后,您的Web浏览器中会弹出一个文件下载对话框,并提示您输入一些说明,例如“打开”或“保存”。 我将向您展示如何使用Perl脚本执行此操作。 你需要什么 任何最新版本...
  • 用java的robot类以及Gui 制作一个游戏(阴阳师)脚本 ** 由于阴阳师这个游戏肝度太大,就决定写一个脚本来模拟玩家的重复性操作.所以我就决定用java中的robot类中的一些方法来模拟鼠标点击,移动等功能,具体方法见下图. ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 1,089
精华内容 435
关键字:

如何制作一个脚本