Statistics
| Branch: | Tag: | Revision:

root / lib / client / gnt_backup.py @ eb28ecf6

History | View | Annotate | Download (4.2 kB)

1 02266fe0 Michael Hanselmann
#
2 dd4b1106 Iustin Pop
#
3 dd4b1106 Iustin Pop
4 db5a8a2d Iustin Pop
# Copyright (C) 2006, 2007, 2010 Google Inc.
5 dd4b1106 Iustin Pop
#
6 dd4b1106 Iustin Pop
# This program is free software; you can redistribute it and/or modify
7 dd4b1106 Iustin Pop
# it under the terms of the GNU General Public License as published by
8 dd4b1106 Iustin Pop
# the Free Software Foundation; either version 2 of the License, or
9 dd4b1106 Iustin Pop
# (at your option) any later version.
10 dd4b1106 Iustin Pop
#
11 dd4b1106 Iustin Pop
# This program is distributed in the hope that it will be useful, but
12 dd4b1106 Iustin Pop
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 dd4b1106 Iustin Pop
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 dd4b1106 Iustin Pop
# General Public License for more details.
15 dd4b1106 Iustin Pop
#
16 dd4b1106 Iustin Pop
# You should have received a copy of the GNU General Public License
17 dd4b1106 Iustin Pop
# along with this program; if not, write to the Free Software
18 dd4b1106 Iustin Pop
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 dd4b1106 Iustin Pop
# 02110-1301, USA.
20 dd4b1106 Iustin Pop
21 7260cfbe Iustin Pop
"""Backup related commands"""
22 dd4b1106 Iustin Pop
23 2d54e29c Iustin Pop
# pylint: disable-msg=W0401,W0613,W0614,C0103
24 2f79bd34 Iustin Pop
# W0401: Wildcard import ganeti.cli
25 2d54e29c Iustin Pop
# W0613: Unused argument, since all functions follow the same API
26 2f79bd34 Iustin Pop
# W0614: Unused import %s from wildcard import (since we need cli)
27 7260cfbe Iustin Pop
# C0103: Invalid name gnt-backup
28 2f79bd34 Iustin Pop
29 dd4b1106 Iustin Pop
from ganeti.cli import *
30 dd4b1106 Iustin Pop
from ganeti import opcodes
31 dd4b1106 Iustin Pop
from ganeti import constants
32 bc696589 Michael Hanselmann
from ganeti import errors
33 dd4b1106 Iustin Pop
34 7c0d6283 Michael Hanselmann
35 e1d2aa39 Alexander Schreiber
_VALUE_TRUE = "true"
36 e1d2aa39 Alexander Schreiber
37 a8005e17 Michael Hanselmann
38 dd4b1106 Iustin Pop
def PrintExportList(opts, args):
39 dd4b1106 Iustin Pop
  """Prints a list of all the exported system images.
40 dd4b1106 Iustin Pop

41 48de3413 Iustin Pop
  @param opts: the command line options selected by the user
42 48de3413 Iustin Pop
  @type args: list
43 48de3413 Iustin Pop
  @param args: should be an empty list
44 48de3413 Iustin Pop
  @rtype: int
45 48de3413 Iustin Pop
  @return: the desired exit code
46 dd4b1106 Iustin Pop

47 dd4b1106 Iustin Pop
  """
48 77921a95 Iustin Pop
  exports = GetClient().QueryExports(opts.nodes, False)
49 d70b3058 Iustin Pop
  retcode = 0
50 dd4b1106 Iustin Pop
  for node in exports:
51 3a24c527 Iustin Pop
    ToStdout("Node: %s", node)
52 3a24c527 Iustin Pop
    ToStdout("Exports:")
53 461f0538 Guido Trotter
    if isinstance(exports[node], list):
54 461f0538 Guido Trotter
      for instance_name in exports[node]:
55 3a24c527 Iustin Pop
        ToStdout("\t%s", instance_name)
56 461f0538 Guido Trotter
    else:
57 3a24c527 Iustin Pop
      ToStdout("  Could not get exports list")
58 d70b3058 Iustin Pop
      retcode = 1
59 d70b3058 Iustin Pop
  return retcode
60 dd4b1106 Iustin Pop
61 dd4b1106 Iustin Pop
62 dd4b1106 Iustin Pop
def ExportInstance(opts, args):
63 dd4b1106 Iustin Pop
  """Export an instance to an image in the cluster.
64 dd4b1106 Iustin Pop

65 48de3413 Iustin Pop
  @param opts: the command line options selected by the user
66 48de3413 Iustin Pop
  @type args: list
67 48de3413 Iustin Pop
  @param args: should contain only one element, the name
68 48de3413 Iustin Pop
      of the instance to be exported
69 48de3413 Iustin Pop
  @rtype: int
70 48de3413 Iustin Pop
  @return: the desired exit code
71 dd4b1106 Iustin Pop

72 dd4b1106 Iustin Pop
  """
73 8d8d650c Michael Hanselmann
  ignore_remove_failures = opts.ignore_remove_failures
74 8d8d650c Michael Hanselmann
75 bc696589 Michael Hanselmann
  if not opts.node:
76 5ec4b9d2 Michael Hanselmann
    raise errors.OpPrereqError("Target node must be specified",
77 5ec4b9d2 Michael Hanselmann
                               errors.ECODE_INVAL)
78 bc696589 Michael Hanselmann
79 dd4b1106 Iustin Pop
  op = opcodes.OpExportInstance(instance_name=args[0],
80 dd4b1106 Iustin Pop
                                target_node=opts.node,
81 17c3f802 Guido Trotter
                                shutdown=opts.shutdown,
82 8d8d650c Michael Hanselmann
                                shutdown_timeout=opts.shutdown_timeout,
83 8d8d650c Michael Hanselmann
                                remove_instance=opts.remove_instance,
84 8d8d650c Michael Hanselmann
                                ignore_remove_failures=ignore_remove_failures)
85 dd4b1106 Iustin Pop
86 44247302 Iustin Pop
  SubmitOpCode(op, opts=opts)
87 44247302 Iustin Pop
  return 0
88 60d49723 Michael Hanselmann
89 8d8d650c Michael Hanselmann
90 dd4b1106 Iustin Pop
def ImportInstance(opts, args):
91 dd4b1106 Iustin Pop
  """Add an instance to the cluster.
92 dd4b1106 Iustin Pop

93 d77490c5 Iustin Pop
  This is just a wrapper over GenericInstanceCreate.
94 dd4b1106 Iustin Pop

95 dd4b1106 Iustin Pop
  """
96 d77490c5 Iustin Pop
  return GenericInstanceCreate(constants.INSTANCE_IMPORT, opts, args)
97 dd4b1106 Iustin Pop
98 dd4b1106 Iustin Pop
99 9ac99fda Guido Trotter
def RemoveExport(opts, args):
100 9ac99fda Guido Trotter
  """Remove an export from the cluster.
101 9ac99fda Guido Trotter

102 48de3413 Iustin Pop
  @param opts: the command line options selected by the user
103 48de3413 Iustin Pop
  @type args: list
104 48de3413 Iustin Pop
  @param args: should contain only one element, the name of the
105 48de3413 Iustin Pop
      instance whose backup should be removed
106 48de3413 Iustin Pop
  @rtype: int
107 48de3413 Iustin Pop
  @return: the desired exit code
108 9ac99fda Guido Trotter

109 9ac99fda Guido Trotter
  """
110 9ac99fda Guido Trotter
  op = opcodes.OpRemoveExport(instance_name=args[0])
111 9ac99fda Guido Trotter
112 400ca2f7 Iustin Pop
  SubmitOpCode(op, opts=opts)
113 9ac99fda Guido Trotter
  return 0
114 9ac99fda Guido Trotter
115 9ac99fda Guido Trotter
116 dd4b1106 Iustin Pop
# this is defined separately due to readability only
117 dd4b1106 Iustin Pop
import_opts = [
118 e588764d Iustin Pop
  IDENTIFY_DEFAULTS_OPT,
119 df62e5db Iustin Pop
  SRC_DIR_OPT,
120 df62e5db Iustin Pop
  SRC_NODE_OPT,
121 dd4b1106 Iustin Pop
  ]
122 dd4b1106 Iustin Pop
123 8d8d650c Michael Hanselmann
124 dd4b1106 Iustin Pop
commands = {
125 6ea815cf Iustin Pop
  'list': (
126 6ea815cf Iustin Pop
    PrintExportList, ARGS_NONE,
127 064c21f8 Iustin Pop
    [NODE_LIST_OPT],
128 6ea815cf Iustin Pop
    "", "Lists instance exports available in the ganeti cluster"),
129 6ea815cf Iustin Pop
  'export': (
130 6ea815cf Iustin Pop
    ExportInstance, ARGS_ONE_INSTANCE,
131 8d8d650c Michael Hanselmann
    [FORCE_OPT, SINGLE_NODE_OPT, NOSHUTDOWN_OPT, SHUTDOWN_TIMEOUT_OPT,
132 aa06f8c6 Michael Hanselmann
     REMOVE_INSTANCE_OPT, IGNORE_REMOVE_FAILURES_OPT, DRY_RUN_OPT,
133 aa06f8c6 Michael Hanselmann
     PRIORITY_OPT],
134 6ea815cf Iustin Pop
    "-n <target_node> [opts...] <name>",
135 6ea815cf Iustin Pop
    "Exports an instance to an image"),
136 6ea815cf Iustin Pop
  'import': (
137 eb28ecf6 Guido Trotter
    ImportInstance, ARGS_ONE_INSTANCE, COMMON_CREATE_OPTS + import_opts,
138 6ea815cf Iustin Pop
    "[...] -t disk-type -n node[:secondary-node] <name>",
139 6ea815cf Iustin Pop
    "Imports an instance from an exported image"),
140 6ea815cf Iustin Pop
  'remove': (
141 aa06f8c6 Michael Hanselmann
    RemoveExport, [ArgUnknown(min=1, max=1)], [DRY_RUN_OPT, PRIORITY_OPT],
142 6ea815cf Iustin Pop
    "<name>", "Remove exports of named instance from the filesystem."),
143 dd4b1106 Iustin Pop
  }
144 dd4b1106 Iustin Pop
145 a8005e17 Michael Hanselmann
146 02266fe0 Michael Hanselmann
def Main():
147 02266fe0 Michael Hanselmann
  return GenericMain(commands)