Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Con la prima rete 5G Standalone attiva in Italia, WINDTRE compie un passo decisivo verso un modello di connettività intelligente che abilita scenari avanzati per imprese e pubbliche amministrazioni, trasformando la rete da infrastruttura a piattaforma per servizi a valore aggiunto
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro punta a diventare uno dei riferimenti assoluti nel segmento dei camera phone di fascia alta. Con un teleobiettivo Hasselblad da 200 MP, una batteria al silicio-carbonio da 7500 mAh e un display da 6,78 pollici con cornici ultra ridotte, il nuovo flagship non teme confronti con la concorrenza, e non solo nel comparto fotografico mobile. La dotazione tecnica include il processore MediaTek Dimensity 9500, certificazione IP69 e un sistema di ricarica rapida a 80W
DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-10-2008, 13:13   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[C#]Semplice Servizio

Ciao a tutti

Mi sto cimentando (solo a fini didattici) a scrivere un piccolo servizio per windows passo dopo passo senza cioè utilizzare il wizard di visual studio.

Studiando vari esempi sono giunto a:

Codice:
//scopo del programma di copiare dei file da una directory in un'altra
using System;
using System.ServiceProcess;
using System.Threading;

namespace TestCronService
{
    public class BatchCopy : ServiceBase
    {
        private BatchCopyAction bc;
        private Timer stateTimer;
        private TimerCallback timerDelegate;

        public BatchCopy()
        {
            this.ServiceName = "TestBatchCopy";
            this.CanStop = true;
            this.CanPauseAndContinue = false;
            this.AutoLog = true;
        }

        protected override void OnStart(string[] args)
        {
            
            bc = new BatchCopyAction();
            timerDelegate = new TimerCallback(bc.DoCopy);
            stateTimer = new Timer(timerDelegate, null, 1000, 1000);

        }

        protected override void OnStop()
        {
            
            stateTimer.Dispose();
        }

        public static void Main()
        {
            Run(new BatchCopy());
        }
    }
}

//File BatchCopyAction.cs
using System;
using System.Collections.Generic;
using System.IO;
using System.Text;

namespace TestCronService
{
    public class BatchCopyAction
    {
        private string source = @"c:\test";
        
        private string destination = @"c:\test\Bck";
        
        public void DoCopy(object stateObject)
        {
            try
            {
                if (Directory.Exists(source))
                {
                    string[] fileInSource = Directory.GetFiles(source);
                    foreach (string fileName in fileInSource)
                    {
                        string sourceFile = Path.GetFileName(fileName);
                        string destFile = Path.Combine(destination, DateTime.Now.ToShortDateString().Replace("/", "-") + DateTime.Now.ToShortTimeString().Replace(".", "-") + sourceFile);
                        File.Copy(sourceFile, destFile, true);
                    }
                }
            }
            catch (IOException ex)
            {
                Console.Write(ex.Message);
            }
        }
               
    }
}

//File BatchCopyInstaller.cs
using System;
using System.ComponentModel;
using System.Configuration.Install;
using System.ServiceProcess;

namespace TestCronService
{
    [RunInstaller(true)]
    public class BatchCopyInstaller : Installer
    {
        private ServiceProcessInstaller processInstaller;
        private ServiceInstaller serviceInstaller;

        public BatchCopyInstaller()
        {
            processInstaller = new ServiceProcessInstaller();
            serviceInstaller = new ServiceInstaller();
            processInstaller.Account = ServiceAccount.LocalSystem;
            serviceInstaller.StartType = ServiceStartMode.Manual;
            serviceInstaller.ServiceName = "TestBatchCopy";
            Installers.Add(serviceInstaller);
            Installers.Add(processInstaller);
        }

    }
}
Compila senza errori e senza warning.

Il problema che ho è quando cerco di installare il servizio e di avviarlo:

questo è il log dopo:

Codice:
InstallUtil /LogToConsole=true TestBatchCopy.exe
Codice:
//log dell'installer

Esecuzione di un'installazione transazionale.

Inizio della fase di installazione.
Vedere il contenuto del file di log per informazioni sullo stato dell'assembly c:\TestCronService.exe.
Il file si trova in c:\TestCronService.InstallLog.

Si è verificata un'eccezione durante la fase di installazione.
System.Security.SecurityException: Origine non trovata, ma non è stato possibile eseguire la ricerca in uno o più log eventi. Log non accessibili: Security.

Sta iniziando la fase di ripristino dello stato precedente dell'installazione.
Vedere il contenuto del file di log per informazioni sullo stato dell'assembly c:\testCronService.exe.
Il file si trova in c:\testCronService.InstallLog.

Fase di ripristino dello stato precedente completata.

Installazione transazionale completata.
e questo invece il log del servizio:
Codice:
Installazione dell'assembly 'c:\TestCronService.exe' in corso...
I parametri interessati sono:
   logtoconsole = true
   assemblypath = c:\TestCronService.exe
   logfile = c:\TestCronService.InstallLog
Installazione del servizio TestBatchCopy in corso...
È in corso la creazione dell'origine di EventLog TestBatchCopy nel log Application...
Ripristino dello stato precedente dell'assembly 'c:\TestCronService.exe' in corso...
I parametri interessati sono:
   logtoconsole = true
   assemblypath = c:\TestCronService.exe
   logfile = c:\TestCronService.InstallLog
Ripristino del log eventi allo stato precedente per l'origine TestBatchCopy.
Si è verificata un'eccezione durante la fase di ripristino dello stato precedente del programma di installazione di System.Diagnostics.EventLogInstaller.
System.Security.SecurityException: Origine non trovata, ma non è stato possibile eseguire la ricerca in uno o più log eventi. Log non accessibili: Security.
Si è verificata un'eccezione durante la fase di ripristino dello stato precedente. L'eccezione verrà ignorata e il ripristino dello stato precedente continuerà, tuttavia è possibile che non venga completamente ripristinato lo stato precedente l'installazione al termine dell'operazione.


grazie mille.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2008, 11:06   #2
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
uppettino
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2008, 11:52   #3
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Ok.. servizio installato ed avviato correttamente. Dovevo solo specificare meglio il tipo di account...

Ad ogni modo...

non funziona

L'unico task che dovrebbe eseguire (contenuto nel file BatchCopyAction), non viene eseguito.

Chi mi da un aiutino?

Grazie mille

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2008, 13:29   #4
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
prova a scrivere nel main:
Codice:
ServiceBase[] ServicesToRun;
ServicesToRun = new ServiceBase[] { new BatchCopy() };
ServiceBase.Run(ServicesToRun);
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2008, 14:03   #5
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da ^TiGeRShArK^ Guarda i messaggi
prova a scrivere nel main:
Codice:
ServiceBase[] ServicesToRun;
ServicesToRun = new ServiceBase[] { new BatchCopy() };
ServiceBase.Run(ServicesToRun);
Niente da fare..

Ho fatto un'altra prova:

se provo a creare un semplice file di testo me lo crea.
La cosa strana è che me lo crea appena lancio il servizio e poi basta.
Credo quindi che l'utilizzo del Timer non sia corretto.

Grazie ancora.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2008, 18:36   #6
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
aspè...
Ma vedi che il timer lo dovresti lanciare in un thread a parte, altrimenti quando esci dalla onStart il timer ti muore ora che mi ci fai pensare..

EDIT: o meglio.. non so come funziona il timer quindi mi sfugge se gira automaticamente in un altro thread..
__________________

Ultima modifica di ^TiGeRShArK^ : 30-10-2008 alle 18:41.
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2008, 12:55   #7
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da ^TiGeRShArK^ Guarda i messaggi
aspè...
Ma vedi che il timer lo dovresti lanciare in un thread a parte, altrimenti quando esci dalla onStart il timer ti muore ora che mi ci fai pensare..

EDIT: o meglio.. non so come funziona il timer quindi mi sfugge se gira automaticamente in un altro thread..
Mumble... potrebbe essere anche così.

Ciò però non mi spiega perchè almeno sulla OnStart non effettua la prima copia.

Il metodo che copia i file se lo utilizzo in un progetto eseguibile funziona, quindi escluderei che sia questo.

Come ulteriore prova ho anche utilizzato il wizard di visual studio ma il risultato è lo stesso: non avviene nulla.

Grazie mille.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi Wind Tre 'accende' il 5G Standalone in Italia: s...
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Addio console: Just Dance Now trasforma ...
Driver Radeon Adrenalin 25.10: perch&egr...
Oltre le GPU: NVIDIA annuncia NVQLink, ...
Samsung lancia il Team Galaxy Italia per...
Magic Leap: indistinguibili dai normali ...
Aruba Cloud: trasparenza sui costi e str...
Quando il cloud si blocca e resti al fre...
Integrare per competere, la sfida digita...
Leggenda del rally e modernità: S...
La Python Software Foundation rinuncia a...
Full HD e QLED, è in offerta un TV da 32...
Honda ha rilasciato un nuovo video sul p...
Resident Evil Requiem: arriva su Switch ...
Marshall Acton III in promo su Amazon in...
2 portatili che costano poco ma vanno be...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 00:49.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v