[go: up one dir, main page]
More Web Proxy on the site http://driver.im/ skip to main content
10.1145/2568088.2568092acmconferencesArticle/Chapter ViewAbstractPublication PagesicpeConference Proceedingsconference-collections
research-article

Exploring synergies between bottleneck analysis and performance antipatterns

Published: 22 March 2014 Publication History

Abstract

The problem of interpreting the results of performance analysis is quite critical, mostly because the analysis results (i.e. mean values, variances, and probability distributions) are hard to transform into feedback for software engineers that allows to remove performance problems. Approaches aimed at identifying and removing the causes of poor performance in software systems commonly fall in two categories: (i) bottleneck analysis, aimed at identifying overloaded software components and/or hardware resources that affect the whole system performance, and (ii) performance antipatterns, aimed at detecting and removing common design mistakes that notably induce performance degradation.
In this paper, we look for possible synergies between these two categories of approaches in order to empower the performance investigation capabilities. In particular, we aim at showing that the approach combination allows to provide software engineers with broader sets of alternative solutions leading to better performance results. We have explored this research direction in the context of Layered Queueing Network models, and we have considered a case study in the e-commerce domain. After comparing the results achievable with each approach separately, we quantitatively show the benefits of merging bottleneck analysis and performance antipatterns.

References

[1]
UML 2.0 Superstructure Specification, OMG document formal/05-07-04, 2005.
[2]
A. Aleti, B. Buhnova, L. Grunske, A. Koziolek, and I. Meedeniya. Software architecture optimization methods: A systematic literature review. IEEE Trans. Software Eng., 39(5):658--683, 2013.
[3]
D. Arcelli, V. Cortellessa, and D. Di Ruscio. Applying model differences to automate performance-driven refactoring of software models. In European Workshop on Computer Performance Engineering (EPEW), pages 312--324, 2013.
[4]
D. Arcelli, V. Cortellessa, and C. Trubiani. Antipattern-based model refactoring for software performance improvement. In International ACM SIGSOFT conference on Quality of Software Architectures (QoSA), pages 33--42, 2012.
[5]
S. Balsamo, A. Di Marco, P. Inverardi, and M. Simeoni. Model-based performance prediction in software development: A survey. IEEE Trans. Software Eng., 30(5):295--310, 2004.
[6]
A. Cicchetti, D. Di Ruscio, and A. Pierantonio. A metamodel independent approach to difference representation. Journal of Object Technology, 6(9):165--185, 2007.
[7]
V. Cortellessa, A. Di Marco, and P. Inverardi. Model-Based Software Performance Analysis. Springer, 2011.
[8]
V. Cortellessa, A. Di Marco, and C. Trubiani. An approach for modeling and detecting software performance antipatterns based on first-order logics. Journal of Software and Systems Modeling, 2012.
[9]
V. Cortellessa, A. Di Marco, and C. Trubiani. Software performance antipatterns: Modeling and analysis. In Formal Methods for Model-Driven Engineering (SFM), pages 290--335, 2012.
[10]
G. Franks, P. Maly, M. Woodside, D. C. Petriu, A. Hubbard, and M. Mroz. Layered Queueing Network Solver and Simulator, 2013. {online}http://www.sce.carleton.ca/rads/lqns/LQNS-UserMan-jan13.pdf.
[11]
G. Franks, D. C. Petriu, C. M. Woodside, J. Xu, and P. Tregunno. Layered bottlenecks and their mitigation. In International Conference on the Quantitative Evaluation of Systems (QEST), pages 103--114, 2006.
[12]
M. Harman and L. Tratt. Pareto optimal search based refactoring at the design level. In Conference on Genetic and evolutionary computation (GECCO), pages 1106--1113, 2007.
[13]
H. Koziolek. Performance evaluation of component-based software systems: A survey. Perform. Eval., 67(8):634--658, 2010.
[14]
N. Mani, D. C. Petriu, and C. M. Woodside. Studying the impact of design patterns on the performance analysis of service oriented architecture. In EUROMICRO Conference on Software Engineering and Advanced Applications, pages 12--19, 2011.
[15]
N. Mani, D. C. Petriu, and C. M. Woodside. Propagation of incremental changes to performance model due to soa design pattern application. In ACM/SPEC International Conference on Performance Engineering (ICPE), pages 89--100, 2013.
[16]
A. Martens, H. Koziolek, S. Becker, and R. Reussner. Automatically improve software architecture models for performance, reliability, and cost using evolutionary algorithms. In WOSP/SIPEW International Conference on Performance Engineering, pages 105--116, 2010.
[17]
T. Mens and T. Tourwé. A survey of software refactoring. IEEE Trans. Software Eng., 30(2):126--139, 2004.
[18]
Object Management Group (OMG). UML Profile for MARTE, 2009. OMG Document formal/08-06-09.
[19]
M. O'Keeffe and M. í Cinnéide. Search-based refactoring for software maintenance. J. Syst. Softw., 81(4):502--516, Apr. 2008.
[20]
T. Parsons and J. Murphy. Detecting Performance Antipatterns in Component Based Enterprise Systems. Journal of Object Technology, 7(3):55--91, 2008.
[21]
D. C. Petriu and H. Shen. Applying the UML Performance Profile: Graph Grammar-Based Derivation of LQN Models from UML Specifications. In Computer Performance Evaluation / TOOLS, pages 159--177, 2002.
[22]
O. Seng, J. Stammel, and D. Burkhart. Search-based determination of refactorings for improving the class structure of object-oriented systems. In Conference on Genetic and evolutionary computation (GECCO), pages 1909--1916, 2006.
[23]
C. U. Smith. Introduction to software performance engineering: Origins and outstanding problems. In Formal Methods for Performance Evaluation, International School on Formal Methods for the Design of Computer, Communication, and Software Systems (SFM), pages 395--428, 2007.
[24]
C. U. Smith and C. V. Millsap. Software performance engineering for oracle applications: Measurements and models. In International Computer Measurement Group (CMG) Conference, pages 331--342, 2008.
[25]
C. U. Smith and L. G. Williams. More new software antipatterns: Even more ways to shoot yourself in the foot. In International Computer Measurement Group (CMG) Conference, pages 717--725, 2003.
[26]
L. G. Williams and C. U. Smith. Software performance engineering: A tutorial introduction. In International Computer Measurement Group (CMG) Conference, pages 387--398, 2007.
[27]
C. M. Woodside, G. Franks, and D. C. Petriu. The Future of Software Performance Engineering. In International Workshop on the Future of Software Engineering (FOSE), pages 171--187, 2007.
[28]
M. Woodside, D. C. Petriu, J. Merseguer, D. B. Petriu, and M. Alhaj. Transformation challenges: from software models to performance models. Journal of Software and Systems Modeling, 2013. accepted.
[29]
J. Xu. Rule-based automatic software performance diagnosis and improvement. Perform. Eval., 67(8):585--611, 2010.

Cited By

View all
  • (2024)Dependability Modeling in an Industrial Environment2024 IEEE 35th International Symposium on Software Reliability Engineering Workshops (ISSREW)10.1109/ISSREW63542.2024.00045(43-48)Online publication date: 28-Oct-2024
  • (2024)Flocks of Birds: A Quantitative EvaluationLeveraging Applications of Formal Methods, Verification and Validation. REoCAS Colloquium in Honor of Rocco De Nicola10.1007/978-3-031-73709-1_17(271-286)Online publication date: 9-Oct-2024
  • (2023)Explainable-DSE: An Agile and Explainable Exploration of Efficient HW/SW Codesigns of Deep Learning Accelerators Using Bottleneck AnalysisProceedings of the 28th ACM International Conference on Architectural Support for Programming Languages and Operating Systems, Volume 410.1145/3623278.3624772(87-107)Online publication date: 25-Mar-2023
  • Show More Cited By

Recommendations

Comments

Please enable JavaScript to view thecomments powered by Disqus.

Information & Contributors

Information

Published In

cover image ACM Conferences
ICPE '14: Proceedings of the 5th ACM/SPEC international conference on Performance engineering
March 2014
310 pages
ISBN:9781450327336
DOI:10.1145/2568088
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

Sponsors

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 22 March 2014

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. bottleneck analysis
  2. model-based performance analysis
  3. performance antipatterns
  4. software performance
  5. software performance feedback

Qualifiers

  • Research-article

Funding Sources

Conference

ICPE'14
Sponsor:

Acceptance Rates

ICPE '14 Paper Acceptance Rate 21 of 78 submissions, 27%;
Overall Acceptance Rate 252 of 851 submissions, 30%

Upcoming Conference

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)11
  • Downloads (Last 6 weeks)3
Reflects downloads up to 05 Jan 2025

Other Metrics

Citations

Cited By

View all
  • (2024)Dependability Modeling in an Industrial Environment2024 IEEE 35th International Symposium on Software Reliability Engineering Workshops (ISSREW)10.1109/ISSREW63542.2024.00045(43-48)Online publication date: 28-Oct-2024
  • (2024)Flocks of Birds: A Quantitative EvaluationLeveraging Applications of Formal Methods, Verification and Validation. REoCAS Colloquium in Honor of Rocco De Nicola10.1007/978-3-031-73709-1_17(271-286)Online publication date: 9-Oct-2024
  • (2023)Explainable-DSE: An Agile and Explainable Exploration of Efficient HW/SW Codesigns of Deep Learning Accelerators Using Bottleneck AnalysisProceedings of the 28th ACM International Conference on Architectural Support for Programming Languages and Operating Systems, Volume 410.1145/3623278.3624772(87-107)Online publication date: 25-Mar-2023
  • (2023)Continuous Dependability Assessment of Microservice SystemsSoftware Architecture. ECSA 2022 Tracks and Workshops10.1007/978-3-031-36889-9_11(138-147)Online publication date: 16-Jul-2023
  • (2021)Envisioning Model-Based Performance Engineering FrameworksProcedia Computer Science10.1016/j.procs.2021.04.008184(541-548)Online publication date: 2021
  • (2021)Integrating the analysis of multiple non-functional properties in model-driven engineeringSoftware and Systems Modeling10.1007/s10270-021-00953-320:6(1777-1791)Online publication date: 28-Nov-2021
  • (2020)VisArch: Visualisation of Performance-based Architectural RefactoringsSoftware Architecture10.1007/978-3-030-58923-3_12(182-190)Online publication date: 8-Sep-2020
  • (2019)A statistics-based performance testing methodology for cloud applicationsProceedings of the 2019 27th ACM Joint Meeting on European Software Engineering Conference and Symposium on the Foundations of Software Engineering10.1145/3338906.3338912(188-199)Online publication date: 12-Aug-2019
  • (2017)Automatic Feedback Generation in Software Performance Engineering: A ReviewOriental journal of computer science and technology10.13005/ojcst/10.02.0810:2(305-310)Online publication date: 6-Apr-2017
  • (2016)Model-Driven Application Refactoring to Minimize Deployment Costs in Preemptible Cloud Resources2016 IEEE 9th International Conference on Cloud Computing (CLOUD)10.1109/CLOUD.2016.0052(335-342)Online publication date: Jun-2016
  • Show More Cited By

View Options

Login options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media