Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / logic / management / commands / backend-list.py @ b704b537

History | View | Annotate | Download (3.2 kB)

1
# Copyright 2012-2013 GRNET S.A. All rights reserved.
2
#
3
# Redistribution and use in source and binary forms, with or
4
# without modification, are permitted provided that the following
5
# conditions are met:
6
#
7
#   1. Redistributions of source code must retain the above
8
#      copyright notice, this list of conditions and the following
9
#      disclaimer.
10
#
11
#   2. Redistributions in binary form must reproduce the above
12
#      copyright notice, this list of conditions and the following
13
#      disclaimer in the documentation and/or other materials
14
#      provided with the distribution.
15
#
16
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27
# POSSIBILITY OF SUCH DAMAGE.
28
#
29
# The views and conclusions contained in the software and
30
# documentation are those of the authors and should not be
31
# interpreted as representing official policies, either expressed
32
# or implied, of GRNET S.A.
33

    
34
from synnefo.db.models import Backend
35
from snf_django.management.commands import ListCommand
36
from synnefo.api import util
37

    
38

    
39
class Command(ListCommand):
40
    help = "List Ganeti backends"
41
    object_class = Backend
42

    
43
    def get_vms(backend):
44
        return backend.virtual_machines.filter(deleted=False).count()
45

    
46
    def get_mem(backend):
47
        return "%s/%s" % (backend.mfree, backend.mtotal)
48

    
49
    def get_disk(backend):
50
        return "%s/%s" % (backend.dfree, backend.dtotal)
51

    
52
    def get_ips(backend):
53
        free_ips = 0
54
        total_ips = 0
55
        for network in util.backend_public_networks(backend):
56
            pool = network.get_pool(with_lock=False)
57
            free_ips += pool.count_available()
58
            total_ips += pool.pool_size
59
        return "%s/%s" % (free_ips, total_ips)
60

    
61
    FIELDS = {
62
        "id": ("id", "Backend's unique ID"),
63
        "clustername": ("clustername", "The name of the Ganeti cluster"),
64
        "port": ("port", ""),
65
        "username": ("username", "The RAPI user"),
66
        "drained": ("drained", "Whether backend is marked as drained"),
67
        "offline": ("offline", "Whether backend if marked as offline"),
68
        "vms": (get_vms, "Number of VMs that this backend hosts"),
69
        "ips": (get_ips, "free/total number of public IPs"),
70
        "mem": (get_mem, "free/total memory (MB)"),
71
        "disk": (get_mem, "free/total disk (GB)"),
72
        "hypervisor": ("hypervisor", "The hypervisor the backend is using"),
73
        "disk_templates": ("disk_templates", "Enabled disk-templates"),
74
    }
75

    
76
    fields = ["id", "clustername", "port", "username", "drained", "offline",
77
              "vms", "hypervisor", "ips", "disk_templates"]