From 342eec6ac6d5cb6e91b222feca877767ac9fd482 Mon Sep 17 00:00:00 2001 From: Mr Chen Date: Thu, 28 Feb 2019 13:14:58 +0800 Subject: [PATCH] =?UTF-8?q?=E5=88=A0=E9=99=A4=E4=B8=8D=E5=BF=85=E8=A6=81?= =?UTF-8?q?=E6=8F=92=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugins/abkill/ico.png | Bin 181 -> 0 bytes plugins/abkill/index.html | 16 - plugins/abkill/index.py | 172 ----------- plugins/abkill/info.json | 16 - plugins/abkill/init.d/abkill.tpl | 76 ----- plugins/abkill/install.sh | 32 -- plugins/abkill/js/abkill.js | 1 - plugins/abkill/script/abkill.py | 85 ------ plugins/score/ico.png | Bin 832 -> 0 bytes plugins/score/img/ico-score.png | Bin 1296 -> 0 bytes plugins/score/img/ico-ts-cpu-active.png | Bin 1526 -> 0 bytes plugins/score/img/ico-ts-cpu.png | Bin 1336 -> 0 bytes plugins/score/img/ico-ts-disk-active.png | Bin 1400 -> 0 bytes plugins/score/img/ico-ts-disk.png | Bin 1103 -> 0 bytes plugins/score/img/ico-ts-mem-active.png | Bin 874 -> 0 bytes plugins/score/img/ico-ts-mem.png | Bin 683 -> 0 bytes plugins/score/img/ico-ts-refresh.png | Bin 2941 -> 0 bytes plugins/score/img/ico-ts-score.jpg | Bin 3977 -> 0 bytes plugins/score/index.html | 249 ---------------- plugins/score/index.py | 355 ----------------------- plugins/score/info.json | 16 - plugins/score/install.sh | 38 --- plugins/score/js/score.js | 301 ------------------- plugins/score/testcpu.c | 129 -------- 24 files changed, 1486 deletions(-) delete mode 100644 plugins/abkill/ico.png delete mode 100755 plugins/abkill/index.html delete mode 100755 plugins/abkill/index.py delete mode 100755 plugins/abkill/info.json delete mode 100644 plugins/abkill/init.d/abkill.tpl delete mode 100755 plugins/abkill/install.sh delete mode 100755 plugins/abkill/js/abkill.js delete mode 100755 plugins/abkill/script/abkill.py delete mode 100755 plugins/score/ico.png delete mode 100755 plugins/score/img/ico-score.png delete mode 100755 plugins/score/img/ico-ts-cpu-active.png delete mode 100755 plugins/score/img/ico-ts-cpu.png delete mode 100755 plugins/score/img/ico-ts-disk-active.png delete mode 100755 plugins/score/img/ico-ts-disk.png delete mode 100755 plugins/score/img/ico-ts-mem-active.png delete mode 100755 plugins/score/img/ico-ts-mem.png delete mode 100755 plugins/score/img/ico-ts-refresh.png delete mode 100755 plugins/score/img/ico-ts-score.jpg delete mode 100755 plugins/score/index.html delete mode 100755 plugins/score/index.py delete mode 100755 plugins/score/info.json delete mode 100755 plugins/score/install.sh delete mode 100755 plugins/score/js/score.js delete mode 100755 plugins/score/testcpu.c diff --git a/plugins/abkill/ico.png b/plugins/abkill/ico.png deleted file mode 100644 index 65fa8e5f7464648b017edfc51fa53d248880f621..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 181 zcmeAS@N?(olHy`uVBq!ia0vp^5+KaM1|%Pp+x`GjHJ&bxAs*hzDGLk}mTdgVvsg@k zC$UGNsIc&-e}K3gYxTD`j)uh#bR5b#72^-q_-*0e5ZQ2AV8YYIVhxKA96h>}(dGTk z&FntP%?kxxegp}fv{RU(Q+QH%u1{tfqvgQ{fBwLurt3a+&bVV|p`&1K=kTlJ)4>(2 eQ(71t_cC<<%#d{Sp6~?d4hBzGKbLh*2~7ayxk1qY diff --git a/plugins/abkill/index.html b/plugins/abkill/index.html deleted file mode 100755 index 2dda19b1e..000000000 --- a/plugins/abkill/index.html +++ /dev/null @@ -1,16 +0,0 @@ -
-
-
-

服务

-

自启动

-

黑名单

-

异常日志

-
-
-
-
-
-
- \ No newline at end of file diff --git a/plugins/abkill/index.py b/plugins/abkill/index.py deleted file mode 100755 index efc39a388..000000000 --- a/plugins/abkill/index.py +++ /dev/null @@ -1,172 +0,0 @@ -# coding: utf-8 - -import time -import random -import os -import urllib -import binascii -import json -import re -import sys -import subprocess - -sys.path.append(os.getcwd() + "/class/core") -import public - - -app_debug = False -if public.getOs() == 'darwin': - app_debug = True - - -def getPluginName(): - return 'abkill' - - -def getPluginDir(): - return public.getPluginDir() + '/' + getPluginName() - - -def getServerDir(): - return public.getServerDir() + '/' + getPluginName() - - -def getInitDFile(): - if app_debug: - return '/tmp/' + getPluginName() - return '/etc/init.d/' + getPluginName() - - -def getArgs(): - args = sys.argv[2:] - tmp = {} - args_len = len(args) - - if args_len == 1: - t = args[0].strip('{').strip('}') - t = t.split(':') - tmp[t[0]] = t[1] - elif args_len > 1: - for i in range(len(args)): - t = args[i].split(':') - tmp[t[0]] = t[1] - - return tmp - - -def initDreplace(): - initd_file = getInitDFile() - - if not os.path.exists(initd_file): - return getServerDir() - - return initd_file - - -def status(): - data = public.execShell( - "ps -ef|grep " + getPluginName() + " |grep -v grep | grep -v python | awk '{print $2}'") - if data[0] == '': - return 'stop' - return 'start' - - -def csvnOp(method): - - if app_debug: - os_name = public.getOs() - if os_name == 'darwin': - return "Apple Computer does not support" - - _initd_csvn = '/etc/init.d/csvn' - _initd_csvn_httpd = '/etc/init.d/csvn-httpd' - #_csvn = getServerDir() + '/bin/csvn' - #_csvn_httpd = getServerDir() + '/bin/csvn-httpd' - - ret_csvn_httpd = public.execShell(_initd_csvn_httpd + ' ' + method) - # ret_csvn = public.execShell(_initd_csvn + ' ' + method) - subprocess.Popen(_initd_csvn + ' ' + method, - stdout=subprocess.PIPE, shell=True) - if ret_csvn_httpd[1] == '': - return 'ok' - return 'fail' - - -def start(): - return csvnOp('start') - - -def stop(): - return csvnOp('stop') - - -def restart(): - return csvnOp('restart') - - -def reload(): - return csvnOp('reload') - - -def initdStatus(): - if not app_debug: - if public.getOs() == 'darwin': - return "Apple Computer does not support" - - _initd_csvn = '/etc/init.d/csvn' - _initd_csvn_httpd = '/etc/init.d/csvn-httpd' - - if os.path.exists(_initd_csvn) and os.path.exists(_initd_csvn_httpd): - return 'ok' - return 'fail' - - -def initdInstall(): - import shutil - if not app_debug: - if public.getOs() == 'darwin': - return "Apple Computer does not support" - - _csvn = getServerDir() + '/bin/csvn' - _csvn_httpd = getServerDir() + '/bin/csvn-httpd' - - ret_csvn = public.execShell(_csvn + ' install') - ret_csvn_httpd = public.execShell(_csvn_httpd + ' install') - if ret_csvn[1] == '' and ret_csvn_httpd[1] == '': - return 'ok' - return 'fail' - - -def initdUinstall(): - if not app_debug: - if public.getOs() == 'darwin': - return "Apple Computer does not support" - - _csvn = getServerDir() + '/bin/csvn' - _csvn_httpd = getServerDir() + '/bin/csvn-httpd' - - ret_csvn = public.execShell(_csvn + ' remove') - ret_csvn_httpd = public.execShell(_csvn_httpd + ' remove') - return 'ok' - - -if __name__ == "__main__": - func = sys.argv[1] - if func == 'status': - print status() - elif func == 'start': - print start() - elif func == 'stop': - print stop() - elif func == 'restart': - print restart() - elif func == 'reload': - print reload() - elif func == 'initd_status': - print initdStatus() - elif func == 'initd_install': - print initdInstall() - elif func == 'initd_uninstall': - print initdUinstall() - else: - print 'fail' diff --git a/plugins/abkill/info.json b/plugins/abkill/info.json deleted file mode 100755 index e486cb31c..000000000 --- a/plugins/abkill/info.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "sort": 7, - "ps": "异常程序监控和KILL", - "shell": "install.sh", - "name": "abkill", - "title": "异常程序监控", - "versions": "0.1", - "updates":"0.1", - "tip": "soft", - "checks": "server/abkill", - "author": "midoks", - "date": "201-04-01", - "home": "https://www.collab.net", - "type": "异常程序监控和KILL", - "pid": "4" -} \ No newline at end of file diff --git a/plugins/abkill/init.d/abkill.tpl b/plugins/abkill/init.d/abkill.tpl deleted file mode 100644 index 5534b24e9..000000000 --- a/plugins/abkill/init.d/abkill.tpl +++ /dev/null @@ -1,76 +0,0 @@ -#!/bin/bash -PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin - -ak_path={$SERVER_PATH}/abkill - -ak_start(){ - isStart=$(ps aux |grep 'abkill.py'|grep -v grep|awk '{print $2}') - if [ "$isStart" == '' ];then - echo -e "Starting abkill... \c" - cd $ak_path && nohup python abkill.py >> $ak_path/task.log 2>&1 & - sleep 0.3 - isStart=$(ps aux |grep 'abkill.py'|grep -v grep|awk '{print $2}') - if [ "$isStart" == '' ];then - echo -e "\033[31mfailed\033[0m" - echo '------------------------------------------------------' - tail -n 20 $ak_path/task.log - echo '------------------------------------------------------' - echo -e "\033[31mError: abkill service startup failed.\033[0m" - return; - fi - echo -e "\033[32mdone\033[0m" - else - echo "Starting abkill(pid $isStart) already running" - fi -} - - -ak_stop() -{ - echo -e "Stopping abkill... \c"; - pids=$(ps aux | grep 'abkill.py' | grep -v grep|awk '{print $2}') - arr=($pids) - - for p in ${arr[@]} - do - kill -9 $p - done - echo -e "\033[32mdone\033[0m" - -} - -ak_status() -{ - isStart=$(ps aux|grep 'abkill.py'|grep -v grep|awk '{print $2}') - if [ "$isStart" != '' ];then - echo -e "\033[32mabkill (pid $(echo $isStart)) already running\033[0m" - else - echo -e "\033[31mabkill not running\033[0m" - fi -} - - -ak_reload() -{ - isStart=$(ps aux|grep 'abkill.py'|grep -v grep|awk '{print $2}') - - if [ "$isStart" != '' ];then - ak_stop - ak_start - else - echo -e "\033[31mmw not running\033[0m" - mw_start - fi -} - - -case "$1" in - 'start') ak_start;; - 'stop') ak_stop;; - 'reload') ak_reload;; - 'restart') - ak_stop - sleep 0.3 - ak_start;; - 'status') ak_status;; -esac \ No newline at end of file diff --git a/plugins/abkill/install.sh b/plugins/abkill/install.sh deleted file mode 100755 index 8b92a9131..000000000 --- a/plugins/abkill/install.sh +++ /dev/null @@ -1,32 +0,0 @@ -#!/bin/bash -PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin -export PATH - -curPath=`pwd` -rootPath=$(dirname "$curPath") -rootPath=$(dirname "$rootPath") -serverPath=$(dirname "$rootPath") - - -install_tmp=${rootPath}/tmp/bt_install.pl - -Install_abkill() -{ - echo '正在安装脚本文件...' > $install_tmp - mkdir -p $serverPath/abkill - echo '0.1' > $serverPath/abkill/version.pl - echo '安装完成' > $install_tmp -} - -Uninstall_abkill() -{ - rm -f $serverPath/abkill - echo "卸载完成" > $install_tmp -} - -action=$1 -if [ "${1}" == 'install' ];then - Install_abkill -else - Uninstall_abkill -fi diff --git a/plugins/abkill/js/abkill.js b/plugins/abkill/js/abkill.js deleted file mode 100755 index 702b10e8c..000000000 --- a/plugins/abkill/js/abkill.js +++ /dev/null @@ -1 +0,0 @@ -pluginService('abkill'); \ No newline at end of file diff --git a/plugins/abkill/script/abkill.py b/plugins/abkill/script/abkill.py deleted file mode 100755 index 3f9df2fbd..000000000 --- a/plugins/abkill/script/abkill.py +++ /dev/null @@ -1,85 +0,0 @@ -# coding: utf-8 - -# 使用示例: -# 1、将此文件重命名为btkill.py , 然后上传到服务器/root目录 -# 2、执行 python /root/btkill.py - -import time -import os -import sys -sys.path.append("/usr/local/lib/python2.7/site-packages") -import psutil - - -class btkill: - __limit = 10 # Cpu使用率触发上限 - __vmsize = 1048576 / 4 # 虚拟内存触发上限(字节) - - def checkMain(self): - pids = psutil.pids() - print pids - num = 0 - for pid in pids: - try: - p = psutil.Process(pid) - if p.exe() == "": - continue - name = p.name() - if self.whiteList(name): - continue - cputimes = p.cpu_times() - if cputimes.user < 0.1: - continue - print p - percent = p.cpu_percent(interval=1) - vm = p.memory_info().vms - if percent > self.__limit or vm > self.__vmsize: - log = time.strftime('%Y-%m-%d %X', time.localtime()) + " (PID=" + str( - pid) + ", NAME=" + name + ", VMS=" + str(vm) + ", PERCENT=" + str(percent) + "%)" - # p.kill() - num += 1 - print log + " >> killed\n" - except Exception as ex: - print str(ex) - return num - - # 检查白名单 - def whiteList(self, name): - wlist = ['yum', 'apt-get', 'apt', 'redis-cli', 'memcached', 'sshd', 'vm', 'vim', 'htop', 'top', 'sh', 'bash', 'zip', 'gzip', 'rsync', - 'tar', 'unzip', 'php', 'composer', 'pkill', 'mongo', 'mongod', 'php-fpm', 'nginx', 'httpd', 'lsof', 'ps', 'redis-server', - 'mysqld', 'mysqld_safe', 'mysql', 'pure-ftpd', 'sparse_dd', 'stunnel', 'squeezed', 'vncterm', 'awk', 'ruby', 'postgres', - 'mpathalert', 'vncterm', 'multipathd', 'fe', 'elasticsyslog', 'syslogd', 'v6d', 'xapi', 'screen', 'runsvdir', 'svlogd', - 'java', 'udevd', 'ntpd', 'irqbalance', 'qmgr', 'wpa_supplicant', 'mysqld_safe', 'sftp-server', 'lvmetad', 'gitlab-web', - 'pure-ftpd', 'auditd', 'master', 'dbus-daemon', 'tapdisk', 'sshd', 'init', 'ksoftirqd', 'kworker', 'kmpathd', - 'kmpath_handlerd', 'python', 'kdmflush', 'bioset', 'crond', 'kthreadd', 'migration', 'rcu_sched', 'kjournald', - 'gcc', 'gcc++', 'nginx', 'mysqld', 'php-cgi', 'login', 'firewalld', 'iptables', 'systemd', 'network', 'dhclient', - 'systemd-journald', 'NetworkManager', 'systemd-logind', 'systemd-udevd', 'polkitd', 'tuned', 'rsyslogd', 'AliYunDunUpdate', 'AliYunDun', 'sendmail'] - wslist = ['vif', 'qemu', 'scsi_eh', 'xcp', - 'xen', 'docker', 'yunsuo', 'aliyun', 'PM2'] - - for key in wlist: - if key == name: - return True - - for key in wslist: - if name.find(key) != -1: - return True - - return False - - # 开始处理 - def start(self): - num = 0 - while True: - num += self.checkMain() - print "查杀完成, 共查杀[" + str(num) + "]个异常进程!" - time.sleep(3) - print '=======================================' - print "查杀完成, 共查杀[" + str(num) + "]个异常进程!" - - -if __name__ == "__main__": - print "正在检测异常进程..." - print '=======================================' - c = btkill() - c.start() diff --git a/plugins/score/ico.png b/plugins/score/ico.png deleted file mode 100755 index 8a6e3be1f7abd14c22db271c3b2282d502309d51..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 832 zcmV-G1Hb%f$$Qwa^MBlBWY{~l_6819WFx|Z~%Ekt<<;#g(k5z zM`b`CRK_tVC&KX+pYRc%5rT8bF6t%4HYnUf*4Piq9K=wBLJ1LghVxjC5$J_(=#MEV zDC+rRfmUNC0%J8O14xHuP6FP>T$F{cf%!cMAy5cGrP$qGxRY29CA`24WHV8-89r;Z zjvfI8cK5>*-VBEb}|K~!%wUS525fD`7IAB9@))uPNGyaPEX^Ygm0)J+D<}< z)@BEM-4(PdlqSsJV1HkTRge-}dP!hVpA=(Gw zD8j{E^|m@_ZgFOPhjJ!EX2Jz12~UyRNxvHSsI~oyd{zhTE*{xECPN0v#YY$mA18f1 zaZ)_OeXI-03y8seK@XEbM~Q*z-lMdO{{8Vy>$4S}Rs~IqJ6iE)C}bjJUGeBi8xRRd2gZ4t0i=aIW)SHIyTHk$E1wAE}^dSZYl@W(rguH=# z25Jry2aU^C1-&a)+};KTl@C{31RVx1gHOm8eL-?Z(61OAokP2D%kT=$AJRn7hgJnW zBIf86g99sy8_wn?JPp>HAm-?4tAbY2_R+g2ZQ@-@R?NXOe8+XPhL4H;xCm}R;T~#O z71V(WScxidm^>AEBRfhVjhQ;);;%$yc-sGav4h4Xc2GO09rOp@&c>0ICYPcB0000< KMNUMnLSTZOXnMf_ diff --git a/plugins/score/img/ico-score.png b/plugins/score/img/ico-score.png deleted file mode 100755 index 42a9ac3080cfee4804d1111855460b6abe5f8358..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1296 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 VG=P0@r}Y2;002ovPDHLkV1mz&3Ml{p diff --git a/plugins/score/img/ico-ts-mem-active.png b/plugins/score/img/ico-ts-mem-active.png deleted file mode 100755 index ea383549c6e41ba2f783fc22a37ed3c1ad5efca8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 874 zcmV-w1C{)VP)pF9CSrkbW?9;ba!ELWdK2BZ(?O2Mrm?o zcW-iQb09-gHt4*vi~s-t7IZ~ebVG7wVRUJ4ZXi@?ZDjy3H7_tWFEKan@iX}V00P2E zL_t(oh3(cqXcJ)=$MNs;-X%@ZK|#TS+E>gVIyk5$i3rt6C(%KyZTy3Xi-VwxASgIE zsNmorC{(nm;-F404rWM`7CTfZ4*r4bAB$B)MWr^m+~c62sZ9=R8wCAr_uliqpS$Ky6N6uXn>ob|PDV zaYVMQ$fWv~-cB~oISeqeJ3Cm6m==T=3M~;|3QKNpT0G}4z}T+b@I;Ih!c$e&#!BTv zC9JYwuJG}l`PW`kbd3swz)JV$lYXE%*9bUr%4SmgW?dgE0`!Bfu7F3=h3B>_c|wtc z0(REn?@@S%?M^*3;lNrWoK zy!YDk16AQ=*Eg<5w1Cu}2%`aZ^vh;-owyitB^3Uaimko^9$6L{uw%tGp!OXr{zOBp zKjMEJjB0})PX4;ZgZoXKReeWcV4b=Ygq57^EPO~jmf10B36X}YxNCjbBd07*qoM6N<$f~k*< AGXMYp diff --git a/plugins/score/img/ico-ts-mem.png b/plugins/score/img/ico-ts-mem.png deleted file mode 100755 index fb497b6f3bac27aaa2036cd8b864371217603511..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 683 zcmV;c0#yBpP)(~lxJ!J3ud7OAo*0f|7f^3 zjwF8tJOnOEzTGU$W<3*`=cRFBD`gfQ1E+wmz>MTi%fM?Uv+x`^4txPlO8%@Ca0>4N z$ACrPgyb(J-&8p`h4+C&!25LVNWPqj90uM1`+-gtytP93XJ8-D2X<#0M>}1w zNjqhmr?ivLtQ*cp4uf zI7?=sR|uB;Akc|O1aK6XCK;hIY7~Nj9&nntFYb~wgFyszWa?$_@c@{QNHo+k@L(1G ze6Zw`zy)AqN!%}B4%h<3bhz(k;Z7kK*aO^%NCeO#sqwW4?*J$Un}wd_JBg^VSy%wt zlD8tj%h`>Q>tq%_MI>73|F9Z=E;z06d0=x%+z;R`$rzmlHk9}m&B9zEn51SmOOg!L zCYfN@BfJBW!xzkOOrcwK!<{$Bgnl2<3 R*ERqE002ovPDHLkV1f^N91H*e diff --git a/plugins/score/img/ico-ts-refresh.png b/plugins/score/img/ico-ts-refresh.png deleted file mode 100755 index 1c84c4f66d9320e6021beb8f2983f4d7443d061f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2941 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 diff --git a/plugins/score/img/ico-ts-score.jpg b/plugins/score/img/ico-ts-score.jpg deleted file mode 100755 index 86a277bd36898ebc812e483c004ce2e04ade60d1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3977 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 hGsc+7mr=?lf4PPivH8fRt -.chaphb { - color: #20a53a; - font-size: 14px; - left: 14px; - position: relative; - top: 62px; -} -.testServer{ - padding:15px; -} -.ts-head{ - height:130px; - position:relative; -} -.ts-h-score{ - float: left; - height: 62px; - margin: 30px 0 0 40px; - display:none; -} -.old-score { - color: #888; - font-size: 14px; - left: 50%; - margin-left: -100px; - position: absolute; - text-align: center; - top: 90px; - width: 200px; -} -.ts-stamper{ - border-radius: 45px; - height: 90px; - left: 280px; - position: absolute; - top: 20px; - width: 90px; - transform:rotate(-30deg); -} -.ts-h-s-img{ - background-repeat:no-repeat; - background-size:90px auto; - background-position:center center; - height:62px; - width:96px; - float:left; -} -.ts-h-s-img1{ - background-image:url(""); -} -.ts-h-s-img2{ - background-image:url(""); -} -.ts-h-s-img3{ - background-image:url(""); -} -.ts-h-s-imging{ - background-image:url(""); -} -.ts-h-s-num{ - color: #20a53a; - float: left; - font-size: 20px; - margin-left: 30px; -} -.ts-h-s-num span{ - font-size: 22px; - line-height: 60px; - margin-right: 8px; -} -.ts-h-s-num span img{ - margin-left:10px; -} -.ts-btn{ - border: 1px solid #cacad9; - background-color:#fff; - border-radius: 3px; - height: 40px; - line-height: 40px; - color:#666; - position: absolute; - left: 265px; - text-align: center; - top: 39px; - width: 140px; - cursor:pointer; -} -.ts-btn-start{ - border: 1px solid #20a53a; - background-color:#20a53a; - left:265px; - color:#fff; -} -.ts-btn-start:hover{ - background-color:#10952a; -} -.ts-btn-reset:hover,.btphb:hover{ - border: 1px solid #20a53a; - color:#20a53a; -} -.ts-info{ - height:30px; - color:#666; - border-bottom:#CACAD9 1px solid; - padding-left:40px; - font-size:14px; -} -.ts-info font{ - font-size:16px; - font-weight:bold; - margin-right:3px; - color:#20a53a; -} -.ts-info a{ - color: #20a53a; - margin-left: 20px; -} -.ts-info img{ - margin-left:6px; -} -.ts-content{ - float: left; - padding: 40px 0; - width: 100%; -} -.ts-c-box{ - width:33%; - float:left; - text-align:center; - position:relative; -} -.ts-c-b-score{ - font-size:16px; - height:30px; - color:#868686; -} -.ts-c-b-img{ - border:#B9B9C8 1px solid; - height:90px; - width:90px; - border-radius:45px; - margin:0 auto; - background-repeat:no-repeat; - background-position:center center; - position:relative; - z-index:1; -} -.ts-cpu-ing .ts-c-b-img{ - border:0 none; -} -.ts-c-b-name{ - color:#888; - font-size:16px; - line-height:40px; -} -.ts-c-b-info{ - color:#aaa; -} - -@-webkit-keyframes rotation{ - from {-webkit-transform: rotate(0deg);} - to {-webkit-transform: rotate(360deg);} -} -.ts-box-rotate{ - background:url("") no-repeat; - border-radius: 50px; - height: 100px; - left: 61px; - position: absolute; - top: 25px; - width: 100px; - z-index: 0; - animation: rotation 2s linear infinite; - -moz-animation: rotation 2s linear infinite; - -webkit-animation: rotation 2s linear infinite; - -o-animation: rotation 2s linear infinite; -} - -.ts-cpu .ts-c-b-img{ - background-image:url(""); -} -.ts-mem .ts-c-b-img{ - background-image:url(""); -} -.ts-disk .ts-c-b-img{ - background-image:url(""); -} - -.ts-cpu-ing .ts-c-b-img{ - background-image:url(""); - border:none; -} -.ts-mem-ing .ts-c-b-img{ - background-image:url(""); - border:none; -} -.ts-disk-ing .ts-c-b-img{ - background-image:url(""); - border:none; -} -.ts-cpu-over .ts-c-b-img{ - background-image:url(""); - border-color:#20a53a; -} -.ts-mem-over .ts-c-b-img{ - background-image:url(""); - border-color:#20a53a; -} -.ts-disk-over .ts-c-b-img{ - background-image:url(""); - border-color:#20a53a; -} - -
-
-
-
-
正在跑分中
-
-
-
开始跑分
-
-
公式:1万次整数+2万次浮点+1亿位圆周率+1万次排序 +((磁盘读+磁盘写)*IO速度)+内存容量
-
-
-
-
-
CPU
-
cpu运算能力
-
-
-
-
-
磁盘
-
磁盘读写能力
-
-
-
-
-
内存
-
内存容量
-
-
-
- \ No newline at end of file diff --git a/plugins/score/index.py b/plugins/score/index.py deleted file mode 100755 index 3a1db22b1..000000000 --- a/plugins/score/index.py +++ /dev/null @@ -1,355 +0,0 @@ -# coding: utf-8 - -import time -import psutil -import random -import os -import urllib -import binascii -import json -import re -import sys - -sys.path.append(os.getcwd() + "/class/core") -import public - - -class score_main: - - __APIURL = 'https://www.bt.cn/api/Auth' - __UPATH = 'data/userInfo.json' - __userInfo = None - __PDATA = None - - def CheckToken(self): - pdata = {} - data = {} - if os.path.exists(self.__UPATH): - self.__userInfo = json.loads(public.readFile(self.__UPATH)) - if self.__userInfo: - pdata['access_key'] = self.__userInfo['access_key'] - data['secret_key'] = self.__userInfo['secret_key'] - else: - pdata['access_key'] = 'test' - data['secret_key'] = '123456' - pdata['data'] = data - self.__PDATA = pdata - - # 修正信息 - def SetScore(self, get): - if hasattr(get, 'ips'): - return self.SubmitSetScore('ips', get.ips) - if hasattr(get, 'virt'): - return self.SubmitSetScore('virt', get.virt) - - # 发送信息修正 - def SubmitSetScore(self, key, value): - self.CheckToken() - self.__PDATA['data'][key] = value - self.__PDATA['data'] = self.De_Code(self.__PDATA['data']) - result = json.loads(public.httpPost( - self.__APIURL + '/SetSocre', self.__PDATA)) - result['data'] = self.En_Code(result['data']) - return result - - # 获取得分列表 - def GetScore(self, get): - self.CheckToken() - self.__PDATA['data'] = self.De_Code(self.__PDATA['data']) - result = json.loads(public.httpPost( - self.__APIURL + '/GetSocre', self.__PDATA)) - result['data'] = self.En_Code(result['data']) - return result - - # 获取配置信息 - def GetConfig(self, get=None): - virt = '/usr/sbin/virt-what' - if not os.path.exists(virt): - if os.path.exists('/etc/yum.repos.d/epel.repo'): - os.system( - 'mv /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel.repo_backup') - os.system('yum install virt-what -y') - if os.path.exists('/etc/yum.repos.d/epel.repo_backup'): - os.system( - 'mv /etc/yum.repos.d/epel.repo_backup /etc/yum.repos.d/epel.repo') - - data = {} - data['virt'] = public.ExecShell('virt-what')[0].strip() - cpuinfo = open('/proc/cpuinfo', 'r').read() - rep = "model\s+name\s+:\s+(.+)" - tmp = re.search(rep, cpuinfo) - - data['cpu'] = tmp.groups()[0] - data['core'] = psutil.cpu_count() - data['memory'] = psutil.virtual_memory().total / 1024 / 1024 - data['system'] = self.GetSystemVersion() - - scoreInfo = self.readScore() - data['disk'] = str(scoreInfo['read']) + ',' + str(scoreInfo['write']) - data['mem_score'] = scoreInfo['mem'] - data['cpu_score'] = scoreInfo['cpu1'] + \ - scoreInfo['cpu2'] + scoreInfo['cpu3'] + scoreInfo['cpu4'] - data['disk_score'] = scoreInfo['disk_score'] - data['total_score'] = scoreInfo['mem'] + \ - data['cpu_score'] + scoreInfo['disk_score'] - return data - - # 提交到云端 - def SubmitScore(self, get): - try: - self.CheckToken() - pdata = self.GetConfig(get) - if not pdata['total_score']: - return public.returnMsg(False, '请先跑分!') - pdata['secret_key'] = self.__userInfo['secret_key'] - self.__PDATA['data'] = self.De_Code(pdata) - result = json.loads(public.httpPost( - self.__APIURL + '/SubmitScore', self.__PDATA)) - result['data'] = self.En_Code(result['data']) - return result - except: - return None - - # 取操作系统版本 - def GetSystemVersion(self): - version = public.readFile('/etc/redhat-release') - if not version: - version = public.readFile( - '/etc/issue').replace('\\n \\l', '').strip() - else: - version = version.replace('release ', '').strip() - return version - - # 写当前得分 - def writeScore(self, type, value): - scoreFile = '/www/server/panel/plugin/score/score.json' - if not os.path.exists(scoreFile): - data = {} - data['cpu1'] = 0 - data['cpu2'] = 0 - data['cpu3'] = 0 - data['cpu4'] = 0 - data['mem'] = 0 - data['disk_score'] = 0 - data['read'] = 0 - data['write'] = 0 - public.writeFile(scoreFile, json.dumps(data)) - - data = json.loads(public.readFile(scoreFile)) - data[type] = value - public.writeFile(scoreFile, json.dumps(data)) - - # 读当前得分 - def readScore(self): - scoreFile = '/www/server/panel/plugin/score/score.json' - if not os.path.exists(scoreFile): - data = {} - data['cpu1'] = 0 - data['cpu2'] = 0 - data['cpu3'] = 0 - data['cpu4'] = 0 - data['mem'] = 0 - data['disk_score'] = 0 - data['read'] = 0 - data['write'] = 0 - public.writeFile(scoreFile, json.dumps(data)) - data = json.loads(public.readFile(scoreFile)) - return data - - # 测试CPU - def testCpu(self, get, n=1): - data = {} - data['cpuCount'] = psutil.cpu_count() - if not hasattr(get, 'type'): - get.type = '0' - import re - cpuinfo = open('/proc/cpuinfo', 'r').read() - rep = "model\s+name\s+:\s+(.+)" - tmp = re.search(rep, cpuinfo) - data['cpuType'] = "" - if tmp: - data['cpuType'] = tmp.groups()[0] - - import system - data['system'] = system.system().GetSystemVersion() - path = '/www/server/panel/plugin/score/testcpu' - if not os.path.exists(path): - os.system('gcc ' + path + '.c -o ' + path + ' -lpthread') - start = time.time() - os.system(path + ' 32 ' + get.type) - end = time.time() - data['score'] = int(400 * 10 / (end - start)) - if not os.path.exists(path): - data['score'] = 0 - self.writeScore('cpu' + get.type, data['score']) - return data - pass - - # 测试整数运算 - def testInt(self): - return self.testIntOrFloat(1) - - # 测试浮点运行 - def testFloat(self): - return self.testIntOrFloat(1.01) - - # CPU测试体 - def testIntOrFloat(self, n=1): - start = time.time() - num = 10000 * 100 - for i in range(num): - if i == 0: - continue - a = n + i - b = n - i - c = n * i - d = n / i - n = n + 1 - - end = time.time() - usetime = end - start - return num / 100 / usetime - - # 冒泡算法测试 - def testBubble(self): - start = time.time() - num = 10000 * 5 - xx = 'qwertyuiopasdfghjklzxcvbnm1234567890' - for c in xrange(num): - lst = [] - for k in range(10): - lst.append(xx[random.randint(0, len(xx) - 1)]) - lst = self.bubbleSort(lst) - end = time.time() - usetime = end - start - return num / 5 / usetime - - # 冒泡排序 - def bubbleSort(self, lst): - length = len(lst) - for i in xrange(0, length, 1): - for j in xrange(0, length - 1 - i, 1): - if lst[j] < lst[j + 1]: - temp = lst[j] - lst[j] = lst[j + 1] - lst[j + 1] = temp - return lst - - # 二叉树算法测试 - def testTree(self): - import testTree - - start = time.time() - elems = range(3000) # 生成树节点 - tree = testTree.Tree() # 新建一个树对象 - for elem in elems: - tree.add(elem) # 逐个加入树的节点 - - tree.level_queue(tree.root) - tree.front_digui(tree.root) - tree.middle_digui(tree.root) - tree.later_digui(tree.root) - tree.front_stack(tree.root) - tree.middle_stack(tree.root) - tree.later_stack(tree.root) - - end = time.time() - usetime = end - start - return 3000 / usetime - - # 测试内存 - def testMem(self, get): - mem = psutil.virtual_memory() - self.writeScore('mem', mem.total / 1024 / 1024) - # 提交数据 - self.SubmitScore(get) - return mem.total / 1024 / 1024 - - # 测试磁盘 - def testDisk(self, get): - import os - data = {} - os.system('rm -f testDisk_*') - filename = "testDisk_" + \ - time.strftime('%Y%m%d%H%M%S', time.localtime()) - data['write'] = self.testDiskWrite(filename) - import shutil - filename2 = "testDisk_" + \ - time.strftime('%Y%m%d%H%M%S', time.localtime()) - shutil.move(filename, filename2) - data['read'] = self.testDiskRead(filename2) - diskIo = psutil.disk_partitions() - diskInfo = [] - for disk in diskIo: - tmp = {} - tmp['path'] = disk[1] - tmp['size'] = psutil.disk_usage(disk[1])[0] - diskInfo.append(tmp) - data['diskInfo'] = diskInfo - writeDisk = data['write'] - if data['write'] > 1000: - writeDisk = 1000 - readDisk = data['read'] - if data['read'] > 1000: - readDisk = 1000 - - data['score'] = (writeDisk * 6) + (readDisk * 6) - os.remove(filename2) - - self.writeScore('disk_score', data['score']) - self.writeScore('write', data['write']) - self.writeScore('read', data['read']) - return data - pass - - # 测试磁盘写入速度 - def testDiskWrite(self, filename): - import random - start = time.time() - fp = open(filename, 'w+') - strTest = "" - strTmp = "" - for n in range(4): - strTmp += chr(random.randint(97, 122)) - for n in range(1024): - strTest += strTmp - - for i in range(1024 * 256): - fp.write(strTest) - - del(strTest) - del(strTmp) - fp.close() - end = time.time() - usetime = end - start - return int(1024 / usetime) - - # 测试磁盘读取速度 - def testDiskRead(self, filename): - os.system('echo 3 > /proc/sys/vm/drop_caches') - import random - start = time.time() - fp = open(filename, 'r') - size = 4096 - while True: - tmp = fp.read(size) - if not tmp: - break - del(tmp) - fp.close() - end = time.time() - usetime = end - start - return int(1024 / usetime) - - def testWorkNet(self): - pass - - # 加密数据 - def De_Code(self, data): - pdata = urllib.urlencode(data) - return binascii.hexlify(pdata) - - # 解密数据 - def En_Code(self, data): - result = urllib.unquote(binascii.unhexlify(data)) - return json.loads(result) diff --git a/plugins/score/info.json b/plugins/score/info.json deleted file mode 100755 index 25db28b12..000000000 --- a/plugins/score/info.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "title":"跑分测试", - "tip":"lib", - "name":"score", - "type":"扩展", - "ps":"测试服务器基础性能!", - "versions": "1.3", - "shell":"install.sh", - "checks":"server/score", - "author":"mdserver-web", - "home":"github.com/midoks/mdserver-web", - "date":"2018-11-02", - "default":false, - "display":0, - "pid":"4" -} \ No newline at end of file diff --git a/plugins/score/install.sh b/plugins/score/install.sh deleted file mode 100755 index a1f8e557d..000000000 --- a/plugins/score/install.sh +++ /dev/null @@ -1,38 +0,0 @@ -#!/bin/bash -PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin -export PATH - -curPath=`pwd` -rootPath=$(dirname "$curPath") -rootPath=$(dirname "$rootPath") -serverPath=$(dirname "$rootPath") - -install_tmp=${rootPath}/tmp/bt_install.pl - -Install_score() -{ - echo '正在安装脚本文件...' > $install_tmp - - mkdir -p $serverPath/score - - gcc $curPath/testcpu.c -o $serverPath/score/testcpu -lpthread - if [ ! -f $serverPath/score/testcpu ];then - sleep 0.1 - gcc $curPath/testcpu.c -o $serverPath/score/testcpu -lpthread - fi - - echo '安装完成' > $install_tmp -} - -Uninstall_score() -{ - rm -rf $serverPath/score - echo '卸载完成' > $install_tmp -} - -action=$1 -if [ "${1}" == 'install' ];then - Install_score -else - Uninstall_score -fi diff --git a/plugins/score/js/score.js b/plugins/score/js/score.js deleted file mode 100755 index f1cfec773..000000000 --- a/plugins/score/js/score.js +++ /dev/null @@ -1,301 +0,0 @@ -(function($){ - -$.fn.stamper = function(options) { - var opts = $.extend({ - scale : 5, // 图片初始大小,在原始图片大小上的倍数 - speed : 600 // 动画持续时间,单位毫秒 - }, options); - - this.each(function(index) { - var target = $(this); - var imgId = target.attr("data-stamper-img-id"); - if (!imgId) { - imgId = "jquery_stamper_img_" + (new Date().getTime()) + "_" + index; - target.attr("data-stamper-img-id", imgId); - } - var img = new Image(); - img.src = opts.image; - img.onload = function() { - var orgiCoor = getImageCoordinate(target, img); - var initCoor = getStartCoordinate(target, img, opts.scale); - var imgObj = getImageElement(imgId).attr("src", img.src) - .css({ - position : "absolute", - opacity : "0", - left : "-106px", - top : "-116px", - width : initCoor.w + "px", - height : initCoor.h + "px" - }) - .show() - .animate({ - opacity : "1", - left : "0px", - top : "0px", - width : orgiCoor.w + "px", - height : orgiCoor.h + "px" - }, opts.speed, opts.complete); - }; - }); -}; - -/** 获取img的DOM对象 **/ -function getImageElement(id) { - var img = $("#" + id); - if (img.length == 0) { - return $("").appendTo($(".ts-stamper")).hide(); - } else { - return img.hide(); - } -} - -/** 获取图片的落脚坐标点(以当前元素为基准)和尺寸信息,格式:{x:10,y:20,h:100,w:200} **/ -function getImageCoordinate(target, image) { - var offset = $(target).offset(); - var cx = offset.left + $(target).width()/2; - var cy = offset.top + $(target).height()/2; - return { - x : cx - image.width/2, - y : cy - image.height/2, - w : image.width, - h : image.height - }; -} - -/** 给定倍数(multiple)获取图片的开始位置和大小信息,格式:{x:10,y:20,h:100,w:200} **/ -function getStartCoordinate(target, image, multiple) { - var offset = $(target).offset(); - var cx = offset.left + $(target).width()/2; - var cy = offset.top + $(target).height()/2; - var width = image.width * multiple; - var height = image.height * multiple; - return { - x : cx - width/2, - y : cy - height/2, - w : width, - h : height - }; -} -})(jQuery); - -function startTest(){ - var name = $(".ts-btn").text(); - switch(name){ - case '开始跑分': - startTestServer(name); - break; - case '正在跑分': - stopTestServer(); - break; - case '重新跑分': - startTestServer(name); - break; - } -} -if(getCookie("#Total") >0){ - $(".old-score").html("上次跑分:"+getCookie("#Total") + ' 分 我的排名').show(); -} - -function startTestServer(name){ - layer.confirm('测试过程可能需要几分钟时间且占用大量服务器资源,继续吗?',{title:'性能测试',closeBtn:2},function(){ - layer.closeAll('dialog'); - if(name == "重新跑分"){ - $(".btphb").remove(); - $(".ts-content").find(".ts-box-rotate").remove(); - $(".ts-h-s-num").html('正在跑分中'); - $(".ts-btn-reset").removeAttr("onclick").width(140); - $(".ts-cpu-over").removeClass("ts-cpu-over"); - $(".ts-disk-over").removeClass("ts-disk-over"); - $(".ts-mem-over").removeClass("ts-mem-over"); - $(".ts-h-s-img").removeClass("ts-h-s-img1"); - $(".ts-h-s-img").removeClass("ts-h-s-img2"); - $(".ts-h-s-img").removeClass("ts-h-s-img3"); - $(".ts-h-s-img").addClass("ts-h-s-imging"); - $(".ts-stamper").html(""); - } - $(".old-score").fadeOut(); - $(".ts-btn").removeClass("ts-btn-start").text("正在跑分").animate({"left":"490px"}); - $(".ts-h-score").fadeIn(); - $(".ts-cpu").addClass("ts-cpu-ing").append("
"); - $(".ts-info").html("正在测试整数运算性能[1万次]"); - var cpuscore = 0; - $.get('/plugin?action=a&name=score&s=testCpu&type=1',function(rint){ - cpuscore += rint.score; - $(".ts-info").html("正在测试浮点运算性能[2万次]"); - $.get('/plugin?action=a&name=score&s=testCpu&type=2',function(rfloat){ - cpuscore += rfloat.score; - $(".ts-info").html("正在测试圆周率运算[1亿位]"); - $.get('/plugin?action=a&name=score&s=testCpu&type=3',function(rpi){ - cpuscore += rpi.score; - $(".ts-info").html("正在测试二叉树排序算法[1万次]"); - $.get('/plugin?action=a&name=score&s=testCpu&type=4',function(r1){ - r1.score += cpuscore; - $(".ts-cpu").removeClass("ts-cpu-ing").addClass("ts-cpu-over").find(".ts-box-rotate").remove(); - $(".ts-disk").addClass("ts-disk-ing").append("
"); - $(".ts-cpu .ts-c-b-score").html(r1.score); - $(".ts-cpu .ts-c-b-info").html(r1.cpuType + ' ' +r1.cpuCount + ' 核心'); - //$("#cpuType").html('型号:' + r1.cpuType); - setCookie('cpuTotal',r1.score); - setCookie('cpuCount',r1.cpuCount + ' 核心'); - setCookie('cpuType','型号:' + r1.cpuType); - $(".ts-info").html("正在测试磁盘性能"); - $.get('/plugin?action=a&name=score&s=testDisk',function(r2){ - $(".ts-disk").removeClass("ts-disk-ing").addClass("ts-disk-over").find(".ts-box-rotate").remove(); - $(".ts-mem").addClass("ts-mem-ing").append("
"); - $(".ts-disk .ts-c-b-score").html(r2.score); - $(".ts-disk .ts-c-b-info").html('读: ' + r2.read + ' MB,写: ' + r2.write + ' MB'); - setCookie('diskTotal',r2.score); - setCookie('diskRead','Read: ' + r2.read + ' MB'); - setCookie('diskWrite','Write: ' + r2.write + ' MB'); - $(".ts-info").html("正在测试内存"); - $.get('/plugin?action=a&name=score&s=testMem','',function(r3){ - $(".ts-mem").removeClass("ts-mem-ing").addClass("ts-mem-over").find(".ts-box-rotate").remove(); - $(".ts-mem .ts-c-b-score").html(parseInt(r3)); - $(".ts-mem .ts-c-b-info").html( r3 + ' MB'); - var total = r1.score+r2.score+ parseInt(r3); - $(".ts-h-s-num span").html(total + ' 分').css({"font-size":"40px"}); - setCookie("#memTotal",r3 + ' MB'); - setCookie("#Total",total); - $(".ts-btn").addClass("ts-btn-reset").text("重新跑分").css({"left":"550px","width":"80px"}).attr("onclick","startTestServer('重新跑分')"); - $(".ts-h-score").after('
我的排名
'); - if(total<2500){ - $(".ts-h-s-img").removeClass("ts-h-s-imging").addClass("ts-h-s-img1"); - scoreIco("1"); - } - if(total>2500 && total<10000){ - $(".ts-h-s-img").removeClass("ts-h-s-imging").addClass("ts-h-s-img2"); - scoreIco("2"); - } - if(total > 10000){ - $(".ts-h-s-img").removeClass("ts-h-s-imging").addClass("ts-h-s-img3"); - scoreIco("3"); - } - - var data = "soc="+total; - $.get("/ajax?action=GetAd&name=zun",data,function(rad){ - $(".ts-info").html(rad); - }); - }); - }); - }); - }); - }); - }); - }); -} -function stopTestServer(){ - /* - $(".ts-btn").addClass("ts-btn-start").removeClass("ts-btn-reset").text("开始测试").animate({"left":"233px"}); - $(".ts-h-score").fadeOut(); - $(".ts-info").html("跑分计算规则为:通过计算cpu运算能力,计算内存吞吐能力,计算磁盘读写能力"); - */ - //layer.msg("测试中,不能停止",{shade:0.3}); - return false; -} -function scoreIco(ico) { - var img = ''; - switch(ico){ - case "1": - img = ''; - break; - case "2": - img = ''; - break; - case "3": - img = ''; - break; - } - $(".ts-stamper").stamper({ - image : img, - scale : 3, - speed : 300, - complete : function() { - //alert("完成啦~~~~"); - } - }) -} - -function GetScore(){ - $.get('/plugin?action=a&name=score&s=GetScore',function(rdata){ - - }); -} -GetScore(); -//我的排名 -function btphb(){ - $.get("/ssl?action=GetUserInfo",function(rdata){ - if(rdata.status){ - var loadT = layer.msg("获取列表..",{icon:16,time:0}); - var tr = ""; - $.get("/plugin?action=a&name=score&s=GetScore",function(pm){ - layer.close(loadT); - if(pm.status){ - for(var i=0; i'+pm.data[i].core+'核 | '+pm.data[i].memory+'MB | 读'+pm.data[i].disk.split(",")[0]+'MB/s | 写'+pm.data[i].disk.split(",")[1]+'MB/s'+pm.data[i].virt+''+pm.data[i].isp+''+pm.data[i].total_score+'查看排名'; - } - layer.open({ - type: 1, - area: "700px", - title: "我的服务器跑分", - closeBtn: 2, - shadeClose: false, - content: '
\ -
\ - \ - \ - '+tr+'\ -
服务器IP配置平台服务商跑分查看排名
\ -
\ -
' - - }) - } - - }) - } - else{ - bindBTName(2,'b'); - } - }); -} - -//绑定修改宝塔账号 -function bindBTName(a,type){ - var titleName = "绑定宝塔账号"; - if(type == "b"){ - btn = ""; - } - if(a == 1) { - p1 = $("#p1").val(); - p2 = $("#p2").val(); - $.post(" /ssl?action=GetToken", "username=" + p1 + "&password=" + p2, function(b) { - if(b.status) { - $(".btn-bw").click(); - layer.msg(b.msg, { - icon: 1 - }); - $.get("/plugin?action=a&name=score&s=SubmitScore",function(p){ - //layer.msg(p.msg,{icon:p.status?1:2}); - }); - btphb(); - } else { - layer.msg(b.msg, { - icon: 2 - }) - } - }); - return - } - var bindw = layer.open({ - type: 1, - area: "290px", - title: titleName, - closeBtn: 2, - shift: 5, - shadeClose: false, - content: "
账号
密码
"+btn+"
" - }) - $(".btn-bw").click(function(){ - layer.close(bindw); - }); -} \ No newline at end of file diff --git a/plugins/score/testcpu.c b/plugins/score/testcpu.c deleted file mode 100755 index 10ff234fa..000000000 --- a/plugins/score/testcpu.c +++ /dev/null @@ -1,129 +0,0 @@ -#include -#include -#include -#include - -const int N_qsort = 10000; -const int N_int = 10000; -const int N_float = 20000; -const int N_pi = 50000000; - - -int thread_count = 0; - -void int_comp(void); -void float_comp(void); -void pi_comp(void); -void to_qsort(int arr[],int low,int high); -void qsort_comp(void); -void thread(void); -void thread_int(void); -void thread_float(void); -void thread_pi(void); -void thread_qsort(void); - -int main(int argc,char** argv){ - int count,i,result,type; - count = atoi(argv[1]); - type = atoi(argv[2]); - if(argc < 3){ - printf("ERROR: Parameter error[%d]",argc); - } - pthread_t tid; - for(i=0;i=high) return; - int first=low; - int last=high; - int key=arr[first]; - while(first=key) --last; - arr[first]=arr[last]; - while(first0;i--) arr[N_qsort-1]=i; - to_qsort(arr,0,N_qsort-1); -} \ No newline at end of file