Why can't I email myself at: MyEmail@74.125.235.55?

120

21

I opened cmd and typed ping gmail.com. It shows me:

C:\Windows\system32>ping gmail.com

Pinging gmail.com [74.125.235.55] with 32 bytes of data:
Reply from 74.125.235.55: bytes=32 time=6ms TTL=56
Reply from 74.125.235.55: bytes=32 time=6ms TTL=56
Reply from 74.125.235.55: bytes=32 time=6ms TTL=56
Reply from 74.125.235.55: bytes=32 time=215ms TTL=56

Ping statistics for 74.125.235.55:
    Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
    Minimum = 6ms, Maximum = 215ms, Average = 58ms

C:\Windows\system32>

I have a Gmail account, so I emailed myself but instead of email@gmail.com I used email@74.125.235.55.

Response:

This is an automatically generated Delivery Status Notification

THIS IS A WARNING MESSAGE ONLY.

YOU DO NOT NEED TO RESEND YOUR MESSAGE.

Delivery to the following recipient has been delayed:

xxxxxx@74.125.235.54

Message will be retried for 2 more day(s)

Technical details of temporary failure: The recipient server did not accept our requests to connect. Learn more at http://mail.google.com/support/bin/answer.py?answer=7720 [74.125.235.54 (1): Connection refused]

----- Original message -----

MIME-Version: 1.0 Received: by 10.223.93.196 with SMTP id w4mr3261626fam.44.1309944998035; Wed, 06 Jul 2011 02:36:38 -0700 (PDT) Received: by 10.223.104.194 with HTTP; Wed, 6 Jul 2011 02:36:37 -0700 (PDT) Date: Wed, 6 Jul 2011 17:36:37 +0800 Message-ID: Subject: test From: Joseph To: xxxxxx@74.125.235.54 Content-Type: multipart/alternative; boundary=20cf3054a49348815504a763560c

testtest

I did not receive the email. Why?

Why can't I just substitute the gmail.com part with 74.125.235.55?

Pacerier

Posted 2011-07-06T11:01:41.270

Reputation: 22 232

Answers

152

Because 74.125.235.55 isn't the MX (mail exchange) for gmail.com.

If you ping gmail.com, ping uses the A record to perform its task, but sending emails (often) incorporates other servers.

You can use the tool dig (on Windows: nslookup -q=mx gmail.com as grawity mentioned in the comments) to see those DNS records:

Probe:~ trurl$ dig -t ANY gmail.com

; <<>> DiG 9.6.0-APPLE-P2 <<>> -t ANY gmail.com
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 65087
;; flags: qr rd ra; QUERY: 1, ANSWER: 13, AUTHORITY: 0, ADDITIONAL: 9

;; QUESTION SECTION:
;gmail.com.         IN  ANY

;; ANSWER SECTION:
gmail.com.      3519    IN  MX  30 alt3.gmail-smtp-in.l.google.com.
gmail.com.      3519    IN  MX  5 gmail-smtp-in.l.google.com.
gmail.com.      74086   IN  NS  ns4.google.com.
gmail.com.      3519    IN  MX  10 alt1.gmail-smtp-in.l.google.com.
gmail.com.      74086   IN  NS  ns3.google.com.
gmail.com.      3   IN  A   209.85.148.18
gmail.com.      3519    IN  MX  40 alt4.gmail-smtp-in.l.google.com.
gmail.com.      3   IN  A   209.85.148.83
gmail.com.      3   IN  A   209.85.148.17
gmail.com.      74086   IN  NS  ns1.google.com.
gmail.com.      3   IN  A   209.85.148.19
gmail.com.      3519    IN  MX  20 alt2.gmail-smtp-in.l.google.com.
gmail.com.      74086   IN  NS  ns2.google.com.

As you can see, there are even multiple servers handling email for gmail.com and each of those have different priorities (the number in the last column).

And if you proceed further, you'll see that gmail-smtp-in.l.google.com (the first mx in the list above) points to a different IP address:

;; QUESTION SECTION:
;gmail-smtp-in.l.google.com.    IN  ANY

;; ANSWER SECTION:
gmail-smtp-in.l.google.com. 42  IN  A   74.125.39.27

So you'd have to use recipient@[74.125.39.27] (this is the right syntax as JdeBP mentioned in the comments).


BUT Google won't accept these mails:

Jul  6 13:25:15 lofi postfix/smtp[31213]: C6FXXXXXXX: to=<REMOVED@[74.125.39.27]>,
relay=74.125.39.27[74.125.39.27]:25, delay=3.4, delays=0.16/0.01/0.15/3.1, dsn=5.1.1,
status=bounced(host 74.125.39.27[74.125.39.27] said:
550-5.1.1 The email account that you tried to reach does not exist. Please try
550-5.1.1 double-checking the recipient's email address for typos or
550-5.1.1 unnecessary spaces. Learn more at
550 5.1.1 http://mail.google.com/support/bin/answer.py?answer=6596 REMOVEDg.99
(in reply to RCPT TO command))

Thinking further about this: Google won't or can't accept these mails because they don't know to whom you like to send it. The server behind 74.125.39.27 could handle emails for gmail.com, google.com, picasa.com (etc., etc...), so there's no way to distinguish the user.

trurl

Posted 2011-07-06T11:01:41.270

Reputation: 2 102

49You forgot to mention that email@74.125.39.27 would be the wrong syntax anyway, per RFC 5322 § 3.4.1. – JdeBP – 2011-07-06T12:40:23.933

13Relevant RFC section. – Humphrey Bogart – 2011-07-06T13:51:13.250

9nslookup will give similar information on Windows machines. – MikeJ-UK – 2011-07-06T14:16:10.590

12nslookup -q=mx gmail.com to be precise. – user1686 – 2011-07-06T21:42:22.940

25

When you send email to user@domain.com, the outgoing mail server uses the DNS MX record of the destination domain to determine which IP address is responsible for handling mail at that domain. This may not be the same IP address returned during a normal ping.

Using the 'dig' tool on Linux I can determine that the MX record for gmail.com resolves to the following set of servers:

gmail-smtp-in.l.google.com.
alt1.gmail-smtp-in.l.google.com.
alt2.gmail-smtp-in.l.google.com.
alt3.gmail-smtp-in.l.google.com.
alt4.gmail-smtp-in.l.google.com.

which produce completely different ping results:

$ ping gmail-smtp-in.l.google.com.
PING gmail-smtp-in.l.google.com (209.85.227.27) 56(84) bytes of data.
64 bytes from wy-in-f27.1e100.net (209.85.227.27): icmp_req=1 ttl=50 time=12.8 ms

Whether you can actually send email directly to that IP address likely depends on your email client and mail server, and you may need to put the address in square brackets as per slotishtype's answer.

user89061

Posted 2011-07-06T11:01:41.270

Reputation:

11

Try to use:

email@[74.125.235.55]

slotishtype

Posted 2011-07-06T11:01:41.270

Reputation: 2 875

This might not work, as the guys analysis illustrates but maybe worth a try. – slotishtype – 2011-07-06T11:22:00.413

1The address "xxxxx@[74.125.235.55]" in the "To" field was not recognized. Please make sure that all addresses are properly formed. – Pacerier – 2011-07-06T11:38:43.190

I know, that is a gmail specific setting. You can send it from a different mail client but it may not send. – slotishtype – 2011-07-06T11:39:47.543

btw i'm curious what's the reason that made you think that that would work? – Pacerier – 2011-07-06T11:43:03.047

16@[ip] is a special syntax in the RFC that is defined as bypassing MX lookup. – Random832 – 2011-07-06T13:15:40.270

7

74.125.235.55 is not a Gmail gateway. If you go direct yourself to the IP address in your browser it won't go to the Gmail website; it'll go to Google, so that could be one point.

Sandeep Bansal

Posted 2011-07-06T11:01:41.270

Reputation: 6 168

1so what's the gmail gateway? to rephrase, what numbers must i type in the browser to get the page that i usually see at gmail.com ? – Pacerier – 2011-07-06T11:41:17.057

2@Pacerier, web servers will display different pages depending on which domain name you use to access them. For instance, I administer iconsf.org and iconsfinc.com. They're on the same server at the same IP address, but what web page you see depends on which name you type. If you just use the IP address you will always see iconsf.org. – CarlF – 2011-07-06T12:24:43.243

6

First, that IP address itself is not going to be listed as a DNS MX record (even if you used the mail server's correct IP address), as the others said, so it is not going to find the server in the first place (it is also not going to route based on that IP address as the @thedomain is just used for lookups). Even if you used telnet to connect to the server directly (this is how experts test email directly), it would still fail for the following reason:

Whenever I configure a mail system, and I do a lot of them, with Microsoft Exchange or others, you always have to tell it what are the domains it will accept. I always enter @thedomain.com, which means it will only accept emails for that domain. Since @74.125.235.55 is not a domain, and certainly not in the accepted domains list, even if you were directly connected to the mail server, it will still reject it.

KCotreau

Posted 2011-07-06T11:01:41.270

Reputation: 24 985

2

Actually, 74.125.235.55 is a domain (per RFC 5322 § 3.4.1 it's not the syntax of an IP address in an addr-spec). It's a nonexistent domain, but it is a domain, much to the annoyance of several content DNS server operators. Note also that several MTSes will automatically accept mail addressed to their SMTP Relay servers' IP addresses (in the syntactically correct manner). Older versions of exim did this. So does qmail.

– JdeBP – 2011-07-06T13:10:52.610

@JdeBP I am not an expert on that RFC, and when I looked at it, by head wanted to explode, but shouldn't it have a .com or .net to actually be a domain? In any case, for all practical purposes, it is not a domain, and certainly is not in the given question. – KCotreau – 2011-07-06T13:17:40.283

1

That's part of the problem: It is a domain in the question, especially for practical purposes. It's just that the questioner is like you, and doesn't realize that. In an addr-spec the sequence of characters 74.125.235.55 is a domain, with the labels 55, 235, 125, and 74 in descending order from the root. In 2008, Duane Wessels et al. put such nonexistent domain names as causing some 3.8% of the queries at ICANN's "K" root content DNS server. It's now time for you to read RFC 4697 § 2.9. ☺

– JdeBP – 2011-07-06T13:38:55.067

I should have said "resolvable" domain in my first comment. Yes, it is trying to be resolved, but without the .com, etc. it will always fail. – KCotreau – 2011-07-06T13:50:58.193

3

The issue is what an email address actually is.

In many protocols schemes, the address syntax xxx@example.com means just "connect to Internet host example.com and specify (for the relevant protocol) user xxx". SSH, FTP, SCP and other follow this pattern: example.com is just a fancy name for an IP address (which is resolved the same as when doing a ping). For emails, it's different. The full string xxx@example.com is here an email address, the domain is part of the address, is not just the server to which a connect to send it; this server is called the "relay", and it is obtained, from that host part, by a special DNS request (MX records) as explained in other answers, but, bear in mind:

  1. it might coincide or not with the "normal" IP address for example.com (A record). frequently they are different.

  2. once the client discover the relay and connects to it, it still must tell the full mail address "I want to send a mail to xxx@example.com" (the same relay can process mails for different domains).

BTW, the second point (but not the first) also applies to HTTP, since 1.1: the domain is used to resolve the host IP address, but it's also used for specifying the resource.

leonbloy

Posted 2011-07-06T11:01:41.270

Reputation: 603

2

Remember that destination mail servers look at the whole address, including the name that follows the @ sign. The Gmail mail servers will only route messages that end in @gmail.com, discarding or rejecting all other addresses[1].

Gmail's mail server IP address is 74.125.45.27. But the address tyler@gmail.com is not the same thing as tyler@74.125.45.27. Gmail would say "I know who tyler@gmail.com is, but I've never heard of the name tyler@74.125.45.27", and decide that it couldn't deliver to the second address.


[1] Yes, I know that's not exactly true, and yes, I know about Google Apps.

tylerl

Posted 2011-07-06T11:01:41.270

Reputation: 2 064