Revision 39b8ea63

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

  
36
import re
37

  
38
class WorkerGlue(object):
39

  
40
    pmap = {}
41
    worker_id = None
42
    ioctx_pool = None
43

  
44
    @classmethod
45
    def setmap(cls, pid, index):
46
        WorkerGlue.pmap[pid] = index
47
        WorkerGlue.worker_id = index
48

  
49
    @classmethod
50
    def setupXsegPool(cls, ObjectPool, Segment, Xseg_ctx, cfile, pool_size=8):
51
        worker_id = WorkerGlue.worker_id
52
        ARCHIPELAGO_CONF_FILE = cfile
53
        ARCHIPELAGO_SEGMENT_TYPE = 'segdev'
54
        ARCHIPELAGO_SEGMENT_NAME = 'xsegbd'
55
        cfg = {}
56
        bcfg = open(ARCHIPELAGO_CONF_FILE).read()
57
        cfg['SEGMENT_PORTS'] = re.search('SEGMENT_PORTS\s*=\s*\d+',
58
                bcfg).group(0).split('=')[1]
59
        cfg['SEGMENT_SIZE'] = re.search('SEGMENT_SIZE\s*=\s*\d+',
60
                bcfg).group(0).split('=')[1]
61
        ARCHIPELAGO_SEGMENT_PORTS = int(cfg['SEGMENT_PORTS'])
62
        ARCHIPELAGO_SEGMENT_SIZE = int(cfg['SEGMENT_SIZE'])
63
        ARCHIPELAGO_SEGMENT_ALIGNMENT = 12
64

  
65
        class XsegPool(ObjectPool):
66

  
67
            def __init__(self):
68
                super(XsegPool, self).__init__(size=pool_size)
69
                self.segment = Segment(ARCHIPELAGO_SEGMENT_TYPE,
70
                                       ARCHIPELAGO_SEGMENT_NAME,
71
                                       ARCHIPELAGO_SEGMENT_PORTS,
72
                                       ARCHIPELAGO_SEGMENT_SIZE,
73
                                       ARCHIPELAGO_SEGMENT_ALIGNMENT)
74
                self.worker_id = worker_id
75
                self.cnt = 1
76

  
77
            def _pool_create(self):
78
                if self.worker_id == 1:
79
                    ioctx = Xseg_ctx(self.segment, self.worker_id + self.cnt)
80
                    self.cnt += 1
81
                    return ioctx
82
                else:
83
                    ioctx = Xseg_ctx(self.segment,
84
                                     (self.worker_id - 1) * pool_size + 2 +
85
                                     self.cnt)
86
                    self.cnt += 1
87
                    return ioctx
88

  
89
            def _pool_verify(self, poolobj):
90
                return True
91

  
92
            def _pool_cleanup(self, poolobj):
93
                return False
94

  
95
        WorkerGlue.ioctx_pool = XsegPool()

Also available in: Unified diff