SlideShare a Scribd company logo
Support Training
jclouds: The
Rackspace Java SDK
Everett Toews
Developer Advocate
@everett_toews
You need:
JDK 1.6+
Maven 3+
Rackspace account
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Intro
2
Developer
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Committer on jclouds
3
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Intro
4
Advocate
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Intro
5
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Intro
6
Operations
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Co-author of The OpenStack Operations Guide
7docs.openstack.org/ops
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Intro
8
In startup we
are not allow
dev team for
talk to ops team
except by API.
@DevOps_Borat
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Agenda
9
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
The Workshop
•Introduction
•jclouds Overview
•SDKs
•Terminology
•Cloud Accounts
•Getting Started
10
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
The Workshop
•Examples
•Authentication
•Logging
•Cloud Files
•Cloud Servers
•Cloud Block Storage
•Cloud Load Balancers
•Cloud DNS
•Cross-cloud
11
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
The Workshop
•Wreck-It
•Bug Reports
•Troubleshooting
•Help!
•Potpourri
•Wrap Up
12
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Introduction to jclouds
13
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
jclouds
14
• Cross-cloud toolkit
• Open Source (Apache v2)
• Community
• Portable APIs
• Ecosystem APIs
• Provider APIs
• Java
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
jclouds’ Supported Clouds
•Compute
•Rackspace Cloud
Servers
•HP Cloud Compute
•AWS EC2
•ElasticHosts
•GoGrid
•All Clouds
15
•Storage
•Rackspace Cloud
Files
•HP Cloud Storage
•AWS S3
•Azure
•CloudOne
•All Clouds
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
jclouds Community
16
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
17
APIs and Providers
APIs
Providers
openstack-nova ec2 rackspace-clouddns
rackspace-
cloudservers-us
rackspace-
cloudservers-uk
aws-ec2
rackspace-
clouddns-us
rackspace-
clouddns-uk
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
18
APIs
APIs
openstack-nova
NovaApi:
ServerApi
FlavorApi
ImageApi
=Extensions=
KeyPairApi
SecurityGroupApi
FloatingIpApi
...
ec2
EC2Api:
TagApi
SubnetApi
WindowsApi
rackspace-clouddns
CloudDNSApi:
LimitApi
DomainApi
RecordApi
ReverseDNSApi
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
19
Providers
Providers
rackspace-
cloudservers-us
rackspace-
cloudservers-uk
rackspace-
cloudservers-us
rackspace-
cloudservers-uk
rackspace-
clouddns-us
rackspace-
clouddns-uk
•configuration
•provider specific features
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
jclouds Layers (APIs)
•ComputeService
•OpenStack
•Rackspace
•HP, AWS, etc.
•NovaApi (*Api)
•OpenStack
•Rackspace
•HP
20
Portable
Ecosystem
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
21
jclouds Compute Venn (APIs)
Portable
Ecosystem
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
jclouds Layers (APIs)
22
•BlobStore
•OpenStack
•Rackspace
•HP, AWS, etc.
•SwiftApi
•OpenStack
•Rackspace
•HP
•CloudFilesClient
•Rackspace
Portable
Ecosystem
Provider
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
23
jclouds Storage Venn (APIs)
Portable
Ecosystem
Provider
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
jclouds Community
24
After 3 beer I
can able use
any of cloud
API.
@DevOps_Borat
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Where Does jclouds Live?
25
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDK Deployment
26
Your
System
S
D
K
Cloud
A
P
I
VM
VM
VM
User
System
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDK Deployment
27
A
P
I
Cloud
Your
System
S
D
K
User
System
VM
VM
VM
VM
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
What Can jclouds
Do For You Today?
28
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
29
Plumbing
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
30
(Re)Authentication
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
31
Pagination
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
32
State Polling
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
33
Rate Limiting
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
34
Retry
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
35
Smoothing
Rough Edges
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
36
Open Source
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
37
In devops
nobody is get
fire for buy
open source.
@DevOps_Borat
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
38
Community
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
39
Packaged
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
40
All-in-one
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
41
Extensions
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
42
No lock-in
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
43
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
44
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
45
Battle Tested Code
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
46
Sample Code
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
47
Documentation
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
48
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
SDKs
49
Survey is show
junior devops
are still believe
in Tooth Fairy,
Santa Claus and
documentation. @DevOps_Borat
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Code
50
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Code
51
j.mp/jcldstrain
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Cloud Accounts
52
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Rackspace
•Username
•API Key
•(Password is useable too)
53
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Terminology
54
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Terminology
jclouds Rackspace/OpenStack
Compute Cloud Servers/Nova
Node Server
Location Region
Hardware Flavor
NodeMetadata Server details
User Metadata Metadata
BlobStore Cloud Files/Swift
Blob File/Object
55
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Getting Started
56
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Getting Started
•developer.rackspace.com
•Java
•Getting Started with jclouds
•Get jclouds
•Review JARs
57
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
58
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
59
Cloud Files
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
60
Cloud Servers
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
61
Logging
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
62
Authentication
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
63
?
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Examples
64
Cross-Cloud
j.mp/jcldsglue2013
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
65
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Wreck-It
•Misspell username
•Upload Object to Container that doesn’t
exist
•Create Server in a location that doesn’t
exist
•Use a bad Flavor/Image
•Remove Rackspace JARs from the
classpath
•etc.
66
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Bug Reports,
Troubleshooting,
and Help
67
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Bug Reports
•Get the version
•Get the code
•Get the wire and header logs
•gist or pastie
68
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Troubleshooting
•Download the version
•Run the code
•Compare the wire and header logs
69
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Troubleshooting
•Isolate the problem
•jclouds/User Problem (HTTP 4xx)
•Rackspace Problem (HTTP 5xx)
•Use curl to verify
70
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Troubleshooting
•Debug the source code
•mvn dependency:copy-dependencies
"-DoutputDirectory=./lib"
"-Dclassifier=sources”
71
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Responding
•Ideally:
•Contribute examples/doc
•Send the link to the customer
• jclouds.org/documentation/devguides/contributing-to-jclouds/
•github.rackspace.com/van5941/CLAs
72
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Responding
•Encourage customers to join the jclouds
community:
•jclouds-user-subscribe@apache.org
• www.mail-archive.com/user@jclouds.incubator.apache.org/
73
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Help!
•developer.rackspace.com/support
•javadocs.jclouds.cloudbees.net
•#jclouds on IRC @ freenode.net
•jclouds-user-subscribe@apache.org
•jclouds-dev-subscribe@apache.org
74
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Potpourri
75
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Potpourri
•Moved to Apache Software Foundation
•groupId change
• 1.6.0: <groupId>org.jclouds.X</groupId>
• 1.6.1: <groupId>org.apache.jclouds.X</groupId>
•Package change
•1.6.0: import org.jclouds
•1.7 (2.0?): import org.apache.jclouds
76
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Potpourri
•Google’s Guice & Guava
•Removal of the AsyncApis in 1.7 (2.0?)
•Dropping support for Java 1.6?
•Cloud Files isn’t multi-region...yet
•Cloud Databases in progress
•More endpoints
77
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Potpourri
•Command Line Interface
•Jenkins Plugin
•jclouds-chef
•Who Uses jclouds?
•CloudBees
•Cloudify
•EnterpriseDB
•Pallet
•...
78
RACKSPACE® HOSTING | WWW.RACKSPACE.COM
Potpourri
•More examples
•Other installation methods
•Stay up-to-date with jclouds
•blog.phymata.com
•@everett_toews
•What else can we do to stay in sync?
79
Thank You
Everett Toews
Developer Advocate
@everett_toews
And don’t forget to terminate your VMs
developer.rackspace.com
j.mp/jcldstrain

More Related Content

PPT
Rackspace Private Cloud presentation for ChefConf 2013
PPTX
Solve the Cross-Cloud Conundrum with jclouds at Gluecon 2013
PPT
Rackspace Private Cloud presentation for ChefConf 2014
PDF
Webinar slides: Replication Topology Changes for MySQL and MariaDB
PDF
Automated MySQL failover with MHA: Getting started & moving past its quirks
PPT
Jurijs Velikanovs - RAC Attack 101 - How to install 12c RAC on your laptop
PPT
Looking at RAC, GI/Clusterware Diagnostic Tools
PDF
Docker Basics & Alfresco Content Services
Rackspace Private Cloud presentation for ChefConf 2013
Solve the Cross-Cloud Conundrum with jclouds at Gluecon 2013
Rackspace Private Cloud presentation for ChefConf 2014
Webinar slides: Replication Topology Changes for MySQL and MariaDB
Automated MySQL failover with MHA: Getting started & moving past its quirks
Jurijs Velikanovs - RAC Attack 101 - How to install 12c RAC on your laptop
Looking at RAC, GI/Clusterware Diagnostic Tools
Docker Basics & Alfresco Content Services

What's hot (20)

PPTX
Kafka Tutorial: Advanced Producers
PPTX
tow nodes Oracle 12c RAC on virtualbox
PDF
System Hardening Using Ansible
PDF
Unsafe SSL webinar
PDF
MHA (MySQL High Availability): Getting started & moving past quirks
PDF
Deployment Best Practices on WebLogic Server (DOAG IMC Summit 2013)
PDF
Natively clouded Journey
PPTX
It's in the cloud
PDF
Take home your very own free Vagrant CFML Dev Environment - Presented at dev....
PDF
Become a MySQL DBA - webinar series - slides: Which High Availability solution?
PDF
Become a MySQL DBA - slides: Deciding on a relevant backup solution
PDF
Scaling i/o bound Microservices
PDF
Infrastructure as code
PDF
PDF
Containerising bootiful microservices javaeeconf
PPTX
OTN Tour 2014: Rac 11g vs 12c
PDF
MySQL DevOps at Outbrain
PPTX
Quarkus bootstrap 2020
PDF
GraphConnect Europe 2016 - Moving Graphs to Production at Scale - Ian Robinson
PPT
Professional deployment
Kafka Tutorial: Advanced Producers
tow nodes Oracle 12c RAC on virtualbox
System Hardening Using Ansible
Unsafe SSL webinar
MHA (MySQL High Availability): Getting started & moving past quirks
Deployment Best Practices on WebLogic Server (DOAG IMC Summit 2013)
Natively clouded Journey
It's in the cloud
Take home your very own free Vagrant CFML Dev Environment - Presented at dev....
Become a MySQL DBA - webinar series - slides: Which High Availability solution?
Become a MySQL DBA - slides: Deciding on a relevant backup solution
Scaling i/o bound Microservices
Infrastructure as code
Containerising bootiful microservices javaeeconf
OTN Tour 2014: Rac 11g vs 12c
MySQL DevOps at Outbrain
Quarkus bootstrap 2020
GraphConnect Europe 2016 - Moving Graphs to Production at Scale - Ian Robinson
Professional deployment
Ad

Viewers also liked (7)

PPTX
jclouds at HKJUG
PDF
Getting started with jClouds
KEY
Jclouds Intro
PPTX
Eucalyptus основные особенности
PPTX
Cloud APIs - обзор API западных провайдеров и API Scalaxy, Нат Гаджибалаев
PPTX
Introduction to Apache jclouds
PPTX
Intro to Docker Swarm
jclouds at HKJUG
Getting started with jClouds
Jclouds Intro
Eucalyptus основные особенности
Cloud APIs - обзор API западных провайдеров и API Scalaxy, Нат Гаджибалаев
Introduction to Apache jclouds
Intro to Docker Swarm
Ad

Similar to jclouds Support Training (20)

PPTX
Software Development kits
PPTX
Control the Clouds - Developer Experience with jclouds.pptx
PPTX
Solve the Cross-Cloud Conundrum with jclouds
PPTX
jclouds workshop
PDF
Be a Cloud Native
PPTX
Doc or Die
PDF
Behind the Curtain: Operating an OpenStack Powered Private Cloud
PPTX
Deploy from OpenStack Trunk into a Production Environment
PPTX
Cloud Technology Stack Comparison (OpenStack) - Cloud Connect Chicago 2012
PDF
DeveloperWeek 2014
PPTX
Operating OpenStack - Case Study in the Rackspace Cloud
PPTX
DevOps, CI, APIs, Oh My! - Texas Linux Fest 2012
ODP
Testing at-cloud-speed sans-app-sec-austin-2013
PPTX
PyCon Russia 2014 - Auto Scale in the Cloud
PDF
The Next Generation IT Department MUST HAVE CLOUD
PPTX
Migrating Traditional Apps from On-Premises to the Hybrid Cloud
PPTX
Behind The Scenes: New Rackspace Cloud Control Panel
PPTX
Learning to Scale OpenStack
PPTX
Intro to OpenStack - WAJUG
PDF
Autoscaling Best Practices
Software Development kits
Control the Clouds - Developer Experience with jclouds.pptx
Solve the Cross-Cloud Conundrum with jclouds
jclouds workshop
Be a Cloud Native
Doc or Die
Behind the Curtain: Operating an OpenStack Powered Private Cloud
Deploy from OpenStack Trunk into a Production Environment
Cloud Technology Stack Comparison (OpenStack) - Cloud Connect Chicago 2012
DeveloperWeek 2014
Operating OpenStack - Case Study in the Rackspace Cloud
DevOps, CI, APIs, Oh My! - Texas Linux Fest 2012
Testing at-cloud-speed sans-app-sec-austin-2013
PyCon Russia 2014 - Auto Scale in the Cloud
The Next Generation IT Department MUST HAVE CLOUD
Migrating Traditional Apps from On-Premises to the Hybrid Cloud
Behind The Scenes: New Rackspace Cloud Control Panel
Learning to Scale OpenStack
Intro to OpenStack - WAJUG
Autoscaling Best Practices

More from Everett Toews (20)

PDF
All You Need to Know About Kustomize
PDF
Intro to InnerSource
PPTX
An OpenShift Migration: From 3.9 to 4.5
PPTX
Cloud Native Summit 2019 Summary
PPTX
DevOps: Chop wood. Carry water.
PPTX
Ciao: Continuous Integration for Apps on OpenStack
PPTX
Introduction to Apache jclouds at NYJavaSIG
PPTX
DevStack: Learn OpenStack by Running OpenStack
PPTX
Enabling Walk Up Contributions to Your Documentation at GlueCon
PPTX
You Sir, Sir Vey
PPTX
Walk n Doc
PPTX
Nashorn
PPTX
Enabling Walk Up Contributions to Your Project Documentation
PPTX
Introduction to Apache jclouds at ApacheCon 2014
PPTX
Women Who Code
PPTX
PPTX
Cybera Summit
PPTX
The OpenStack Community Welcomes Developers in All Languages
PPTX
NetflixOSS on OpenStack
PPTX
DevStack
All You Need to Know About Kustomize
Intro to InnerSource
An OpenShift Migration: From 3.9 to 4.5
Cloud Native Summit 2019 Summary
DevOps: Chop wood. Carry water.
Ciao: Continuous Integration for Apps on OpenStack
Introduction to Apache jclouds at NYJavaSIG
DevStack: Learn OpenStack by Running OpenStack
Enabling Walk Up Contributions to Your Documentation at GlueCon
You Sir, Sir Vey
Walk n Doc
Nashorn
Enabling Walk Up Contributions to Your Project Documentation
Introduction to Apache jclouds at ApacheCon 2014
Women Who Code
Cybera Summit
The OpenStack Community Welcomes Developers in All Languages
NetflixOSS on OpenStack
DevStack

Recently uploaded (20)

PDF
A contest of sentiment analysis: k-nearest neighbor versus neural network
PPTX
Modernising the Digital Integration Hub
PDF
gpt5_lecture_notes_comprehensive_20250812015547.pdf
PPT
What is a Computer? Input Devices /output devices
PDF
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
PDF
Microsoft Solutions Partner Drive Digital Transformation with D365.pdf
PDF
A comparative study of natural language inference in Swahili using monolingua...
PPTX
TLE Review Electricity (Electricity).pptx
PPTX
The various Industrial Revolutions .pptx
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PDF
NewMind AI Weekly Chronicles - August'25-Week II
PDF
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
PPTX
O2C Customer Invoices to Receipt V15A.pptx
PDF
project resource management chapter-09.pdf
PPTX
Tartificialntelligence_presentation.pptx
PPTX
OMC Textile Division Presentation 2021.pptx
PDF
DASA ADMISSION 2024_FirstRound_FirstRank_LastRank.pdf
PDF
2021 HotChips TSMC Packaging Technologies for Chiplets and 3D_0819 publish_pu...
PDF
DP Operators-handbook-extract for the Mautical Institute
PDF
Web App vs Mobile App What Should You Build First.pdf
A contest of sentiment analysis: k-nearest neighbor versus neural network
Modernising the Digital Integration Hub
gpt5_lecture_notes_comprehensive_20250812015547.pdf
What is a Computer? Input Devices /output devices
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
Microsoft Solutions Partner Drive Digital Transformation with D365.pdf
A comparative study of natural language inference in Swahili using monolingua...
TLE Review Electricity (Electricity).pptx
The various Industrial Revolutions .pptx
Assigned Numbers - 2025 - Bluetooth® Document
NewMind AI Weekly Chronicles - August'25-Week II
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
O2C Customer Invoices to Receipt V15A.pptx
project resource management chapter-09.pdf
Tartificialntelligence_presentation.pptx
OMC Textile Division Presentation 2021.pptx
DASA ADMISSION 2024_FirstRound_FirstRank_LastRank.pdf
2021 HotChips TSMC Packaging Technologies for Chiplets and 3D_0819 publish_pu...
DP Operators-handbook-extract for the Mautical Institute
Web App vs Mobile App What Should You Build First.pdf

jclouds Support Training

  • 1. Support Training jclouds: The Rackspace Java SDK Everett Toews Developer Advocate @everett_toews You need: JDK 1.6+ Maven 3+ Rackspace account
  • 2. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Intro 2 Developer
  • 3. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Committer on jclouds 3
  • 4. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Intro 4 Advocate
  • 5. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Intro 5
  • 6. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Intro 6 Operations
  • 7. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Co-author of The OpenStack Operations Guide 7docs.openstack.org/ops
  • 8. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Intro 8 In startup we are not allow dev team for talk to ops team except by API. @DevOps_Borat
  • 9. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Agenda 9
  • 10. RACKSPACE® HOSTING | WWW.RACKSPACE.COM The Workshop •Introduction •jclouds Overview •SDKs •Terminology •Cloud Accounts •Getting Started 10
  • 11. RACKSPACE® HOSTING | WWW.RACKSPACE.COM The Workshop •Examples •Authentication •Logging •Cloud Files •Cloud Servers •Cloud Block Storage •Cloud Load Balancers •Cloud DNS •Cross-cloud 11
  • 12. RACKSPACE® HOSTING | WWW.RACKSPACE.COM The Workshop •Wreck-It •Bug Reports •Troubleshooting •Help! •Potpourri •Wrap Up 12
  • 13. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Introduction to jclouds 13
  • 14. RACKSPACE® HOSTING | WWW.RACKSPACE.COM jclouds 14 • Cross-cloud toolkit • Open Source (Apache v2) • Community • Portable APIs • Ecosystem APIs • Provider APIs • Java
  • 15. RACKSPACE® HOSTING | WWW.RACKSPACE.COM jclouds’ Supported Clouds •Compute •Rackspace Cloud Servers •HP Cloud Compute •AWS EC2 •ElasticHosts •GoGrid •All Clouds 15 •Storage •Rackspace Cloud Files •HP Cloud Storage •AWS S3 •Azure •CloudOne •All Clouds
  • 16. RACKSPACE® HOSTING | WWW.RACKSPACE.COM jclouds Community 16
  • 17. RACKSPACE® HOSTING | WWW.RACKSPACE.COM 17 APIs and Providers APIs Providers openstack-nova ec2 rackspace-clouddns rackspace- cloudservers-us rackspace- cloudservers-uk aws-ec2 rackspace- clouddns-us rackspace- clouddns-uk
  • 18. RACKSPACE® HOSTING | WWW.RACKSPACE.COM 18 APIs APIs openstack-nova NovaApi: ServerApi FlavorApi ImageApi =Extensions= KeyPairApi SecurityGroupApi FloatingIpApi ... ec2 EC2Api: TagApi SubnetApi WindowsApi rackspace-clouddns CloudDNSApi: LimitApi DomainApi RecordApi ReverseDNSApi
  • 19. RACKSPACE® HOSTING | WWW.RACKSPACE.COM 19 Providers Providers rackspace- cloudservers-us rackspace- cloudservers-uk rackspace- cloudservers-us rackspace- cloudservers-uk rackspace- clouddns-us rackspace- clouddns-uk •configuration •provider specific features
  • 20. RACKSPACE® HOSTING | WWW.RACKSPACE.COM jclouds Layers (APIs) •ComputeService •OpenStack •Rackspace •HP, AWS, etc. •NovaApi (*Api) •OpenStack •Rackspace •HP 20 Portable Ecosystem
  • 21. RACKSPACE® HOSTING | WWW.RACKSPACE.COM 21 jclouds Compute Venn (APIs) Portable Ecosystem
  • 22. RACKSPACE® HOSTING | WWW.RACKSPACE.COM jclouds Layers (APIs) 22 •BlobStore •OpenStack •Rackspace •HP, AWS, etc. •SwiftApi •OpenStack •Rackspace •HP •CloudFilesClient •Rackspace Portable Ecosystem Provider
  • 23. RACKSPACE® HOSTING | WWW.RACKSPACE.COM 23 jclouds Storage Venn (APIs) Portable Ecosystem Provider
  • 24. RACKSPACE® HOSTING | WWW.RACKSPACE.COM jclouds Community 24 After 3 beer I can able use any of cloud API. @DevOps_Borat
  • 25. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Where Does jclouds Live? 25
  • 26. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDK Deployment 26 Your System S D K Cloud A P I VM VM VM User System
  • 27. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDK Deployment 27 A P I Cloud Your System S D K User System VM VM VM VM
  • 28. RACKSPACE® HOSTING | WWW.RACKSPACE.COM What Can jclouds Do For You Today? 28
  • 29. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 29 Plumbing
  • 30. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 30 (Re)Authentication
  • 31. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 31 Pagination
  • 32. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 32 State Polling
  • 33. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 33 Rate Limiting
  • 34. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 34 Retry
  • 35. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 35 Smoothing Rough Edges
  • 36. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 36 Open Source
  • 37. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 37 In devops nobody is get fire for buy open source. @DevOps_Borat
  • 38. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 38 Community
  • 39. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 39 Packaged
  • 40. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 40 All-in-one
  • 41. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 41 Extensions
  • 42. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 42 No lock-in
  • 43. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 43
  • 44. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 44
  • 45. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 45 Battle Tested Code
  • 46. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 46 Sample Code
  • 47. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 47 Documentation
  • 48. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 48
  • 49. RACKSPACE® HOSTING | WWW.RACKSPACE.COM SDKs 49 Survey is show junior devops are still believe in Tooth Fairy, Santa Claus and documentation. @DevOps_Borat
  • 50. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Code 50
  • 51. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Code 51 j.mp/jcldstrain
  • 52. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Cloud Accounts 52
  • 53. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Rackspace •Username •API Key •(Password is useable too) 53
  • 54. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Terminology 54
  • 55. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Terminology jclouds Rackspace/OpenStack Compute Cloud Servers/Nova Node Server Location Region Hardware Flavor NodeMetadata Server details User Metadata Metadata BlobStore Cloud Files/Swift Blob File/Object 55
  • 56. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Getting Started 56
  • 57. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Getting Started •developer.rackspace.com •Java •Getting Started with jclouds •Get jclouds •Review JARs 57
  • 58. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 58
  • 59. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 59 Cloud Files
  • 60. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 60 Cloud Servers
  • 61. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 61 Logging
  • 62. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 62 Authentication
  • 63. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 63 ?
  • 64. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Examples 64 Cross-Cloud j.mp/jcldsglue2013
  • 65. RACKSPACE® HOSTING | WWW.RACKSPACE.COM 65
  • 66. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Wreck-It •Misspell username •Upload Object to Container that doesn’t exist •Create Server in a location that doesn’t exist •Use a bad Flavor/Image •Remove Rackspace JARs from the classpath •etc. 66
  • 67. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Bug Reports, Troubleshooting, and Help 67
  • 68. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Bug Reports •Get the version •Get the code •Get the wire and header logs •gist or pastie 68
  • 69. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Troubleshooting •Download the version •Run the code •Compare the wire and header logs 69
  • 70. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Troubleshooting •Isolate the problem •jclouds/User Problem (HTTP 4xx) •Rackspace Problem (HTTP 5xx) •Use curl to verify 70
  • 71. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Troubleshooting •Debug the source code •mvn dependency:copy-dependencies "-DoutputDirectory=./lib" "-Dclassifier=sources” 71
  • 72. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Responding •Ideally: •Contribute examples/doc •Send the link to the customer • jclouds.org/documentation/devguides/contributing-to-jclouds/ •github.rackspace.com/van5941/CLAs 72
  • 73. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Responding •Encourage customers to join the jclouds community: •jclouds-user-subscribe@apache.org • www.mail-archive.com/user@jclouds.incubator.apache.org/ 73
  • 74. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Help! •developer.rackspace.com/support •javadocs.jclouds.cloudbees.net •#jclouds on IRC @ freenode.net •jclouds-user-subscribe@apache.org •jclouds-dev-subscribe@apache.org 74
  • 75. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Potpourri 75
  • 76. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Potpourri •Moved to Apache Software Foundation •groupId change • 1.6.0: <groupId>org.jclouds.X</groupId> • 1.6.1: <groupId>org.apache.jclouds.X</groupId> •Package change •1.6.0: import org.jclouds •1.7 (2.0?): import org.apache.jclouds 76
  • 77. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Potpourri •Google’s Guice & Guava •Removal of the AsyncApis in 1.7 (2.0?) •Dropping support for Java 1.6? •Cloud Files isn’t multi-region...yet •Cloud Databases in progress •More endpoints 77
  • 78. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Potpourri •Command Line Interface •Jenkins Plugin •jclouds-chef •Who Uses jclouds? •CloudBees •Cloudify •EnterpriseDB •Pallet •... 78
  • 79. RACKSPACE® HOSTING | WWW.RACKSPACE.COM Potpourri •More examples •Other installation methods •Stay up-to-date with jclouds •blog.phymata.com •@everett_toews •What else can we do to stay in sync? 79
  • 80. Thank You Everett Toews Developer Advocate @everett_toews And don’t forget to terminate your VMs developer.rackspace.com j.mp/jcldstrain