Ok. I am a newbie to asio so bear with me:
I have the following piece of code for handling
a unreliable network and/or server crashed/servicing
where I do not want the client  to fail.
My solution basically involves looping round ,
sleeping and trying again.

....
int no_of_tries = clientEnv.no_of_tries();
while ( no_of_tries > 0 ) {
   try {
      boost::asio::io_service io_service;
      Client theClient( io_service, clientEnv.get_cmd(),
                                     clientEnv.host(), clientEnv.port()  );
      io_service.run();
      ...
       // Some kind of connection error fall through and try again.
   }
    catch (std::exception& e) {
         ....
    }

    sleep( RETRY_POLL_PERIOD );
    no_of_tries--;
}

This does not seem right to me,  but I am not sure how typical
my case is. Are there any known design patterns/idioms that
provide a more robust ways of handling unreliable
networks/glitches and cases where the server needs to be
taken down temporarily ?

  Best regards,
Ta,
   Avi