The Core Technologies Blog

Our Software // Windows Services // 24×7 Operation


How to Setup Email from AlwaysUp


Email from AlwaysUp

AlwaysUp is designed to run your application as a Windows Service and automatically restart it when it crashes or stops for any reason. Even though this frees you from having to take any action on a failure (eliminating those unwelcome “server-not-working” calls at 3 AM), you may still want to:

  • Find out how often your application is failing
  • Know the time when your program stops working (for diagnostic purposes)
  • See how your application is using CPU and memory over the course of the day
  • Find out whenever your server has been rebooted

Automatic email from AlwaysUp will tell you all that, and more!

Specifying Who to Email & When to Send a Message

To setup email in AlwaysUp, edit your application and switch to the Email tab:


AlwaysUp Email Tab

Enter the following:

  1. The email address to notify. To send to multiple addresses, just separate each one with a comma (,).
  2. When AlwaysUp should send you an email — either in response to an important event, or at a regular time. The daily and weekly summary emails are a good way to monitor your application’s activities without having to receive multiple emails throughout the day.
  3. A line of text to be included in the email. This value is optional, but you can use it to explicitly label a server & application when you have many installed with the same name (for example, when you are running the same application on many different workstations).

Server/SMTP Settings

AlwaysUp doesn’t require that you have Outlook or any other email software installed. Instead, it deals directly with your SMTP server – the machine actually responsible for routing your email over the Internet and delivering it to your recipients. Every major provider (such as Gmail, Yahoo and Office 365) supports SMTP mail and it is simply a matter of providing those settings to AlwaysUp so that it can send messages on your behalf.

Click the Configure… button to reveal the details:


Configure Server Settings

The Configure Email Settings window that comes up requests quite a bit of information, but don’t be scared! Your systems administrator will be able to fill this in while balancing a bowl of water on his head and dancing the Macarena, but in case you are entering these values yourself here is what each field means:


Configure Server Settings

  • Address: The email address that will be displayed in the “From” field of the email messages sent by AlwaysUp.
  • Name: The name that will be displayed in the “From” field of the email messages sent. This value is optional.
  • Name/IP: The name (or IP address) of your mail server.
  • Port: The numeric port on which the mail server is available. Note that the default is 25 for regular SMTP servers and 465 for servers using SSL – please specify one if these if in doubt.
  • This server requires encryption: Check and make the appropriate selection if the mail server uses TLS, SSL or STARTTLS.
  • This server requires authentication: Check if the server requires authentication, and select the authentication method. The choices are CRAM-MD5, AUTH-LOGIN, AUTH-PLAIN, and AUTH-NTLM. A login and a password will be required for all but AUTH-NTLM.
  • Login: The user name/login for the mail server. Usually your full email address.
  • Password: The password for your email account.

 

Gmail
How to use your Gmail Account

To send email with your Gmail account, please specify the following settings:

Address: Your full gmail address (your-user-name@gmail.com)
Name: Your name
SMTP Server Name/IP: smtp.gmail.com
Port: 465
Encryption: SSL/TLS
Authentication: AUTH-LOGIN
Login: Your full gmail address (your-user-name@gmail.com)
Password Your gmail password

 

So for someone named Mike Jones, whose Gmail address is jones1985@gmail.com, the Configure Email window should look something like this:


Using Gmail in AlwaysUp

 

Microsoft Office 365
How to use your Microsoft Office 365 Account

If you have an Office 365 mail account, please specify the following settings:

Address: Your full Office 365 email address
Name: Your name
SMTP Server Name/IP: pod51010.outlook.com
Port: 587
Encryption: STARTTLS
Authentication: AUTH-LOGIN
Login: Your full Office 365 email address
Password Your Office 365 password

 

So for Mike Jones, whose Office 365 email address is mike.jones@somecompany.com, the Configure Email window should look something like this:


Using Office 365 in AlwaysUp

Using Another Email Service

This list documents SMTP settings for many other email providers.

 

So that’s it! Please be sure to get in touch if you have any trouble setting up automatic email from AlwaysUp.

Posted in AlwaysUp | Tagged , | Leave a comment

Investigate Crashes & Memory Leaks in your Windows Services with Microsoft’s Debug Diagnostic Tool

Microsoft Debug Diagnostic Tool

Crashes and memory leaks are particularly offensive when the occur in windows services – applications designed to run unattended, 24/7 in the background to perform important tasks. Our AlwaysUp and Service Protector utilities go a long way to diminishing the effect of these insidious failures, but using them is no substitute for finding and fixing a problem at its root.

Developers looking to diagnose failures in their windows services should consider using Microsoft’s Debug Diagnostic Tool. This free desktop application, nicknamed DebugDiag, will monitor your windows service process and create a “dump” describing the state of the application when it crashed (or started using too much memory). You can use this information to narrow down the problem in your own code, or pass it on to the folks who developed the failing service for their expert analysis.

Using the Debug Diagnostic Tool on your Windows Service

  1. Download the Debug Diagnostic Tool from microsoft.com.

  2. Install it. Setup should be quite straightforward, with the usual prompts for a folder, etc.

  3. From Windows Explorer, navigate to the folder where DebugDiag was installed (C:\Program Files\DebugDiag by default). Start DebugDiag.Collection.exe – the application that monitors and collects information from a running process or service.


    Start DebugDiag.Collection.exe

  4. The Debug Diagnostic Tool window should come up and you will be launched immediately into setting up a new “rule” describing what to watch for. From here, you can specify to monitor for crashes, leaks, and even performance-related issues. We’ll select Crash for this tutorial and click Next to move on.


    DebugDiag: Select Crash Option

  5. Next, select the A Specific NT service option:


    DebugDiag: Select Windows Service Option

  6. Select the service you wish to debug from the list. We chose “AA MyService”, a windows service we developed to test our Service Protector application. Click Next.


    DebugDiag: Select Windows Service

  7. Almost there! Leave the Advanced Configuration settings at their default values and click Next to continue:


    DebugDiag: Windows Service Advanced Configuration

  8. You don’t have to make any changes on the Select Dump Location screen either – just make a note of where the dump file will be saved.


    DebugDiag: Windows Service Dump Location

  9. And finally, let’s activate the rule now and click Finish:


    DebugDiag: Activate Now

    After a few seconds, the tool will be monitoring your windows service for crashes:


    DebugDiag: Windows Service Rule Created

Analyzing a Windows Service Crash

When the service crashes, DebugDiag will record a dump file and increment the Userdump count column. Here we can see that 1 crash has occurred and been captured (with the full path to the dump file noted on the right):


DebugDiag: Windows Service Crashed

To dig into the dump file:

  1. Start DebugDiag.Analysis.exe from Windows Explorer:


    Start DebugDiag.Analysis.exe

    The DebugDiag Analysis window will open momentarily:


    DebugDiag Analysis Started

  2. To configure analysis:

    1. Check the CrashHangAnalysis box near to the top.
    2. Click the Add Data Files button, navigate to the location of the dump file (it is mentioned in the Diagnostic tool we set up previously) and select it. A new entry should show up in the lower pane.


    Configure Analysis

  3. And click the Start Analysis button to get going! After a period of “thinking”, the application will open its report in your browser:


    Analysis Summary Report

  4. Scan the report for any smoking guns. Thread call stacks may be particularly useful. For example, this stack trace tells us that our service crashed while handling a button press. (This is not surprising though – that is what we did to force the crash in our testing!)


    Windows Service Call Stack

    Hopefully you will find a telltale sign to help you identify and fix your problem.

Also Find Memory Leaks in your Windows Service

If your windows service is consuming too much memory instead of crashing, configure the collector to watch for memory leaks:


Find Windows Service Memory Leaks

The final report will detail all outstanding memory allocations.

 

Good hunting!

Posted in Windows Services | Tagged , | Leave a comment

AlwaysUp 9: Improvements for running Dropbox/Google Drive/Box Sync/OneDrive 24×7 in the background

Stop Copies before Starting the Service

We are pleased to announce the availability of AlwaysUp version 9.0, our market leading run-anything-as-windows-service solution used by thousands worldwide!

New features include:

Better support for Dropbox, Google Drive and other Applications

Programs that allow you to run only a single copy at a time would occasionally prevent AlwaysUp from starting its own copy in the background. For example, if someone started a copy of Dropbox on their desktop, trying to launch a second copy under AlwaysUp would lead to Dropbox exiting quickly and the service failing to start.

Checking the new Stop all copies of the application running on this computer setting on the Startup will resolve the issue. Instead of simply trying to launch a second copy of your program, AlwaysUp will first stop any existing instances, ensuring that its own copy will start smoothly.

Stop Copies before Starting the Service

We recommend using this setting with the following applications:

… and any others that should only run a single instance.

Additional Power Management Options

To prevent your computer from automatically going to sleep while your important program is being run by AlwaysUp, check the corresponding box on the Extras tab:

Prevent the PC from Sleeping

Reduced Event Logging

As it runs your application as a Windows Service, AlwaysUp writes information, warnings and errors to the Windows Event Log. Usually this is a good thing, keeping you up-to-date on your application’s comings and goings, but it becomes rather “noisy” for applications designed to start and stop frequently. For example, if you have a batch file configured to run every ten minutes, more than 20 events will be generated per hour!

Check the new Minimize event logging as the application stops & restarts box on the Restart tab to improve the situation. Afterwards, you should only see a message when the application starts or terminates unexpectedly. Normal/expected stops and restarts will not be recorded.

Minimize Windows Service Event Logging

 

Be sure to check out the AlwaysUp Version History for the full list of features, fixes and improvements included in this release.

Enjoy!

Posted in AlwaysUp | Tagged , , , , | Leave a comment

AlwaysUp not Starting your Application? Troubleshoot with the Command Prompt

If you find that your application is starting and then quickly stopping when you run it with AlwaysUp, your application may be trying to report an error message that you simply cannot see. In this situation, we recommend starting your application from a command prompt running as a service, to find out if something useful is being written to the console.

How to start CMD.EXE as a service on your desktop

  1. Highlight your troublesome application in AlwaysUp and select Add Copy… from the Application menu.

    (In this guide, our “StartServer” batch file is failing for some unknown reason so we’ll work with that entry…)

    Add Copy


  2. In the Add Application window that comes up:

    1. In the Application field, enter the full path to the windows command prompt. This is:

      C:\Windows\System32\cmd.exe

    2. If there is anything in the Arguments field brought over from the application you copied, please remove it.

    3. Change the Name field to something meaningful. We have entered “CMD Testing” in this guide.

    4. Set the Start the application field to Manually, from AlwaysUp. We don’t want this command prompt service to start automatically at boot.

    Command Prompt Service - General


  3. If you have specified a user on the Logon tab, switch over there and re-enter the password (a security measure).

    Command Prompt Service - Logon


  4. Those are all the changes we need to make so click the Save >> button to record your new service. It will show up on the AlwaysUp console soon.

    Command Prompt Service Saved


  5. Next, start the new CMD service on your desktop by selecting Application > Start “CMD Testing” in this session:

    Start Command Prompt in Session

    In a few seconds, the familiar black box will pop up on your desktop:

    Command Prompt Service Started


  6. And finally, in the command box, type in the full command line you gave to AlwaysUp – application & arguments. Be sure to specify the exact values that you had supplied to your AlwaysUp service! Please cut & paste to ensure accuracy.

    Hit Enter to run your application and pay special attention to what is written to the command prompt.

  7. Hopefully at this point your application will tell us what is wrong! In our case (pictured below), the batch file can’t find the JAR file it is expecting…

    Command Prompt Showing the Error Message

    Resolving the problem

    Common errors include:

    • Running the wrong executable (doh!)
    • Not properly quoting command-line parameters (smacks forehead)
    • Not running from the correct directory (which you can fix by adding the folder on the General tab)
    • Insufficient permissions to access a required resource (are you using the right user on the Logon tab?)


    The AlwaysUp Frequently Asked Questions (FAQ) will help you resolve these and other common issues. And if you’re still stuck, please feel free to contact us for fresh ideas and expert advice :)

    And don’t forget to cleanup when you’re done…

    Once you’ve fixed the problem and verified that your application can start normally with AlwaysUp, please feel free to remove the CMD service by highlighting the entry in AlwaysUp and selecting Application > Remove.

Posted in AlwaysUp | Tagged , | Leave a comment

Getting ready for Windows 10

The next version of Windows, dubbed Windows 10 is expected to be released in the second half of 2015. On October 1, Microsoft provided software makers with an early look at the new OS, so that we can test and certify our applications in advance of the launch. And like a kid in a candy store, we downloaded and eagerly installed the Windows 10 Technical Preview on a VirtualBox VM. The most noticeable change? The return of the Start menu! Finally, Microsoft has come to its senses.

Next, it was on to testing our software. Service Protector, which monitors and automatically restarts failing windows services, passed with flying colors. There with no issues whatsoever. Here it is happily monitoring the Print Spooler service:


Windows 10 Technical Preview - Service Protector

However, things did not go as smoothly for AlwaysUp, our popular utility that runs any application as a windows service. We set up Notepad.exe as a service but quickly ran into trouble starting it:


Windows 10 Technical Preview - AlwaysUp

After a couple of hours of debugging the code, it turns out that the problem is related to to the little-used user reboot notification feature recently introduced in Windows 8 & Server 2012. To avoid getting too technical, let’s just say that the new capability is simply not accepted by Windows 10. Using it causes AlwaysUp to fail to transition the service into the running state and remain in the starting state. And since no controls are accepted in the starting state, all the action buttons are grayed out and the service will remain stuck starting forever! The only way to stop the service is to disable all recovery actions for the service and forcibly terminate AlwaysUpService.exe from the Task Manager. A real mess!

We have reported the problem to Microsoft and hopefully they will resolve it before the official release of Windows 10 next year. If not, a change to our code to eliminate the user reboot notification feature will also fix the problem, so not to worry. We’ll stay on top of it :)

Posted in Miscellaneous | Tagged , , | Leave a comment

How to use the Event Viewer to troubleshoot problems with a Windows Service

A windows service, designed to run “headless” and unattended in the background, cannot easily employ conventional popup windows to report its activities as a user may not even be logged on. Instead, a service is encouraged to send important communication to the Windows Event Log – an administrative utility that collects and stores messages and events. Once recorded, these messages can be very helpful in troubleshooting problems, for example when a service stops unexpectedly or when it fails to start at all.

Viewing Events from Windows Services

Use Microsoft’s Event Viewer to see messages written to the Event Log. Start the application by clicking on the Start button and typing in Event Viewer, or from the Control Panel (search for it by name). The somewhat cluttered window should come up after a few seconds:


Event Viewer

The left hand side shows a tree grouping the various logs captured on your machine. The events from Windows Services (and other applications running on your PC) are filed under Windows Logs > Application. Navigate to that section to load the events in the center of the window, with the entire list in the top and details of the highlighted event underneath:


Event Viewer - Application Log

Messages from your windows service will have the display name of the service in the Source column.

Important Components of an Event

The Event Viewer shows over 10 pieces of information associated with each event, including:

  • Level – How important is this event?

    Each event is classified into one of three categories:

    Information: An informative yet unimportant event. You will probably see a lot of these, and they can be safely ignored unless you are digging into a specific issue from an application or service.

    Warning: A moderately important event. These don’t necessarily signify a failure, and your software will probably limp along, but they should be reviewed regularly to see if anything mentioned can be resolved.

    Error: Indicates a critical problem or failure that may deserve your immediate attention!

  • Date and Time – When did this event occur?

  • Source – Which application reported this event?

    As mentioned before, an event written by a Windows Service will contain the service’s display name as the Source.

  • Description – Which happened?

    The full description shown prominently in the lower pane will (hopefully) provide the relevant details of the event.

For example, this information event is from the Interactive Services detection service (“UI0Detect”) reporting that Notepad is showing itself in Session 0:


Interactive Services Detection Service Event

Viewing Events about Windows Services

While the Application log keeps track of events from a running service, the Windows Logs > System area records when services are started, stopped, crash or fail to start. Look for events with the Source set to Service Control Manager (SCM). For example, here is the SCM telling us that the Windows Print Spooler service has crashed:


Event Viewer System Event

Viewing Events from AlwaysUp and Service Protector

Both AlwaysUp and Service Protector write messages to the Application section of the event logs (Windows Logs > Application).

For AlwaysUp, events from your application named “My Application” will be logged with Source set to My Application (managed by AlwaysUpService). The Event Log Messages Page lists and explains the events reported.

For Service Protector, events related to your service named “MyService” will have a Source of ServiceProtector: MyService.

And for both applications, events related to the starting and stopping of the underlying services themselves appear in the Windows Logs > System section. Look there if you have a problem with AlwaysUp itself failing to start at boot.

Posted in Windows Services | Tagged , , , | Leave a comment

The Top 5 Reasons to Run Your Application as a Windows Service with AlwaysUp

  1. You need to start your application at boot, even if no one logs on

    Windows Service starts after a reboot A regular application will only run after a user has logged in and started it. Not so for Windows Services, which are automatically started by the operating system whenever the computer reboots and run happily without anyone having to do anything. Services are the true set-it-and-forget-it approach.


  2. Your application must be available 24/7

    Windows Services run 24/7
    The automatic, extensible failure protection system built into AlwaysUp will help to minimize the downtime for your legacy application – even if it is buggy, leaks memory or stops working for no good reason!


  3. You don’t have the time, resources or access to the source code to re-write the application as a Windows Service

  4. No coding required The boss needs your software to be a windows service to win the next contract, but your development team is swamped and no one wants to mess around with the code anyway. Use AlwaysUp to “wrap” your application to operate as a windows service so you can satisfy the client and keep your boss happy, all in a day’s work.


  5. You are managing an unreliable application that keeps crashing

    Survive crashes with AlwaysUp
    Support calls for buggy applications have ruined too many evenings and nights! AlwaysUp automatically restarts unstable applications whenever they stop for any reason, so enjoy an uninterrupted dinner with your family for a change!


  6. You prefer to run your program in the background, away from inexperienced users

    Run in the background to avoid user errors
    Mission-critical applications visible on the desktop run the risk of being accidentally shutdown by a user or closed when he logs off. However, a windows service runs on a “hidden” desktop where it is well insulated from those using the computer.


Posted in AlwaysUp | Tagged , | Leave a comment

Introducing the AlwaysUp Troubleshooter: Helping you configure your application as a Windows Service


AlwaysUp Troubleshooter

We are happy to announce the availability of the AlwaysUp Troubleshooter – our online, step-by-step guide to help you identify and resolve the most common problems encountered when configuring your application as a windows service.

The troubleshooter is very easy to use and is packed with illustrative screenshots and helpful tips to quickly guide you to a successful outcome. However, if your issue is complex and demands more than can be achieved in that format, the interview ends with a summary of what has been learned and a contact form that makes it easy to engage our support team for additional help.

So if you are having difficulty setting up your application, script or batch file as a windows service with AlwaysUp, click here to start troubleshooting now!.

Posted in AlwaysUp | Tagged , , | Leave a comment

Tips for Running AutoIt in the Isolated Session 0


The isolated Session 0 desktop

Starting with Windows Vista in 2007 and continuing with every subsequent release, Microsoft has banned users from logging in to the first session created as Windows boots. This “Session 0 Isolation” has been accompanied by a steady erosion of the interactive capabilities of Session 0, rendering the Session 0 desktop virtually unrecognizable in the post-XP world. The prevailing wisdom in Redmond: Why support a proper working desktop in Session 0 when no one in their right mind is expected to use it?


The isolated Session 0 desktop

Unfortunately those of us working with interactive applications and Windows Services in Session 0 don’t have the luxury of ignoring GUI-related issues. And users of the excellent AutoIt automation toolkit have to make special accommodations when creating scripts to click buttons and fill in forms in Session 0. Here is what we have learned while troubleshooting AutoIt with our customers:

  1. WinActivate, WinWaitActive and WinActive Often Fail

    Essential AutoIt functions like WinActivate, WinWaitActive and WinActive rely on the operating system to track the active window. Unfortunately it seems that the active window is not tracked in Session 0 unless a user is actively viewing the desktop! Therefore a script that takes some action only if a window has been activated may never do its work. In this sample code, WinActivate will always return 0 when run in an unattended Session 0 and the button will never be clicked:

    ; Activate  the window and click the button.
    if (WinActivate($windowName)) Then
    	; Click the button on the window.
    	ControlClick($windowName, $buttonName, "")
    EndIf
    

    Our advice: Don’t depend on the Win* functions to find and activate a window. Simply operate on your window regardless of its active state. For example, restructure the code above to look like this:

    ; Try to activate  the window if possible. May fail in Session 0.
    WinActivate($windowName)
    ; Click the button on the window.
    ControlClick($windowName, $buttonName, "")
    
  2. The Mouse Functions (MouseMove, MouseClick, etc.) Don’t Work

    As with window activation, it seems that the mouse is not tracked when session 0 is unattended. Functions that move and manipulate the mouse can fail unexpectedly.

    Our advice: Don’t use the mouse functions in your scripts.

  3. AutoIt Scripts created with Au3Record Are Unreliable

    The Au3Record utility bundled with AutoIt will easily record a set of actions for later replay. It captures mouse movements, mouse clicks, key presses and more. However the script created makes heavy use of the problematic activation and mouse related functions cited above, thus rendering Au3Record scripts virtually useless in Session 0.

    Our advice: Don’t use scripts created by Au3Record in Session 0.

  4. You can Rely on ControlSend and ControlClick in Session 0

    Fortunately functions like ControlSend and ControlClick continue to work as expected in Session 0. Neither of them relies on the target window being active nor the mouse being in a specific position, so they sidestep trouble related to those areas on the isolated desktop.

Are you using AutoIt in the isolated Session 0? Have you run into other functionality that does not work as expected? Please let us know what you have found! Your feedback will be much appreciated.

Posted in Miscellaneous | Tagged , , , | Leave a comment

Using TASKLIST to check your Windows Services

If you are comfortable working with Windows Services from the command line, take a look at Microsoft’s TASKLIST utility. This often overlooked tool — available on all versions of Windows — can help you answer the following questions as you troubleshoot your Windows Services:

What is the PID Associated with a Running Service?

You can use the name of the service to look up the identifier of the process associated with it. For example, to find the PID of the Print Spooler service (named “Spooler”), use:

TASKLIST /SVC /FI "SERVICES eq Spooler"

Here is the result you can expect, with the PID listed in the central column:


TASKLIST - Find a Service's PID

What Windows Services are Being Hosted by a Specific Process?

If you are considering forcibly terminating a process, it may be wise to confirm that doing so will not unexpectedly kill related services! TASKLIST.EXE comes to the rescue by easily showing what services are running in a given process. For example, to see what services are behind the process with PID 1234, type:

TASKLIST /SVC /FI "PID eq 1234"

Here we can see that the svchost process with PID 1284 is managing five (!) core services:


TASKLIST - Find a PID's services

Note that TASKLIST can interrogate remote machines as well. Simply add the /S /U and /P flags to the command line to specify the system, user name and password respectively.

Enjoy!

Posted in Miscellaneous | Tagged | Leave a comment