优化流程:
检查、测试、分析--找出性能瓶颈--寻找优化方案--评估优化方案--制定优化计划
系统优化过程:
检查环境配置--检查数据库设计--检查数据库索引--视图--检查SQL(静态、动态)--检查应用程序代码(页面、代码)--第三方工具新技术--更改程序数据库设计
系统优化中普遍遵循 2:8 原则:
80%的工作只能产生20%的效果;
80%的时间只能产生20%的效果;
80%的性能问题由20%的代码引起;
20%的sql占用了80%的资源;
木桶原理:
木桶能装多少水,是由最短的木板决定的
瓶颈是由最短的木板引起的;
优化的关键是加长最短的木板;
永远有最短的木板,优化要适可而止
优化中常见的误区:
1、没有找到瓶颈;
2、只进行软优化、不进行硬优化;
3、没有经过sql优化就进行更改程序数据库设计;
4、未考虑使用第三方工具、新技术进行优化;
DB2数据库的优化:
监视开关:
db2 update monitor switches using lock ON sort ON bufferpool ON uow ON table ON statement ON
==收集数据库信息
db2 get db cfg for db_irs
-Lock timeout (sec) (LOCKTIMEOUT) = -1 超时时间
更改设置(连接超时)
db2 update db cfg for db_irs using LOCKTIMEOUT 15
==数据库信息
db2 get snapshot for database on db_irs
-Lock list memory in use (Bytes)= 576 锁列表内存
-Database files closed = 0 关闭文件数 MAXFILOP
-Total sorts = 1 排序开销:Sort overflows/Total sorts <0.003
-Sort overflows = 0
==表信息
db2 get snapshot for tables on db_irs
-Rows Read= 98857 正在读取行
-Overflows= 0 溢出
db2 list tablespaces show detail
-Extent size (pages) = 32 表空间设置
-Prefetch size (pages) = 96
-Number of containers = 3
SQL 静态优化:
大小写(数据库中都会转换为大写)
WHERE子句的执行顺序: 从后到前;
-逐表,关系
FROM子句的执行顺序: 从后到前;
-关系表在后;
JOIN连接执行的顺序: 从后到前;
索引:唯一索引、聚集索引、索引、复合索引
-索引是为查询优化而设计,以降低数据增、删、改效率为代价;
-索引可以提高查询的效率,但会降低操作的效率;
-何时使用:经常在where、order或group by子句中出现的列;
-何时不使用:重复多、包含NULL值的列;
在WHERE中尽量不要使用 OR ,!= , in , like
尽量不要使用SELECT * 语句,使用明确列名;
尽量不要在WHERE中包含子查询
尽量少用子查询,用JOIN代替
子查询中,尽量用EXISTS替代IN、用NOT EXISTS替代NOT IN
避免不同类型值的比较
使用存储过程和视图
用EXISTS替代IN、用NOT EXISTS替代NOT IN;
避免在索引列上使用计算:WHERE SAL*12>25000;
用IN来替代OR: WHERE LOC_ID=10 OR LOC_ID=15 OR LOC_ID=20
避免在索引列上使用IS NULL和IS NOT NULL;
总是使用索引的第一个列;
用UNION-ALL替代UNION;
SQL优化的顺序:
-检查SQL或存储过程的语法,考虑其写法是否还有可优化内容
-检查、优化 索引的使用
-检查子查询 考虑SQL子查询是否可以用简单连接的方式进行重新书写
查看锁信息:
db2 get snapshot for locks on db_irs
db2 list applications for db db_irs show detail
db2 list applications
db2 select * from table(snapshot_lock('db_irs',-1)) as locktable
死锁的优化:
1. 等待锁:
-查找修改产生死锁的逻辑,保证业务逻辑顺序的一致;
2. 队列锁: 消减队列
-调整配置(LOCKTIMEOUT)
-增强硬件处理速度
-优化系统占用资源时间()
-减少用户数
3. 混合锁:
锁: (Lock) 是在多用户环境下为保证数据一致性对资源访问的一种限制
从数据库系统的角度来看 锁分为以下三种类型:
独占锁(Exclusive Lock)
独占锁锁定的资源只允许进行锁定操作的程序使用,其它任何对它的操作均不会被接受。执行数据更新命令,即INSERT、 UPDATE 或DELETE 命令时,SQL Server 会自动使用独占锁。但当对象上有其它锁存在时,无法对其加独占锁。独占锁一直到事务结束才能被释放。
共享锁(Shared Lock)
共享锁锁定的资源可以被其它用户读取,但其它用户不能修改它。在SELECT 命令执行时,SQL Server 通常会对对象进行共享锁锁定。通常加共享锁的数据页被读取完毕后,共享锁就会立即被释放。
更新锁(Update Lock)
更新锁是为了防止死锁而设立的。当SQL Server 准备更新数据时,它首先对数据对象作更新锁锁定,这样数据将不能被修改,但可以读取。等到SQL Server 确定要进行更新数据操作时,它会自动将更新锁换为独占锁。但当对象上有其它锁存在时,无法对其作更新锁锁定。
从程序员的角度看 锁分为以下两种类型:
乐观锁(Optimistic Lock)
乐观锁假定在处理数据时,不需要在应用程序的代码中做任何事情就可以直接在记录上加锁、即完全依靠数据库来管理锁的工作。一般情况下,当执行事务处理时SQL Server会自动对事务处理范围内更新到的表做锁定。
悲观锁(Pessimistic Lock)
悲观锁对数据库系统的自动管理不感冒,需要程序员直接管理数据或对象上的加锁处理,并负责获取、共享和放弃正在使用的数据上的任何锁。
锁的级别:
未授权读取(Read Uncommitted):允许脏读取,但不允许更新丢失。如果一个事务已经开始写数据,则另外一个数据则不允许同时进行写操作,但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。
授权读取(Read Committed):允许不可重复读取,但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现。读取数据的事务允许其他事务继续访问该行数据,但是未提交的写事务将会禁止其他事务访问该行。
可重复读取(Repeatable Read):禁止不可重复读取和脏读取,但是有时可能出现幻影数据。这可以通过“共享读锁”和“排他写锁”实现。读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。
序列化(Serializable):提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,但不能并发执行。如果仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作的事务访问到。
Websphere:
1.Java 虚拟机初始堆大小和最大堆大小 512
2.web容器的线程池最小大小和最大大小 客户数
3.Jdbc连接池属性 100 ~ 客户数
4.servlet高速缓存 启用
5.语句高速缓存大小
http server: httpd.conf
1.KeepAlive 保持客户与HTTP SERVER的连接 OFF
2.ThreadsPerChild 服务器响应线程的数量 客户数
3.CustomLog 日志记录
分享到:
相关推荐
联想工程师专用小工具 系统优化加速工具V1.37.1联想工程师专用小工具 系统优化加速工具V1.37.1联想工程师专用小工具 系统优化加速工具V1.37.1联想工程师专用小工具 系统优化加速工具V1.37.1联想工程师专用小工具 ...
根据文档的概述,文件系统优化涵盖了多个方面,包括但不限于: 1. 文件系统的类型选择:不同的文件系统拥有不同的特性,如ext3/ext4是广泛使用在Linux系统上的文件系统,提供了良好的性能和兼容性;BTRFS(B-Tree ...
系统优化加速工具是一种针对计算机性能提升的软件,旨在帮助用户改善电脑运行速度,减少系统卡顿,提升用户体验。联想系统优化加速工具V1.37.1是专门为联想品牌电脑设计的一款工具,它包含了多种功能,能够有效地...
在IT领域,系统优化工具是不可或缺的一部分,它们旨在帮助用户提升计算机性能,解决运行缓慢、资源占用过高以及系统稳定性问题。"超强系统优化工具"就是这样一款应用,它可能包含了多种功能,如磁盘清理、注册表修复...
电力系统优化调度,详细细节参考:https://mianbaoduo.com/o/bread/Ypyampdr from pylab import * #No. of nodes Nodes = [2,5,10,30] Niter_total = sum(Nodes)*10000 TotalAoi_MA = zeros(shape = (4,1)) ...
标题与描述概述的知识点主要集中在系统优化技巧,尤其是针对DOS环境下的系统调整以及Windows系统的瘦身策略。以下是对这些知识点的详细阐述: ### DOS环境下的系统优化 在DOS(磁盘操作系统)环境下,系统优化主要...
《C#系统优化大师源代码》是一份专为有经验的C#开发者和对系统优化感兴趣的程序员准备的宝贵资源。这个项目旨在实现类似"优化大师"的功能,提供一系列的系统维护和性能提升工具,帮助用户优化Windows XP系统。通过...
在智能手机领域,系统优化是一个持续而深入的课题,随着硬件性能的提升和软件需求的增加,对于智能手机底层系统优化的需求也在不断增长。在本次演讲中,吴章金先生主要介绍了从M9到PRO5智能手机的底层系统优化的演进...
"Deepin XP系统优化专用工具" 是一款专为Deepin XP操作系统设计的性能优化软件。Deepin XP是由中国Deepin公司开发的一个基于Linux内核的桌面操作系统,它对Windows XP系统进行了深度定制,提供了独特的用户体验。这...
在IT领域,系统优化是一个重要的主题,特别是在Windows操作系统中,因为优化可以提升系统的性能、减少资源占用并提高用户体验。本文将深入探讨C#语言在构建Windows系统优化工具方面的作用,以及如何通过源码学习和...
标题中的“最常用的系统优化工具”指的是那些能够帮助用户提升计算机性能、整理系统资源、优化配置和维护系统稳定性的软件工具。这些工具通常包括多种功能,例如卸载管理、自启动项管理、系统清理和隐私保护等。在...
系统优化加速工具是一种专门设计用于提升Windows操作系统性能的软件,其主要目标是通过调整系统设置、清理无用文件以及管理启动项来实现系统的快速启动和流畅运行。在Windows环境中,随着时间的推移,系统可能会积累...
《Windows XP系统优化工具详解与应用》 Windows XP作为一款经典的操作系统,虽然已被微软官方停止支持,但因其稳定性和兼容性,仍有许多用户在使用。为了提升XP系统的性能和安全性,各种优化工具应运而生。本文将...
【标题】:“德国超级系统优化工具套装” 这款“德国超级系统优化工具套装”是一款专为提升计算机性能而设计的专业软件,适用于Windows操作系统,特别是“Win7”系统。它集成了多种功能,旨在帮助用户对电脑进行全...
《RecurDyn多体系统优化仿真技术:深入解析与配套实例》 RecurDyn是一款强大的多体动力学软件,主要用于复杂机械系统的动态分析、优化设计和控制策略开发。这款软件结合了先进的刚柔耦合多体动力学算法,能够帮助...
【系统优化工具YLMF DIY1.6】是一款专为用户设计的便捷式系统优化软件,旨在提升计算机的运行效率和整体性能。该工具由YLMF团队开发,集成了多种实用功能,可以帮助用户轻松解决电脑卡顿、启动慢、内存占用高等常见...
物流系统优化是物流管理的核心环节,旨在提升物流效率和经济效益,确保物流管理目标的实现。这一过程涉及到多种方法,主要包括运筹学方法、智能优化方法和模拟仿真法。 运筹学方法是运用数学模型和算法解决物流问题...
联想常见系统优化维护工具是联想笔记本专用的一款电脑系统优化维护工具。电脑系统是很脆弱滴,是需要我们爱护滴,所以大家可以使用这款软件对系统进行优化与维护,以保障自己的正常使用,欢迎下载 联想常见系统优化...
【智能优化求解】基于粒子群算法实现综合能源系统优化附matlab代码.zip这个压缩包文件,主要聚焦在使用粒子群优化算法(Particle Swarm Optimization, PSO)来解决综合能源系统的优化问题。粒子群优化是一种受到自然...