프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

markus / MarkusLogview / SignalREngineServiceWindowsService / SignalREngineServiceWindowsService.cs @ cc749215

이력 | 보기 | 이력해설 | 다운로드 (13.7 KB)

1 84578b97 djkim
using System;
2
using System.Data.Common;
3
using System.Diagnostics;
4
using System.Diagnostics.Contracts;
5
using System.Linq;
6
using System.Reflection;
7
using System.ServiceProcess;
8
using System.Threading;
9
using System.Timers;
10
using MarkusDataModel.Common;
11
using MarkusDataModel.DataModel;
12
using MarkusDataModel.DTOs;
13
using Microsoft.AspNet.SignalR.Client;
14
using ServiceInterface;
15
using SignalREngine;
16
using SignalREngineServiceWindowsService.HubConfig;
17
using TableDependency;
18
using TableDependency.EventArgs;
19
using TableDependency.SqlClient;
20
21
namespace SignalREngineServiceWindowsService
22
{
23
    class SignalREngineServiceWindowsService : ServiceBase
24
    {
25
        #region Default Configuration , Init variable
26
27
        /// <summary>
28
        /// Sql Table Dependency 
29
        /// </summary>
30
        private static SqlTableDependency<CONVERTER_DOC> _convertTableDependency;
31
        private static SqlTableDependency<FINAL_PDF> _finalTableDependency;
32
        private static string entityConnString = ConnectStringBuilder.MarkusConnectionString().ProviderConnectionString.ToString();
33
        private static string hubBaseURL = "http://localhost:8089";
34
        private static string hubName = "MarkusHub";
35
        private static ConvertSetting convSetting = new ConvertSetting();
36
        private static FinalSetting finalSetting = new FinalSetting();
37
        private static DetectedType detectedType = new DetectedType();
38
39
        /// <summary>
40
        /// Logger 
41
        /// </summary>
42
        private static ServiceEventLogger _serviceEventLogger = new ServiceEventLogger();
43
44
        /// <summary>
45
        /// Public Constructor for WindowsService.
46
        /// - Put all of your Initialization code here.
47
        /// </summary>
48
        public SignalREngineServiceWindowsService()
49
        {
50
51
            this.ServiceName = "SignalREngineServiceWindowsService";
52
            this.EventLog.Log = "Application";
53
54
            // These Flags set whether or not to handle that specific
55
            //  type of event. Set to true if you need it, false otherwise.
56
            this.CanHandlePowerEvent = true;
57
            this.CanHandleSessionChangeEvent = true;
58
            this.CanPauseAndContinue = true;
59
            this.CanShutdown = true;
60
            this.CanStop = true;
61
62
        }
63
64
        /// <summary>
65
        /// Dispose of objects that need it here.
66
        /// </summary>
67
        /// <param name="disposing">Whether
68
        ///    or not disposing is going on.</param>
69
        protected override void Dispose(bool disposing)
70
        {
71
            base.Dispose(disposing);
72
        }
73
74
        /// <summary>
75
        /// OnStart(): Put startup code here
76
        ///  - Start threads, get inital data, etc.
77
        /// </summary>
78
        /// <param name="args"></param>
79
        protected override void OnStart(string[] args)
80
        {
81
82
            AllStart_Service();
83
            base.OnStart(args);
84
85
        }
86
        #endregion
87
88
        #region service override method 
89
        /// <summary>
90
        /// OnStop(): Put your stop code here
91
        /// - Stop threads, set final data, etc.
92
        /// </summary>
93
        protected override void OnStop()
94
        {
95
            //this.timer.Stop();
96
            //this.timer = null;
97
            base.OnStop();
98
        }
99
100
        /// <summary>
101
        /// OnPause: Put your pause code here
102
        /// - Pause working threads, etc.
103
        /// </summary>
104
        protected override void OnPause()
105
        {
106
            base.OnPause();
107
        }
108
109
        /// <summary>
110
        /// OnContinue(): Put your continue code here
111
        /// - Un-pause working threads, etc.
112
        /// </summary>
113
        protected override void OnContinue()
114
        {
115
            base.OnContinue();
116
        }
117
118
        /// <summary>
119
        /// OnShutdown(): Called when the System is shutting down
120
        /// - Put code here when you need special handling
121
        ///   of code that deals with a system shutdown, such
122
        ///   as saving special data before shutdown.
123
        /// </summary>
124
        protected override void OnShutdown()
125
        {
126
            base.OnShutdown();
127
        }
128
129
        /// <summary>
130
        /// OnCustomCommand(): If you need to send a command to your
131
        ///   service without the need for Remoting or Sockets, use
132
        ///   this method to do custom methods.
133
        /// </summary>
134
        /// <param name="command">Arbitrary Integer between 128 & 256</param>
135
        protected override void OnCustomCommand(int command)
136
        {
137
            //  A custom command can be sent to a service by using this method:
138
            //#  int command = 128; //Some Arbitrary number between 128 & 256
139
            //#  ServiceController sc = new ServiceController("NameOfService");
140
            //#  sc.ExecuteCommand(command);
141
142
            base.OnCustomCommand(command);
143
        }
144
145
        /// <summary>
146
        /// OnPowerEvent(): Useful for detecting power status changes,
147
        ///   such as going into Suspend mode or Low Battery for laptops.
148
        /// </summary>
149
        /// <param name="powerStatus">The Power Broadcast Status
150
        /// (BatteryLow, Suspend, etc.)</param>
151
        protected override bool OnPowerEvent(PowerBroadcastStatus powerStatus)
152
        {
153
            return base.OnPowerEvent(powerStatus);
154
        }
155
156
        /// <summary>
157
        /// OnSessionChange(): To handle a change event
158
        ///   from a Terminal Server session.
159
        ///   Useful if you need to determine
160
        ///   when a user logs in remotely or logs off,
161
        ///   or when someone logs into the console.
162
        /// </summary>
163
        /// <param name="changeDescription">The Session Change
164
        /// Event that occured.</param>
165
        protected override void OnSessionChange(
166
                  SessionChangeDescription changeDescription)
167
        {
168
            base.OnSessionChange(changeDescription);
169
        }
170
171
        private void InitializeComponent()
172
        {
173
174
        }
175
        #endregion
176
177
        #region Table Dependency Configuration 
178
179
        
180
        public static void DependencyRestart()
181
        {
182
183
            TimeSpan _waitTime = TimeSpan.FromSeconds(2);
184
185
            ServiceController _watcher = new ServiceController("SignalR_Watcher");
186
187
            Process[] watcher = Process.GetProcessesByName("SignalR_Server_Watcher");
188
189
            if ( watcher.Length > 0)
190
            {
191
                watcher[0].Kill();
192
                _serviceEventLogger.WriteEventEntry("singalR Server ::: signalr watcher Service kill ", EventLogEntryType.SuccessAudit);
193
194
195
                _watcher.Refresh();
196
197
                if ( _watcher.Status == ServiceControllerStatus.Running || _watcher.Status == ServiceControllerStatus.StartPending)
198
                {
199
                    _watcher.WaitForStatus(ServiceControllerStatus.Stopped);
200
                }
201
202
                _watcher.Start(new string[] { "Restart" });
203
                _watcher.WaitForStatus(ServiceControllerStatus.Running);
204
205
                _serviceEventLogger.WriteEventEntry("singalR Server ::: signalr watcher Service Restart ", EventLogEntryType.SuccessAudit);
206
207
            }
208
            else
209
            {
210
                _serviceEventLogger.WriteEventEntry("singalR Server :::  signalr watcher Service Not Found", EventLogEntryType.Error);
211
            }
212
213
        }
214
215
        public static void AllStart_Service()
216
        {
217
218
            ConvertDep();
219
            FinalDep();
220
            Startup.StartServer();
221
222
            _serviceEventLogger.WriteEventEntry(" AllStart_Service ", EventLogEntryType.SuccessAudit);
223
224
        }
225
226
227
        public static void ConvertDep()
228
        {
229
230
            try
231
            {
232
                
233
                var convertMapper = new ModelToTableMapper<CONVERTER_DOC>();
234
                convertMapper.AddMapping(s => s.CURRENT_PAGE, "CURRENT_PAGE");
235
236
                _convertTableDependency = new SqlTableDependency<CONVERTER_DOC>(entityConnString, "CONVERTER_DOC", convertMapper);
237
238
                // Registration Dependency Event 
239
                _convertTableDependency.OnError += SqlTableDependency_OnError;
240
                _convertTableDependency.OnChanged += Convert_SqlTableDependency_Changed;
241
242
                _convertTableDependency.Start();
243
244
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " start", EventLogEntryType.SuccessAudit);
245
246
            }
247
            catch (Exception ex)
248
            {
249
                _serviceEventLogger.WriteEventEntry("SQL Dependency ERROR " + MethodBase.GetCurrentMethod().Name + " : " + ex.Message, EventLogEntryType.Error);
250
                DependencyRestart();
251
                throw;
252
            }
253
254
        }
255
256
        public static void FinalDep()
257
        {
258
259
            try
260
            {
261
                var finalMapper = new ModelToTableMapper<FINAL_PDF>();
262
                finalMapper.AddMapping(s => s.CURRENT_PAGE, "CURRENT_PAGE");
263
264
                _finalTableDependency = new SqlTableDependency<FINAL_PDF>(entityConnString, "FINAL_PDF", finalMapper);
265
266
                _finalTableDependency.OnError += SqlTableDependency_OnError;
267
                _finalTableDependency.OnChanged += Final_SqlTableDependency_Changed;
268
269
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " start", EventLogEntryType.SuccessAudit);
270
271
                _finalTableDependency.Start();
272
            }
273
            catch (Exception ex)
274
            {
275
                _serviceEventLogger.WriteEventEntry("SQL Dependency ERROR " + MethodBase.GetCurrentMethod().Name + " : " + ex.Message, EventLogEntryType.Error);
276
                DependencyRestart();
277
                throw;
278
            }
279
280
        }
281
282
        public static void SqlTableDependency_OnError(object sender, ErrorEventArgs e)
283
        {
284
            _serviceEventLogger.WriteEventEntry(" SQL Dependency ERROR " + MethodBase.GetCurrentMethod().Name + " :: " + e.Message, EventLogEntryType.Error);
285
            DependencyRestart();
286
            throw e.Error;
287
        }
288
289
        #endregion
290
291
        #region Detection change data 
292
293
        /// <summary>
294
        /// 컨버팅 테이블 데이터 변경에 대한 이벤트 감지 메서드 
295
        /// </summary>
296
        /// <param name="sender"></param>
297
        /// <param name="e"></param>
298
        public static void Convert_SqlTableDependency_Changed(object sender, RecordChangedEventArgs<CONVERTER_DOC> e)
299
        {
300
            try
301
            {
302
303
                string changeType = e.ChangeType.ToString();
304
                DetectedMakrusConvertTable(e.ChangeType.ToString(), e.Entity);
305
306
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " changeType : " + changeType, EventLogEntryType.SuccessAudit);
307
308
            }
309
            catch (Exception ex)
310
            {
311
                _serviceEventLogger.WriteEventEntry("Convert_SqlTableDependency_Changed Error : " + ex, EventLogEntryType.Error);
312
                throw;
313
            }
314
        }
315
316
        /// <summary>
317
        /// 파이널 테이블 데이터 변경에 대한 이벤트 감지 메서드 
318
        /// </summary>
319
        /// <param name="sender"></param>
320
        /// <param name="e"></param>
321
        public static void Final_SqlTableDependency_Changed(object sender, RecordChangedEventArgs<FINAL_PDF> e)
322
        {
323
            try
324
            {
325
                string changeType = e.ChangeType.ToString();
326
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " changeType : " + changeType, EventLogEntryType.SuccessAudit);
327
328
                DetectedMakrusFinalTable(changeType, e.Entity);
329
330
            }
331
            catch (Exception ex)
332
            {
333
                _serviceEventLogger.WriteEventEntry("Final_SqlTableDependency_Changed Error : " + ex, EventLogEntryType.Error);
334
                throw;
335
            }
336
        }
337
338
        #endregion
339
340
        #region Markus hub invoke method 
341
342
        /// <summary>
343
        /// 컨버팅 테이블에 대한 허브 invoke 메서드 
344
        /// </summary>
345
        /// <param name="type"></param>
346
        /// <param name="data"></param>
347
        public static void DetectedMakrusConvertTable(string type, CONVERTER_DOC data)
348
        {
349
350
            using (var hubConn = new HubConnection(hubBaseURL))
351
            {
352
353
                var hub = hubConn.CreateHubProxy(hubName);
354
355
                hubConn.Start().Wait();
356
357
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name, EventLogEntryType.SuccessAudit);
358
359
                if (type == detectedType.DataInsert)
360
                {
361
                    hub.Invoke(convSetting.InvokeInsert , data);
362
                }
363
                else if (type == detectedType.DataUpdate)
364
                {
365
                    hub.Invoke(convSetting.InvokeChange, data);
366
                }
367
                else if (type == detectedType.DataDelete)
368
                {
369
                    hub.Invoke(convSetting.InvokeDelete, data);
370
                }
371
372
            }
373
374
        }
375
376
        /// <summary>
377
        /// 파이널 테이블에 대한 허브 invoke 메서드 
378
        /// </summary>
379
        /// <param name="type"></param>
380
        /// <param name="data"></param>
381
        public static void DetectedMakrusFinalTable(string type, FINAL_PDF data)
382
        {
383
384
            using (var hubConn = new HubConnection(hubBaseURL))
385
            {
386
387
                var hub = hubConn.CreateHubProxy(hubName);
388
389
                hubConn.Start().Wait();
390
391
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name, EventLogEntryType.SuccessAudit);
392
393
                if (type == detectedType.DataInsert)
394
                {
395
                    hub.Invoke(finalSetting.InvokeInsert, data);
396
                }
397
                else if (type == detectedType.DataUpdate)
398
                {
399
                    hub.Invoke(finalSetting.InvokeChange, data);
400
                }
401
                else if (type == detectedType.DataDelete)
402
                {
403
                    hub.Invoke(finalSetting.InvokeDelete, data);
404
                }
405
406
            }
407
408
        }
409
410
        #endregion
411
    }
412
}
클립보드 이미지 추가 (최대 크기: 500 MB)