Troubleshoot

Logging

MailScheduler keeps track of errors in log files. These log files can be viewed in the application and are also visible in the file storage on the machine.

  • In the frontend, Click on About in the menu and click the pink System logs button. At the left there is a list of log files. The left part of the page shows the lines in the log files. Clicking on a line will open the details of the log item. There is also a download logs button that will compress all log files into a zip file for easy sending.

  • On the filesystem in the directory where MailScheduler.exe is located, there is a directory .app-runtime/storage/logs which contains all log files.

When you encounter an error in the application, it is always helpful to send the logs with the support ticket so we can directly start investigating.

Application startup

When the application does not start, the cause can probably be found in the log files. they are located in <installation_path>/.app-runtime/storage/logs/*.log. When opening a support ticket, please provide these files.

chevron-right Could not startup server, Contact Apps For Tableau support when the problem persistshashtag

The app server is unable to start. This can have multiple causes like:

  • Application is configured as administrator but is currently not running with administrator privileges.

  • Check if there is no other MailScheduler process running in the background. Open Task manager and select the Details tab. You should have only one process called MailScheduler.

  • Check if there is no other process running on the port that is configured in MailScheduler. You can do that with this command in cmd:

netstat -aon
  • Open power shell and navigate to the directory where MailScheduler.exe is located. run this command to manually trigger the application server:

./MailScheduler.exe serve

This command might give more details about what went wrong.

chevron-rightlisten tcp :443: bind: Only one usage of each socket address (protocol/network address/port) is hormally permittedhashtag

When this error appears in your go-application.log it is not able to spin the server because the port you have configured is already in use by another program.

chevron-rightMailScheduler is slow or unresponsivehashtag

A typical reason of a slow experience is the connection to tableau. MailScheduler uses the REST API to fetch the visuals from Tableau. Each unique combination of filters will cause an extra request to tableau for fetching this information. On large mailing lists this can cause delay.

When the frontend for example is slow you can take a look at the application performance. Open Powershell and navigate to the directory where MailScheduler.exe is located. Run this command to see the statistics of the internal workers:

./MailScheduler.exe workers --interactive

This will generate an interactive statistics table like so:

chevron-rightAllowed memory size of xxx bytes exhausted hashtag

Big tasks can involve large amounts of memory. This error indicates that MailScheduler is trying to use more memory than the memory limit is allowing. To resolve this issue, increase the memory limit by altering the app.config.yaml file by adding the memory limit, and setting it to a higher value, like so:

A generally 'safe' memory limit is 1G, or 1 Gigabyte. Note that the indentation in app.config.yaml matters! Always use two spaces.

After setting the new limit, make sure you restart MailScheduler to apply it.

SMTP / Mail Server (TLS & Encryption Issues)

Use this section if you encounter SMTP connection errors such as TLS version mismatch, “wrong version number”, or failures when sending emails from MailScheduler.

chevron-rightCheck if SMTP ports are reachable (Windows / PowerShell)hashtag

Run the following commands from the machine where MailScheduler is installed:

If the connection fails, the port may be blocked by a firewall or network rule.

Determine How Port 465 Is Configured (Linux / macOS / WSL)

Port 465 can be configured in two different ways depending on the mail server. Use the commands below to determine which one applies.

SMTPS (Implicit TLS)

Use this if the server expects SSL/TLS immediately on connection:

SMTP + STARTTLS on Port 465

Use this if the server starts in plain text and upgrades to TLS:

If one command succeeds and the other fails, configure the mail server settings accordingly.

Inspect the Raw SMTP Response (Advanced – PowerShell)

If neither OpenSSL command succeeds, you can inspect the server’s raw response before the connection is dropped using PowerShell:

This can help identify whether the server is responding with SMTP, SMTPS, or an unexpected protocol.

Summary

If you encounter TLS or SSL errors:

  1. Verify the port and encryption combination

  2. Confirm the port is reachable from the application server

  3. Test whether the server expects implicit TLS or STARTTLS

  4. Adjust the configuration accordingly

Most “TLS version mismatch” errors are resolved by correcting the port + encryption settings.

Single Sign-On

Common error messages:

chevron-rightA valid SubjectConfirmation was not found on this Responsehashtag

This could indicate there is a mismatch between the Recipient and Destination URLs. Check in the SAML response XML if Recipient and Destination URL's match. When it does not match it should be configured in your SAML provider.

chevron-rightUnknown AssertionConsumerServiceURLhashtag

The URL in the configuration file is probaby incorrect. Check your app.config.yaml file and look at the app.url variable. That should match the domain that is used to access MailScheduler

chevron-rightAuthentication method by which the user authenticated with the service doesn't match requested authentication methodhashtag

This problem occures/happends, because of the way how the session authentication method (SAML AuthnRequest) is configured on the other SSO app. MailScheduler by defaults use “Password, ProtectedTransport” as request authentication method.

Solution

We have added a configuration variable to allow all options, but allow any cross request authentication method. Within the config.yaml file set the following variable to not strictly check on the cross request authentication method:

Last updated

Was this helpful?