예제 #1
0
        public ServerGroup(string name, ServerVisibility visibility, DarkRiftThreadHelper threadHelper, Logger logger, MetricsCollector metricsCollector)
        {
            this.Name       = name;
            this.Visibility = visibility;

            this.threadHelper = threadHelper;
            this.logger       = logger;

            serversConnectedGauge            = metricsCollector.Gauge("remote_servers_connected", "The number of servers connected to the server in this group.", "group").WithTags(name);
            serverJoinedEventTimeHistogram   = metricsCollector.Histogram("remote_server_joined_event_time", "The time taken to execute the ServerJoined event.", "group").WithTags(name);
            serverLeftEventTimeHistogram     = metricsCollector.Histogram("remote_server_left_event_time", "The time taken to execute the ServerLeft event.", "group").WithTags(name);
            serverJoinedEventFailuresCounter = metricsCollector.Counter("remote_server_joined_event_failures", "The number of failures executing the ServerJoined event.", "group").WithTags(name);
            serverLeftEventFailuresCounter   = metricsCollector.Counter("remote_server_left_event_failures", "The number of failures executing the ServerLeft event.", "group").WithTags(name);
        }
        /// <summary>
        ///     Creates a new remote server.
        /// </summary>
        /// <param name="id">The ID of the server.</param>
        /// <param name="host">The host connected to.</param>
        /// <param name="port">The port connected to.</param>
        /// <param name="group">The group the server belongs to.</param>
        /// <param name="threadHelper">The thread helper to use.</param>
        /// <param name="logger">The logger to use.</param>
        /// <param name="metricsCollector">The metrics collector to use.</param>
        internal DownstreamRemoteServer(ushort id, string host, ushort port, DownstreamServerGroup group, DarkRiftThreadHelper threadHelper, Logger logger, MetricsCollector metricsCollector)
        {
            this.ID           = id;
            this.Host         = host;
            this.Port         = port;
            this.serverGroup  = group;
            this.threadHelper = threadHelper;
            this.logger       = logger;

            messagesSentCounter                    = metricsCollector.Counter("messages_sent", "The number of messages sent to remote servers.");
            messagesReceivedCounter                = metricsCollector.Counter("messages_received", "The number of messages received from remote servers.");
            messageReceivedEventTimeHistogram      = metricsCollector.Histogram("message_received_event_time", "The time taken to execute the MessageReceived event.");
            messageReceivedEventFailuresCounter    = metricsCollector.Counter("message_received_event_failures", "The number of failures executing the MessageReceived event.");
            serverConnectedEventTimeHistogram      = metricsCollector.Histogram("remote_server_connected_event_time", "The time taken to execute the ServerConnected event.", "group").WithTags(group.Name);
            serverDisconnectedEventTimeHistogram   = metricsCollector.Histogram("remote_server_disconnected_event_time", "The time taken to execute the ServerDisconnected event.", "group").WithTags(group.Name);
            serverConnectedEventFailuresCounter    = metricsCollector.Counter("remote_server_connected_event_failures", "The number of failures executing the ServerConnected event.", "group").WithTags(group.Name);
            serverDisconnectedEventFailuresCounter = metricsCollector.Counter("remote_server_disconnected_event_failures", "The number of failures executing the ServerDisconnected event.", "group").WithTags(group.Name);
        }
예제 #3
0
        public ObjectCacheMonitor(PluginLoadData pluginLoadData) : base(pluginLoadData)
        {
            string periodSetting = pluginLoadData.Settings["period"];

            if (periodSetting != null)
            {
                if (!int.TryParse(periodSetting, out period))
                {
                    Logger.Error("'period' setting was not a valid number. Using the default of " + period + "ms.");
                }
            }

            timer = new System.Threading.Timer(CheckObjectCache);

#if PRO
            finalizationsCounter = MetricsCollector.Counter("finalizations", "The number of recyclable objects that have been finalized.", "type");
#endif
        }