8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
# File 'lib/snapback/app/create.rb', line 8
def go
if $options[:size].nil? then
raise "You must specify a size attribute. E.g.: -s 500M"
end
volume_group_name = "#{$config['lvm']['volume_group']}"
logical_volume_name = "#{$config['lvm']['prefix_database']}-#{$options[:database]}"
mount_dir = get_mount_dir $options[:database]
mysql_data_dir = $database.get_data_dir
if !check "Checking database exists #{$options[:database]}", lambda {
$database.db_exists?($options[:database])
} then
check "Creating database '#{$options[:database]}'", lambda {
$database.db_create($options[:database])
}
on_rollback lambda {
check "Database '#{$options[:database]}' is being dropped", lambda {
$database.db_drop($options[:database])
}
}
end
exec_flush
$database.server_stop
on_rollback lambda {
$database.server_start
}
run "Create logical volume",
"lvcreate -L #{$options[:size]} -n #{logical_volume_name} #{volume_group_name}"
on_rollback lambda {
run "Removing logical volume",
"lvremove -f /dev/#{volume_group_name}/#{logical_volume_name}"
}
run "Format logical volume filesystem",
"mkfs.ext4 /dev/#{volume_group_name}/#{logical_volume_name}"
if !File.directory? mount_dir then
run "Make mount directory",
"mkdir #{mount_dir}"
on_rollback lambda {
run "Removing mount directory",
"rmdir #{$mount_dir}"
}
run "Changing permissions of mount directory",
"chmod 0777 #{mount_dir}"
end
exec_mount "/dev/#{volume_group_name}/#{logical_volume_name}", mount_dir
move_mysql_files "#{mysql_data_dir}/#{$options[:database]}", mount_dir
on_rollback lambda {
move_mysql_files mount_dir, "#{mysql_data_dir}/#{$options[:database]}"
}
run "Remove mysql database directory",
"rm -rf #{mysql_data_dir}/#{$options[:database]}"
on_rollback lambda {
run "Re-creating MySQL database directory",
"mkdir #{mysql_data_dir}/#{$options[:database]}"
exec_chown "#{mysql_data_dir}/#{$options[:database]}"
}
exec_link "#{mysql_data_dir}/#{$options[:database]}", mount_dir
exec_chown "#{mysql_data_dir}/#{$options[:database]}"
exec_chown mount_dir
$database.server_start
on_rollback lambda {
$database.server_stop
}
end
|