Example #1
0
        /* Start UDP server */
        private void StartUDPServer()
        {
            SimpleUdpServer udpServer = new SimpleUdpServer(rpcProgram.GetPort(), rpcProgram,
                                                            1);

            rpcProgram.StartDaemons();
            try
            {
                udpServer.Run();
            }
            catch (Exception e)
            {
                Log.Fatal("Failed to start the UDP server.", e);
                if (udpServer.GetBoundPort() > 0)
                {
                    rpcProgram.Unregister(PortmapMapping.TransportUdp, udpServer.GetBoundPort());
                }
                udpServer.Shutdown();
                ExitUtil.Terminate(1, e);
            }
            udpBoundPort = udpServer.GetBoundPort();
        }
Example #2
0
        private static void StartServer()
        {
            ILogX log = null;

            try
            {
                Console.Title = "[Yuanfeng] Log UDP Server v1.0";
                Console.WriteLine("正在启动日志服务...");

                log = LogX.NewLogger(typeof(Program));
                IUdpServerX server = new SimpleUdpServer();

                server.Create(8000, new OnReceivedMsgDelegate((string ipaddr, object obj) =>
                {
                    UdpMsg msg = obj as UdpMsg;
                    switch (msg.Level)
                    {
                    case Level.DEBUG:
                        log.Debug(msg.Logger, msg.Message, msg.Exception);
                        break;

                    case Level.FATAL:
                        log.Fatal(msg.Logger, msg.Message, msg.Exception);
                        break;

                    case Level.INFO:
                        log.Info(msg.Logger, msg.Message, msg.Exception);
                        break;

                    case Level.ERROR:
                        log.Error(msg.Logger, msg.Message, msg.Exception);
                        break;

                    default:
                        break;
                    }
                    Console.Write("[" + ipaddr + "]");
                    Console.Write(msg.Message + ",");
                    Console.WriteLine(msg.Exception);
                }));
                Console.WriteLine("日志服务启动成功..");
                Console.WriteLine(string.Format("服务器IP地址:{0},端口:8000", server.IpAddr));
                Console.WriteLine("操作命令:\n1、exit-关闭日志服务\n2、list-客户端列表");
                Console.Write("<yuanfeng.udpserver>");
                new Thread(new ThreadStart(() =>
                {
                    while (true)
                    {
                        string line = Console.ReadLine();
                        if ("exit".Equals(line))
                        {
                            server.Close(); break;
                        }
                        else if ("list".Equals(line))
                        {
                            foreach (var item in server.Clients)
                            {
                                Console.WriteLine(item);
                            }
                        }
                        else if ("clear".Equals(line))
                        {
                            Console.Clear();
                        }

                        Console.Write("<yuanfeng.udpserver>");
                    }
                })).Start();
            }
            catch (Exception exception) { log.Error(exception); throw new Exception("启动服务失败", exception); }
        }