Content deleted Content added
←Created page with ''''Infrastructure as Code''' ('''IaC''') is the process of managing and provisioning your infrastructure (bare-metal servers, virtual servers, etc.) and configur...' |
m clean up, added orphan, uncategorised tags using AWB |
||
Line 1:
{{Orphan|date=January 2016}}
'''Infrastructure as Code''' ('''IaC''') is the process of managing and provisioning your infrastructure (bare-metal servers, virtual servers, etc.) and configuration through a programmatic framework rather than using scripts or manual processes.
==Overview==
IaC grew as a response to the difficulty posed from two pieces of disruptive technology – utility computing and second-generation web framework. This brought about widespread scaling problems for many enterprises that were previously only witnessed by huge companies.<ref name= CCA>{{cite report |last= Fletcher | first= Colin | last2= Cosgrove | first2=Terrence |title=Innovation Insight for Continuous Configuration Automation Tools|website=Gartner|url=http://www.gartner.com/document/3119319?ref=unauthreader | date=26 August 2015}}</ref> In 2006 specifically, new challenges were brought to the forefront that shook the technology industry; the launch of Amazon web services’ Elastic Compute Cloud and the 1.0 version of [[Ruby on Rails]] just months before.<ref>{{cite journal | last=Bower |first=Joseph L. | last2= Christensen | first2= Claton M. | title= Disruptive Technologies: Catching the Wave | journal= Harvard Business Review}}
==Added Value and Advantages==
The value of Infrastructure as Code can be broken down into three, measurable categories: Cost (reduction), Speed (faster execution) and Risk (remove errors and security violations).<ref>{{cite web| url=http://devops.com/2015/02/26/how-deploy-frequency-impacts-infrastructure-stability/| title=How Deploy Frequency Impacts Infrastructure Stability| last= Macvittie |first= Lori| website= DevOps.com | date= 26 February 2015}}</ref> Cost reduction aims at helping not only the enterprise financially but also in terms of people and effort, meaning that by removing the manual component, people are able to refocuses their efforts towards other enterprise tasks. Infrastructure automation enables speed through faster execution when configuring your infrastructure and aims at providing visibility to help other teams across the enterprise work quickly and more efficiently. Automation removes the risk associated with human error, like manual misconfiguration; removing this can decrease downtime and increase reliability. These outcomes and attributes help the enterprise move towards implementing a culture of DevOps.<ref>{{cite web| url=http://devops.com/2015/05/14/moving-from-infrastructure-automation-to-true-devops/| title= Moving from Infrastructure Automation to True DevOps| last= Phillips |first=Andrew| website= DevOps.com| date= 14 May 2015}}</ref>
==Types of Approaches ==
There are generally two approaches to IaC declarative (functional) vs. imperative (procedural). The difference between the declarative and imperative approach is essential ''what'' versus ''how''. The declarative approach focuses on what the configuration should be; whereas, imperative focuses on how the infrastructure is to be configured.
==Methods==
There are two methods of IaC Push and Pull. The main difference is the manner in which the servers are told how to be configured. In the Pull method the remote server or agent will pull the configuration from the main server. In the Push method the master server pushes the configuration to the remote system.<ref>
==Tools==
There are many tools that fulfill infrastructure automation capabilities and utilize infrastructure as Code. Broadly speaking, any framework, or tool that performs changes or configures infrastructure declaratively or imperatively based on a programmatic approach can be considered IaC.<ref>{{cite report |title=Garner Market Trends: DevOps – Not a Market, but Tool-Centric Philosophy That supports a Continuous Delivery Value Chain |publisher=Gartner |date=18 February 2015}}</ref> Traditionally, Server (lifecycle) automation and configuration management tools were used to accomplish IaC, now enterprises are utilizing Continuous Configuration Automation tools or stand-alone IaC frameworks, such as Microsoft’s PowerShell DSC.<ref name = powershell>
===Continuous Configuration Automation===
All Continuous Configuration Automation (CCA) tools can be thought of as an extension of traditional IaC frameworks; it leverages IaC to change, configure, and automate infrastructure, but also provides visibility, efficiency and flexibility in how your infrastructure is managed.
====Community Content====
An important aspect when considering CCA tools is the community content. As Gartner states the value of CCA tools is “as dependent on user community-contributed content and support as it is on the commercial maturity and performance of the automation tooling.”<ref name=CCA/> Vendors like Puppet and Chef, those that have been around a significant amount of time, have created their own communities; Chef has Chef Community Repository and Puppet has PuppetForge,<ref>{{cite web|url=https://philsturgeon.uk/devops/2012/10/28/puppet-or-chef/|title=Puppet or Chef?| last= Sturgeon |first= Phil
Notable CCA tools include:
Line 62 ⟶ 64:
==Relationship to DevOps==
Infrastructure as Code can be a key attribute of enabling best practices in [[DevOps]] – Developers become more involved in defining configuration and Ops teams get involved earlier in the development process.<ref>{{cite web| url= http://info.easydynamics.com/blog/continuous-integration-infrastructure-as-code |title= Continuous Integration: Infrastructure as Code in DevOps | last= Ramos | first= Martin | website= easydynamics.com | date= 4 November 2015}}</ref> Tools that utilize IaC bring visibility to the state and configuration of servers and ultimately provide the visibility to users within the enterprise, aiming to bring teams together to maximize their efforts.<ref>{{cite report |title=Infrastructure As Code: Fueling the Fire for Faster Application Delivery |publisher=Forrester |date=March 2015}}</ref> Automation in general aims to takes the confusion and error-prone aspect of manual processes and make it more efficient, and productive. Allowing for better software and applications to be created with flexibility, less downtime, and an overall cost effective way for the company. IaC is intended to reduce the complexity that kills efficiency out of manual configuration. Automation and collaboration are considered central points in DevOps; Infrastructure automation tools are often included as components of a DevOps toolchain.<ref>
==References==
{{Reflist}}
[[:Category:Agile software development]]
Line 72 ⟶ 73:
[[:Category:Configuration management]]
[[:Category:Systems engineering]]
{{Uncategorized|date=January 2016}}
|