Agniva De Sarker
66731e2740
MM-29980: Optimize profilesInChannels cache to fast path ( #16116 )
...
* MM-29980: Optimize profilesInChannels cache to fast path
We add one more message type to the fast path- profiles in channels. There
are 2 primary reasons for this:
- This is not really a new model type, but just a map of users. And users already use
the fast path. So we can get some more gains without really investing much more code.
- A more important reason is that with the upcoming striped mutex changes, we will get
a higher throughput at the cost of a bit more CPU utilization. The reason being that
since less amount of time will be spent in lock-contention, the CPU is free to do more
stuff. So this change is to counter that increase.
As usual, this gives much better performance than the original decoder.
Micro-benchmark results
```
name old time/op new time/op delta
LRU/UserMap=new-8 16.6µs ± 3% 3.9µs ± 4% -76.15% (p=0.000 n=10+10)
name old alloc/op new alloc/op delta
LRU/UserMap=new-8 4.78kB ± 0% 2.74kB ± 0% -42.65% (p=0.000 n=10+10)
name old allocs/op new allocs/op delta
LRU/UserMap=new-8 38.0 ± 0% 30.0 ± 0% -21.05% (p=0.000 n=10+10)
```
https://mattermost.atlassian.net/browse/MM-29980
Here are some results from a load test. The comparison is done with a 2 node cluster; one running master
and one running with this patch so that it's easier to compare. The total users are 2000.
<See PR>
```release-note
NONE
```
* Fix gofmt
* Trigger CI
2020-11-04 10:08:10 +05:30
..
2020-10-19 18:07:20 +03:00
2018-01-22 15:32:50 -06:00
2019-11-29 12:59:40 +01:00
2020-01-07 10:47:03 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-03-11 11:50:12 +01:00
2020-03-11 11:50:12 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-04-08 00:52:30 -04:00
2020-05-26 19:21:29 -06:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2019-12-29 15:30:18 +01:00
2020-07-22 20:32:21 -07:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-08-07 12:59:34 -04:00
2019-11-29 12:59:40 +01:00
2020-02-13 17:53:23 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-07-23 10:46:33 -04:00
2020-10-29 10:24:01 -04:00
2020-10-29 10:24:01 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-07-23 10:46:33 -04:00
2020-09-24 12:06:36 +02:00
2020-10-26 18:17:55 +01:00
2020-10-28 16:46:28 -04:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-23 11:43:58 +05:30
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-03-11 11:50:12 +01:00
2020-06-23 08:33:45 -07:00
2020-05-21 12:24:56 +04:00
2020-05-21 12:24:56 +04:00
2020-01-29 11:56:21 -05:00
2020-01-17 08:34:11 +01:00
2020-01-17 08:34:11 +01:00
2020-09-28 17:59:04 +04:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-07-31 17:40:15 +02:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-09-30 21:09:56 +02:00
2020-10-29 15:54:39 -07:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-09-29 21:41:22 -07:00
2020-09-15 21:28:25 +02:00
2020-11-02 15:43:48 +01:00
2020-04-16 15:23:27 +02:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-01-10 09:19:39 -08:00
2020-06-23 10:47:48 -06:00
2020-01-07 10:47:03 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-09-23 18:32:47 +03:00
2020-09-23 18:32:47 +03:00
2020-07-27 10:20:22 +02:00
2020-09-21 10:28:46 +03:00
2020-10-21 16:59:54 -06:00
2020-05-06 10:28:49 -07:00
2020-08-18 15:47:29 -04:00
2019-12-22 12:35:31 +01:00
2020-07-20 11:10:43 +02:00
2020-02-05 10:46:58 +01:00
2020-02-05 10:46:58 +01:00
2020-10-26 21:57:19 +01:00
2020-03-11 11:50:12 +01:00
2020-03-11 11:50:12 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-10-26 15:54:50 +05:30
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2020-07-09 13:25:23 -03:00
2020-08-21 16:49:31 -04:00
2020-10-26 15:54:50 +05:30
2019-07-18 15:05:53 -03:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-02-18 16:32:46 -04:00
2019-06-25 17:44:08 -04:00
2020-01-17 21:08:55 +01:00
2020-01-17 21:08:55 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-03-13 21:12:20 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-09-08 20:36:59 +02:00
2020-09-08 20:36:59 +02:00
2019-11-29 12:59:40 +01:00
2020-07-06 18:20:35 -04:00
2019-11-29 12:59:40 +01:00
2020-10-15 18:01:31 +03:00
2020-01-29 10:08:27 +01:00
2020-06-17 14:47:54 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-08-21 16:49:31 -04:00
2020-10-07 17:41:46 -06:00
2019-11-29 12:59:40 +01:00
2020-08-11 10:24:26 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-08-31 13:40:58 +02:00
2020-08-31 13:40:58 +02:00
2019-12-22 12:35:31 +01:00
2019-11-29 12:59:40 +01:00
2020-11-04 10:08:10 +05:30
2020-08-11 10:24:26 -04:00
2020-08-13 03:35:57 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-08-13 17:30:38 +05:30
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-09-28 11:43:08 -07:00
2020-02-13 17:53:23 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2020-07-27 15:11:39 -04:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-06-25 16:00:12 +02:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-10-30 17:00:21 +02:00
2019-11-29 12:59:40 +01:00
2020-06-16 11:41:05 +02:00
2020-06-16 11:41:05 +02:00
2020-09-15 21:28:25 +02:00
2020-09-15 21:28:25 +02:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2019-11-29 12:59:40 +01:00
2020-07-16 12:37:26 -04:00
2020-07-16 12:37:26 -04:00
2019-11-29 12:59:40 +01:00
2020-07-16 12:37:26 -04:00
2019-11-29 12:59:40 +01:00
2020-05-07 13:27:35 -04:00
2020-03-25 09:43:25 -07:00
2020-11-04 10:08:10 +05:30
2019-11-29 12:59:40 +01:00
2020-09-28 17:59:04 +04:00
2020-10-01 18:48:38 +03:00
2019-11-29 12:59:40 +01:00
2020-10-02 00:28:56 +02:00
2020-05-22 02:44:42 -07:00
2020-11-03 13:14:21 +01:00
2020-01-16 09:18:08 +01:00
2020-11-04 10:05:10 +05:30
2019-11-29 12:59:40 +01:00
2019-12-24 08:51:03 -05:00