Community Pick: Many members of our community have endorsed this article.
Editor's Choice: This article has been selected by our editors as an exceptional contribution.

Allow relaying on Exchange 2007 & Exchange 2010 in 4 easy steps

AkhaterSolutions Architect
I have this application/website that needs to send emails, I have it configured to use our exchange server as SMTP. It can send emails to internal users without any problem however external ones are failing with a " 550 5.7.1 Unable to relay" error

I have been answering this question, under different forms, so often on Experts Exchange lately that I have it copied on a notepad and end up by pasting it again every now and then, so let's see how to fix it.

First of all you should know that a mail server should be configure to unconditionally (not talking about spam/viruses here) accept emails sent to users in the SMTP domains it is serving. However, to avoid spamming others and being blacklisted, it should be very careful about who gets to send emails to other SMTP domains using its services, and that's what is called relaying.

This should explain why, in the above scenario, emails sent to internal users are received but not to external one, that is because Exchange is refusing to relay. To solve your problem and enable your application/web server to be able to send external emails, you should allow it (or its IP address) to relay emails through your Exchange server and here is how to do it in Microsoft Exchange 2007 and Microsoft Exchange 2010.

   1. Add another internal IP to your exchange server, say
   2. Create a new receive connector, configure it to listen only to the newly added IP address & accept SMTP connections only to the application\web server IP address. This can be done by GUI using Exchange Management Console or through Exchange Management Shell by running

      New-ReceiveConnector -Name AllowRelay -usage Custom -Bindings '' -fqdn -RemoteIPRanges WebServerIpAddress -server MYEXCHANGESERVER -permissiongroups AnonymousUsers

   3. Now that the connector is created, you should allow relaying on that connector, this can only by achieved using Management Shell as shown below.

      Get-ReceiveConnector AllowRelay | Add-ADPermission -User "NT AUTHORITY\ANONYMOUS LOGON" -ExtendedRights "ms-Exch-SMTP-Accept-Any-R ecipient"

   4. Finally configure your web server or Application to use the Exchange server's newly assigned IP as SMTP server.

N.B.:Make sure to change the by the additional IP you added to your Exchange server, WebServerIpAddress with the IP of your Webserver/application, MYEXCHANGESERVER by the name of your exchange 2007/2010 and by the FQDN of your exchange server.

Hope this clears out things a little bit

AkhaterSolutions Architect

Comments (10)

This appears to be a common problem. I spent about 8 hours hunting for solutions on the web. This is the only one that worked!

A lot of people mentioned that you should set up a new receive connector, but you are the only one that mentioned the need to bind it to a new ip address.

well done

do i need to bind to a new ip?  I only have one card in the server.  I just tried this and it works find to insternal address but not outside addresses
AkhaterSolutions Architect


you can have 2 IPs on the same NIC, there is no need for another NIC

if it works to install addresses doesn't that mean it is fine, just something else needs to be setup to send it out of the network?
UPDATE - You dont have to use another IP address.  Just create the connector and run the Power Shell command to enable Relay Access.

The key is the powershell command for some reason.  I didnt have to do this with copiers, but with Symantec Backup Exec you seem to have to use the powershell command to get it to work.

View More

Have a question about something in this article? You can receive help directly from the article author. Sign up for a free trial to get started.