Exemple #1
0
            private void Run()
            {
                try
                {
                    if (!_membershipManager.InitiateTakeOverElection())
                    {
                        if (LoggerManager.Instance.ShardLogger != null && LoggerManager.Instance.ShardLogger.IsDebugEnabled)
                        {
                            LoggerManager.Instance.ShardLogger.Debug("MembershipMgr.TakeOverElectionTask.Run()", "The initiation phase of the takeover elections unsuccessful.");
                        }
                        return;
                    }

                    if (LoggerManager.Instance.ShardLogger != null && LoggerManager.Instance.ShardLogger.IsDebugEnabled)
                    {
                        LoggerManager.Instance.ShardLogger.Debug("MembershipMgr.TakeOverElectionTask.Run()", "The initiation phase of the takeover elections successful.");
                    }

                    lock (this)
                    {
                        if (!_stateSynchronized)
                        {
                            Monitor.Wait(this);
                        }
                    }

                    _membershipManager.OnTakeoverElectionsTriggered();
                }
                catch (ThreadAbortException e)
                {
                    if (LoggerManager.Instance.ShardLogger != null && LoggerManager.Instance.ShardLogger.IsErrorEnabled)
                    {
                        LoggerManager.Instance.ShardLogger.Error(_thread.Name, "Thread aborted.");
                    }
                    _thread = null;
                }
                catch (Exception e)
                {
                    if (LoggerManager.Instance.ShardLogger != null && LoggerManager.Instance.ShardLogger.IsErrorEnabled)
                    {
                        LoggerManager.Instance.ShardLogger.Error("TakeOverElectionTask.Run(): ", e.ToString());
                    }
                }
            }