java web项目优化记录:优化考试系统
考试系统在进行压力測试时发现,并发量高之后出现了button无反应。试题答案不能写到数据库的问题,于是针对这些核心问题,进行了优化。
数据库方面:
Select语句:Select * from TEB_VB_XZTRecord改为select 必须的列 form TEB_VB_XZTRecord。之前看的教学视频里就讲过最好别用*。因为查询了不必要的列,所以导致了低效率。
insert优化:考试业务的原因。须要把查询出来的试题,一条条的插入到数据库中。优化前:循环+每次插入一条的insert语句。
优化后:insert 表名(字段名) select (字段名) from 表名 where questionID in(,,,,,,,)
这样的优化在insert语句中用了select字句和inkeyword。相当于在数据库运行了查询之后。直接进行了查询。没有通过java项目的一次次的循环。之前想用一个insert+多个value的方法,发现这样的方式在mysql中行的通,但在oracle中行不通。
程序设计和算法优化:
算法常常受个人思路的影响,比方对复用认识深刻,干过的事情就把成果保存下来,以后再用就高效了。
程序设计也是一样。
缓存同样数据
考生的考试卷面,须要由考试信息、个人信息。考试卷面分值分布,试卷内容 四块内容组成。当中考试信息和卷面分值分布 对每一个考生都同样,因此将同样的信息进行缓存。就降低了大量的查询。而不是用一次查一次。
提前谋划,提前准备
在大并发量时。能够提前干的事就提前干,就像请人在自己家吃饭,到了吃饭的点暂时准备饭菜,肯定手忙脚乱。提前准备出来到时候就悠闲了。
对于考试系统的抽卷来说:考生考试时,每一个考生都随机从题库抽取一套试卷。这样的方法包括了大量的查询和一个循环,因此对性能要求较高。而且大并发量时导致了系统根本没反应。
第一次优化:在考试前为考生抽好试卷,考生登录时仅仅需从答题记录表查询就可以。这样是把抽题的过程提前准备好了。
第二次优化:考虑到第一次优化中扔须要大量的查询。这次优化的逻辑是 抽取固定的卷数,比方抽取50套,每套卷有一个卷号,考试前将50套卷载入到内存中。考生随机抽取到一个卷号,然后依据卷号从内存中拿试卷,这样仅仅要查询一次,然后其它考生都能够从内存中获取试卷,避免了大量的查询。
将事情分开干
很忙的时候,把能够后推推的事情推后点。合理规划好资源和时间。答卷过程中,将客观题判分的环节移到了教师判分逻辑中,由于正确答案须要查询。所以在答题时会同一时候有大量的查询和更新操作。去掉了判分,答题时就仅仅有更新了。
再有就是对String的优化,由于考试系统须要将试题显示在界面,因此须要在后台将试题拼好串,显示在前台,当时用了String。但String不是动态扩容的,仅仅会复制原来的String。加上新内容后新生产一个。因此存在着大量的存储浪费,改为了StringBuffer以后,对内存的要求小了非常多。
java web项目优化记录:优化考试系统的更多相关文章
- [经验] Java Web 项目怎么部署到 Linux 系统上
废话少说, 直奔主题 第一步: 将 web 项目打成 war 包 1: 打开项目的 pom.xml 文件 如果是迭代后的项目, 记得修改项目的版本号, 这里我的是第二版所有就把 1 改成了 2 2: ...
- 记录一个奇怪的异常,无法还原此异常。 普通的Maven Java Web 项目
项目 : 普通的Maven Java Web 项目 操作记录: 使用 Maven 构建项目,指令 tomcat7:run 无异常 但使用 eclipse 的 tomcat 运行项目,报此异常. 后面从 ...
- 关于Maven打包Java Web项目以及热部署插件Jrebel的使用
Java Web/Eclipse/Maven/Tomcat 最近有个新项目是java web项目,记录一下,可能比较乱.虽然没接触过Java,但是eclipse还是用过的 初识项目 同事说,项目是ma ...
- Java Web项目在Mac系统上启动时提示nodename nor servname provided
今天一不小心更新了Mac系统,然后在启动Java Web项目的时候,提示了java.net.UnknownHostException: MAC-mini-local nodename nor serv ...
- Java Web项目在Mac系统上启动时提示nodename nor servname provided的解决办法
今天在Mac系统上启动Java Web项目的时候,提示了Java.net.UnknownHostException: yangxiaomindeMacBook-Pro.local nodename n ...
- 大型Java Web项目的架构和部署问题
一位ID是jackson1225的网友在javaeye询问了一个大型Web系统的架构和部署选型问题,希望能提高现有的基于Java的Web应用的服务能力.由于架构模式和部署调优一直是Java社区的热门话 ...
- Java Web项目中连接Access数据库的配置方法
本文是对前几天的"JDBC连接Access数据库的几种方式"这篇的升级.因为在做一些小项目的时候遇到的问题,因此才决定写这篇博客的.昨天已经将博客公布了.可是后来经过一些验证有点问 ...
- step2-------使用myeclipse创建maven java web项目
1.文章内容概述: 在对项目需求进行分析之后,决定使用maven对我的java web项目进行管理,这篇文章记录了使用myeclipse创建maven java web项目的过程. 2.开发环境: j ...
- Java web项目综合练习(Estore)
Java web项目综合练习(Estore) 复习day18: ajax代码的书写步骤 2)json格式文本,转js对象的方法是那个 项目开发流程介绍 这里学习的JavaWEB项目实战,主要是把前面学 ...
随机推荐
- leetcode221 Maximal Square
思路: dp. 实现: class Solution { public: int maximalSquare(vector<vector<char>>& matrix) ...
- ajax怎么理解?
Ajix是创建交互式网页的前端网页开发技术,不是一种语言,ajax是基于http来传输数据的,他是利用浏览器提供操作http的接口(XMLHttpRequest或者activeXobject),来操作 ...
- C++帮助文档(自己写的)
以下所有记录几乎都是摘抄自<C++ primer 5th 中文> auto 类型说明符 P61 特点: 1. 定义的变量必须有初始值 2. 通过初始值来推算变量的类 ...
- socket相关函数
socket() 我们使用系统调用socket()来获得文件描述符:#include<sys/types.h>#include<sys/socket.h>int socket( ...
- 最优化方法系列:SGD、Adam
整理一下资源,不过最好还是根据书上的理论好好推导一下..... 文章链接:Deep Learning 最优化方法之SGD 72615436 本文是Deep Learning 之 最优化方法系列文章 整 ...
- 《网络管理》IP地址管理与子网划分
IP地址管理——ipmaster ipmaster是一款对IP地址进行管理的软件,使用该软件可以提高网络管理员的工作效率.在大型网络中,使用该软件可以有序且高效地实现大中小型企业网IP地址的分配和管理 ...
- Codeforces_765_D. Artsem and Saunders_(数学)
D. Artsem and Saunders time limit per test 2 seconds memory limit per test 512 megabytes input stand ...
- HDU_1176_免费馅饼
http://acm.hdu.edu.cn/showproblem.php?pid=1176 参考自:http://blog.csdn.net/xcszbdnl/article/details/787 ...
- CAD使用GetxDataDouble读数据(网页版)
主要用到函数说明: MxDrawEntity::GetxDataDouble2 读取一个Double扩展数据,详细说明如下: 参数 说明 [in] LONG lItem 该值所在位置 [out, re ...
- 梦想CAD控件网页版线型
增加线型 主要用到函数说明: _DMxDrawX::AddLinetype 增加一个线型定义.详细说明如下: 参数 说明 BSTR pszName 线型名 BSTR pszLineDefine 线定义 ...