views:

618

answers:

6

Hi. I am creating an array of threads based on the number of records in a database. Each thread then polls an ipaddress and then sleeps for a time and then repolls again. I periodically check the database for any change in the number of hosts. If there are more hosts I start another thread. If there are less hosts I need to kill the specific thread that was monitoring that host. How do i kill the specific thread.

enter code here protected static void GetThreads()
    {
        Thread[] threads;
        do
        {
            dt = getIP_Poll_status();
            threads = new Thread[dt.Rows.Count];
            Console.WriteLine(dt.Rows.Count + " Threads");
            for (int i = 0; i < threads.Length; ++i)
            {
                string ip = dt.Rows[i][0].ToString();
                int sleep = Convert.ToInt32(dt.Rows[i][1].ToString());
                string status = dt.Rows[i][2].ToString();
                string host = dt.Rows[i][3].ToString();
                Hosts.Add(host);
                string port = dt.Rows[i][4].ToString();
                //Console.WriteLine("starting on " + ip + " delay  " + sleep+".current status "+status);
                threads[i] = new Thread(PollingThreadStart);
                threads[i].Start(new MyThreadParameters(ip, sleep, status, host, port));
                threads[i].Name = host;

            }
            Thread.Sleep(50000);
        }

        while (true);
    }
+1  A: 

Given that most of your threads will spend the majority of their time doing nothing, your design might be better realised as a single thread that keeps a list of ip addresses and the time they're due to be polled next. Keep it sorted in order of next poll time.

Pseudocode:

What time does the next ip address need to be polled?
Sleep till then
Poll the address.
Update the poll time for that address to now + interval.
Resort the list
Repeat.

Whenever you have a DB update, update the list and then order the thread to re-evaluate when it needs to stop.

Visage
Could you elaborate a bit more on this. If I have a list of IP's adn each one has an associated Poll Time how would I do this in a single thread?
Conor
Well, your thread knows which IPs need to be polled, and how often they need to be polled, so its trivial to work out which IP needs polling next, and when. At that point you do the polling, and then work out which IP you then need to poll, and how long until you need to do it.
Visage
Imagine that on a given day you have a number of jobs to be done; 1pm wash the car. 1.30 Go shopping 2pm Turn the oven on etc.Your method is the equivalent of rounding up your family and assigning each of them a job and a time. The problem is that most of them will spend all their time sitting round doing nothing, just waiting for their time to arrive. The method I have outlined is basically you doing the jobs in order, and at the end of each one just putting your feet up with a cold beer until its time to do the next. You also dont have a house clogged up with family ;)
Visage
Thanks. In my case i want to poll each Host every 5 seconds. If I have multiple hosts can I do this on the one thread. Can they happen concurrently if they need to
Conor
Well, it depends on how long the polling takes. To extend my example, if you have a job to do at 1pm that will take 2 hours, and another job that needs to be done at 2pm then clearly it wont work. In that case, if jobs absolutely have to happen at a given time (rather than all the '2pm' jobs happeneing sequentially) then you might want to spin off small, short-lived threads to do the actual jobs while keeping the scheduling of those jobs in a single thread.
Visage
+7  A: 

Killing threads forcibly is a bad idea. It can leave the system in an indeterminate state.

You should set a flag (in a thread-safe way) so that the thread will terminate itself appropriately next time it checks. See my threading article for more details and sample code.

I would add that using Sleep is almost always the wrong thing to do, by the way. You should use something which allows for a graceful wake-up, such as Monitor.Wait. That way when there are changes (e.g. the polling thread should die) something can wake the thread up if it's waiting, and it can notice the change immediately.

Jon Skeet
A: 

You don't specify the language you are targetting, but in general you use the same method regardless of the language. Simple use a shared variable that is used to signal the thread when it is time to stop running. The thread should periodically check the value and if it is set it will stop in a graceful fashion. Typically, this is the only safe method to stop a thread.

1800 INFORMATION
Given the sample code, I think it's fair to assume that this is C#. I agree that the OP should have made it explicit though.
Jon Skeet
A: 

I would say:

  1. Don't kill threads. Ask them to die, nicely (vie Events or some shared flag).
  2. Be careful when creating exactly one thread per DB entry. This could mean that some unexpected DB activity where suddenly you have many rows translates into killing the OS with too many threads. Definitely have a limit on the number of threads.
Assaf Lavie
A: 

You could send an interrupt signal to the thead you want to end. The thread that has been signalled would need to catch the ThreadInterruptedException that will be raised, and exit gracefully.

There are other, possibly better, ways to achieve what you want, but they are more complicated...

David Kirkland
A: 

What you are trying to do is a bad idea because of the reasons mentioned above. However you can still give the thread a name which can be the host name. You may find out the thread by checking the name and kill it.

Shafqat Ahmed