Site reliability engineering
Site Reliability Engineering (SRE) is a subset of web development that encompasses principles and practices that integrate software engineering with IT infrastructure and operations[1] to enhance system reliability. SRE shares some similarities with DevOps, which focus on software development and operational practices. HistoryThe field of SRE originated at Google with Ben Treynor Sloss,[2][3] who founded a site reliability team in 2003.[4] The concept expanded within the software development industry, leading various companies to employ site reliability engineers.[5] By March 2016, Google had over 1,000 site reliability engineers on staff.[6] Dedicated SRE teams are common at larger web development companies. In midsize and smaller companies, DevOps teams sometimes serve the dual purpose of SRE.[5] Organizations that have adopted the concept include Airbnb, Dropbox, IBM,[7] LinkedIn,[8] Netflix,[6] and Wikimedia.[9] DefinitionSite reliability engineering, as a job role, may be performed by individuals or collectively as a team. Site reliability engineers (SREs) are responsible for a combination of the following within a broader engineering organization: system availability, latency, performance, efficiency, change management, monitoring, emergency response, and capacity planning.[10] SREs often have backgrounds in software engineering, system engineering, and/or system administration.[11] The focuses of SRE include automation, system design, and improvements to system resilience.[11] SRE is considered a specific implementation of DevOps;[12] focusing specifically on building reliable systems, whereas DevOps covers a broader scope of operations.[13][14][15] Despite having different focuses, some companies have re-branded their operations teams to SRE teams.[5] Principles and practicesCommon definitions of the practices are but not limited to:[1][16]
Common definitions of the principles are but not limited to:
ImplementationsSRE teams collaborate with other departments within organizations to implement principles effectively. Below is an overview of common practices:[18] Kitchen SinkKitchen Sink refers to the expansive and often unbounded scope of services and workflows that SRE teams oversee. Unlike traditional roles with clearly defined boundaries, SREs are tasked with various responsibilities, including system performance optimization, incident management, and automation. This approach allows SREs to address multiple challenges, ensuring that systems run efficiently and evolve in response to changing demands and complexities. InfrastructureInfrastructure SRE teams focus on maintaining and improving the reliability of systems that support other teams' workflows. While they sometimes collaborate with platform engineering teams, their primary responsibility is ensuring up-time, performance, and efficiency. Platform teams, on the other hand, primarily develop the software and systems used across the organization. While reliability is a goal for both, platform teams prioritize creating and maintaining the tools and services used by internal stakeholders, whereas Infrastructure SRE teams are tasked with ensuring those systems run smoothly and meet reliability standards. ToolsSRE teams utilize a variety of tools to measure, maintain, and enhance system reliability. These tools play a role in monitoring performance, identifying issues, and facilitating proactive maintenance. For instance, Nagios Core is widely used for system monitoring and alerting, while Prometheus (software) is popular for collecting and querying metrics in cloud-native environments. Product or applicationSRE teams dedicated to specific products or applications are common in large organizations.[19] These teams are responsible for ensuring the reliability, scalability, and performance of key services. In larger companies, it's typical to have multiple SRE teams, each focusing on different products or applications, ensuring that each area receives specialized attention to meet performance and availability targets. EmbeddedIn an embedded model, individual SREs or small SRE pairs are integrated within software engineering teams. These SREs work closely with developers, applying core SRE principles, such as automation, monitoring, and incident response—directly to the software development lifecycle. This approach helps improve reliability, performance, and collaboration between SREs and developers. ConsultingConsulting SRE teams specialize in advising organizations on the implementation of SRE principles and practices. Typically composed of seasoned SREs with a history across various implementations, these teams provide insights and guidance for specific organizational needs. When working directly with clients, these SREs are often referred to as 'Customer Reliability Engineers.' In large organizations that have adopted SRE, a hybrid model is common[citation needed]. This model includes various implementations, such as multiple Product/Application SRE teams dedicated to addressing the unique reliability needs of different products. An Infrastructure SRE team may collaborate with a Platform engineering group to achieve shared reliability goals for a unified platform that supports all products and applications. IndustrySince 2014, the USENIX organization has hosted the annual SREcon conference, bringing together site reliability engineers from various industries. This conference is a platform for professionals to share knowledge, explore best practices, and discuss trends in site reliability engineering.[20] See alsoReferences
Further reading
External links
|