Improve company productivity with a Business Account.Sign Up

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 2715
  • Last Modified:

ssis Send Mail Task

I have a package with 4 Execute sql tasks. I clicked eah one individually, then clicked event handlers and setup a Send Mail Task (for each one).using the OnError  event handler. To test it, I renamed one of the tables so it would get an error. It got the error, but did not send the email.    sendMail.docx
0
qbjgqbjg
Asked:
qbjgqbjg
  • 4
  • 4
  • 2
  • +1
1 Solution
 
qbjgqbjgConsultantAuthor Commented:
[Send Mail Task] Error: An error occurred with the following error message: "Failure sending mail.  System.Net.WebException: Unable to connect to the remote server  System.Net.Sockets.SocketException: No connection could be made because the target machine actively refused it 10.100.2.12:25".

This is the error.
0
 
Reza RadConsultant, TrainerCommented:
the error is in SEND MAIL TASK not execute sql task.
I think ssis can not connect to smtp connection. could you re-check it ?
0
 
qbjgqbjgConsultantAuthor Commented:
I am checking with the person in IT that manages the servers. He gave me the Smtp connection.
0
A proven path to a career in data science

At Springboard, we know how to get you a job in data science. With Springboard’s Data Science Career Track, you’ll master data science  with a curriculum built by industry experts. You’ll work on real projects, and get 1-on-1 mentorship from a data scientist.

 
Reza RadConsultant, TrainerCommented:
could you connect to smtp server with outlook ?
0
 
AmmarRCommented:
Dear qbjgqbjg:


the normal SSIS send mail task is useless, it doesnt allow you to specify the credintials of the sender and this way the user that is running the SSIS package should always has a valid email and authenticated and authorised to send, and when you are running the ssis package using a sql job, the agent has to be run by an authorised domain user.

so that is why you need to use a SSIS script task As mentioned by MohammedU and below is a simple code

    Public Sub Main()

        Using reader As New StreamReader(response.GetResponseStream())
            Dim myAddress = "emailaddress@yourdomain.com"

            Dim myEmail As New MailMessage(myAddress, myAddress)
            myEmail.Subject = "From SSIS using HTML"
            myEmail.IsBodyHtml = True   ' this value should be true
            myEmail.Body = reader.ReadToEnd()

            Dim smtp As New SmtpClient("smtp.yoursmtp.com", port) ' you need to mention the smtp port
            smtp.Credentials = New NetworkCredential(myAddress, "yourpassword")
            smtp.EnableSsl = True
            smtp.Send(myEmail)
        End Using

        Dts.TaskResult = ScriptResults.Success
    End Sub


check the following article for more details

http://www.mssqltips.com/tip.asp?tip=1753
0
 
Reza RadConsultant, TrainerCommented:
@AmmarR:
Send Mail Task is not useless,
you can set sender configuration there
also you can set To or CC or BCC in configuration there.
but this does not means that this is static configuration.
you can simply use expression and there are ToLine, CCLine , BCCLine properties there which allows you to send mail to any address dynamically.

Am I understand your post correctly? If you mean something else explain it more.

0
 
qbjgqbjgConsultantAuthor Commented:
I have never used VB at all. I still am waiting for our server guy to get back to me. I think the problem is with the authentication. We use Windows authenication on a lot of things but there is a firewall that may be affecting it. I might have to learn enough VB to use the script.
0
 
novaspoonmanCommented:
See if your mail admin will allow relaying from that server without SMTP authentication, if you want to avoid code. It's not that most secure solution, but it is an alternative.
0
 
Reza RadConsultant, TrainerCommented:
you can simply check the connection with outlook,
try to connect to server with outlook and send a dummy mail with credential provided
0
 
AmmarRCommented:
sorry @reza_rad: and guys, i didnt mean to say its useless in that sense, i meant its very limited and doenst give you all the necessary options to setup email client.

by the way qbjgqbjg:, if you SQL Server Integration Services is running under a valid domain account, which has access to send email, then you can simply run the send email task without all these configurations and problems.

check image below, see my account here is running under Network system, yours should be under a valid domain account

 
sql-server-ssis.jpg
0
 
qbjgqbjgConsultantAuthor Commented:
Thanks for all of the suggestions.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Build your data science skills into a career

Are you ready to take your data science career to the next step, or break into data science? With Springboard’s Data Science Career Track, you’ll master data science topics, have personalized career guidance, weekly calls with a data science expert, and a job guarantee.

  • 4
  • 4
  • 2
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now