Statistics
| Branch: | Tag: | Revision:

root / scripts / gnt-backup @ f2e9e0e8

History | View | Annotate | Download (5.9 kB)

1 dd4b1106 Iustin Pop
#!/usr/bin/python
2 dd4b1106 Iustin Pop
#
3 dd4b1106 Iustin Pop
4 dd4b1106 Iustin Pop
# Copyright (C) 2006, 2007 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 dd4b1106 Iustin Pop
22 dd4b1106 Iustin Pop
import sys
23 dd4b1106 Iustin Pop
from optparse import make_option
24 dd4b1106 Iustin Pop
25 dd4b1106 Iustin Pop
from ganeti.cli import *
26 dd4b1106 Iustin Pop
from ganeti import cmdlib
27 dd4b1106 Iustin Pop
from ganeti import opcodes
28 dd4b1106 Iustin Pop
from ganeti import constants
29 dd4b1106 Iustin Pop
30 dd4b1106 Iustin Pop
def PrintExportList(opts, args):
31 dd4b1106 Iustin Pop
  """Prints a list of all the exported system images.
32 dd4b1106 Iustin Pop
33 dd4b1106 Iustin Pop
  Args:
34 dd4b1106 Iustin Pop
   opts - class with options as members (should be empty)
35 dd4b1106 Iustin Pop
   args - should be empty
36 dd4b1106 Iustin Pop
37 dd4b1106 Iustin Pop
  Returns:
38 dd4b1106 Iustin Pop
    nothing
39 dd4b1106 Iustin Pop
40 dd4b1106 Iustin Pop
  """
41 dd4b1106 Iustin Pop
  op = opcodes.OpQueryExports(nodes=opts.nodes)
42 dd4b1106 Iustin Pop
  exports = SubmitOpCode(op)
43 dd4b1106 Iustin Pop
  for node in exports:
44 dd4b1106 Iustin Pop
    print ("Node: %s" % node)
45 dd4b1106 Iustin Pop
    print ("Exports:")
46 461f0538 Guido Trotter
    if isinstance(exports[node], list):
47 461f0538 Guido Trotter
      for instance_name in exports[node]:
48 461f0538 Guido Trotter
        print ("\t%s" % instance_name)
49 461f0538 Guido Trotter
    else:
50 461f0538 Guido Trotter
      print ("  Could not get exports list")
51 dd4b1106 Iustin Pop
52 dd4b1106 Iustin Pop
53 dd4b1106 Iustin Pop
def ExportInstance(opts, args):
54 dd4b1106 Iustin Pop
  """Export an instance to an image in the cluster.
55 dd4b1106 Iustin Pop
56 dd4b1106 Iustin Pop
  Args:
57 dd4b1106 Iustin Pop
   opts - class with options as members
58 dd4b1106 Iustin Pop
   args - list with a single element, the instance name
59 dd4b1106 Iustin Pop
60 dd4b1106 Iustin Pop
  Returns:
61 dd4b1106 Iustin Pop
    1 in case of error, 0 otherwise
62 dd4b1106 Iustin Pop
63 dd4b1106 Iustin Pop
  """
64 dd4b1106 Iustin Pop
  op = opcodes.OpExportInstance(instance_name=args[0],
65 dd4b1106 Iustin Pop
                                target_node=opts.node,
66 dd4b1106 Iustin Pop
                                shutdown=opts.shutdown)
67 dd4b1106 Iustin Pop
68 dd4b1106 Iustin Pop
  SubmitOpCode(op)
69 dd4b1106 Iustin Pop
70 60d49723 Michael Hanselmann
71 dd4b1106 Iustin Pop
def ImportInstance(opts, args):
72 dd4b1106 Iustin Pop
  """Add an instance to the cluster.
73 dd4b1106 Iustin Pop
74 dd4b1106 Iustin Pop
  Args:
75 dd4b1106 Iustin Pop
   opts - class with options as members
76 dd4b1106 Iustin Pop
   args - list with a single element, the new instance name
77 dd4b1106 Iustin Pop
  Opts used:
78 dd4b1106 Iustin Pop
   memory - amount of memory to allocate to instance (MiB)
79 dd4b1106 Iustin Pop
   size - amount of disk space to allocate to instance (MiB)
80 dd4b1106 Iustin Pop
   os - which OS to run on instance
81 dd4b1106 Iustin Pop
   node - node to run new instance on
82 dd4b1106 Iustin Pop
   src_node - node containing the export
83 dd4b1106 Iustin Pop
   src_dir - directory on the old node with the export in it
84 dd4b1106 Iustin Pop
85 dd4b1106 Iustin Pop
  Returns:
86 dd4b1106 Iustin Pop
    1 in case of error, 0 otherwise
87 dd4b1106 Iustin Pop
88 dd4b1106 Iustin Pop
  """
89 dd4b1106 Iustin Pop
  instance = args[0]
90 dd4b1106 Iustin Pop
91 60d49723 Michael Hanselmann
  (pnode, snode) = SplitNodeOption(opts.node)
92 60d49723 Michael Hanselmann
93 dd4b1106 Iustin Pop
  op = opcodes.OpCreateInstance(instance_name=instance, mem_size=opts.mem,
94 dd4b1106 Iustin Pop
                                disk_size=opts.size, swap_size=opts.swap,
95 dd4b1106 Iustin Pop
                                disk_template=opts.disk_template,
96 098c0958 Michael Hanselmann
                                mode=constants.INSTANCE_IMPORT,
97 60d49723 Michael Hanselmann
                                pnode=pnode, snode=snode,
98 a181730e Michael Hanselmann
                                vcpus=opts.vcpus, ip_check=opts.ip_check,
99 dd4b1106 Iustin Pop
                                ip=opts.ip, bridge=opts.bridge, start=False,
100 dd4b1106 Iustin Pop
                                src_node=opts.src_node, src_path=opts.src_dir,
101 147af04d Iustin Pop
                                wait_for_sync=opts.wait_for_sync, mac="auto")
102 dd4b1106 Iustin Pop
  SubmitOpCode(op)
103 dd4b1106 Iustin Pop
  return 0
104 dd4b1106 Iustin Pop
105 dd4b1106 Iustin Pop
106 dd4b1106 Iustin Pop
# this is defined separately due to readability only
107 dd4b1106 Iustin Pop
import_opts = [
108 dd4b1106 Iustin Pop
  DEBUG_OPT,
109 60d49723 Michael Hanselmann
  make_option("-n", "--node", dest="node",
110 60d49723 Michael Hanselmann
              help="Target node and optional secondary node",
111 60d49723 Michael Hanselmann
              metavar="<pnode>[:<snode>]"),
112 d5687e89 Guido Trotter
  cli_option("-s", "--os-size", dest="size", help="Disk size, in MiB unless"
113 d5687e89 Guido Trotter
             " a suffix is used",
114 dd4b1106 Iustin Pop
             default=20 * 1024, type="unit", metavar="<size>"),
115 dd4b1106 Iustin Pop
  cli_option("--swap-size", dest="swap", help="Swap size",
116 dd4b1106 Iustin Pop
             default=4 * 1024, type="unit", metavar="<size>"),
117 dd4b1106 Iustin Pop
  cli_option("-m", "--memory", dest="mem", help="Memory size",
118 dd4b1106 Iustin Pop
             default=128, type="unit", metavar="<mem>"),
119 dd4b1106 Iustin Pop
  make_option("-p", "--cpu", dest="vcpus", help="Number of virtual CPUs",
120 dd4b1106 Iustin Pop
              default=1, type="int", metavar="<PROC>"),
121 dd4b1106 Iustin Pop
  make_option("-t", "--disk-template", dest="disk_template",
122 dd4b1106 Iustin Pop
              help="Custom disk setup (diskless, plain, local_raid1 or"
123 dd4b1106 Iustin Pop
              " remote_raid1)", default=None, metavar="TEMPL"),
124 dd4b1106 Iustin Pop
  make_option("-i", "--ip", dest="ip",
125 dd4b1106 Iustin Pop
              help="IP address ('none' [default], 'auto', or specify address)",
126 dd4b1106 Iustin Pop
              default='none', type="string", metavar="<ADDRESS>"),
127 dd4b1106 Iustin Pop
  make_option("--no-wait-for-sync", dest="wait_for_sync", default=True,
128 dd4b1106 Iustin Pop
              action="store_false", help="Don't wait for sync (DANGEROUS!)"),
129 dd4b1106 Iustin Pop
  make_option("-b", "--bridge", dest="bridge",
130 dd4b1106 Iustin Pop
              help="Bridge to connect this instance to",
131 dd4b1106 Iustin Pop
              default=None, metavar="<bridge>"),
132 dd4b1106 Iustin Pop
  make_option("--src-node", dest="src_node", help="Source node",
133 dd4b1106 Iustin Pop
              metavar="<node>"),
134 dd4b1106 Iustin Pop
  make_option("--src-dir", dest="src_dir", help="Source directory",
135 dd4b1106 Iustin Pop
              metavar="<dir>"),
136 bdd55f71 Iustin Pop
  make_option("--no-ip-check", dest="ip_check", default=True,
137 bdd55f71 Iustin Pop
              action="store_false", help="Don't check that the instance's IP"
138 bdd55f71 Iustin Pop
              " is alive"),
139 dd4b1106 Iustin Pop
  ]
140 dd4b1106 Iustin Pop
141 dd4b1106 Iustin Pop
commands = {
142 dd4b1106 Iustin Pop
  'list': (PrintExportList, ARGS_NONE,
143 dd4b1106 Iustin Pop
           [DEBUG_OPT,
144 1e020d1b Michael Hanselmann
            make_option("--node", dest="nodes", default=[], action="append",
145 59885275 Guido Trotter
                        help="List only backups stored on this node"
146 59885275 Guido Trotter
                             " (can be used multiple times)"),
147 dd4b1106 Iustin Pop
            ],
148 dd4b1106 Iustin Pop
           "", "Lists instance exports available in the ganeti cluster"),
149 dd4b1106 Iustin Pop
  'export': (ExportInstance, ARGS_ONE,
150 60d49723 Michael Hanselmann
             [DEBUG_OPT, FORCE_OPT,
151 60d49723 Michael Hanselmann
              make_option("-n", "--node", dest="node", help="Target node",
152 60d49723 Michael Hanselmann
                          metavar="<node>"),
153 dd4b1106 Iustin Pop
              make_option("","--noshutdown", dest="shutdown",
154 dd4b1106 Iustin Pop
                          action="store_false", default=True,
155 dd4b1106 Iustin Pop
                          help="Don't shutdown the instance (unsafe)"), ],
156 dd4b1106 Iustin Pop
             "[opts...] <name>",
157 dd4b1106 Iustin Pop
             "Exports an instance to an image"),
158 dd4b1106 Iustin Pop
  'import': (ImportInstance, ARGS_ONE, import_opts, "[opts...] <name>",
159 dd4b1106 Iustin Pop
             "Imports an instance from an exported image"),
160 dd4b1106 Iustin Pop
  }
161 dd4b1106 Iustin Pop
162 dd4b1106 Iustin Pop
if __name__ == '__main__':
163 3ecf6786 Iustin Pop
  sys.exit(GenericMain(commands))