示例#1
0
 /// <summary>
 /// 创建一个双机热备的 malock 服务器
 /// </summary>
 public MalockServer(MalockConfiguration configuration)
 {
     if (configuration == null)
     {
         throw new ArgumentNullException("configuration it cannot be considered a null");
     }
     this.configuration  = configuration;
     this.malockEngine   = new MalockEngine(configuration);
     this.malockListener = new MalockSocketListener(configuration.Port);
     do
     {
         this.onAboredHandler        = this.ProcessAborted;
         this.onReceivedHandler      = this.ProcessReceived;
         this.malockListener.Accept += (sender, e) =>
         {
             MalockSocket socket = (MalockSocket)e;
             lock (socket)
             {
                 socket.Received  += this.onReceivedHandler;
                 socket.Aborted   += this.onAboredHandler;
                 socket.Connected += this.onConnectedHandler;
                 socket.Run();
             }
         };
     } while (false);
     this.onConnectedHandler = (sender, e) => this.ProcessAccept(sender, (MalockSocket)sender);
 }
        protected void OnAccept(MalockSocket e)
        {
            EventHandler <MalockSocket> evt = this.Accept;

            if (evt != null)
            {
                evt(this, e);
            }
        }
示例#3
0
 internal MalockSocketStream(MalockSocket socket, Stream stream)
 {
     if (socket == null)
     {
         throw new ArgumentNullException("socket");
     }
     if (stream == null)
     {
         throw new ArgumentNullException("stream");
     }
     this.Stream = stream;
     this.Socket = socket;
 }
示例#4
0
        private void ProcessMessage(MalockSocket socket, MalockNodeMessage message)
        {
            switch (socket.LinkMode)
            {
            case MalockMessage.LINK_MODE_CLIENT:
                this.ProcessClient(socket, message);
                break;

            case MalockMessage.LINK_MODE_SERVER:
                this.ProcessServer(socket, message);
                break;

            default:
                socket.Abort();
                break;
            }
        }
示例#5
0
        private void ProcessAccept(object sender, MalockSocket e)
        {
            if (e.LinkMode == MalockMessage.LINK_MODE_CLIENT)
            {
                MalockTable malock = this.malockEngine.GetTable();
                malock.AllocKeyCollection(e.Identity);
            }

            /*
             * This creates a bug in a distributed atomic-state deadlock.
             *  else if (e.LinkMode == Message.LINK_MODE_SERVER)
             *  {
             *      this.malockEngine.GetAllInfo(new MalockTaskInfo()
             *      {
             *          Identity = e.Identity,
             *          Socket = e,
             *          Timeout = -1,
             *          Type = MalockTaskType.kGetAllInfo
             *      });
             *  }
             */
        }
示例#6
0
 private void ProcessServer(MalockSocket socket, MalockNodeMessage message)
 {
     if (message.Command == MalockNodeMessage.SERVER_COMMAND_SYN_ENTER)
     {
         socket.UserToken = message;
         MalockTable malock = this.malockEngine.GetTable();
         malock.Enter(message.Key, message.Identity);
     }
     else if (message.Command == MalockNodeMessage.SERVER_COMMAND_SYN_EXIT)
     {
         MalockTable malock = this.malockEngine.GetTable();
         malock.Exit(message.Key, message.Identity);
         do
         {
             this.malockEngine.AckPipelineExit(new MalockTaskInfo()
             {
                 Key      = message.Key,
                 Identity = message.Identity,
             });
         } while (false);
     }
     else if (message.Command == MalockNodeMessage.SERVER_COMMAND_SYN_FREE)
     {
         string[]    keys;
         MalockTable malock = this.malockEngine.GetTable();
         malock.Exit(message.Identity, out keys);
         this.malockEngine.AckPipelineEnter(message.Identity, keys);
     }
     else if (message.Command == MalockNodeMessage.SERVER_COMMAND_SYN_LOADALLINFO)
     {
         this.malockEngine.GetAllInfo(new MalockTaskInfo()
         {
             Identity = socket.Identity,
             Socket   = socket,
             Timeout  = -1,
             Type     = MalockTaskType.kGetAllInfo
         });
     }
 }
示例#7
0
        private void ProcessAborted(object sender, EventArgs e)
        {
            MalockSocket socket = (MalockSocket)sender;

            if (socket.LinkMode == MalockMessage.LINK_MODE_CLIENT)
            {
                if (!string.IsNullOrEmpty(socket.Identity))
                {
                    this.malockEngine.Abort(new MalockTaskInfo()
                    {
                        Type      = MalockTaskType.kAbort,
                        Key       = null,
                        Stopwatch = null,
                        Timeout   = -1,
                        Sequence  = MalockMessage.NewId(),
                        Socket    = socket,
                        Identity  = socket.Identity,
                    });
                }
            }
            else if (socket.LinkMode == MalockMessage.LINK_MODE_SERVER)
            {
                MalockNodeMessage message = (MalockNodeMessage)socket.UserToken;
                if (message != null)
                {
                    string[]    keys;
                    MalockTable malock = this.malockEngine.GetTable();
                    malock.Exit(message.Identity, out keys);
                    this.malockEngine.AckPipelineEnter(message.Identity, keys);
                }
            }
            lock (socket)
            {
                socket.Aborted   -= this.onAboredHandler;
                socket.Connected -= this.onConnectedHandler;
                socket.Received  -= this.onReceivedHandler;
            }
        }
示例#8
0
        private void ProcessClient(MalockSocket socket, MalockNodeMessage message)
        {
            if (message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_ENTER ||
                message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_EXIT ||
                message.Command == MalockNodeMessage.CLIENT_COMMAND_GETALLINFO ||
                message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_ACKPIPELINEEXIT ||
                message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_ACKPIPELINEENTER)
            {
                MalockTaskInfo info = new MalockTaskInfo();
                switch (message.Command)
                {
                case MalockNodeMessage.CLIENT_COMMAND_LOCK_ENTER:
                    info.Type = MalockTaskType.kEnter;
                    break;

                case MalockNodeMessage.CLIENT_COMMAND_LOCK_EXIT:
                    info.Type = MalockTaskType.kExit;
                    break;

                case MalockNodeMessage.CLIENT_COMMAND_GETALLINFO:
                    info.Type = MalockTaskType.kGetAllInfo;
                    break;

                case MalockNodeMessage.CLIENT_COMMAND_LOCK_ACKPIPELINEEXIT:
                    info.Type = MalockTaskType.kAckPipelineExit;
                    break;

                case MalockNodeMessage.CLIENT_COMMAND_LOCK_ACKPIPELINEENTER:
                    info.Type = MalockTaskType.kAckPipelineEnter;
                    break;
                }
                info.Sequence = message.Sequence;
                info.Socket   = socket;
                info.Key      = message.Key;
                info.Identity = socket.Identity;
                info.Timeout  = message.Timeout;
                do
                {
                    Stopwatch sw = new Stopwatch();
                    info.Stopwatch = sw;
                    sw.Start();
                } while (false);
                if (message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_EXIT)
                {
                    this.malockEngine.Exit(info);
                }
                else if (message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_ENTER)
                {
                    if (this.malockEngine.Enter(info))
                    {
                        this.malockEngine.AckPipelineEnter(info);
                    }
                    else
                    {
                        this.malockEngine.GetPoll().Add(info);
                    }
                }
                else if (message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_ACKPIPELINEEXIT)
                {
                    this.malockEngine.AckPipelineExit(info); // anti-deadlock
                }
                else if (message.Command == MalockNodeMessage.CLIENT_COMMAND_LOCK_ACKPIPELINEENTER)
                {
                    this.malockEngine.AckPipelineEnter(info);
                }
                else if (message.Command == MalockNodeMessage.CLIENT_COMMAND_GETALLINFO)
                {
                    this.malockEngine.GetAllInfo(info);
                }
            }
        }