备份tsm备份oracle 报错
ANS0326E This node has exceeded its maximum number of mount points.
q node f=d
q node node_NAME f=d
tsm: TSMSERVER>update node CWORACLE maxnummp=2
ANR2150E UPDATE NODE: Node CWORACLE is currently accessing the server.
ANS8001I Return code 12.
q session
cancel sess all
tsm: TSMSERVER>update node QBYPDB maxnummp=2
ANR2063I Node QBYPDB updated.
1,新增文件post-commit.bat
内容:
rem REPOS-PATH (the path to this repository) set REPOS=%1 rem REV (the number of the revision just committed) set REV=%2 set HOOK_DIR=F:/Repositories/版本库名/hooks set PYTHON_BIN=C:/Python27/python.exe %PYTHON_BIN% %HOOK_DIR%/sendEmail.py %REPOS% %REV%
放在F:/Repositories/版本库名/hooks下
2,安装python2.7(已安装则跳过)
去官网下地2.7的版本http://www.python.org/getit/
3,新增sendEmail.py
#coding: utf-8 import sys import os import smtplib from email.mime.text import MIMEText from email.header import Header mail_host = 'smtp.qq.com' #发送邮件的smtp地址 mail_user = '****@qq.com' # 发送通知邮件的用户名 mail_pass = '****' # 用户的密码 me = 'SVN Service' + '<' + '****' + '@' + 'qq.com' + '>' #发送邮件人的地址标识 to_list = ['****@qq.com'] # 收件人 html_template = """ <html> <h2 style="color:#FFFFFF; background: #008040;">基本信息</h2> <div> <b>版本库:</b> <a href=/blog_article/"svn_%s">%s</a>/index.html </div> <div> <b>版本号:</b>%s </div> <div> <b>提交者:</b>%s </div> <div> <b>提交时间:</b>%s </div> <h2 style="color:#FFFFFF; background: #4682B4;">提交说明</h2> <font size="4" color="#BF6000"><xmp>%s</xmp></font> <h2 style="color:#FFFFFF; background: #5353A8;">文件清单</h2> <xmp>%s</xmp> <hr> <center> ☆ Powered by <a href=/blog_article/"http_/garyelephant.me">Gary</a>/index.html </center> <center> ☆ Inspired by <a href=/blog_article/"http_/crearo-sw.blogspot.com">CREARO-SW</a>/index.html </center> </html> """ def get_repo_name(repo): return os.path.basename(repo) def get_author(repo, rev): """svnlook author -r REV REPOS 获得提交者 """ cmd = '%s author -r %s %s' % (svnlook_bin_path, rev, repo) output = os.popen(cmd).read() return output def get_date(repo, rev): """svnlook date -r REV REPOS 获得提交时间 """ cmd = '%s date -r %s %s' % (svnlook_bin_path, rev, repo) output = os.popen(cmd).read() return output def get_log(repo, rev): """svnlook log -r REV REPOS 获得提交日志 """ cmd = '%s log -r %s %s' % (svnlook_bin_path, rev, repo) output = os.popen(cmd).read() return output def get_file_list(repo, rev): """svnlook changed -r REV REPOS 获得发生变更的文件 """ cmd = '%s changed -r %s %s' % (svnlook_bin_path, rev, repo) output = os.popen(cmd).read() return output def send_mail(msg, sender, to_list): try: s = smtplib.SMTP() s.connect(mail_host) s.login(mail_user,mail_pass) s.sendmail(sender, to_list, msg.as_string()) s.close() return True except Exception, e: print str(e) return False def write_mail(sender, to_list, sub, content): msg = MIMEText(content, _subtype = 'html', _charset='utf-8') msg['Subject'] = sub msg['From'] = sender msg['To'] = ';'.join(to_list) msg["Accept-Language"]="zh-CN" msg["Accept-Charset"]="ISO-8859-1,utf-8" return msg global svnlook_bin_path def write_mail_content(repo, rev): """ repo: repository rev: revision """ repo_name = get_repo_name(repo) author = get_author(repo, rev) date = get_date(repo, rev) log = get_log(repo, rev) file_list = get_file_list(repo, rev) content = html_template % (repo, repo_name, rev, author, date, log.decode("GBK").encode('UTF-8'), file_list.decode("GBK").encode('UTF-8')) return content if __name__ == '__main__': svnlook_bin_path = '"C:/Program Files/VisualSVN Server/bin/svnlook.exe"' subject = 'SVN Commit Notification' content = write_mail_content(sys.argv[1], sys.argv[2]) msg = write_mail(me, to_list, subject, content) send_mail(msg, me, to_list)同样放在F:/Repositories/版本库名/hooks
可以测试提交一个文件。效果如下:
鸣谢:http://blog.csdn.net/gaoyingju/article/details/8884276
摘要:Perf是Linux kernel自带的系统性能优化工具。Perf的优势在于与Linux Kernel的紧密结合,它可以最先应用到加入Kernel的new feature。pef可以用于查看热点函数,查看cashe miss的比率,从而帮助开发者来优化程序性能。
本文来源:http://blog.csdn.net/trochiluses/article/details/10261339
1.perf的安装
由于我们经常是在自己编译的内核上进行开发工作,这里需要有包含调式信息的内核启动镜像文件vmlinux,在自定义内核的基础之上,进入linux内核源码,linux/tools/perf
make
make install
提示:
1)可能在编译的时候,有报错大概是由于平台问题,数据类型不匹配,导致所有的warning都被当作error对待:出现这问题的原因是-Werror这个gcc编译选项。只要在makefile中找到包含这个-Werror选项的句子,将-Werror删除,或是注释掉就行了
2)安装完毕,perf可执行程序往往位于当前目录,可能不在系统的PATH路径中,此时需要改变环境变量PATH
性能调优工具如 perf,Oprofile 等的基本原理都是对被监测对象进行采样,最简单的情形是根据 tick 中断进行采样,即在 tick 中断内触发采样点,在采样点里判断程序当时的上下文。假如一个程序 90% 的时间都花费在函数 foo() 上,那么 90% 的采样点都应该落在函数 foo() 的上下文中。运气不可捉摸,但我想只要采样频率足够高,采样时间足够长,那么以上推论就比较可靠。因此,通过 tick 触发采样,我们便可以了解程序中哪些地方最耗时间,从而重点分析。
稍微扩展一下思路,就可以发现改变采样的触发条件使得我们可以获得不同的统计数据:
以时间点 ( 如 tick) 作为事件触发采样便可以获知程序运行时间的分布。
以 cache miss 事件触发采样便可以知道 cache miss 的分布,即 cache 失效经常发生在哪些程序代码中。如此等等。
因此让我们先来了解一下 perf 中能够触发采样的事件有哪些。
使用perf list(在root权限下运行),可以列出所有的采样事件
事件分为以下三种:
1)Hardware Event 是由 PMU 硬件产生的事件,比如 cache 命中,当您需要了解程序对硬件特性的使用情况时,便需要对这些事件进行采样;
2)Software Event 是内核软件产生的事件,比如进程切换,tick 数等 ;
3)Tracepoint event 是内核中的静态 tracepoint 所触发的事件,这些 tracepoint 用来判断程序运行期间内核的行为细节,比如 slab 分配器的分配次数等。
上述每一个事件都可以用于采样,并生成一项统计数据,时至今日,尚没有文档对每一个 event 的含义进行详细解释。
3. perf stat——概览程序的运行情况
面对一个问题程序,最好采用自顶向下的策略。先整体看看该程序运行时各种统计事件的大概,再针对某些方向深入细节。而不要一下子扎进琐碎细节,会一叶障目的。
有些程序慢是因为计算量太大,其多数时间都应该在使用 CPU 进行计算,这叫做 CPU bound 型;有些程序慢是因为过多的 IO,这种时候其 CPU 利用率应该不高,这叫做 IO bound 型;对于 CPU bound 程序的调优和 IO bound 的调优是不同的。
如果您认同这些说法的话,Perf stat 应该是您最先使用的一个工具。它通过概括精简的方式提供被调试程序运行的整体情况和汇总数据。
本篇中,我们将在以后使用这个例子test1.c:
测试用例:test1
//test.c void longa() { int i,j; for(i = 0; i < 1000000; i++) j=i; //am I silly or crazy? I feel boring and desperate. } void foo2() { int i; for(i=0 ; i < 10; i++) longa(); } void foo1() { int i; for(i = 0; i< 100; i++) longa(); } int main(void) { foo1(); foo2(); }
将它编译为可执行文件 test1
gcc – o test1 – g test.c注意:此处一定要加-g选项,加入调试和符号表信