data:image/s3,"s3://crabby-images/53d43/53d435fd535d92dc238064ef02eb9eab61c9f531" alt=""
Hi, In our application, inside the "main()" a tcp port made to listen, and the io_service is ran. It receives connection, and reads data from the connection. Then it create a thread and passes the "io_service" and the related "socket" as a reference to the new thread. Further communication are performed inside the thread. So far this works fine. Now inside the thread, I have created a "thread interruption point". This thread interruption point is inside a while loop for testing, and the while loop is inside the "async_read_handler". (That is the read handler never returns - When testing code is execution control is here-). By opening a new "telnet client", I have tried to connect to the listening port, it is connected, but the async_accept handler routine is not called! What could be the reason? How can I rectify this? Thanks, Lloyd ______________________________________ Scanned and protected by Email scanner
data:image/s3,"s3://crabby-images/82c71/82c710aa0a57b507807e0d35a3199f81ab9d8c67" alt=""
Now inside the thread, I have created a "thread interruption point". This thread interruption point is inside a while loop for testing, and the while loop is inside the "async_read_handler". (That is the read handler never returns - When testing code is execution control is here-). By opening a new "telnet client", I have tried to connect to the listening port, it is connected, but the async_accept handler routine is not called! What could be the reason? How can I rectify this?
Who calls async_read_handler? Check that the thread you're blocking (with "while" loop) is not supposed to pump the handlers, i.e. it's not the thread that executes io_service::run(). P.S. it's worth asking asio-related question on asio mailng list.
data:image/s3,"s3://crabby-images/53d43/53d435fd535d92dc238064ef02eb9eab61c9f531" alt=""
By debugging one thing I recognised is, io_service::run() is called from the
main thread, and blocked thread is another one. But, in the blocked thread I
have async_read() call handler. Inside the handler the thread is blocking.
This is causing the problem.
Now I will explain the real problem. There is a data write (to the disk)
handler routine. If the disk is full I want the thread to wait until some
disk space is free.For this what I do is, in the write handler there is a
infinite while loop. Inside this thread interruption is enabled. The it
checks for free space in the disk. If it is available, it breaks the while.
Other wise it sleeps for some time, continues in the loop. Is there a better
way to handle this?
Thanks a lot,
Lloyd
----- Original Message -----
From: "Igor R"
Now inside the thread, I have created a "thread interruption point". This> thread interruption point is inside a while loop for testing, and the while> loop is inside the "async_read_handler". (That is the read handler never> returns - When testing code is execution control is here-). By opening a new> "telnet client", I have tried to connect to the listening port, it is> connected, but the async_accept handler routine is not called! What could be> the reason? How can I rectify this? Who calls async_read_handler? Check that the thread you're blocking(with "while" loop) is not supposed to pump the handlers, i.e. it'snot the thread that executes io_service::run(). P.S. it's worth asking asio-related question on asio mailng list._______________________________________________Boost-users mailing listBoost-users@lists.boost.orghttp://lists.boost.org/mailman/listinfo.cgi/boost-users
______________________________________ Scanned and protected by Email scanner
data:image/s3,"s3://crabby-images/fd056/fd056e89606453afae0d177c355e278872d45694" alt=""
De: Lloyd
Now I will explain the real problem. There is a data write (to the disk) handler routine. If the disk is full I want the thread to wait until some disk space is free.For this what I do is, in the write handler there is a infinite while loop. Inside this thread interruption is enabled. The it checks for free space in the disk. If it is available, it breaks the while. Other wise it sleeps for some time, continues in the loop. Is there a better way to handle this?
When the handler fails because of a disk full, it could, instead of entering a loop, schedule a timer and return immediately. When the timer fires, its handler would retry the write.
participants (3)
-
Eric MALENFANT
-
Igor R
-
Lloyd