如何应对金融市场的快速变化,建立符合市场需求的新一代信息系统是证券一直在追求的目标。为了能够实现效率和敏捷,新一代信息系统应用组件往往采取分布式部署的方式,使得应用程序的环境非常复杂。在这种复杂的IT架构当中,核心的数据库管理成了重中之重。
证券急需从手动为主的被动式数据库管理方式,转换为以专业可视化数据库管理软件为基础的智能运维管理。证券在提高IT系统性能及数据库性能管理方面一直先行先试,本篇重点介绍证券如何通过MaxGauge性能优化管理软件实现在数据库智能运维与分析方面的一些经验。众多数据库性能管理软件中,我们选择了MaxGauge作为数据库性能管理解决方案。这是由于MaxGauge是已经在金融市场上经过验证的,轻量级、专业的秒级别性能管理解决方案。通过MaxGauge我们实现了以下管理目标。
1.可视化管理。之前为了确认数据库的运行情况,需要手动连接数据库运行SQL来获取各种信息。除了耗费时间以外,可视化程度不高,也无法做到实时确认数据库状态。而通过MaxGauge的秒级别统一监控画面,可以对所有实例的运行情况做到秒级别实时监控,减少了大量的日常检查工作。
2.快速定位问题。在导入MaxGauge之前,由于管理的数据库很多,只有当问题发生时才会
连接数据库进行分析,由于手动获取各种数据库信息,所以需要耗费大量时间来排除故障。而通过MaxGauge可以设定核心性能指标的临界值,当数据库产生影响之前,发现问题点,并且通过简单双击,就能确定产生问题的各种信息,做到快速定位问题,解决问题。
3.障碍分析。之前数据库发生障碍,通过Failover等紧急处理方式,恢复业务以后,由于没有问题时间点的数据库运行记录,很难分析具体的问题原因。AWR等工具由于时效性差,无法提供问题当时的原因。MaxGauge的历史记录分析功能,可以把每秒的数据库运行情况及性能统计信息保留起来,可以快速回溯问题发生当时数据库正常处理的应用程序、性能指标、等待事件、SQL等信息,协助DBA得出具体问题原因,以防止相同问题再次发生。
4.容量管理。容量管理是数据库管理中非常重要的工作,可以根据各种资源的使用趋势,确认当前及未来的业务运营情况下,资源是否满足需求的积极应对方案。之前这些工作也消耗大量工作时间。通过MaxGauge自动收集保存所有性能数据,并且完成趋势报告书,这就大大减少了手动统计工作。
5.MaxGauge与智能运维平台的无缝融合。证券使用智能运维平台设置了数据库管理所需要的目标KPI及KPI分析方法,再通过MaxGauge实现了对数据库数千种指标进行实时采集监控,关键的数据库指标如lockwaiting,logicreadxlogfilesync、logfileparallelwrite,activesession等将会直接通过数据总线到达智能运维平台。借助证券智能运维平台的单指标异常检测功能实现对这些核心指标的实时异常检测,从而解决了传统的只能通过固定阈值来进行监控的弊端。同时,MaxGauge采集到的数据库指标与证券APMxNPM,基础监控、日志采集平台采集
到的业务数据、运行数据、网络数据、基础性能数据、日志共同实现了业务的全链路监控。在故障发生的时候,首先通过单指标异常实时监控发现问题,然后通过多指标异常的离算法、聚类算法、排序算法给出最有可能的故障模块或者KPI,最后通过日志模版提取与检测算法对相关的日志进行异常日志定位分析,最终帮助运维人员快速定位问题到故障发生原因,进而快速恢复业务,提升RTO水平。
数据库的性能容量分析也是日常重要的工作之一,证券目前正在探索基于MaxGauge收集到的KPI进行智能趋势分析,对KPI指标进行的安全区间判断,达到预测分析、智能告警,进一步提升数据库的容量精细化管理。
当前企业的竞争力中信息系统的重要性越发明显的情况下,信息系统的性能问题不仅仅是系统管理人员的问题,而是影响一个企业兴衰的关键问题。证券将会持续在IT性能智能管理的路上做到深耕细作。
学习C语言不是一朝一夕的事情,但也不需要花费十年时间才能精通。如何以最小的代价学习并精通C语言是本文的主题。请注意,即使是“最小的代价”,也绝不是什么捷径,而是以最短的时间取得最多的收获,同时也意味着你需要经历艰苦的过程。
一、要读就读好书,否则不如不读
所有初学者面临的第一个问题便是:如何选择教材,好的开始是成功的一半,选择一本优秀的教材是事半功倍的关键因素。不幸的是,学校通常会帮你指定一本很差劲的C语言课本;而幸运的是,你还可以再次选择。
大名鼎鼎的谭浩强教授出了一本《C语言程序设计》,据说发行量有超过400万,据我所知,很多学校都会推荐这本书作为C语言课本。虽然本人的名字(谭浩宇)跟教授仅仅一字之差,但我是无比坚定地黑他这本书的。这本书不是写给计算机专业的学生的,而是给
那些需要考计算机等级考试的其它专业学生看的。这本书的主要缺点是:例子程序非常不专业,不能教给你程序设计应该掌握的思考方式;程序风格相当地不好,会让你养成乱写代码的恶习;错误太多,曾经有人指出过这本书的上百个错误,其中不乏关键的概念性错误。好了,这本书我也不想说太多了,有兴趣大家可以百度一下:)
Kernighan和Ritchie的《TheCProgrammingLanguage》(中译名《C程序设计语言》)堪称经典中的经典,不过旧版的很多内容都已过时,和现在的标准C语言相去甚远,大家一定要看最新的版本,否则不如不看。另外,即使是最经典最权威的书,也没有办法面面俱到,所以手边常备一本《C语言参考手册》是十分必要的。《C语言参考手册》就是《CReferenceManual》,是C语言标准的详细描述,包括绝大多数C标准库函数的细节,算得上是最好的标准C语言的工具书。顺便提一句,最新的《C程序设计语言》是根据C89标准修订的,而《C语言参考手册》描述的是C99标准,二者可能会有些出入,建议按照C99标准学习。还有一本《C和指针》,写得也是相当地不错,英文名是《PointersonC»,特别地强调指针的重要性,算是本书的一个特点吧。不过这本书并不十分适合初学者,如果你曾经学过C语言,有那么一些C语言的基础但又不是很扎实,那么你可以尝试一下这本书。我相信,只要你理解了指针,C语言便不再神秘。
如果你已经啃完了一本C语言教材,想要更进一步,那么有两本书你一定要看。首先是《CTrapsandPitfalls》(中译名《C陷井与缺陷》),很薄的一本小册子,内容非常非常地有趣。要注意一点,这本书是二十多年前写成的,里面提到的很多C语言的缺陷都已被改进,不过能够了解一些历史也不是什么坏事。然后你可以挑战一下《ExpertCProgramming》(中译名《C专家编程》),书如其名,这本书颇具难度,一旦你仔细读完并能透彻理解,你便可以放心大胆地在简历上写“精通C语言”了。
切记一个原则,不要读自己目前还看不懂的书,那是浪费生命。如果你看不懂,那你一定是缺失了某些必需基础知识。此时,你要仔细分析自己需要补充哪些内容,然后再去书店寻讲述的这些内容的书籍。把基础知识补充完毕再回头来学习,才会真正的事半功倍。
二、UIIiX/Linux还是WindoWs,这是个很大的问题
不同的编程环境会造就出不同思维的程序员。Windows的程序员大多依赖集成开发环境,比如ViSUalSUIdi0,而UniX程序员更加钟爱Makefile与控制台。显而易见,集成开发环境更容易上手,在c语言入门书籍排行榜Windows上学习C语言,只需要会按几个基本的VisutalC++工具栏按钮就可以开始写Heno,World!了,而在UniX下,你需要一些控制台操作的基本知识。有人也许认为U
nix的环境更简洁,但习惯的力量是很大的,大家都很熟悉WindoWS的基本操作,而为了学习C语言去专门装一个Unix系统,似乎有点不划算。
对于一个只懂得Windows基本操作、连DOS是什么都不知道的新手而言,尽快做一些有趣而有意义的事情才是最重要的。用C语言写一个小程序远比学习Is、Cat等命令有趣,况且我们要专注于C语言本身,就不得不暂时忽略一些东西,比如编译链接的过程、Makefile的写法等等等等。
所以我建议初学者应该以VisualC++6.0(不是VisualC++.NET)或者DevC++作为主要的学习环境,而且千万不要在IDE的使用技巧上过多纠缠,因为今后你一定要转向Unix环境的。ViSUalC++6.0使用很方便,调试也很直观,但其默认的编译器对C标准的支持并不好,而DevC++使用gcc编译器,对C99的标准都支持良好。使用顺带提一下,很多大学的C语言课程还在使用TUrboC2.0作为实验环境,这是相当不可取的,原因其一是TC2.0对C标准几乎没有支持,其二是TC2.0编译得到的程序是16位的,这对今后理解32位的程序会造成极大的困扰(当然,用djgpp之类的东西可以使TC2.0编译出32位程序,不过那过于复杂了)。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论