一.性能优化中的角色分工 (1).老外的角色分工         在oracle性能优化方法论中,将IT系统中不同角色需要承担的性能优化工作罗列如下. 各司其职的角色分工 业务分析人员 1.业务需求优化 设计人员 2.数据库逻辑设计优化 3.应用流程设计优化 应用开发人员 4.SQL语句优化 5.数据库物理设计优化 数据库管理人员 6.内存和CPU的优化 7.磁盘I/O系统设计和优化 8.系统资源竞争的监测和优化 操作系统管理员 9.操作系统优化 网络管理员 10.网络配置优化       …
        一.概述         Loadrunner拥有极为丰富的工具箱,供予我们制造出各种奇妙魔法的能力.其中就有此次要讨论的socket套接字操作.     二.socket概述         socket是操作系统中I/O系统的网络延伸部分,它扩展了操作系统的基本I/O到网络通信,使进程和机器之间的通信成为可能.如果想完全地理解socket在Loadrunner中如何工作的,熟悉一些关于它的历史会很有帮助.           当前常用的socket,最早起源于BSD UNIX…
通常而言大家普遍的认知里switch case的效率高于if else.根据我的理解而言switch的查找类似于二叉树,if则是线性查找.按照此逻辑推理对于对比条件数目大于3时switch更优,并且对比条件数目越多时switch的优势越为明显. 一.测试目的 最近与开发同学对于前面提到的性能问题,有着各自不同的见解,为证明我的观点,现设计如下测试场景验证 PS:一个方法里多达65个if else   二.测试策略 利用Junit4执行本次测试,分别设计50个.70个.100个条件式测试,每轮测试…
Hint 是Oracle 提供的一种SQL语法,它允许用户在SQL语句中插入相关的语法,从而影响SQL的执行方式. 因为Hint的特殊作用,所以对于开发人员不应该在代码中使用它,Hint 更像是Oracle提供给DBA用来分析问题的工具 .在SQL代码中使用Hint,可能导致非常严重的后果,因为数据库的数据是变化的,在某一时刻使用这个执行计划是最优的,在另一个时刻,却可能很差,这也是CBO 取代RBO的原因之一,规则是死的,而数据是时刻变化的,为了获得最正确的执行计划,只有知道表中数据的实际情况…
一.概述       Loadrunner作为HP出品的性能测试工具,拥有太多奇妙魔法甜点供予性能测试人员享用,其中吃起来比较有嚼劲的那就是关联了.当然在关联之后我们还需要一些简单的字符处理,用以生成我们所需要的切糕.煎饼果子等.        ps:在此我只会分享手动关联技巧.   二.为什么要关联        通常而言我们的网络应用软件都需要输入账户密码登陆,在用户验证通过登陆以后,服务器如何确认谁是谁呢?        此时一般而言就是SESSIONID了,如下图所示:        …
一.索引概述      索引(index),它是数据库必不可少的一部分.它其实很简单呐!很好理解.      索引好比如一本书的目录,一张地图,一个写字楼里挂在大堂墙上的公司名录,一个地铁站的出口指示牌.      关系型数据库技术的精髓就是通过关系表进行规范化的数据存储,并通过各种表连接技术和各种类型的索引技术来进行信息的检索和处理.合理的索引策略将保证各种操作的高效和快捷,没有合理的索引,将不得不按表进行全部遍历,这意味着退回到文件系统的处理方式,更意味着资源.时间的大量消耗.     二.…
     在上一章里,重点分享了命令行SQL分析工具的使用方法.在本章将重点分享PL/SQL的SQL分析工具. 一.如何打开PL/SQL执行计划      开启PL/SQL这工具,推荐如下方法: 点击文件菜单,选择新建子菜单,选中解释计划窗口 键盘快捷方法,先按alt,然后按F,接着按N,最后按E 二.设置PL/SQL执行计划      初次打开“解释计划窗口”,只能看到基数.优化器.耗费等基本信息,其实这个可以在PL/SQL工具里面设置的.可以看到很多其它信息,如下所示:       三.看懂…
一.SQL语句到底是怎么执行的? 想了解SQL语句到底是怎么执行的,那就需要进行SQL语句执行计划分析. 那什么是SQL语句执行计划呢? 就是Oracle服务器执行SQL语句的过程.例如确定是否使用索引.表连接顺序.表连接技术等. 深入关注理解SQL语句的执行机制,至少要对关键模块的SQL语句进行Oracle SQL语句的执行计划分析.   分析内容至少包括如下方面:      1.表访问方式      2.表索引类型和策略      3.表连接类型和过程      4.排序过程      5.…
自顶向下的性能优化方法论 系统优化是包括系统设计.开发.产品上线.平台优化的全过程,不同阶段的优化工作对全系统所带来的效益是不同的.理想的性能优化论应该采用自顶向下的优化方法,即在项目设计.开发和上线等各项目阶段,均全面贯彻性能优化思想.特别是从头就开始不仅考虑业务功能的实现,而且同时考虑性能和代价. 下图是Oracle公司总结的在不同阶段进行优化工作所带来的效益和代价变化图.   设计阶段囊括的优化相关工作包括: 业务规则的优化设计: 数据库体系结构的优化设计: 数据库逻辑结构设计: 数据库物…
      性能工程师可以具备的专业素养 程序语言原理,包括:C.C++.java及jvm.ASP,因为建站大部分外围应用和中间件都是JAVA编写,大部分的电商平台采用的ASP编写,底层核心系统是C/C++编写: 数据库管理和性能优化,数据库永远的性能要点,包括:传统的关系型数据库oracle.db2.mysql.sql server等,更有对象型新贵数据库mongodb.hadoop.Cassandra等: kernel的实现(比如内存管理.文件系统.系统调用.线程与进程管理),如果不熟悉ke…
       <java performance><品悟性能优化 oracle><面向模式的软件架构-模式系统>读书笔记应用调优分享.      性能问题的解决,首先需要有理论和方法论的指导.否则东一耙,西一棒子,那就是二师兄耕地.既没有从总体上把握住性能问题,同时又浪费了大量宝贵的资源和时间.另外,缺乏方法论的指导,很多问题的解决也只会成为隔靴抓痒,无法从根本上解决问题. 一.关于性能优化的误区与反思 1.性能优化就是调参数 简单地认为性能优化就是调系统参数: 系统参…
接上一节  python学习笔记--Django入门四 管理站点 设置字段可选 编辑Book模块在email字段上加上blank=True,指定email字段为可选,代码如下: class Author(models.Model): first_name = models.CharField(max_length=) last_name = models.CharField(max_length=) email = models.EmailField(blank=True ) 所有字段都默认bl…
Netty 源码 ChannelHandler(四)编解码技术 Netty 系列目录(https://www.cnblogs.com/binarylei/p/10117436.html) 一.拆包与粘包问题 由于 TCP 是面向字节流的,什么意思呢:虽然应用程序和 TCP 的交互是一次一个数据块(大小不等),但 TCP 把应用程序交下来的数据仅仅看成式一连串的无结构的字节流.TCP 并不知道所传送的字节流的含义. 因此 TCP 不保证接收方应用程序所收到的数据块和发送方应用程序所发出的数据块具有…
四种会话跟踪技术 page:代表与一个页面相关的对象和属性.一个页面由一个编译好的 Java servlet 类(可以带有任何的 include 指令,但是没有 include 动作)表示.这既包括 servlet ,又包括被编译成 servlet 的 JSP 页面. request:代表与Web客户机发出的一个请求相关的对象和属性.一个请求可能跨越多个页面,涉及多个 Web 组件(由于 forward 指令和 include 动作的关系). session:代表与用于某个 Web 客户机的一个…
全流程指导Visual Studio Code+Markdown Nice+gitee+PicGo管理自己的技术博客 1.背景 我挺喜欢写博客,但每一次将博客转移到公众号或者知乎,总是需要调整格式,不能一步到位.有没有办法可以管理自己的博客,还真有:MarkDown文档.各个平台,一步到位,格式完全相同.完美! 2.简介 Markdown 简称md,是一种轻量级标记语言,它允许人们使用易读易写的纯文本格式编写文档.最常见的是gituhub中的说明文档.这是一种非常擅长写作,而不用在意写作格式的工…
最近接了个小任务,和公司的iOS小伙伴们分享下instruments的具体使用,于是有了这篇博客...性能优化是一个很大的话题,这里讨论的主要是内存泄露部分. 一. 一些相关概念 很多人应该比较了解这块内容了...可以权当复习复习... 1.内存空间的划分: 我们知道,一个进程占用的内存空间,包含5种不同的数据区:(1)BSS段:通常是存放未初始化的全局变量:(2)数据段:通常是存放已初始化的全局变量.(3)代码段:通常是存放程序执行代码.(4)堆:通常是用于存放进程运行中被动态分配的内存段,O…
禅道官网:http://www.cnezsoft.com/ 简介: 开源免费的项目管理软件.集产品管理.项目管理.测试管理一体以及事物管理组织管理的功能 使用原因: 开源 方便跟踪管理Bug 使用简单易学 及多种管理于一身 1.Bug操作流程 2.Bug的几种解决方案 已解决 延期处理 不予处理 外部原因: 第三方问题 设计如此: 无效Bug 无法重现: 无效Bug 重复Bug : 无效Bug 3.Bug等级简介 Priority: bug的重要性及其解决顺序. Notes: 程序员/工程师可以…
一.Tomcat工作原理 1. TCP的三次握手四次挥手 三次握手: 说明: 类比于A和B打电话: A对B说:你好,我是A,你能听到我说话吗? B对A说:嗯,我能听到你说话 A对B说:好,那我们开始聊天吧 在服务器上使用如下命令能看到当前服务器的连接情况 netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}' 返回结果说明: LAST_ACK 5 (正在等待处理的请求数)SYN_RECV 30ESTABLISHED…
前言 前几篇我们比较基础的讲了下MVC中的知识,这一节我们穿插点知识,讲讲MVC中我们可以提高性能的办法. Razor视图引擎优化(优化一) 我们知道默认情况下配置MVC去解析一个视图会首先约定通过查找所有的匹配Web Form视图引擎的名称.例如当我们查找一个不存在的视图时,会出现如下错误: 从上面我们可以很明显的知道,如果我们MVC应用程序中没有使用ASPX视图时,当我们在Action方法中通过 return View() 返回视图或者 Html.RenderPartial 等查找视图时每次…
本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫. Hi,大家好,欢迎大家和我一起学习 K8S. Deployment 是 K8S v1.2 引入的概念,与之一起引入还有 ReplicaSet.这两个概念是等同的,准确说是 Deployment 内部调用 ReplicaSet 来实现. 之前这个概念是由 Replication Controller 来实现的,但由…
前言 MySQL中的explain命令显示了mysql如何使用索引来处理select语句以及连接表.explain显示的信息可以帮助选择更好的索引和写出更优化的查询语句. 一.格式 explain + select 语句: 例如:explain select * from tb_student; 二.5.5和5.7版本explain的区别 5.7之后的版本默认会有 partitions 和 filtered两列,但是5.5版本中是没有的,需要 使用explain partitions selec…
WeTest 导读 企鹅电竞从17年6月接入weex,到现在已经有一年半的时间,这段时间里面,针对遇到的问题,企鹅电竞终端主要做了下面的优化: image组件 预加载 预渲染 Image组件 weex的list组件和image组件非常容易出问题,企鹅电竞本身又存在很多无限列表的weex页面,list和image的组合爆发的内存问题,导致接入weex后app的内存问题导致的crash一直居高不下. list组件问题 首先来说一下list,list对应的实现是WXListComponent,对应的v…
优化特定类型的查询 COUNT()的作用 COUNT()是一个特殊函数,有两个非常不同的作用:它可以统计某个列值的数量,也可以统计行数.在统计列值时要求列值是非空的(不统计NULL). 如果在COUNT()的括号中指定了列或者列的表达式, 则统计的就是这个表达式有值的结果数. 因为很多人对NULL理解有可题, 所以这里很容易产生误解. COUNT()的另一个作用是统计结果集的行数.当MySQL确认括号内的表达式值不可能为空时,实际上就是在统计行数. 最简单的就是当我们使用COUNT(*)的时候,…
要管理fragment们,需使用FragmentManager,要获取它,需在activity中调用方法getFragmentManager(). 你可以用FragmentManager来做以上事情: 1使用方法findFragmentById()或findFragmentByTag(),获取activity中已存在的fragment们. 2使用方法popBackStack()从activity的后退栈中弹出fragment们(这可以模拟后退键引发的动作). 3用方法addOnBackStack…
在讨论页面重绘.回流之前.需要对页面的呈现流程有些了解,页面是怎么把html结合css等显示到浏览器上的,下面的流程图显示了浏览器对页面的呈现的处理流程.可能不同的浏览器略微会有些不同.但基本上都是类似的.   页面呈现流程 在讨论页面重绘.回流之前.需要对页面的呈现流程有些了解,页面是怎么把html结合css等显示到浏览器上的,下面的流程图显示了浏览器对页面的呈现的处理流程.可能不同的浏览器略微会有些不同.但基本上都是类似的. 1. 浏览器把获取到的html代码解析成1个Dom树,html中的…
前面介绍MongoDB基础,在这里,我们推荐两个网站,我们可以看看,评论是相当具体:http://www.w3cschool.cc/mongodb/mongodb-tutorial.html.http://www.yiibai.com/mongodb/mongodb_create_backup.html#.好这篇文章来看一下MongoDB的数据管理,架构搭建.好.先来看张图: 下边依照这张图进行一一介绍. 一,管理篇,当然主要是对数据库的管理,包含我们最关心的数据.和管理这些数据的用户. 不管非…
上一节  Django入门三 Django 与数据库的交互:数据建模 "管理员界面"是基础功能中的重要部分. django.contrib 包 Django自动管理工具是django.contrib的一部分.django.contrib是一套庞大的功能集,它是Django基本代码的组成部分,Django框架就是由众多包含附加组件(add-on)的基本代码构成的. 你可以把django.contrib看作是可选的Python标准库或普遍模式的实际实现. 它们与Django捆绑在一起,这样…
(这个editor今天有毛病,把我的format全搞乱了,抱歉!) Inheritance 是OOP 的一个重要特征.虽然业界有许多同行不喜欢inheritance,但是正确地使用inheritance是一个应用层面和架构层面的重要设计决定. 大量使用inheritance,尤其在类似std container 中使用,会对程序性能产生何等影响呢? 从我个人的经验来看,constructor对创建具有深层inheritance链的class,有很大的影响. 如果应用容许,最好使用没有constr…
前言 本文翻译自“为电池寿命做优化”系列文档中的其中一篇,用于介绍如何使用Battery Historian分析电源使用情况. 中国版官网原文地址为:https://developer.android.google.cn/topic/performance/power/battery-historian. 路径为:Android Developers > Docs > 指南 > Best practies > Performance > Optimize for batter…
4.1进程性能统计信息 4.1.1. 内核时间VS用户时间 一个应用程序所耗时间最基本的划分是内核时间与用户时间.内核时间是消耗在Linux内核上的时间,而用户时间则是消耗在应用程序或库代码上的时间.Linux有工具,如time和ps,可以(大致)表明应用程序将其时间花费在应用程序代码上还是话费在内核代码上. 4.1.2 库时间VS应用程序时间 任何应用程序,即便其复杂性非常低,也需要依赖系统库才能执行复杂的操作.这些库可能导致性能问题,因此,能够查看应用程序在某个库中花费了多少时间很重要了.在…