Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
0ee54c8a
C
ClickHouse
项目概览
2dot5
/
ClickHouse
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
ClickHouse
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
0ee54c8a
编写于
7月 28, 2020
作者:
K
kssenii
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix build, async acks -> sync acks, fix tests
上级
92efb847
变更
7
展开全部
显示空白变更内容
内联
并排
Showing
7 changed file
with
83 addition
and
125 deletion
+83
-125
src/Storages/RabbitMQ/RabbitMQBlockInputStream.cpp
src/Storages/RabbitMQ/RabbitMQBlockInputStream.cpp
+18
-15
src/Storages/RabbitMQ/RabbitMQBlockInputStream.h
src/Storages/RabbitMQ/RabbitMQBlockInputStream.h
+0
-1
src/Storages/RabbitMQ/ReadBufferFromRabbitMQConsumer.cpp
src/Storages/RabbitMQ/ReadBufferFromRabbitMQConsumer.cpp
+9
-19
src/Storages/RabbitMQ/ReadBufferFromRabbitMQConsumer.h
src/Storages/RabbitMQ/ReadBufferFromRabbitMQConsumer.h
+4
-5
src/Storages/RabbitMQ/StorageRabbitMQ.cpp
src/Storages/RabbitMQ/StorageRabbitMQ.cpp
+0
-3
src/Storages/RabbitMQ/WriteBufferToRabbitMQProducer.cpp
src/Storages/RabbitMQ/WriteBufferToRabbitMQProducer.cpp
+1
-0
tests/integration/test_storage_rabbitmq/test.py
tests/integration/test_storage_rabbitmq/test.py
+51
-82
未找到文件。
src/Storages/RabbitMQ/RabbitMQBlockInputStream.cpp
浏览文件 @
0ee54c8a
...
...
@@ -124,11 +124,15 @@ Block RabbitMQBlockInputStream::readImpl()
auto
new_rows
=
read_rabbitmq_message
();
if
(
new_rows
)
{
auto
exchange_name
=
storage
.
getExchange
();
auto
consumer_tag
=
buffer
->
getConsumerTag
();
auto
delivery_tag
=
buffer
->
getDeliveryTag
();
auto
redelivered
=
buffer
->
getRedelivered
();
buffer
->
updateNextDeliveryTag
(
delivery_tag
);
for
(
size_t
i
=
0
;
i
<
new_rows
;
++
i
)
{
virtual_columns
[
0
]
->
insert
(
exchange_name
);
...
...
@@ -137,10 +141,9 @@ Block RabbitMQBlockInputStream::readImpl()
virtual_columns
[
3
]
->
insert
(
redelivered
);
}
if
(
delivery_tag
>
last_inserted_delivery_tag
)
last_inserted_delivery_tag
=
delivery_tag
;
total_rows
=
total_rows
+
new_rows
;
}
buffer
->
allowNext
();
if
(
!
new_rows
||
!
checkTimeLimit
())
...
...
@@ -167,7 +170,7 @@ void RabbitMQBlockInputStream::readSuffixImpl()
if
(
!
buffer
)
return
;
buffer
->
ackMessages
(
last_inserted_delivery_tag
);
buffer
->
ackMessages
();
}
}
src/Storages/RabbitMQ/RabbitMQBlockInputStream.h
浏览文件 @
0ee54c8a
...
...
@@ -39,7 +39,6 @@ private:
const
Block
virtual_header
;
ConsumerBufferPtr
buffer
;
UInt64
last_inserted_delivery_tag
;
};
}
src/Storages/RabbitMQ/ReadBufferFromRabbitMQConsumer.cpp
浏览文件 @
0ee54c8a
...
...
@@ -14,7 +14,7 @@
namespace
DB
{
static
const
auto
QUEUE_SIZE
=
50000
;
/// Equals capacity of a single rabbitmq queue
static
const
auto
QUEUE_SIZE
=
50000
;
ReadBufferFromRabbitMQConsumer
::
ReadBufferFromRabbitMQConsumer
(
ChannelPtr
consumer_channel_
,
...
...
@@ -57,10 +57,7 @@ ReadBufferFromRabbitMQConsumer::ReadBufferFromRabbitMQConsumer(
ReadBufferFromRabbitMQConsumer
::~
ReadBufferFromRabbitMQConsumer
()
{
if
(
ack
.
load
()
&&
max_tag
&&
consumer_channel
)
consumer_channel
->
ack
(
max_tag
,
AMQP
::
multiple
);
consumer_channel
->
close
();
received
.
clear
();
BufferBase
::
set
(
nullptr
,
0
,
0
);
}
...
...
@@ -68,7 +65,7 @@ ReadBufferFromRabbitMQConsumer::~ReadBufferFromRabbitMQConsumer()
void
ReadBufferFromRabbitMQConsumer
::
initQueueBindings
(
const
size_t
queue_id
)
{
bool
bindings_created
=
false
,
bindings_error
=
false
;
std
::
atomic
<
bool
>
bindings_created
=
false
,
bindings_error
=
false
;
auto
success_callback
=
[
&
](
const
std
::
string
&
queue_name_
,
int
msgcount
,
int
/* consumercount */
)
{
...
...
@@ -220,13 +217,6 @@ void ReadBufferFromRabbitMQConsumer::subscribe(const String & queue_name)
message_received
+=
row_delimiter
;
received
.
push
({
deliveryTag
,
message_received
,
redelivered
});
std
::
lock_guard
lock
(
wait_ack
);
if
(
ack
.
exchange
(
false
)
&&
prev_tag
&&
prev_tag
<=
max_tag
&&
consumer_channel
)
{
consumer_channel
->
ack
(
prev_tag
,
AMQP
::
multiple
);
/// Will ack all up to last tag staring from last acked.
LOG_TRACE
(
log
,
"Consumer {} acknowledged messages with deliveryTags up to {}"
,
consumer_tag
,
prev_tag
);
}
}
})
.
onError
([
&
](
const
char
*
message
)
...
...
@@ -239,7 +229,7 @@ void ReadBufferFromRabbitMQConsumer::subscribe(const String & queue_name)
void
ReadBufferFromRabbitMQConsumer
::
checkSubscription
()
{
if
(
count_subscribed
==
num_queues
)
if
(
count_subscribed
==
num_queues
||
!
consumer_channel
->
usable
()
)
return
;
wait_subscribed
=
num_queues
;
...
...
@@ -264,13 +254,14 @@ void ReadBufferFromRabbitMQConsumer::checkSubscription()
}
void
ReadBufferFromRabbitMQConsumer
::
ackMessages
(
UInt64
last_inserted_delivery_tag
)
void
ReadBufferFromRabbitMQConsumer
::
ackMessages
()
{
if
(
last_inserted_delivery_tag
>
prev_tag
)
UInt64
delivery_tag
=
last_inserted_delivery_tag
;
if
(
delivery_tag
&&
delivery_tag
>
prev_tag
)
{
std
::
lock_guard
lock
(
wait_ack
);
/// See onReceived() callback.
prev_tag
=
last_inserted_delivery_tag
;
ack
.
store
(
true
);
prev_tag
=
delivery_tag
;
consumer_channel
->
ack
(
prev_tag
,
AMQP
::
multiple
);
/// Will ack all up to last tag staring from last acked.
LOG_TRACE
(
log
,
"Consumer {} acknowledged messages with deliveryTags up to {}"
,
consumer_tag
,
prev_tag
);
}
}
...
...
@@ -291,7 +282,6 @@ bool ReadBufferFromRabbitMQConsumer::nextImpl()
auto
*
new_position
=
const_cast
<
char
*>
(
current
.
message
.
data
());
BufferBase
::
set
(
new_position
,
current
.
message
.
size
(),
0
);
allowed
=
false
;
max_tag
=
current
.
delivery_tag
;
return
true
;
}
...
...
src/Storages/RabbitMQ/ReadBufferFromRabbitMQConsumer.h
浏览文件 @
0ee54c8a
...
...
@@ -50,7 +50,8 @@ public:
void
allowNext
()
{
allowed
=
true
;
}
// Allow to read next message.
void
checkSubscription
();
void
ackMessages
(
UInt64
last_inserted_delivery_tag
);
void
updateNextDeliveryTag
(
UInt64
delivery_tag
)
{
last_inserted_delivery_tag
=
delivery_tag
;
}
void
ackMessages
();
auto
getConsumerTag
()
const
{
return
consumer_tag
;
}
auto
getDeliveryTag
()
const
{
return
current
.
delivery_tag
;
}
...
...
@@ -80,18 +81,16 @@ private:
String
consumer_tag
;
ConcurrentBoundedQueue
<
MessageData
>
received
;
UInt64
prev_tag
=
0
,
max
_tag
=
0
;
UInt64
last_inserted_delivery_tag
=
0
,
prev
_tag
=
0
;
MessageData
current
;
std
::
vector
<
String
>
queues
;
std
::
unordered_map
<
String
,
bool
>
subscribed_queue
;
std
::
atomic
<
bool
>
ack
=
false
;
std
::
mutex
wait_ack
;
bool
nextImpl
()
override
;
void
initQueueBindings
(
const
size_t
queue_id
);
void
subscribe
(
const
String
&
queue_name
);
void
iterateEventLoop
();
};
}
src/Storages/RabbitMQ/StorageRabbitMQ.cpp
浏览文件 @
0ee54c8a
...
...
@@ -284,9 +284,6 @@ void StorageRabbitMQ::unbindExchange()
{
std
::
call_once
(
flag
,
[
&
]()
{
if
(
exchange_removed
.
load
())
return
;
setup_channel
->
removeExchange
(
bridge_exchange
)
.
onSuccess
([
&
]()
{
...
...
src/Storages/RabbitMQ/WriteBufferToRabbitMQProducer.cpp
浏览文件 @
0ee54c8a
...
...
@@ -150,6 +150,7 @@ void WriteBufferToRabbitMQProducer::countRow()
void
WriteBufferToRabbitMQProducer
::
writingFunc
()
{
String
payload
;
current
=
0
;
auto
returned_callback
=
[
&
](
const
AMQP
::
Message
&
message
,
int16_t
/* code */
,
const
std
::
string
&
/* description */
)
{
...
...
tests/integration/test_storage_rabbitmq/test.py
浏览文件 @
0ee54c8a
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录