版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、畢業(yè)設(shè)計(jì)外文資料翻譯(譯文)題目名稱: optimizing java applications 學(xué) 院: 計(jì)算機(jī)科學(xué)技術(shù) 專業(yè)年級(jí): 計(jì)算機(jī)科學(xué)與技術(shù)(工)07級(jí) 學(xué)生姓名: 徐 洋 班級(jí)學(xué)號(hào): 1班32號(hào) 指導(dǎo)教師: 張淑英 二一一 年 三 月 十五 日譯文題目: java應(yīng)用軟件最優(yōu)化 原文題目: optimizing java applications 原文出處: database system implementation optimizing java applications use sound practices to make code-and development tea
2、ms-more efficientwithout the right tools and techniques, tuning for performance can be unbearably difficult, yet you cant afford to turn your back on the process. its absolutely critical. with the size and complexity of most java applications, its getting much more important to get an early handle o
3、n performance. gartner estimates that only 14% of applications meet all measured and tested response time estimates. lets consider a true scenario. a development team works on a complex, proprietary application designed to automate the scheduling and loading of railroad freight trains. after the dev
4、elopment cycle, they performance test the application during a planned tuning cycle, and then they begin to get into trouble: they find that they must make sweeping design changes to satisfy performance problems, which will result in major architectural upheaval-theyve waited too long to test. they
5、waste time on a cache that has no bearing on performance-theyve set their priorities incorrectly. the team discovers memory leaks, but the manual detection and troubleshooting cost the team weeks-theyve neglected investment in good tools. when all is said and done, the project is delivered $240,000
6、over budget and more importantly three months late. this story is repeated with increasing regularity across many j2ee development shops. the problems are severe, and also frequently preventable. in this paper, well talk about some ways to move performance out of an inefficient box at the end of the
7、 cycle, and into the fabric of your everyday routine. whats wrong?before looking at effective ways to tune, lets consider some common tuning practices that dont work. at least one of these potential traps plague the vast majority of java developers: neglecting tools. without the right set of tools,
8、you dont have a fighting chance. solving a single tricky memory leak without supporting tools will often cost your employer more than the price of a good performance tool, based on labor and delayed deployment costs. throw in abilities like profiling and threading support, and the right tools go fro
9、m the realm of luxury to essential, but developers and managers alike neglect this area with frightening regularity. setting priorities incorrectly. work on the right performance problem at the right time, and youll be a highly effective tuner. many developers still try to optimize every line of cod
10、e as they go, a tremendously inefficient philosophy. others neglect performance until the end of the cycle, when critical structural changes are all but impossible. we can improve dramatically on both of these approaches. many managers fear placing too much emphasis on performance too soon, yet this
11、 fear is often misplaced. proponents of agile development processes have successfully demonstrated the benefit of continuous integration, so much so that it is working into mainstream development methods. many programming books like kent becks best-selling extreme programming explained provide hard
12、evidence supporting continuous integration, claiming that integration costs increase exponentially with delay. when you think about it, poor performance is often a symptom of an integration problem. gone are the days when performance optimization meant tweaking a couple of lines of code in a single
13、method. today, performance relates primarily to how components work together, across frameworks, applications, components and distributed systems. threading, memory management and distributed communication are the new realms of performance tuning. said another way, performance has largely become an
14、integration issue, and should be attacked at the earliest possible moment. if you can attack performance problems before they have a chance to fester, you dramatically reduce the time that it takes to solve them. with time, they grow in scope and complexity. a better performance process, then, shoul
15、d let you detect problems as early as possible. at first, this goal can sound impractical, but many teams already have the right tools in place to get the job done. how should you tune?the fundamental key to a sound performance process is setting priorities effectively, so automation is critical to
16、your success. the best way to automate is to expand your regular unit tests to also include performance tests. junit is an open source automated testing tool, and is a widely accepted framework for unit testing. if youre already using a tool like junit, youre halfway there. in short, your system wil
17、l automatically measure performance and notify you when a performance test case fails. you can then immediately fix the problem at the time its introduced. to inject performance tests into an existing test suite, you merely need to do the following steps: 1. define performance requirements. 2. add y
18、our automated performance test suites. 3. make the fix. if youre like many developers, you probably invest most of your effort on the third step, even though you havent nailed your specific problem. we shift most of that effort into building reusable test cases that repeatedly warn you when performa
19、nce wanders out of an acceptable range. lets address each of these steps in more detail. step 1 define performance requirementswhen you gather requirements for an application, youll often be working from a use case, which is a task that a user wants to accomplish with your system. for each use case,
20、 you should make sure that you understand any performance requirements. does your scenario require immediate response to an end-user, or a batched set of reports with no hard performance requirement? is the user in an internal call center with a customer, or possibly an internet customer? how many s
21、imultaneous users are expected on average and at peak times? by gathering performance criteria for each major use case, youll have some hard data that you can use to manage the rest of the process. remember, no application is perfect: you can always optimize. for efficiency, you should do precisely
22、enough to meet the requirements of your customer. you may well make a conscious decision to over-deliver, anticipating possible future scalability requirements. you can always build in more stringent requirements into your test cases. step 2 automate performance testingmany development teams use the
23、 agile programming practice of writing test cases before the rest of the code. the benefits are well documented, so well not repeat them here. you know youre done when you satisfy the test cases. its the responsibility of each developer to code and maintain a working effective test suite. you should
24、 add performance requirements to your test cases. if you use junit, you can use a junit extension like junitperf (discussed below) to add your performance tests. by adopting automated test suites, you can safely work performance optimization into your everyday routine, without the danger of setting
25、priorities incorrectly. remember: the purpose of your performance tests is to warn you when your codes performance creeps out of accepted tolerances. when that happens, you can drop what youre doing and drill down with your performance tool to profile and solve your performance problem. with this pr
26、ocess, you will greatly reduce your dependence on any special tuning process or team. poor performance can be handled just like any other bug. test scalability and response timewell hit the bare highlights of performance test construction here. you want your test cases to handle simple measurements
27、for response time, and complex measurements of scalability. response time is simply the time between the start and end of a request. scalability measures the number of requests that your application can handle simultaneously. these tests measure each type of performance. timed tests. check the respo
28、nse time of a single method or use case. you can build your timed tests to run a single test, or run multiple tests, and take an average. you can also build your timed tests to disregard early iterations through a test. either way, you must make sure that you discard the overhead for setting up the
29、test. (in most cases, the time is negligible, and its often measurable.) load tests. check the scalability of the system under the load of many simulated users. youll probably want to accumulate several timed tests into a test suite. your tool should let you simulate the user community, whether they
30、 are randomly distributed or evenly spaced. you may want to run your tests at different intervals. basic timed tests can run with the rest of your junit suites. since load tests take longer, you may want to run that test suite less frequently. you may also wind up adding some requirements that test
31、resource usage over time, like memory. some of the better performance test tools allow you to automate this type of testing as well. if yours doesnt, periodic manual tests will do. run your tests throughout the cyclerather than running all of your tests at the end of the cycle, this process calls fo
32、r running your automated tests throughout the cycle. most teams have their junit test cases create a test report after every automated build. this way, youve got an accurate picture of what your system performance looks like at any point in time. remember to address performance as you go. your use c
33、ase is not completed until all of your test cases successfully run. you will find that adding performance tests to your automated test suites is an incredibly liberating experience. by coding the test cases, youll be able to run them throughout the development cycle-not just the end. youll catch pro
34、blems early as theyre introduced, and while they are easy to solve. step 3 make the fixnow that youve identified the areas of your application that need attention, you can finally optimize the scenario. the role of your test suite is to identify what you need to fix, when you need to fix it. instead
35、 of trying to optimize everything, you optimize exactly what needs it. try to choose simple algorithms that work, and spend time on optimizations only when they dont meet your performance requirements. instead of waiting until the end of the cycle, you improve performance on an every-day basis, when
36、 problems are introduced. you do precisely the right amount of work on performance-nothing more, nothing less. you can make design improvements earlier in the cycle, when user requirements dictate that you do so. the result is gratifying. your customers get faster applications, in less time. the see
37、ming paradox is that by adding performance work into your everyday routine, you will become much more efficient overall. what do you need to succeed?you probably already know that good performance tools are the secret to effective optimization. its just too expensive to do business . currently, newp
38、ort group estimates that the average amount of time required to solve a performance problem, from the time that the problem ticket is opened, at 25.8 hours. with compressed budgets and increasing expectations, thats insanely expensive. to have any hope of success, youve simply got to beat the indust
39、rys average, and find the problems faster, and before they leave your protected development environment. invest in tools that support automation and optimizationour process defined two major phases of optimization: identifying the problem, and fixing the problem. both phases need supporting tools. y
40、oull need specialized tools to help you manage performance, and youll want tools to help you identify problems at both development and post-production time: youll need a tool that supports performance unit tests. if youre using junit to automate your test cases, you can use a simple extension like j
41、unitperf to implement your performance tests. youll need a tool to profile and debug your performance problems. for example, borlands optimizeit suite supports your optimization after you find a problem. your tool should be able to quickly profile your code for a scenario, and drill down into proble
42、m areas like memory management and thread interaction. youll need operations tools, like precices indepth and insight, that allow you to keep measuring an application post-production. this tool fills the role of automated unit tests, but after youve moved into production. with so much data and exper
43、ience clearly available about the cost of performance problems and the impact of optimization tools, its amazing to see how many organizations neglect to properly equip their development teams. as frameworks grow in complexity, that practice will simply have to change, as teams wont be able to remai
44、n productive without them. at its core, tuning is effectively gathering and using information. lets look at three specific areas where an optimization tool can make your life easier: profiling code, solving memory leaks, and optimizing threads. start with a profilerafter your test cases have shown t
45、hat you have a scenario with a problem, your first step is to profile the scenario. your tool will add up the cumulative execution time in each method of your code. as you know, a profile is not a flat list of methods: each method usually calls many others. tools with good profilers let you drill do
46、wn graphically, and find the coding sections that are requiring the most time. for example, if you find that an unhealthy amount of time is spent dealing with string manipulation, you know that you should tweak the algorithms that build or manage strings. if, instead, you find that most of the time
47、is spent on communications-related activities, then youve probably got to reduce the number of network round-trip communications, possibly through a cache or a session facade. in any case, the profiler alone can often provide enough information to help you rapidly localize and solve your problem. so
48、lve memory leakssome problems are especially hard to track manually, because they are outside of an applications sphere of control. the garbage collector and heap are usually hidden to the application, but performance tools designed to find memory leaks can watch heaps and trigger garbage collection
49、, giving you enough control to solve the problem. java virtual machines automate memory allocation, and use a technique called reachable objects to do garbage collection. an object is reachable if you can access it directly from some thread, or through a reference in another reachable object. when a
50、n object with a long life span keeps an unwanted reference to an unused object (like a static variable), youve got a leak. to solve memory leaks, youve got to be able to see the heap: the pool of all allocated objects. theres no good way to do so without a tool. even so, finding a leak can be tediou
51、s, but by analyzing two heaps after some time has elapsed, some tools like borlands optimizeit suite can find many leaks automatically by comparing a current heap to a snap shot of a past heap, (see figure 1.) figure 1. the better performance tools can find leaks by comparing two heaps.untangle thre
52、adswith memory management, most developers claim that threading issues are the most difficult performance problems to solve. sometimes, your development environment will have a suitable debugger, but more often, it takes a specialized tool. the problem is that when you run multiple threads in a trad
53、itional debugger, you change the behavior of the application. you need to be able to visualize the threads, as they would operate in a production environment, and see where thread blocking and contention hurt you. look for features that help with these tasks in your thread tool: resolving thread con
54、tentions. when performance issues occur in applications with multiple threads, often the problem is resource contention. multiple threads often compete for the same resources, leaving many threads to block. a good debugger helps you to visually see where too much contention is hurting you, and where
55、 some tasks are taking too long and impacting other threads. solving deadlocks. after an application deadlocks, usually you cant gather any more information. a thread debugger like the one in figure 2 can help you pinpoint exactly which thread is waiting on which resource. note that the debugger aut
56、omatically identifies both the threads and resources involved in the deadlock. figure 2. this thread debugger identifies the culprits in a deadlock situation.summarizing effective java optimizationin the end, you dont wander into good performance by accident: you invest in it. in this paper, weve ou
57、tlined two critical investments. first, a good process, with automated performance tests where possible, will allow you to monitor and optimize your application performance as early as possible, as problems are introduced. second, a good set of tools is as essential for the java developer as they ar
58、e for a carpenter or mechanic. these investments will save you time and money. finding problems earlier in the development cycle will let you fix them faster, when any design changes are less expensive. automating performance testing will let you focus on developing code, knowing that your test suite will catch performance problems as theyre introduced, making you more productive. and inve
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年物流園區(qū)建設(shè)項(xiàng)目合作開發(fā)合同
- 2024年版銷售人員全面工作合同樣本
- 2024年研發(fā)合作合同范本:新產(chǎn)品研發(fā)與推廣
- 義務(wù)教育數(shù)學(xué)課程標(biāo)準(zhǔn)(2022年版)題庫答案
- 2024年跨境電商銷售合同英文版版B版
- 2024年土特產(chǎn)區(qū)域代理合作協(xié)議范本3篇
- 2024年電子支付系統(tǒng)技術(shù)許可合同
- 2025年度軟件園辦公場(chǎng)地使用權(quán)及廣告發(fā)布合同3篇
- 2025年度二零二五年度邊坡防護(hù)施工與地質(zhì)勘察合同2篇
- 2024年股東權(quán)益共享協(xié)議書
- 0的認(rèn)識(shí)和加、減法(說課稿)-2024-2025學(xué)年一年級(jí)上冊(cè)數(shù)學(xué)人教版(2024)001
- 2025年廣西旅發(fā)南國(guó)體育投資集團(tuán)限公司招聘高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2024-2025學(xué)年銅官山區(qū)數(shù)學(xué)三年級(jí)第一學(xué)期期末調(diào)研試題含解析
- ISO 56001-2024《創(chuàng)新管理體系-要求》專業(yè)解讀與應(yīng)用實(shí)踐指導(dǎo)材料之18:“7支持-7.1資源”(雷澤佳編制-2025B0)
- ISO 56001-2024《創(chuàng)新管理體系-要求》專業(yè)解讀與應(yīng)用實(shí)踐指導(dǎo)材料之17:“6策劃-6.6合作”(雷澤佳編制-2025B0)
- ISO 56001-2024《創(chuàng)新管理體系-要求》專業(yè)解讀與應(yīng)用實(shí)踐指導(dǎo)材料之16:“6策劃-6.5組織結(jié)構(gòu)”(雷澤佳編制-2025B0)
- 全國(guó)英語教師賽課一等獎(jiǎng)七年級(jí)上冊(cè)(人教2024年新編)《Unit 7 Happy Birthday》教學(xué)設(shè)計(jì)
- 碳排放監(jiān)測(cè)技術(shù)
- 2024年世界職業(yè)院校技能大賽高職組“關(guān)務(wù)實(shí)務(wù)組”賽項(xiàng)參考試題庫(含答案)
- 超市項(xiàng)目投標(biāo)書模板
- 耐火材料行業(yè)競(jìng)爭(zhēng)格局分析(如市場(chǎng)份額、競(jìng)爭(zhēng)優(yōu)劣勢(shì)等)
評(píng)論
0/150
提交評(píng)論