Skip to content

Commit

Permalink
add corks to coalesce writes for several heavy calltrees.
Browse files Browse the repository at this point in the history
Signed-off-by: Jason Volk <[email protected]>
  • Loading branch information
jevolk committed Mar 21, 2024
1 parent d3acc0a commit 8676f04
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 0 deletions.
4 changes: 4 additions & 0 deletions src/api/client_server/sync.rs
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,10 @@ async fn sync_helper(
.extend(services().users.keys_changed(sender_user.as_ref(), since, None).filter_map(std::result::Result::ok));

let all_joined_rooms = services().rooms.state_cache.rooms_joined(&sender_user).collect::<Vec<_>>();

// Coalesce database writes for the remainder of this scope.
let _cork = services().globals.db.cork_and_flush()?;

for room_id in all_joined_rooms {
let room_id = room_id?;
if let Ok(joined_room) = load_joined_room(
Expand Down
3 changes: 3 additions & 0 deletions src/service/rooms/timeline/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -221,6 +221,9 @@ impl Service {
leaves: Vec<OwnedEventId>,
state_lock: &MutexGuard<'_, ()>, // Take mutex guard to make sure users get the room state mutex
) -> Result<Vec<u8>> {
// Coalesce database writes for the remainder of this scope.
let _cork = services().globals.db.cork_and_flush()?;

let shortroomid = services().rooms.short.get_shortroomid(&pdu.room_id)?.expect("room exists");

// Make unsigned fields correct. This is not properly documented in the spec,
Expand Down
6 changes: 6 additions & 0 deletions src/service/sending/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,7 @@ impl Service {
Some(response) = futures.next() => {
match response {
Ok(outgoing_kind) => {
let _cork = services().globals.db.cork();
self.db.delete_all_active_requests_for(&outgoing_kind)?;

// Find events that have been added since starting the last request
Expand Down Expand Up @@ -202,6 +203,7 @@ impl Service {
let mut retry = false;
let mut allow = true;

let _cork = services().globals.db.cork();
let entry = current_transaction_status.entry(outgoing_kind.clone());

entry
Expand Down Expand Up @@ -384,6 +386,7 @@ impl Service {
pub fn send_push_pdu(&self, pdu_id: &[u8], user: &UserId, pushkey: String) -> Result<()> {
let outgoing_kind = OutgoingKind::Push(user.to_owned(), pushkey);
let event = SendingEventType::Pdu(pdu_id.to_owned());
let _cork = services().globals.db.cork()?;
let keys = self.db.queue_requests(&[(&outgoing_kind, event.clone())])?;
self.sender.send((outgoing_kind, event, keys.into_iter().next().unwrap())).unwrap();

Expand All @@ -396,6 +399,7 @@ impl Service {
.into_iter()
.map(|server| (OutgoingKind::Normal(server), SendingEventType::Pdu(pdu_id.to_owned())))
.collect::<Vec<_>>();
let _cork = services().globals.db.cork()?;
let keys = self.db.queue_requests(&requests.iter().map(|(o, e)| (o, e.clone())).collect::<Vec<_>>())?;
for ((outgoing_kind, event), key) in requests.into_iter().zip(keys) {
self.sender.send((outgoing_kind.clone(), event, key)).unwrap();
Expand All @@ -408,6 +412,7 @@ impl Service {
pub fn send_reliable_edu(&self, server: &ServerName, serialized: Vec<u8>, id: u64) -> Result<()> {
let outgoing_kind = OutgoingKind::Normal(server.to_owned());
let event = SendingEventType::Edu(serialized);
let _cork = services().globals.db.cork()?;
let keys = self.db.queue_requests(&[(&outgoing_kind, event.clone())])?;
self.sender.send((outgoing_kind, event, keys.into_iter().next().unwrap())).unwrap();

Expand All @@ -418,6 +423,7 @@ impl Service {
pub fn send_pdu_appservice(&self, appservice_id: String, pdu_id: Vec<u8>) -> Result<()> {
let outgoing_kind = OutgoingKind::Appservice(appservice_id);
let event = SendingEventType::Pdu(pdu_id);
let _cork = services().globals.db.cork()?;
let keys = self.db.queue_requests(&[(&outgoing_kind, event.clone())])?;
self.sender.send((outgoing_kind, event, keys.into_iter().next().unwrap())).unwrap();

Expand Down

0 comments on commit 8676f04

Please sign in to comment.