microsoft / CCF

Confidential Consortium Framework
https://microsoft.github.io/CCF/
Apache License 2.0
764 stars 205 forks source link

Fix retirement bugs in 2tx reconfig #3184

Closed wintersteiger closed 2 years ago

wintersteiger commented 2 years ago

This fixes a bug in the retirement logic for 2tx reconfiguration. A node would not revert to being a follower after it's change to RETIRING was rolled back. It does so with this fix, but it now triggers a long series of elections, sometimes ending up in a situation where it rejects append entries for a long time (possibly forever).

Also adds a function to wait for reconfiguration completion in tests to avoid tests interfering with each other.

ccf-bot commented 2 years ago

cwinter_2tx_fixes@36349 aka 20211109.4 vs main ewma over 20 builds from 35983 to 36343

Click to see table | build_id | build_number | tpcc_sgx_cft^ | tpcc_sgx_cft_mem | ls_sgx_cft^ | ls_sgx_cft_mem | ls_jwt_sgx_cft^ | ls_jwt_sgx_cft_mem | ls_js_sgx_cft^ | ls_js_sgx_cft_mem | ls_full_js_sgx_cft^ | ls_full_js_sgx_cft_mem | ls_js_jwt_sgx_cft^ | ls_js_jwt_sgx_cft_mem | Historical query (/s)^ | CHAMP put (/s)^ | CHAMP get (/s)^ | |-----------:|:---------------|----------------:|-------------------:|--------------:|-----------------:|------------------:|---------------------:|-----------------:|--------------------:|----------------------:|-------------------------:|---------------------:|------------------------:|-------------------------:|------------------:|------------------:| | 35983 | 20211104.36 | 6623.75 | 9.34585e+07 | 24153.7 | 1.7961e+07 | 4524.32 | 1.56017e+07 | 2561.82 | 1.0621e+07 | 2385.18 | 1.03588e+07 | 1781.03 | 8.78598e+06 | 8997.21 | 1.47773e+06 | 3.66362e+07 | | 35993 | 20211104.39 | 6593.45 | 9.26721e+07 | 24179.2 | 1.76989e+07 | 4277.92 | 1.53396e+07 | 2724.66 | 1.0621e+07 | 2384.04 | 1.35046e+07 | 1815.6 | 9.04813e+06 | 7661.79 | 1.44194e+06 | 3.56168e+07 | | 36000 | 20211104.41 | 6531.64 | 9.08371e+07 | 24395.1 | 1.7961e+07 | 4511.4 | 1.53396e+07 | 2727.53 | 1.45532e+07 | 2430.86 | 1.0621e+07 | 1822.44 | 8.78598e+06 | 8955.56 | 1.48783e+06 | 3.65714e+07 | | 36015 | 20211105.2 | 6769.27 | 9.24099e+07 | 24388.2 | 1.82232e+07 | 4336.35 | 1.53396e+07 | 2688.14 | 1.11453e+07 | 2404.87 | 1.35046e+07 | 1810.07 | 9.04813e+06 | 8155.93 | 1.45588e+06 | 3.56794e+07 | | 36023 | 20211105.5 | 6686.92 | 9.26721e+07 | 24291.3 | 1.7961e+07 | 4510.22 | 1.53396e+07 | 2752.03 | 1.32424e+07 | 2387.71 | 1.03588e+07 | 1812.27 | 9.04813e+06 | 9126.51 | 1.46557e+06 | 3.67019e+07 | | 36055 | 20211105.15 | 6339.57 | 9.10992e+07 | 23449.6 | 1.7961e+07 | 4493.2 | 1.56017e+07 | 2641.13 | 1.0621e+07 | 2438.52 | 1.03588e+07 | 1821.64 | 8.52384e+06 | 8044.79 | 1.45175e+06 | 3.58036e+07 | | 36072 | 20211105.20 | 6404.73 | 9.31964e+07 | 24182.4 | 1.7961e+07 | 4548.66 | 1.56017e+07 | 2730.08 | 1.11453e+07 | 2404.87 | 1.03588e+07 | 1819.8 | 8.78598e+06 | 9010.11 | 1.45723e+06 | 3.54933e+07 | | 36093 | 20211105.26 | 6383.19 | 9.13613e+07 | 23899.9 | 1.84853e+07 | 4564.67 | 1.53396e+07 | 2751.26 | 1.27181e+07 | 2388.8 | 1.03588e+07 | 1809.5 | 8.78598e+06 | 8860.21 | 1.42539e+06 | 3.62478e+07 | | 36119 | 20211105.34 | 6639.73 | 9.08371e+07 | 24021.7 | 1.7961e+07 | 4556.39 | 1.56017e+07 | 2707.25 | 1.11453e+07 | 2448.04 | 1.03588e+07 | 1824 | 8.78598e+06 | 9127.4 | 1.42055e+06 | 3.57417e+07 | | 36151 | 20211105.41 | 6411.38 | 9.21478e+07 | 23988.2 | 1.76989e+07 | 4404.64 | 1.56017e+07 | 2686.24 | 1.11453e+07 | 2394.23 | 1.37667e+07 | 1810.21 | 8.78598e+06 | 7900.52 | 1.48469e+06 | 3.56794e+07 | | 36175 | 20211105.49 | 6196.54 | 9.13613e+07 | 24188.1 | 1.76989e+07 | 4560.4 | 1.56017e+07 | 2717.61 | 1.08831e+07 | 2408.57 | 1.37667e+07 | 1823.64 | 8.78598e+06 | 8640.03 | 1.45723e+06 | 3.58663e+07 | | 36199 | 20211108.2 | 6679.71 | 9.16235e+07 | 24403.9 | 1.82232e+07 | 4512.94 | 1.56017e+07 | 2642.89 | 1.08831e+07 | 2389.14 | 1.03588e+07 | 1813.17 | 9.04813e+06 | 8657.9 | 1.44867e+06 | 3.57411e+07 | | 36209 | 20211108.5 | 6568.8 | 9.16235e+07 | 23823.6 | 1.7961e+07 | 4524.23 | 1.56017e+07 | 2738.77 | 1.35046e+07 | 2408.15 | 1.03588e+07 | 1778.25 | 9.04813e+06 | 9209.83 | 1.4535e+06 | 3.56794e+07 | | 36245 | 20211108.15 | 6689.06 | 9.08371e+07 | 23554.6 | 1.76989e+07 | 4533.54 | 1.58639e+07 | 2624.5 | 1.35046e+07 | 2391.73 | 1.32424e+07 | 1793.17 | 1.08831e+07 | 8644.18 | 1.45433e+06 | 3.58669e+07 | | 36258 | 20211108.18 | 6525.53 | 9.10992e+07 | 23920.7 | 1.74367e+07 | 4270.07 | 1.53396e+07 | 2767.91 | 1.08831e+07 | 2417.78 | 1.0621e+07 | 1816.12 | 8.78598e+06 | 8800.23 | 1.42958e+06 | 3.57448e+07 | | 36276 | 20211108.23 | 6618.33 | 9.21478e+07 | 24098.6 | 1.76989e+07 | 4501.93 | 1.58639e+07 | 2703.61 | 1.35046e+07 | 2417.73 | 1.0621e+07 | 1818 | 8.78598e+06 | 7884.9 | 1.47869e+06 | 3.62471e+07 | | 36293 | 20211108.28 | 6473.88 | 9.05749e+07 | 22759 | 1.76989e+07 | 4496.44 | 1.50774e+07 | 2670.77 | 1.4291e+07 | 2364.52 | 1.32424e+07 | 1796.24 | 8.78598e+06 | 8143.45 | 1.45671e+06 | 3.58669e+07 | | 36320 | 20211108.36 | 6598.1 | 9.13613e+07 | 23531 | 1.74367e+07 | 4342.36 | 1.53396e+07 | 2703.76 | 1.11453e+07 | 2429.28 | 1.4291e+07 | 1810.14 | 8.78598e+06 | 8414.72 | 1.45764e+06 | 3.5128e+07 | | 36342 | 20211109.2 | 6368.1 | 9.18856e+07 | 24399.8 | 1.76989e+07 | 4496.62 | 1.56017e+07 | 2734.62 | 1.11453e+07 | 2362.59 | 1.40289e+07 | 1824.39 | 1.00967e+07 | 8717.88 | 1.48329e+06 | 3.48893e+07 | | 36343 | 20211109.3 | 6598.73 | 9.16235e+07 | 23415.1 | 1.7961e+07 | 4537.28 | 1.6126e+07 | 2758.67 | 1.27181e+07 | 2405.29 | 1.37667e+07 | 1817.35 | 8.78598e+06 | 8851.61 | 1.46201e+06 | 3.51286e+07 |

images

wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

/azp run

azure-pipelines[bot] commented 2 years ago
Azure Pipelines successfully started running 3 pipeline(s).
wintersteiger commented 2 years ago

All good. This is ready for review.