This repository has been archived by the owner on Sep 18, 2021. It is now read-only.
/
AliasedQueue.scala
66 lines (56 loc) · 2.11 KB
/
AliasedQueue.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/*
* Copyright 2012 Twitter, Inc.
* Copyright 2012 Robey Pointer <robeypointer@gmail.com>
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.lag.kestrel
import com.twitter.ostrich.stats.Stats
import com.twitter.util.Time
import java.util.concurrent.atomic.AtomicLong
import config._
class AliasedQueue(val name: String, @volatile var config: AliasConfig,
queueLookup: (String => Option[PersistentQueue])) {
def statNamed(statName: String) = "q/" + name + "/" + statName
// # of items EVER added to the alias:
val putItems = new AtomicLong(0)
Stats.removeCounter(statNamed("put_items"))
Stats.makeCounter(statNamed("put_items"), putItems)
// # of bytes EVER added to the alias:
val putBytes = new AtomicLong(0)
Stats.removeCounter(statNamed("put_bytes"))
Stats.makeCounter(statNamed("put_bytes"), putBytes)
val createTime: Long = Time.now.inSeconds
Stats.addGauge(statNamed("create_time"))(createTime)
/**
* Add a value to the end of the aliased queue(s).
*/
def add(value: Array[Byte], expiry: Option[Time], addTime: Time): Boolean = {
putItems.getAndIncrement()
putBytes.getAndAdd(value.length)
config.destinationQueues.foldLeft(true) { case (result, name) =>
val thisResult = queueLookup(name) match {
case Some(q) => q.add(value, expiry, None, addTime)
case None => true
}
result && thisResult
}
}
def dumpStats(): Array[(String, String)] = synchronized {
Array(
("put_items", putItems.toString),
("put_bytes", putBytes.toString),
("children", config.destinationQueues.size.toString)
)
}
}