private void StartMethod() { Stopwatch stopwatch = new Stopwatch(); stopwatch.Start(); logger.LogInfoMessage(nameof(TmcWinService) + " starting TMC settler....."); logger.LogInfoMessage(nameof(TmcWinService) + " Start Job schedule for "); logger.LogInfoMessage(nameof(TmcWinService) + "Creating multithreading Threads to spool from 145 to e_transaction for each channel"); logger.LogInfoMessage(nameof(TmcWinService) + "Instantiating EtranzactChannelTransaction Threads "); EtranzactChannelTransaction etzTrx = new EtranzactChannelTransaction(); Thread etzTrxThread = new Thread(new ThreadStart(etzTrx.Run)); logger.LogInfoMessage(nameof(TmcWinService) + "Starting the EtranzactChannelTransaction Threads "); etzTrxThread.Start(); logger.LogInfoMessage(nameof(TmcWinService) + "Instantiating NonEtzCardTransaction Threads "); NonEtzCardTransaction nonEtzCard = new NonEtzCardTransaction(); Thread nonEtzCardThread = new Thread(new ThreadStart(nonEtzCard.Run)); logger.LogInfoMessage(nameof(TmcWinService) + "Starting the NonEtzCardTransaction Threads "); nonEtzCardThread.Start(); logger.LogInfoMessage(nameof(TmcWinService) + "Instantiating MastercardTransactions Threads "); MastercardTransactions mastercardTrx = new MastercardTransactions(); Thread mastercardTrxThread = new Thread(new ThreadStart(mastercardTrx.Run)); logger.LogInfoMessage(nameof(TmcWinService) + "Starting the MastercardTransactions Threads "); mastercardTrxThread.Start(); //mastercardTrxThread.Join(); //nonEtzCardThread.Join(); //etzTrxThread.Join(); stopwatch.Stop(); }
public void Run() { //Check for Time Processing if (DateTime.Now.Hour >= 1 && DateTime.Now.Hour < 4) { //Check if there is a closed SettleBatch--- if Closed for the day, settlement has been completed.Assumed // E_SETTLE_BATCH settle_batch = new E_SETTLE_BATCH(); var settle_batch = Settlement.GetSettleBatch(); if (settle_batch.CLOSED == null || settle_batch == null) { string batchID = Settlement.SetSettleBatch(); using (var db = new EtzbkDataContext()) { db.Database.ExecuteSqlCommand("UPDATE E_SETTLEMENT_DOWNLOAD_BK SET SETTLE_BATCH ='" + batchID + "' WHERE SETTLE_BATCH IS NULL"); db.Database.ExecuteSqlCommand("UPDATE E_FEE_DETAIL_BK SET SETTLE_BATCH ='" + batchID + "' WHERE SETTLE_BATCH IS NULL"); db.Database.ExecuteSqlCommand("UPDATE E_SETTLE_BATCH SET CLOSED='1' WHERE BATCH_ID='" + batchID + "'"); } //Set settlebatch on strations with Settlebatch null and less than today's date } } // Stopwatch stopwatch = new Stopwatch(); stopwatch.Start(); logger.LogInfoMessage(nameof(TmcSettler) + " starting TMC settler....."); logger.LogInfoMessage(nameof(TmcSettler) + " Start Job schedule for "); logger.LogInfoMessage(nameof(TmcSettler) + "Creating multithreading Threads to spool from 145 to e_transaction for each channel"); logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating EtranzactChannelTransaction Threads "); EtranzactChannelTransaction etzTrx = new EtranzactChannelTransaction(); Thread etzTrxThread = new Thread(new ThreadStart(etzTrx.Run)); logger.LogInfoMessage(nameof(TmcSettler) + "Starting the EtranzactChannelTransaction Threads "); etzTrxThread.Start(); logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating NonEtzCardTransaction Threads "); NonEtzCardTransaction nonEtzCard = new NonEtzCardTransaction(); Thread nonEtzCardThread = new Thread(new ThreadStart(nonEtzCard.Run)); logger.LogInfoMessage(nameof(TmcSettler) + "Starting the NonEtzCardTransaction Threads "); nonEtzCardThread.Start(); logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating MastercardTransactions Threads "); MastercardTransactions mastercardTrx = new MastercardTransactions(); Thread mastercardTrxThread = new Thread(new ThreadStart(mastercardTrx.Run)); logger.LogInfoMessage(nameof(TmcSettler) + "Starting the MastercardTransactions Threads "); mastercardTrxThread.Start(); //mastercardTrxThread.Join(); //nonEtzCardThread.Join(); //etzTrxThread.Join(); stopwatch.Stop(); logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating TaskProducerConsumer Threads "); TaskProducerConsumer taskProducerConsumer = new TaskProducerConsumer(); Thread taskProducerConsumerThread = new Thread(new ThreadStart(taskProducerConsumer.Run)); logger.LogInfoMessage(nameof(TmcSettler) + "Starting the TaskProducerConsumer Threads "); taskProducerConsumerThread.Start(); //taskProducerConsumerThread.Join(); /* * logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating CardloadProducer Threads "); * CardloadProducer cardloadProducer = new CardloadProducer(); * Thread cardloadProducerThread = new Thread(new ThreadStart(cardloadProducer.Run)); * logger.LogInfoMessage(nameof(TmcSettler) + "Starting the CardloadProducer Threads "); * cardloadProducerThread.Start(); * * logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating TransferProducer Threads "); * TransferProducer transferdProducer = new TransferProducer(); * Thread transferProducerThread = new Thread(new ThreadStart(transferdProducer.Run)); * logger.LogInfoMessage(nameof(TmcSettler) + "Starting the TransferProducer Threads "); * transferProducerThread.Start(); * * * * logger.LogInfoMessage(nameof(TmcSettler) + "Instantiating PaymentProducer Threads "); * PaymentProducer paymentProducer = new PaymentProducer(); * Thread paymentProducerThread = new Thread(new ThreadStart(paymentProducer.Run)); * logger.LogInfoMessage(nameof(TmcSettler) + "Starting the PaymentProducer Threads "); * paymentProducerThread.Start(); * * paymentProducerThread.Join(); * transferProducerThread.Join(); * cardloadProducerThread.Join(); * * mastercardTrxThread.Join(); * nonEtzCardThread.Join(); * etzTrxThread.Join(); * */ Console.WriteLine("Round completed in " + stopwatch.Elapsed); Console.ReadLine(); }