當前位置: 首頁>>代碼示例>>Python>>正文


Python Client.write_bulk方法代碼示例

本文整理匯總了Python中tempodb.Client.write_bulk方法的典型用法代碼示例。如果您正苦於以下問題:Python Client.write_bulk方法的具體用法?Python Client.write_bulk怎麽用?Python Client.write_bulk使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在tempodb.Client的用法示例。


在下文中一共展示了Client.write_bulk方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Client

# 需要導入模塊: from tempodb import Client [as 別名]
# 或者: from tempodb.Client import write_bulk [as 別名]
"""
http://tempo-db.com/api/write-series/#bulk-write-multiple-series
"""

import datetime
from tempodb import Client

client = Client("your-api-key", "your-api-secret")

ts = datetime.datetime.now()
data = [
    {"key": "custom-series-key1", "v": 1.11},
    {"key": "custom-series-key2", "v": 2.22},
    {"key": "custom-series-key3", "v": 3.33},
    {"key": "custom-series-key4", "v": 4.44},
]

print client.write_bulk(ts, data)
開發者ID:blakesmith,項目名稱:tempodb-python,代碼行數:20,代碼來源:tempodb-bulk-write-demo.py

示例2: StatsdServer

# 需要導入模塊: from tempodb import Client [as 別名]
# 或者: from tempodb.Client import write_bulk [as 別名]
class StatsdServer(object):

    def __init__(self, conf):
        TRUE_VALUES = set(('true', '1', 'yes', 'on', 't', 'y'))
        self.logger = logging.getLogger('statsdpy')
        self.logger.setLevel(logging.INFO)
        self.syslog = SysLogHandler()
        self.formatter = logging.Formatter('%(name)s: %(message)s')
        self.syslog.setFormatter(self.formatter)
        self.logger.addHandler(self.syslog)
        self.conf = conf
        self.graphite_host = conf.get('graphite_host', '127.0.0.1')
        self.graphite_port = int(conf.get('graphite_port', '2003'))
        self.listen_addr = conf.get('listen_addr', '127.0.0.1')
        self.listen_port = int(conf.get('listen_port', 8125))
        self.debug = conf.get('debug', 'yes') in TRUE_VALUES
        self.combined_events = conf.get('combined_events', 'no') in TRUE_VALUES
        self.flush_interval = int(conf.get('flush_interval', 10))
        self.pct_threshold = int(conf.get('percent_threshold', 90))
        self.graphite_addr = (self.graphite_host, self.graphite_port)
        self.keycheck = re.compile(r'\s+|/|[^a-zA-Z_\-0-9\.]')
        self.ratecheck = re.compile('^@([\d\.]+)')
        self.counters = {}
        self.timers = {}
        self.stats_seen = 0

        self.tempodb_enabled = conf.get('tempodb_enabled', 'false') in TRUE_VALUES
        self.tempodb_key = conf.get('tempodb_key', '')
        self.tempodb_secret = conf.get('tempodb_secret', '')
        self.tempodb_host = conf.get('tempodb_host', 'localhost')
        self.tempodb_port = int(conf.get('tempodb_port', 443))
        self.tempodb_secure = conf.get('tempodb_secure', "true") in TRUE_VALUES
        self.tempodb_client = TempoDBClient(self.tempodb_key, self.tempodb_secret, \
                                            self.tempodb_host, self.tempodb_port, \
                                            self.tempodb_secure)

    def report_stats(self, payload):
        """
        Send data
        """
        if self.debug:
            print "reporting stats -> {\n%s}" % "".join(payload)
        self.report_stats_graphite(payload)

        if self.tempodb_enabled:
            self.report_stats_tempodb(payload)

    def report_stats_graphite(self, payload):
        """
        Send data to graphite host

        :param stats: Data to send to graphite (list of graphite strings)
        """
        try:
            with eventlet.Timeout(5, True) as timeout:
                graphite = socket.socket()
                graphite.connect(self.graphite_addr)
                graphite.sendall("".join(payload))
                graphite.close()
        except Exception as err:
            self.logger.critical("error connecting to graphite: %s" % err)
            if self.debug:
                print "error connecting to graphite: %s" % err

    def report_stats_tempodb(self, payload):
        data = {}
        for stat in payload:
            components = stat[:-1].split(" ")
            if len(components) == 3:
                key = components[0]
                value = float(components[1])
                ts = datetime.datetime.utcfromtimestamp(int(components[2]))

                data.setdefault(ts, list()).append({
                    'key': key,
                    'v': value,
                })

        try:
            with eventlet.Timeout(5, True):
                for key, value in data.items():
                    self.tempodb_client.write_bulk(key, value)
        except Exception as err:
            self.logger.critical("error connecting to tempodb: %s" % err)
            if self.debug:
                print "error connecting to tempodb: %s" % err

    def stats_flush(self):
        """
        Periodically flush stats to graphite
        """
        payload = []
        while True:
            tstamp = int(time.time())
            eventlet.sleep(self.flush_interval)
            if self.debug:
                print "seen %d stats so far." % self.stats_seen
                print "current counters: %s" % self.counters
            for item in self.counters:
                stats = 'stats.%s %s %s\n' % (item,
#.........這裏部分代碼省略.........
開發者ID:tempodb,項目名稱:statsdpy,代碼行數:103,代碼來源:statsd.py

示例3: Client

# 需要導入模塊: from tempodb import Client [as 別名]
# 或者: from tempodb.Client import write_bulk [as 別名]
"""
http://tempo-db.com/api/write-series/#bulk-write-multiple-series
"""

import datetime
from tempodb import Client

client = Client("your-api-key", "your-api-secret")

bulk = {
    "t": datetime.datetime.now().isoformat(),
    "data": [
        {"key": "custom-series-key1", "v": 1.11},
        {"key": "custom-series-key2", "v": 2.22},
        {"key": "custom-series-key3", "v": 3.33},
        {"key": "custom-series-key4", "v": 4.44},
    ],
}

print client.write_bulk(bulk)
開發者ID:idan,項目名稱:tempodb-python,代碼行數:22,代碼來源:tempodb-bulk-write-demo.py

示例4: ClientTest

# 需要導入模塊: from tempodb import Client [as 別名]
# 或者: from tempodb.Client import write_bulk [as 別名]

#.........這裏部分代碼省略.........
        data = [DataPoint(datetime.datetime(2012, 3, 27), 12.34)]
        result = self.client.write_key("key1", data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/series/key/key1/data/',
            auth=('key', 'secret'),
            data="""[{"t": "2012-03-27T00:00:00", "v": 12.34}]""",
            headers=self.post_headers
        )
        self.assertEquals(result, '')

    def test_write_key_escape(self):
        self.client.session.post.return_value = MockResponse(200, "")
        data = [DataPoint(datetime.datetime(2012, 3, 27), 12.34)]
        result = self.client.write_key("ke:y/1", data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/series/key/ke%3Ay%2F1/data/',
            auth=('key', 'secret'),
            data="""[{"t": "2012-03-27T00:00:00", "v": 12.34}]""",
            headers=self.post_headers
        )
        self.assertEquals(result, '')

    def test_increment_id(self):
        self.client.session.post.return_value = MockResponse(200, "")
        data = [DataPoint(datetime.datetime(2012, 3, 27), 1)]
        result = self.client.increment_id("id1", data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/series/id/id1/increment/',
            auth=('key', 'secret'),
            data="""[{"t": "2012-03-27T00:00:00", "v": 1}]""",
            headers=self.post_headers
        )
        self.assertEquals(result, '')

    def test_increment_key(self):
        self.client.session.post.return_value = MockResponse(200, "")
        data = [DataPoint(datetime.datetime(2012, 3, 27), 1)]
        result = self.client.increment_key("key1", data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/series/key/key1/increment/',
            auth=('key', 'secret'),
            data="""[{"t": "2012-03-27T00:00:00", "v": 1}]""",
            headers=self.post_headers
        )
        self.assertEquals(result, '')

    def test_increment_key_escape(self):
        self.client.session.post.return_value = MockResponse(200, "")
        data = [DataPoint(datetime.datetime(2012, 3, 27), 1)]
        result = self.client.increment_key("ke:y/1", data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/series/key/ke%3Ay%2F1/increment/',
            auth=('key', 'secret'),
            data="""[{"t": "2012-03-27T00:00:00", "v": 1}]""",
            headers=self.post_headers
        )
        self.assertEquals(result, '')

    def test_write_bulk(self):
        self.client.session.post.return_value = MockResponse(200, "")
        data = [
            { 'id': '01868c1a2aaf416ea6cd8edd65e7a4b8', 'v': 4.164 },
            { 'id': '38268c3b231f1266a392931e15e99231', 'v': 73.13 },
            { 'key': 'your-custom-key', 'v': 55.423 },
            { 'key': 'foo', 'v': 324.991 },
        ]
        ts = datetime.datetime(2012, 3, 27)
        result = self.client.write_bulk(ts, data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/data/',
            auth=('key', 'secret'),
            data="""{"data": %s, "t": "2012-03-27T00:00:00"}""" % simplejson.dumps(data),
            headers=self.post_headers
        )
        self.assertEqual(result, '')

    def test_increment_bulk(self):
        self.client.session.post.return_value = MockResponse(200, "")
        data = [
            { 'id': '01868c1a2aaf416ea6cd8edd65e7a4b8', 'v': 4 },
            { 'id': '38268c3b231f1266a392931e15e99231', 'v': 2 },
            { 'key': 'your-custom-key', 'v': 1 },
            { 'key': 'foo', 'v': 1 },
        ]
        ts = datetime.datetime(2012, 3, 27)
        result = self.client.increment_bulk(ts, data)

        self.client.session.post.assert_called_once_with(
            'https://example.com/v1/increment/',
            auth=('key', 'secret'),
            data="""{"data": %s, "t": "2012-03-27T00:00:00"}""" % simplejson.dumps(data),
            headers=self.post_headers
        )
        self.assertEqual(result, '')
開發者ID:InPermutation,項目名稱:tempodb-python,代碼行數:104,代碼來源:tests.py

示例5: Client

# 需要導入模塊: from tempodb import Client [as 別名]
# 或者: from tempodb.Client import write_bulk [as 別名]
"""
http://tempo-db.com/api/write-series/#bulk-write-multiple-series
"""
from __future__ import print_function

import datetime
from tempodb import Client

# Modify these with your credentials found at: http://tempo-db.com/manage/
API_KEY = 'your-api-key'
API_SECRET = 'your-api-secret'
SERIES_KEY = 'your-custom-key'

client = Client(API_KEY, API_SECRET)

ts = datetime.datetime.now()
data = [
    { 'key': 'custom-series-key1', 'v': 1.11 },
    { 'key': 'custom-series-key2', 'v': 2.22 },
    { 'key': 'custom-series-key3', 'v': 3.33 },
    { 'key': 'custom-series-key4', 'v': 4.44 },
]

print(client.write_bulk(ts, data))
開發者ID:ixmatus,項目名稱:tempodb-python,代碼行數:26,代碼來源:tempodb-bulk-write-demo.py


注:本文中的tempodb.Client.write_bulk方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。