~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/slave/queue_consumer.h

  • Committer: Olaf van der Spek
  • Date: 2011-07-04 19:11:47 UTC
  • mto: This revision was merged to the branch mainline in revision 2367.
  • Revision ID: olafvdspek@gmail.com-20110704191147-s99ojek811zi1fzj
Remove unused Name_resolution_context::error_reporter

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
 
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
 
3
 *
 
4
 *  Copyright (C) 2011 David Shrewsbury
 
5
 *
 
6
 *  This program is free software; you can redistribute it and/or modify
 
7
 *  it under the terms of the GNU General Public License as published by
 
8
 *  the Free Software Foundation; either version 2 of the License, or
 
9
 *  (at your option) any later version.
 
10
 *
 
11
 *  This program is distributed in the hope that it will be useful,
 
12
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
13
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
14
 *  GNU General Public License for more details.
 
15
 *
 
16
 *  You should have received a copy of the GNU General Public License
 
17
 *  along with this program; if not, write to the Free Software
 
18
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
19
 */
 
20
 
 
21
#pragma once
 
22
 
 
23
#include <plugin/slave/queue_thread.h>
 
24
#include <plugin/slave/sql_executor.h>
 
25
#include <drizzled/session.h>
 
26
 
 
27
namespace drizzled
 
28
{
 
29
  namespace message
 
30
  {
 
31
    class Transaction;
 
32
  }
 
33
}
 
34
 
 
35
namespace slave
 
36
{
 
37
 
 
38
class QueueConsumer : public QueueThread, public SQLExecutor
 
39
{
 
40
public:
 
41
  QueueConsumer() :
 
42
    QueueThread(),
 
43
    SQLExecutor("slave", "replication"),
 
44
    _check_interval(5)
 
45
  { }
 
46
 
 
47
  bool init();
 
48
  bool process();
 
49
  void shutdown();
 
50
 
 
51
  void setSleepInterval(uint32_t seconds)
 
52
  {
 
53
    _check_interval= seconds;
 
54
  }
 
55
 
 
56
  uint32_t getSleepInterval()
 
57
  {
 
58
    return _check_interval;
 
59
  }
 
60
  
 
61
  /**
 
62
   * Update applier status in state table.
 
63
   *
 
64
   * @param err_msg Error message string
 
65
   * @param status false = STOPPED, true = RUNNING
 
66
   */
 
67
  void setApplierState(const std::string &err_msg, bool status);
 
68
 
 
69
private:
 
70
  typedef std::vector<uint64_t> TrxIdList;
 
71
 
 
72
  /** Number of seconds to sleep between checking queue for messages */
 
73
  uint32_t _check_interval;
 
74
 
 
75
  bool getListOfCompletedTransactions(TrxIdList &list);
 
76
 
 
77
  bool getMessage(drizzled::message::Transaction &transaction,
 
78
                  std::string &commit_id,
 
79
                  uint64_t trx_id,
 
80
                  std::string &originating_server_uuid,
 
81
                  uint64_t &originating_commit_id,
 
82
                  uint32_t segment_id);
 
83
 
 
84
  /**
 
85
   * Convert the given Transaction message into equivalent SQL.
 
86
   *
 
87
   * @param[in] transaction Transaction protobuf message to convert.
 
88
   * @param[in,out] aggregate_sql Buffer for total SQL for this transaction.
 
89
   * @param[in,out] segmented_sql Buffer for carried over segmented statements.
 
90
   *
 
91
   * @retval true Success
 
92
   * @retval false Failure
 
93
   */
 
94
  bool convertToSQL(const drizzled::message::Transaction &transaction,
 
95
                    std::vector<std::string> &aggregate_sql,
 
96
                    std::vector<std::string> &segmented_sql);
 
97
 
 
98
  /**
 
99
   * Execute a batch of SQL statements.
 
100
   *
 
101
   * @param sql Batch of SQL statements to execute.
 
102
   * @param commit_id Commit ID value to store in state table.
 
103
   * @param originating_server_uuid Server ID of the master where
 
104
   *   this SQL was originally applied.
 
105
   * @param originating_commit_id Commit ID of the master where
 
106
   *   this SQL was originally applied.
 
107
   *
 
108
   * @retval true Success
 
109
   * @retval false Failure
 
110
   */
 
111
  bool executeSQLWithCommitId(std::vector<std::string> &sql,
 
112
                              const std::string &commit_id,
 
113
                              const std::string &originating_server_uuid,
 
114
                              uint64_t originating_commit_id);
 
115
  
 
116
  /**
 
117
   * Remove messages for a given transaction from the queue.
 
118
   *
 
119
   * @param trx_id Transaction ID for the messages to remove.
 
120
   *
 
121
   * @retval true Success
 
122
   * @retval false Failure
 
123
   */
 
124
  bool deleteFromQueue(uint64_t trx_id);
 
125
 
 
126
  /**
 
127
   * Determine if a Statement message is an end message.
 
128
   *
 
129
   * @retval true Is an end Statement message
 
130
   * @retval false Is NOT an end Statement message
 
131
   */
 
132
  bool isEndStatement(const drizzled::message::Statement &statement);
 
133
};
 
134
 
 
135
} /* namespace slave */
 
136