2
0
mirror of https://github.com/openvswitch/ovs synced 2025-10-23 14:57:06 +00:00
Files
openvswitch/lib
Rodriguez Betancourt, Esteban 9854d473ad json: Use reference counting in JSON objects
After profiling OVSDB insert performance it was found
that some significant portion of its time OVSDB is
calling the function json_clone.

Also, the current usages of json_clone never modify the json,
just keeps it to prevent it to be freed.

With that in mind the struct json, json_create, json_clone
and json_destroy were modified to keep a count of how many
references of the json struct are left. Only when that count
reaches zero the json struct is freed.

The old "json_clone" function was renamed as "json_deep_clone".

Some examples of the performance difference:

In these tests a test table with 4 columns (string, string,
bool, integer) was used. All the tests used "commit block".

*** 50 process each inserting 1000 rows ***

Master OVS
Test Duration                   131 seconds
Average Inserts Per second      746.2687 inserts/s
Average Insert Duration         134.1382 ms
Minimal Insert Duration           0.166202 ms
Maximum Insert Duration	        489.8593 ms

JSON GC Patch
Test Duration                   86 seconds
Average Inserts Per second    1176 inserts/s
Average Insert Duration         82.26761 ms
Minimal Insert Duration          0.165448 ms
Maximum Insert Duration        751.2111 ms

*** 5 process each inserting 10000 rows ***

Master OVS
Test Duration                      8 seconds
Average Inserts Per second      7142.857 inserts/s
Average Insert Duration            0.656431 ms
Minimal Insert Duration            0.125197 ms
Maximum Insert Duration           11.93203 ms

JSON GC Patch
Test Duration                      7 seconds
Average Inserts Per second      8333.333 inserts/s
Average Insert Duration            0.55688 ms
Minimal Insert Duration            0.143233 ms
Maximum Insert Duration           26.26319 ms

Signed-off-by: Esteban Rodriguez Betancourt <estebarb@hpe.com>
Signed-off-by: Ben Pfaff <blp@ovn.org>
2016-10-04 16:04:25 -07:00
..
2016-05-16 17:46:55 -07:00
2016-05-16 17:46:55 -07:00
2016-09-21 18:00:02 -07:00
2016-07-27 18:53:27 -07:00
2016-06-29 18:19:40 -07:00
2016-06-24 09:17:00 -07:00
2016-06-24 09:17:00 -07:00
2016-04-27 15:00:37 -07:00
2016-04-27 15:00:37 -07:00
2016-08-15 11:07:47 -07:00
2016-05-18 19:39:18 -07:00
2016-04-18 08:49:59 -07:00
2016-08-03 17:01:03 -07:00
2016-10-03 14:11:40 -07:00
2016-10-03 14:11:40 -07:00
2015-06-11 17:28:37 -07:00
2015-12-14 05:12:34 -08:00
2016-03-30 13:01:21 -07:00
2016-08-08 11:00:37 -07:00
2016-08-08 11:00:37 -07:00
2015-03-03 13:37:37 -08:00
2016-05-18 19:39:18 -07:00
2016-08-12 10:00:57 -07:00
2016-07-29 16:52:03 -07:00
2016-02-10 13:36:04 -08:00
2016-06-26 20:31:28 -07:00