NOTE: v1.0.0 is a major rewrite with breaking changes. Please review this readme for new usage and check the changelog
This cookbook provides backups to Rackspace Cloud Files. On Rackspace Cloud Servers it will install and configure the Rackspace Cloud Backup (RCBU) service for backups. On cloud the RCBU agent will be installed and registered and each backup location configured as a unique backup job. Jobs are currently triggered via Cron for timing compatibility.
Non-Rackspace Cloud servers currently unsupported and will fail convergance.
- Chef 11
- A Rackspace Cloud Hosting account is required to use this tool. And a valid
username
andapi_key
are required to authenticate into your account.
This cookbook will install the EPEL repository on RHEL based systems.
API credentials are stored in the shared node['rackspace']['cloud_credentials'] hash.
Attribute | Description | Required |
---|---|---|
node['rackspace']['cloud_credentials']['username'] | Rackspace API username | Yes |
node['rackspace']['cloud_credentials']['api_key'] | Rackspace API key | Yes |
node['rackspace_cloudbackup']['backups'] is a list of hashes, each list entry representing a location to back up. The hash format is as follows:
{
label: Unique backup label*
location: filesystem path to backup (Required)
comment: Some comment (optional)
enable: Enable the backup, Boolean, Optional with default of true
cloud: Hash of options specific to Rackspace Cloud Servers. Format: {
notify_email: Email address for notifications on Rackspace Cloud**
version_retention: Retention value, see API documentation***
}
time: Time override hash for this backup in Cron format. (Optional) Format: {
day: Day of month to run backup
month: Month to run backup
hour: Hour to run backup
minute: Minute to run backup
weekday: Day of week to run backup
}
cron: Cron override hash for this backup. (Optional) Format: {
user: User to run the job as
mailto: Address to send error messages to
path: Cron path
shell: Cron shell
home: Cron home
}
}
Notes:
-
- This backup is the unique identifier for the job. It defaults to
"Backup for #{node['ipaddress']}, backing up #{job['location']}"
for compatability with earlier versions. Changing the label may result in orphaned or lost backups.
- This backup is the unique identifier for the job. It defaults to
- ** Mail sent to this address will come from a Rackspace RCBU server, not the local server. It must be a valid address.
- *** 3.3.1. Create backup configuration
Example:
# Note that some further defaults are required. See below for a complete example.
node.default['rackspace_cloudbackup']['backups'] =
[
{ location: "/var/www",
comment: "Web Content Backup",
cloud: {
# Override the default to send notifications to webmaster
# See below for default values
notify_email: "webmaster@yourdomain.com"
}
},
{ location: "/etc",
time: {
# Only backup the server configuration on the first of the month at midnight
day: 1,
month: '*',
hour: 0,
minute: 0,
weekday: '*'
}
},
# This is the minimal block, a single location with all other options default
{ location: "/home" },
]
In addition to the node['rackspace_cloudbackup']['backups'] hash a node['rackspace_cloudbackup']['backups_defaults'] hash is provided for default node-wide job setting. This allows deduplication of common settings in the primary configuration hash list. See attributes/default.rb for default values and further details.
Attribute | Purpose |
---|---|
node['rackspace']['datacenter'] | Datacenter to back up to, must match cloud server datacenter. |
node['rackspace_cloudbackup']['backups_defaults']['cloud_notify_email'] | Email address for notifications on Rackspace Cloud |
node['rackspace_cloudbackup']['backups_defaults']['cloud_version_retention'] | Cloud version retention value, see API documentation |
Attribute | Purpose |
---|---|
node['rackspace_cloudbackup']['backups_defaults']['time']['day'] | Default backup day, Cron format |
node['rackspace_cloudbackup']['backups_defaults']['time']['month'] | Default backup month, Cron format |
node['rackspace_cloudbackup']['backups_defaults']['time']['hour'] | Default backup hour, Cron format |
node['rackspace_cloudbackup']['backups_defaults']['time']['minute'] | Default backup minute, Cron format |
node['rackspace_cloudbackup']['backups_defaults']['time']['weekday'] | Default backup weekday, Cron format |
Below is a complete example codeblock.
# Define API values
node.default['rackspace']['cloud_credentials']['username'] = '{your api username}'
node.default['rackspace']['cloud_credentials']['api_key'] = '{your api key}'
# Set the default notification email
node.default['rackspace_cloudbackup']['backups_defaults']['cloud_notify_email'] = 'root@yourdomain.com'
# Define the backups
node.default['rackspace_cloudbackup']['backups'] =
[
{ location: "/var/www",
comment: "Web Content Backup",
cloud: {
# Override the default to send notifications to webmaster
notify_email: "webmaster@yourdomain.com"
}
},
{ location: "/etc",
time: {
# Only backup the server configuration on the first of the month at midnight
day: 1,
month: '*',
hour: 0,
minute: 0,
weekday: '*'
}
},
# This is the minimal block, a single location with all other options default
{ location: "/home" },
]
# Remember that this must be called after all recipies which modify the hash have completed.
include_recipe 'rackspace_cloudbackup'
Please see https://github.com/rackspace-cookbooks/contributing for how to contribute.
Authors:
- Matthew Thode (prometheanfire)
- Tom Noonan II
Copyright:: 2012 - 2014 Rackspace
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.