<HTML><BODY><p>tarantool instance didn't close socket explicitly which could cause hot standby instance to fail to bind in case it tries to bind before socket is closed by OS. Now it is fixed by closing socket explicitly before wal_dir.</p><p>Closes #3967<br>---<br>Branch: https://github.com/tarantool/tarantool/tree/i.kosarev/gh-3967-close-socket-explicitly<br>Issue: https://github.com/tarantool/tarantool/issues/3967</p><p>src/box/box.cc | 1 +<br> src/box/iproto.cc | 6 ++++++<br> src/box/iproto.h | 3 +++<br> 3 files changed, 10 insertions(+)</p><p>diff --git a/src/box/box.cc b/src/box/box.cc<br>index 41ba341ee..bf1d5720a 100644<br>--- a/src/box/box.cc<br>+++ b/src/box/box.cc<br>@@ -1661,6 +1661,7 @@ box_free(void)<br> sequence_free();<br> gc_free();<br> engine_shutdown();<br>+ iproto_socket_free();<br> wal_free();<br> }<br> }<br>diff --git a/src/box/iproto.cc b/src/box/iproto.cc<br>index 19a945d2a..3bdb4f2c6 100644<br>--- a/src/box/iproto.cc<br>+++ b/src/box/iproto.cc<br>@@ -2075,3 +2075,9 @@ iproto_set_msg_max(int new_iproto_msg_max)<br> iproto_do_cfg(&cfg_msg);<br> cpipe_set_max_input(&net_pipe, new_iproto_msg_max / 2);<br> }<br>+<br>+void<br>+iproto_socket_free()<br>+{<br>+ evio_service_stop(&binary);<br>+}<br>\ No newline at end of file<br>diff --git a/src/box/iproto.h b/src/box/iproto.h<br>index b9a6cf8f7..6a9627705 100644<br>--- a/src/box/iproto.h<br>+++ b/src/box/iproto.h<br>@@ -80,6 +80,9 @@ iproto_listen(const char *uri);<br> void<br> iproto_set_msg_max(int iproto_msg_max);<br> <br>+void<br>+iproto_socket_free();<br>+<br> #endif /* defined(__cplusplus) */<br> <br> #endif<br>-- <br>2.17.1</p><br></BODY></HTML>