运维工程师必须掌握的基础技能有哪些?
如何解决Redis缓存雪崩、缓存穿透、缓存并发等问题? Redis缓存雪崩解决方案由于缓存层承载着大量请求,有效地保护了存储层,但是如果缓存层由于某些原因不能提供服务,于是所有的请求都会达到存储层,存储层的调用量会暴增,造成存储层也会级联宕机的情况。缓存雪崩的英文原意是stampeding herd(奔逃的野牛),指的是缓存层宕掉后,流量会像奔逃的野牛一样,打向后端存储。预防和解决缓存雪崩问题,可以从以下三个方面进行着手。1)保证缓存层服务高可用性。和飞机都有多个引擎一样,如果缓存层设计成高可用的,即使个别节点、个别机器、甚至是机房宕掉,依然可以提供服务,例如前面介绍过的Redis Sentinel和Redis Cluster都实现了高可用。2)依赖隔离组件为后端限流并降级。无论是缓存层还是存储层都会有出错的概率,可以将它们视同为资源。作为并发量较大的系统,假如有一个资源不可用,可能会造成线程全部阻塞(hang)在这个资源上,造成整个系统不可用。降级机制在高并发系统中是非常普遍的:比如推荐服务中,如果个性化推荐服务不可用,可以降级补充热点数据,不至于造成前端页面是开天窗。在实际项目中,我们需要对重要的资源(例如Redis、MySQL、HBase、外部接口)都进行隔离,让每种资源都单独运行在自己的线程池 中,。
如何定义中间件产品? 应用中间件WAS的监控方法可以参考本次线上交流的分享 http://www. talkwithtrend.com/Artic le/216341 tomcat监控工具有市面上的probe等。同时,可以查看中间件的日志、FFDC。
如何解决Redis缓存雪崩、缓存穿透、缓存并发等问题? 缓存穿透很多项目在使用Redis或其他缓存框架的时候,都是先查询缓存,查询不的话再查询数据库,查到之后再放到内存中;如果一个key值本身就不存在,那么每一次都会查询数据库,也就是常说的【缓存穿透】。应对方法:如果在Redis中查询不到,并且查询数据库也没有结果,那么就将这个key写入到Redis中,value=空,并设置一个超时过期时间,例如五分钟,那么五分钟以内的对这个可以的所有查询就可以拦截下来,如果数据库有key对应的数据了,那么五分钟后Redis中的缓存过期,会访问数据库并加载缓存;但是如果被恶意攻击,每次请求的key都不相同且不存在,那么依然会穿透到数据库;布隆过滤器:将可能存在的数据Hash到一个足够大的bitmap上,它可以告诉你“某个key一定不存在或者可能存在”,一个一定不存在的数据会被bitmap拦截。缓存雪崩很多时候,Redis中的缓存是要设置过期时间的,假如Redis中的数据,过期时间都设置成一样的,那么到了时间之后,全部缓存过期失效,下一秒所有的请求都会访问数据库,那么数据库可能因为访问量多大导致“崩溃”,这就是缓存雪崩。应对方法:最暴力的解决办法,缓存不设置自动过期时间,只要缓存不崩,数据库就不会崩。另外一个办法,就是让。
如何用oradebug dump系统状态 dumpsystemstate产生的跟踪文件包含了系统中所有进程的进程状态等信息。每个进程对应跟踪文件中的一段内容,反映该进程的状态信息,包括进程信息,会话信息,enqueues信息(主要是lock的信息),缓冲区的信息和该进程在SGA区中持有的(held)对象的状态等信息。dumpsystemstate产生的跟踪文件是从dump那一刻开始到dump任务完成之间一段事件内的系统内所有进程的信息。那么通常在什么情况下使用systemstate比较合适呢?Oracle推荐的使用systemstate事件的几种情况是:数据库hang住了数据库很慢进程正在hang数据库出现某些错误资源争用dumpsystemstate的语法为:ALTERSESSIONSETEVENTS‘immediatetracenamesystemstatelevel10′;也可以使用ORADEBUG实现这个功能:sqlplus-prelim/assysdbaoradebugsetmypidoradebugunlimit;oradebugdumpsystemstate10如果希望在数据库发生某种错误时调用systemstate事件,可以在参数文件(spfile或者pfile)中设置event参数,例如,当系统发生死锁(出现ORA-00060错误)时dumpsystemstate:event=“60tracenamesystemstatelevel10〃LEVEL参数:10Dumpallprocesses(IGNstate)5Level4+Dumpallprocessesinvolvedinwaitchains(NLEAFstate)4。