Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
slapos
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Eteri
slapos
Commits
e6f228a3
Commit
e6f228a3
authored
Jun 07, 2013
by
Cédric Le Ninivin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve slaprunner resilient recipe
parent
d519b13e
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
41 additions
and
8 deletions
+41
-8
slapos/recipe/slaprunner/backup.py
slapos/recipe/slaprunner/backup.py
+30
-6
software/slaprunner/common.cfg
software/slaprunner/common.cfg
+2
-0
software/slaprunner/instance-runner-export.cfg.in
software/slaprunner/instance-runner-export.cfg.in
+3
-0
software/slaprunner/instance-runner-import.cfg.in
software/slaprunner/instance-runner-import.cfg.in
+6
-2
No files found.
slapos/recipe/slaprunner/backup.py
View file @
e6f228a3
##############################################################################
##############################################################################
#
#
# Copyright (c) 2013 Vifib SARL and Contributors. All Rights Reserved.
# Copyright (c) 2013 Vifib SARL and Contributors. All Rights Reserved.
...
@@ -57,8 +58,24 @@ class ExportRecipe(GenericBaseRecipe):
...
@@ -57,8 +58,24 @@ class ExportRecipe(GenericBaseRecipe):
content
=
textwrap
.
dedent
(
"""
\
content
=
textwrap
.
dedent
(
"""
\
#!%(shell-binary)s
#!%(shell-binary)s
umask 077
umask 077
cd ~/%(srv-directory)s/ ;
\
\
sync_element () {
tar --exclude=runner/software/* -czf %(backup-directory)s/runner.tgz runner/
path=$1
backup_path=$2
shift 2
element_list=$*
for element in $element_list
do
cd $path;
if [ -f $element ] || [ -d $element ]; then
%(rsync-binary)s -avz --safe-links $element $backup_path;
fi
done
}
sync_element %(srv-directory)s/runner %(backup-directory)s/runner/ instance project proxy.db softwareLink
sync_element %(etc-directory)s %(backup-directory)s/etc/ .rcode .project .users
if [ -d %(backup-directory)s/runner/software ]; then
rm %(backup-directory)s/runner/software/*
fi
"""
%
self
.
options
)
"""
%
self
.
options
)
self
.
createExecutable
(
wrapper
,
content
=
content
)
self
.
createExecutable
(
wrapper
,
content
=
content
)
...
@@ -88,10 +105,17 @@ class ImportRecipe(GenericBaseRecipe):
...
@@ -88,10 +105,17 @@ class ImportRecipe(GenericBaseRecipe):
Create a script to restore the database from 'custom' format.
Create a script to restore the database from 'custom' format.
"""
"""
content
=
textwrap
.
dedent
(
"""
\
content
=
textwrap
.
dedent
(
"""
\
#!%(shell-binary)s
\
\
#!%(shell-binary)s
umask 077
\
\
umask 077
cd ~/%(srv-directory)s/ ;
\
\
cd %(backup-directory)s;
tar -xzf %(backup-directory)s/runner.tgz runner/ ;
\
\
%(rsync-binary)s -avz --delete runner/ %(srv-directory)s/runner;
%(rsync-binary)s -avz etc/ %(etc-directory)s;
ifs=$IFS IFS=';'
read user pass remaining < %(etc-directory)s/.users
IFS=$ifs
trap 'rm -f login_cookie' EXIT
%(curl-binary)s -vg6L -F clogin="$user" -F cpwd="$pass" --dump-header login_cookie %(backend-url)s/doLogin;
%(curl-binary)s -vg6LX POST --cookie login_cookie --max-time 5 %(backend-url)s/runSoftwareProfile;
"""
%
self
.
options
)
"""
%
self
.
options
)
self
.
createExecutable
(
wrapper
,
content
=
content
)
self
.
createExecutable
(
wrapper
,
content
=
content
)
...
...
software/slaprunner/common.cfg
View file @
e6f228a3
[buildout]
[buildout]
extends =
extends =
../../component/cloud9/buildout.cfg
../../component/cloud9/buildout.cfg
../../component/curl/buildout.cfg
../../component/dash/buildout.cfg
../../component/dash/buildout.cfg
../../component/dropbear/buildout.cfg
../../component/dropbear/buildout.cfg
../../component/git/buildout.cfg
../../component/git/buildout.cfg
...
@@ -12,6 +13,7 @@ extends =
...
@@ -12,6 +13,7 @@ extends =
../../stack/slapos.cfg
../../stack/slapos.cfg
parts =
parts =
rdiff-backup
template
template
slapos-cookbook
slapos-cookbook
eggs
eggs
...
...
software/slaprunner/instance-runner-export.cfg.in
View file @
e6f228a3
...
@@ -11,8 +11,11 @@ parts +=
...
@@ -11,8 +11,11 @@ parts +=
recipe = slapos.cookbook:slaprunner.export
recipe = slapos.cookbook:slaprunner.export
wrapper = $${directory:bin}/$${slap-parameter:namebase}-exporter
wrapper = $${directory:bin}/$${slap-parameter:namebase}-exporter
srv-directory = $${directory:srv}
srv-directory = $${directory:srv}
etc-directory = $${directory:etc}
backup-directory = $${directory:backup}
backup-directory = $${directory:backup}
shell-binary = ${dash:location}/bin/dash
shell-binary = ${dash:location}/bin/dash
rsync-binary = ${rsync:location}/bin/rsync
# Extends publish section with resilient parameters
# Extends publish section with resilient parameters
[urls]
[urls]
...
...
software/slaprunner/instance-runner-import.cfg.in
View file @
e6f228a3
...
@@ -10,7 +10,11 @@ parts +=
...
@@ -10,7 +10,11 @@ parts +=
[importer]
[importer]
recipe = slapos.cookbook:slaprunner.import
recipe = slapos.cookbook:slaprunner.import
wrapper = $${directory:bin}/$${slap-parameter:namebase}-
ex
porter
wrapper = $${directory:bin}/$${slap-parameter:namebase}-
im
porter
srv-directory = $${directory:srv}
srv-directory = $${directory:srv}
etc-directory = $${directory:etc}
backup-directory = $${directory:backup}
backup-directory = $${directory:backup}
shell-binary = ${dash:location}/bin/dash
shell-binary = ${dash:location}/bin/dash
rsync-binary = ${rsync:location}/bin/rsync
curl-binary = ${curl:location}/bin/curl
backend-url = $${slaprunner:access-url}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment