Sam Selikoff
New York, NY • January 22, 2015
@samselikoff
Front-end engineer at
sam@ted.com
Rails
JS
CSS
HTML
Data Layer
Frontend app
JS
CSS
HTML
Then
Now
JSON API
What does it mean to deploy a frontend app?
How do frontend apps get served?
When you visit gmail.com
Index
JS
CSS
<link href="..."> <script src="...">
{
  key: "value"
}
                            So serving a JS app means
So what's in a deploy?
JS
CSS
Often, just
JS
CSS
Index
Step 1
Step 2
Server-side deployments involve
They're complex!
We should avoid all this
if we're only deploying a CSS change
Development, testing and deployments are
isolated, independent, fast
Frontend Backend
Should every Ember app be deployed in this way?
Probably not.
The main cost here is complexity
Is it worth it?
Application Complexity
Worth it
development time
complexity
Architectural complexity
One to one
Many to many
Backends
Frontends
Worth it
Ultimately, it depends on
your environment.
Main idea:
Avoid redeploying the backend
Hosted vs. OSS options
Hosted options
Heroku Buildpack, Divshot, others
But, can get expensive, and proxying can involve extra hops
Open Source options
Roll your own
Some Ember CLI Addons exist for the frontend piece
Another way...
front_end_builds
Open Source options
(inspired by Luke Melia's 2014 RailsConf talk)
front_end_builds
BACKEND
FRONTEND
A Rails engine that lets you
An Ember CLI addon that lets you
front_end_builds: the Rails engine
Rails app
Index
Ember app
Index
Index
front_end_builds: the Rails engine
Install
gem 'front_end_builds'
...
bundle install
rake front_end_builds:install:migrations
rake db:migratefront_end_builds: the Rails engine
Install
front_end_builds: the Rails engine
Mount the Admin
# routes.rb
Rails.application.routes.draw do
  mount FrontEndBuilds::Engine, at: '/frontend-admin'
endfront_end_builds: the Rails engine
Mount the Admin
front_end_builds: the Rails engine
Create a new Frontend
front_end_builds: the Rails engine
Create a route
# routes.rb
Rails.application.routes.draw do
  mount FrontEndBuilds::Engine, at: '/frontend-admin'
  front_end 'my-crm', '/acme/customers'
endTime to push a build!
front_end_builds: the Ember CLI addon
Ember App
Index
front_end_builds
Rails app
S3
JS
CSS
front_end_builds: the Ember CLI addon
Install
ember install:addon ember-cli-front-end-builds
# or
npm install --save-dev ember-cli-front-end-builds
ember generate ember-cli-front-end-buildsfront_end_builds: the Ember CLI addon
Install
front_end_builds: the Ember CLI addon
Setup
ember deploy:setupfront_end_builds: the Ember CLI addon
Setup
front_end_builds: the Ember CLI addon
Deploy!
ember deploy --environment stagingfront_end_builds: the Ember CLI addon
Deploy!
Front End Builds gives you
More possibilities like...
ember-cli-new-build
Excited?
Join
@samselikoff
sam@ted.com