||This article focuses too much on specific examples without explaining their importance to its main subject. (March 2017)|
||It has been suggested that this article be merged into software rejuvenation. (Discuss) Proposed since March 2017.|
In software engineering, software aging refers to all software's tendency to fail, or cause a system failure after running continuously for a certain time. As the software gets older it becomes less immune and will eventually stop functioning as it should, therefore rebooting or reinstalling the software can be seen as a short term fix. A proactive fault management method to deal with the software aging incident is software rejuvenation. This method can be classified as an environment diversity technique that usually is implemented through software rejuvenation agents (SRA).
From both an academic and industrial point of view, the software aging phenomenon has increased. The main focus has been to understand its effects from a verifiable observation and theoretical understanding.
"Programs, like people, get old. We can't prevent aging, but we can understand its causes, take steps to limit its effects, temporarily reverse some of the damage it has caused, and prepare for the day when the software is no longer viable."
Memory bloating and leaking, along with data corruption and unreleased file-locks are particular causes of software aging.
Proactive management of software aging
Software failures are a more likely cause of unplanned systems outages compared to hardware failures. This is because software exhibits over time an increasing failure rate due to data corruption, numerical error accumulation and unlimited resource consumption. In widely used and specialized software, a common action to clear a problem is rebooting because aging occurs due to the complexity of software which is never free of errors. It is almost impossible to fully verify that a piece of software is bug-free. Even high-profile software such as Windows and Mac OSX must receive continual updates to improve performance and fix bugs. Software development tends to be driven by the need to meet release deadlines rather than to ensure long-term reliability. Designing software that can be immune to aging is difficult. Not all software will age at the same rate as some users use the system more intensively than others.
To prevent crashes or degradation a software rejuvenation can be employed proactively as inevitably aging leads to failures in software systems. This happens by removing the accumulated error condition and freeing up system resources, some examples to clean the internal state of the software are to flush operating system kernel tables, garbage collection, reinitialize internal data structures and a well known example of rejuvenation is a system reboot.
Different systems have also implemented the software rejuvenation method which are:
- Transaction processing systems
- Web servers
- Spacecraft systems
||This article may be unbalanced towards certain viewpoints. (March 2017)|
In most systems, programs can request temporary memory from the system when they need it. However, any system has a limited total amount of memory and if one application is using a large amount of it, then other applications won't be able to. In low memory conditions, the system usually functions slower, applications become unresponsive and those that request large amounts of memory unexpectedly may crash. The applications should "free" dynamically requested memory (return it to the system's pool) when they have finished using it, so it can be used by another application when needed.
A memory leak happens when the application is allocated memory but does not free after it has finished using it. This eventually causes the system to run out of memory. In Microsoft Windows, for example, the memory use of Windows Explorer plug-ins and long-lived processes such as services can impact the reliability of the system to the point of making it unusable. A reboot might be needed to make the system work again.
Software rejuvenation helps with memory leaks as it forces all the memory used by an application to be released. The application can be restarted but starts with a clean slate.
|This section does not cite any sources. (March 2017) (Learn how and when to remove this template message)|
Two methods for implementing rejuvenation are:
- Time based rejuvenation
- Prediction based rejuvenation
Garbage collection is a form of automatic memory management whereby the system automatically recovers unused memory. For example, the .NET Framework manages the allocation and release of memory for software running under it. But automatically tracking these objects takes time and is not perfect.
.NET based web services manage several logical types of memory such as stack, unmanaged and managed heap (free space). As the physical memory gets full, the OS writes rarely-used parts of it to disk, so that it can reallocate it to another application, a process known as paging or swapping. But if the memory does need to be used, it must be reloaded from disk. If several applications are all making large demands, the OS can spend much of its time merely moving data between main memory and disk, a process known as disk thrashing. Since the garbage collector has to examine all of the allocations to decide which are in use, it may exacerbate this thrashing. As a result, extensive swapping can lead to garbage collection cycles extended from milliseconds to tens of seconds. This results in usability problems.
- Shereshevsky, Mark; Crowell, Jonathan; Cukic, Bojan; Gandikota, Vijai; Liu, Yan (2003-01-01). "Software Aging and Multifractality of Memory Resources". 2014 44th Annual IEEE/IFIP International Conference on Dependable Systems and Networks. Los Alamitos, CA, USA: IEEE Computer Society. 0: 721. doi:10.1109/DSN.2003.1209987. ISBN 0-7695-1952-0.
- Grottke, M.; Matias, R.; Trivedi, K.S. (2008-11-01). "The fundamentals of software aging". IEEE International Conference on Software Reliability Engineering Workshops, 2008. ISSRE Wksp 2008: 1–6. doi:10.1109/ISSREW.2008.5355512.
- Parnas, D.L. (1994-05-01). "Software aging". 16th International Conference on Software Engineering, 1994. Proceedings. ICSE-16: 279–287. doi:10.1109/ICSE.1994.296790.
- Garg, S.; van Moorsel, A.; Vaidyanathan, K.; Trivedi, K.S. (1998-11-01). "A methodology for detection and estimation of software aging". The Ninth International Symposium on Software Reliability Engineering, 1998. Proceedings: 283–292. doi:10.1109/ISSRE.1998.730892.
- Castelli, V.; Harper, R.E.; Heidelberger, P.; Hunter, S.W.; Trivedi, K.S.; Vaidyanathan, K.; Zeggert, W.P. (2001-03-01). "Proactive management of software aging". IBM Journal of Research and Development. 45 (2): 311–332. doi:10.1147/rd.452.0311. ISSN 0018-8646.
- Gross, K.C.; Bhardwaj, V.; Bickford, R. (2002-12-01). "Proactive detection of software aging mechanisms in performance critical computers". 27th Annual NASA Goddard/IEEE Software Engineering Workshop, 2002. Proceedings: 17–23. doi:10.1109/SEW.2002.1199445.
- Trivedi, Kishor S.; Vaidyanathan, Kalyanaraman (2004-01-01). Reis, Ricardo, ed. Software Rejuvenation - Modeling and Analysis. IFIP International Federation for Information Processing. Springer US. pp. 151–182. doi:10.1007/1-4020-8159-6_6. ISBN 978-1-4020-8158-3.
- Li, Lei; Vaidyanathan, K.; Trivedi, K.S. (2002-01-01). "An approach for estimation of software aging in a Web server". Empirical Software Engineering, 2002. Proceedings. 2002 International Symposium n: 91–100. doi:10.1109/ISESE.2002.1166929.
- "Overview of Memory Leaks". msdn.microsoft.com. Retrieved 2015-11-04.
- "Preventing Memory Leaks in Windows Applications (Windows)". msdn.microsoft.com. Retrieved 2015-11-04.
- S.R., Chaitra; Basu, Anirban. "Software Rejuvenation in Web Services" (PDF). International Journal of Computer Applications. 54 (8): 31–35. doi:10.5120/8589-2340.
- R. Matias Jr. and P. J. Freitas Filho, "An experimental study on software aging and rejuvenation in web servers," Proceedings of the 30th Annual International Computer Software and Applications Conference (COMPSAC'06), Vol. 01, pp. 189 – 196, 2006.
- M. Grottke, R. Matias Jr., and K. S. Trivedi, "The Fundamentals of Software Aging," Workshop of Software Aging and Rejuvenation (WoSAR/ISSRE), 2008.
- R. Matias Jr, P. Barbetta, K. Trivedi, P. Freitas Filho "Accelerated Degradation Tests Applied to Software Aging Experiments," IEEE Transactions on Reliability 59(1): 102-114,2010.
- M. Grottke, L. Li, K. Vaidyanathan, and K.S. Trivedi, "Analysis of software aging in a web server," IEEE Transactions on Reliability, vol. 55, no. 3, pp. 411–420, 2006.
- M. Grottke, K. Trivedi, "Fighting Bugs: Remove, Retry, Replicate, and Rejuvenate," IEEE Computer 40(2): 107-109, 2007.
- More papers on Proceedings of Workshop of Software Aging and Rejuvenation (WoSAR'08,'10, '11, '12, '13, '14) at IEEE Xplore.