terraform/website/source/index.html.erb

293 lines
10 KiB
Plaintext
Raw Normal View History

2014-07-16 23:51:48 +02:00
<!-- Main jumbotron for a primary marketing message or call to action -->
<div id="jumbotron-mask">
<div id="jumbotron">
<div class="jumbotron-content" id="jumbotron-content">
2016-10-11 04:08:13 +02:00
<div class="container">
<div class="row">
<div class="col-sm-12">
<h2 class="tag-line" id="tag-line" style="visibility: hidden;">Write, plan, and create infrastructure</h2>
</div>
</div>
</div>
2014-07-24 05:35:57 +02:00
</div>
2014-07-16 23:51:48 +02:00
</div>
</div>
2016-10-05 23:05:07 +02:00
<div class="cta" id="primary-cta">
<div class="container">
<div class="row">
2016-10-11 04:08:13 +02:00
<div class="col-md-8">
2016-10-05 23:05:07 +02:00
<p class="lead">Terraform is an open source tool that allows you to codify APIs into
declarative configuration files that can be shared amongst team members,
treated as code, edited, reviewed, and versioned. Safely and
predictably create, change, and improve production infrastructure.</p>
2016-10-11 04:08:13 +02:00
</div>
<div class="col-md-4">
<p class="center vert-container">
2016-10-06 20:55:13 +02:00
<a class="terra-btn" href="/intro/index.html">Get Started</a>
2016-10-05 23:05:07 +02:00
</p>
2016-10-11 04:08:13 +02:00
</div>
2016-10-05 23:05:07 +02:00
</div>
2016-10-11 04:08:13 +02:00
</div><!-- /. row -->
</div><!-- / .container -->
</div><!-- / .#primary-cta -->
2016-10-05 23:05:07 +02:00
2016-10-07 20:00:02 +02:00
<div class="skew-item" id="customer-logos">
2016-10-05 23:05:07 +02:00
<div class="container">
<div class="row">
<div class="col-sm-12">
<p>Trusted in production by:</p>
2016-10-11 04:08:13 +02:00
</div>
<div class="">
2016-10-05 23:05:07 +02:00
<ul class="customer-list">
<li id="nike">Nike</li>
<li id="hbo">HBO</li>
<li id="capital-one">Capital One</li>
<li id="target">Target</li>
<li id="hotels-dot-com">Hotels.com</li>
<li id="home-depot">Home Depot</li>
2016-10-05 23:05:07 +02:00
</ul>
</div>
</div>
2016-10-07 20:00:02 +02:00
</div> <!-- / .container -->
<div class="feature-skew" id="customer-logos-bg"></div>
</div> <!-- / #customer-logos -->
2016-10-05 23:05:07 +02:00
2016-10-05 20:52:58 +02:00
<div id="feature-overview">
2014-07-16 23:51:48 +02:00
<div class="container">
2014-07-23 00:31:43 +02:00
<div class="row">
2016-10-03 21:20:26 +02:00
<div class="col-sm-12">
<h2>Features</h2>
2014-07-16 23:51:48 +02:00
</div>
2016-10-03 21:20:26 +02:00
<div class="col-md-4 col-sm-12">
2016-10-05 01:03:46 +02:00
<div class="feature-card feature-card-write">
2016-10-03 21:20:26 +02:00
<h3>Write</h3>
<p>Infrastructure as code</p>
</div>
</div>
2016-10-03 21:20:26 +02:00
<div class="col-md-4 col-sm-12">
2016-10-05 01:03:46 +02:00
<div class="feature-card feature-card-plan">
2016-10-03 21:20:26 +02:00
<h3>Plan</h3>
<p>Workflows, not technologies</p>
2014-07-16 23:51:48 +02:00
</div>
</div>
2016-10-03 21:20:26 +02:00
<div class="col-md-4 col-sm-12">
2016-10-05 01:03:46 +02:00
<div class="feature-card feature-card-create">
2016-10-03 21:20:26 +02:00
<h3>Create</h3>
<p>Cloneable infrastructure</p>
</div>
</div>
2014-07-16 23:51:48 +02:00
</div>
2016-10-03 21:20:26 +02:00
</div>
</div>
2014-07-16 23:51:48 +02:00
2016-10-05 20:52:58 +02:00
<div class="skew-item feature" id="feature-write">
2016-10-03 21:51:57 +02:00
<div class="container">
<div class="row">
<div class="col-sm-12">
<h2>Infrastructure as code</h2>
<p class="lead">Define infrastructure as code to increase operator productivity through collaboration and automation.</p>
</div>
<div class="col-sm-4">
<h3>Collaborate &amp; share</h3>
<p>Terraform configuration and state can be stored in version control,
shared, and collaborated on by teams of operators.</p>
<h3>Evolve your infrastructure</h3>
<p>Track the complete history of infrastructure versions.</p>
<h3>Automation friendly</h3>
<p>If it can be codified, it can be automated.</p>
</div>
</div>
</div> <!-- /container -->
<div class="feature-skew" id="feature-write-bg">
<img class="feature-image" src="/assets/images/feature-write-bg.svg" />
</div>
2016-10-03 21:51:57 +02:00
</div> <!-- /feature -->
2014-07-23 04:39:04 +02:00
2016-10-05 20:52:58 +02:00
<div class="skew-item feature" id="feature-plan">
2016-10-03 22:06:23 +02:00
<div class="container">
<div class="row">
<div class="col-sm-12">
<h2>One safe workflow across providers</h2>
<p class="lead">Terraform provides an elegant user experience for
operators to safely and predictably make changes to infrastructure.</p>
</div>
<div class="col-sm-4">
<h3>Map resource dependencies</h3>
<p>Understand how a minor change could have potential cascading effects
across an infrastructure before executing that change. Terraform
builds a dependency graph from the configurations, and walks this
graph to generate plans, refresh state, and more.</p>
</div>
<div class="col-sm-4">
<h3>Separation of plan &amp; apply</h3>
<p>Separating plans and applies reduces mistakes and uncertainty at
scale. Plans show operators what would happen, applies execute
changes.</p>
</div>
<div class="col-sm-4">
<h3>One workflow</h3>
<p>Use Terraform to create resources across all major infrastructure
providers (AWS, GCP, Azure, OpenStack, VMware, and more).</p>
</div>
</div>
</div> <!-- /container -->
2016-10-05 20:52:58 +02:00
<div class="feature-skew" id="feature-plan-bg"></div>
2016-10-03 22:06:23 +02:00
</div> <!-- /feature -->
2016-10-05 20:52:58 +02:00
<div class="skew-item feature" id="feature-create">
2016-10-03 22:10:31 +02:00
<div class="container">
<div class="row">
<div class="col-sm-12">
<h2>Cloneable infrastructure</h2>
<p class="lead">Infrastructures share commonality across environments
and organizations. Terraform lets operators easily use the same
configurations in multiple places to save time. </p>
</div>
<div class="col-sm-4">
<h3>Identical environments</h3>
<p>Use the same Terraform configuration to provision identical staging,
qa, and production environments.</p>
</div>
<div class="col-sm-4">
<h3>Shareable modules</h3>
<p>Common Terraform configurations can be packaged as modules and used
across teams and organizations.</p>
</div>
<div class="col-sm-4">
<h3>Combine multiple providers consistently</h3>
<p>Terraform allows you to effortlessly combine high-level system
providers. Launch a server from one cloud provider, add a DNS entry
with its IP with a different provider. Built-in dependency resolution
means things happen in the right order.</p>
</div>
</div>
</div> <!-- /container -->
<div class="feature-skew" id="feature-create-bg">
<img id="feature-create-img" class="feature-image" src="/assets/images/feature-create-bg.svg" />
</div>
2016-10-03 22:10:31 +02:00
</div> <!-- /feature -->
<div class="skew-item" id="demos">
2014-07-16 23:51:48 +02:00
<div class="container">
<div class="terminals row">
2016-10-04 20:07:55 +02:00
<div class="col-sm-12">
<h2>Examples</h2>
</div>
2014-07-16 23:51:48 +02:00
2016-10-05 03:08:55 +02:00
<div class="col-md-6 explantion">
2016-10-04 20:07:55 +02:00
<h3>Layering Resources</h3>
<p>Use attributes from other resources to create a layered
infrastructure. Terraform handles ordering resource creation
automatically.
2014-07-16 23:51:48 +02:00
</p>
</div>
<div class="terminal-item col-xs-12 col-lg-12">
<div class="terminal">
<header>
<h4>Example Configuration</h4>
2014-07-16 23:51:48 +02:00
</header>
<div class="terminal-window">
2014-07-25 20:21:29 +02:00
<div class="">
2014-07-16 23:51:48 +02:00
<div class="display">
2014-07-28 19:48:25 +02:00
<p>resource <span class="txt-spe">"digitalocean_droplet"</span> <span class="txt-str">"web"</span> {</p>
<p> name = <span class="txt-str">"tf-web"</span></p>
<p> size = <span class="txt-str">"512mb"</span></p>
<p> image = <span class="txt-str">"centos-5-8-x32"</span></p>
<p> region = <span class="txt-str">"sfo1"</span></p>
<p>}</p>
<p> </p>
2014-07-28 19:48:25 +02:00
<p>resource <span class="txt-spe">"dnsimple_record"</span> <span class="txt-str">"hello"</span> {</p>
<p> domain = <span class="txt-str">"example.com"</span></p>
<p> name = <span class="txt-str">"test"</span></p>
<p> value = <span class="txt-str">"<span class="txt-var">${digitalocean_droplet.web.ipv4_address}</span>"</span></p>
<p> type = <span class="txt-str">"A"</span></p>
<p>}</p>
2014-07-16 23:51:48 +02:00
</div>
</div>
</div>
</div>
</div> <!-- /.terminal-item -->
2016-10-05 03:08:55 +02:00
<div class="col-md-6 explantion">
2016-10-04 20:07:55 +02:00
<h3>Fast, Simplified Interaction</h3>
2016-10-05 20:52:58 +02:00
<p>Simple and intuitive configuration makes even the most complicated
services approachable: no more web consoles, loading bars, or
confusing CLI clients.
2014-07-16 23:51:48 +02:00
</p>
</div>
<div class="terminal-item col-xs-12 col-lg-12">
<div class="terminal">
<header>
<h4>Example Configuration</h4>
2014-07-16 23:51:48 +02:00
</header>
<div class="terminal-window">
2014-07-25 20:21:29 +02:00
<div class="">
2014-07-16 23:51:48 +02:00
<div class="display">
2014-07-28 19:48:25 +02:00
<p>resource <span class="txt-spe">"aws_elb"</span> <span class="txt-str">"frontend"</span> {</p>
2014-07-28 19:41:17 +02:00
<p> name = <span class="txt-str">"frontend-load-balancer"</span></p>
<p> listener {</p>
2014-07-28 19:41:17 +02:00
<p> instance_port = <span class="txt-int">8000</span></p>
<p> instance_protocol = <span class="txt-str">"http"</span></p>
<p> lb_port = <span class="txt-int">80</span></p>
<p> lb_protocol = <span class="txt-str">"http"</span></p>
<p> }</p>
<p> </p>
2014-07-28 19:41:17 +02:00
<p> instances = [<span class="txt-str">"<span class="txt-var">${aws_instance.app.*.id}</span>"</span>]</p>
<p>}</p>
<p> </p>
2014-07-28 19:48:25 +02:00
<p>resource <span class="txt-spe">"aws_instance"</span> <span class="txt-str">"app"</span> {</p>
2014-07-28 19:41:17 +02:00
<p> count = <span class="txt-int">5</span></p>
2015-12-15 23:20:24 +01:00
<p> </p>
<p> ami = <span class="txt-str">"ami-408c7f28"</span></p>
<p> instance_type = <span class="txt-str">"t1.micro"</span></p>
<p>}</p>
2014-07-16 23:51:48 +02:00
</div>
</div>
</div>
</div>
</div> <!-- /.terminal-item -->
2016-10-11 17:55:19 +02:00
<div class="cta col-sm-12 col-lg-8 col-lg-offset-2" id="demo-cta">
2016-10-05 03:08:55 +02:00
<p class="lead">The intro contains a walkthrough guide, introductory literature and
a range of examples to experiment with Terraform.</p>
<p>
2016-10-06 20:55:13 +02:00
<a class="terra-btn" href="/intro/index.html">Get started</a>
2016-10-05 03:08:55 +02:00
</p>
</div>
2014-07-16 23:51:48 +02:00
</div>
</div><!-- /.container -->
<div class="feature-skew" id="demo-bg"></div>
2014-07-16 23:51:48 +02:00
</div><!-- /#demos -->
<div class="skew-item" id="latest-announcement">
<div class="container">
<div class="row">
<div class="col-sm-12">
<p class="lead"><strong>Latest:</strong> Weve released Terraform 0.7!</p>
<p>
2016-10-06 20:55:13 +02:00
<a class="outline-btn" href="https://www.hashicorp.com/blog/terraform-0-7.html">Read more</a>
</p>
</div>
</div>
</div><!-- /.container -->
<div class="feature-skew" id="latest-announcement-bg"></div>
</div><!-- /#latest-announcement -->
2016-10-05 04:27:35 +02:00
<div class="skew-item" id="enterprise-intro">
2016-10-05 04:27:35 +02:00
<div class="container">
<div class="row">
<div class="col-sm-12">
2016-10-06 01:47:07 +02:00
<h2><span>Terraform Enterprise</span></h2>
2016-10-05 04:27:35 +02:00
<p class="lead">Collaborative Infrastructure Automation for
organizations and businesses. Collaborate on Terraform configurations,
validate changes, and automate provisioning.</p>
<p>
2016-10-06 20:55:13 +02:00
<a class="outline-btn" href="https://www.hashicorp.com/terraform.html">Checkout Terrform Enterprise</a>
2016-10-05 04:27:35 +02:00
</div>
</div>
</div><!-- / .container -->
<div class="feature-skew" id="enterprise-intro-bg"></div>
</div><!-- / #latest-announcement -->