terraform/website/source/index.html.erb

280 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">
2016-10-25 02:59:55 +02:00
<h2 class="tag-line" id="tag-line" style="visibility: hidden;">Write, plan, and create infrastructure as code</h2>
2016-10-11 04:08:13 +02:00
</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-25 02:59:55 +02:00
<p class="lead">Terraform enables you to safely and predictably create, change, and
2016-10-31 23:52:32 +01:00
improve production infrastructure. It is an open source tool that
codifies APIs into declarative configuration files that can be shared amongst team members,
2016-10-25 02:59:55 +02:00
treated as code, edited, reviewed, and versioned. </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
<div class="temp-skew"></div>
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>
<div class="col-sm-4">
2016-10-31 20:18:45 +01:00
<a href="#write-section" class="feature-card feature-card-write">
2016-10-03 21:20:26 +02:00
<h3>Write</h3>
<p>Infrastructure as code</p>
2016-10-31 20:18:45 +01:00
</a>
</div>
<div class="col-sm-4">
2016-10-31 20:18:45 +01:00
<a href="#plan-section" class="feature-card feature-card-plan">
2016-10-03 21:20:26 +02:00
<h3>Plan</h3>
2016-10-25 02:59:55 +02:00
<p>Preview changes before applying</p>
2016-10-31 20:18:45 +01:00
</a>
2014-07-16 23:51:48 +02:00
</div>
<div class="col-sm-4">
2016-10-31 20:18:45 +01:00
<a href="#create-section" class="feature-card feature-card-create">
2016-10-03 21:20:26 +02:00
<h3>Create</h3>
2016-10-25 02:59:55 +02:00
<p>Reproducible infrastructure</p>
2016-10-31 20:18:45 +01:00
</a>
</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">
2016-10-31 20:18:45 +01:00
<div id="write-section" class="row">
2016-10-03 21:51:57 +02:00
<div class="col-sm-12">
<h2>Infrastructure as code</h2>
2016-10-31 23:52:32 +01:00
<p class="lead">Define infrastructure as code to increase operator productivity and transparency.</p>
2016-10-03 21:51:57 +02:00
</div>
<img class="feature-image" id="feature-image-write-sm-screen" src="/assets/images/feature-write-bg.svg" />
2016-10-03 21:51:57 +02:00
<div class="col-sm-4">
<h3>Collaborate &amp; share</h3>
2016-10-31 23:52:32 +01:00
<p>Terraform configuration can be stored in version control,
2016-10-03 21:51:57 +02:00
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" id="feature-image-write-lg-screen" 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">
2016-10-31 20:18:45 +01:00
<div id="plan-section" class="row">
2016-10-03 22:06:23 +02:00
<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>
2016-10-14 20:34:27 +02:00
<div class="col-sm-12">
<img class="feature-image" id="feature-image-plan-sm-screen" src="/assets/images/feature-plan-sm-bg.svg" />
<img class="feature-image" id="feature-image-plan-lg-screen" src="/assets/images/feature-plan-bg.svg" />
</div>
2016-10-03 22:06:23 +02:00
<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">
2016-10-31 20:18:45 +01:00
<div id="create-section" class="row">
2016-10-14 20:34:27 +02:00
<div class="col-sm-6">
2016-10-31 23:52:32 +01:00
<h2>Reproducible infrastructure</h2>
<p class="lead">Terraform lets operators easily use the same
configurations in multiple places to reduce mistakes and save time.</p>
2016-10-03 22:10:31 +02:00
</div>
2016-10-14 20:34:27 +02:00
<div class="col-sm-6">
2016-10-14 20:35:32 +02:00
<img class="feature-image" id="feature-image-create" src="/assets/images/feature-create-bg.svg" />
2016-10-14 20:34:27 +02:00
</div>
</div>
<div class="row">
2016-10-03 22:10:31 +02:00
<div class="col-sm-4">
2016-10-31 23:52:32 +01:00
<h3>Environment parity</h3>
2016-10-03 22:10:31 +02:00
<p>Use the same Terraform configuration to provision identical staging,
2016-10-31 23:52:32 +01:00
QA, and production environments.</p>
2016-10-03 22:10:31 +02:00
</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 -->
2016-10-14 20:35:32 +02:00
<div class="feature-skew" id="feature-create-bg"></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-25 02:59:55 +02:00
<h3>Composing Resources</h3>
<p>Use attributes from other resources to create an infrastructure
composed of resources across multiple providers.
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>
2016-10-25 02:59:55 +02:00
<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>
2016-10-25 02:59:55 +02:00
<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-31 23:52:32 +01:00
<p class="lead">The intro contains a walkthrough guide, introductory literature, and
2016-10-05 03:08:55 +02:00
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
2016-10-31 23:52:32 +01:00
organizations. Collaborate on Terraform configurations,
validate changes, and automate provisioning across providers.</p>
2016-10-05 04:27:35 +02:00
<p>
2016-10-31 23:52:32 +01:00
<a class="outline-btn" href="https://www.hashicorp.com/terraform.html">Learn More</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 -->