Skip to content
https://googleblog.com

Infrastructure

· 9 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.
SCORE
77
GRADE
C
FIX
2
REVIEW
3
PASS
4
INFO
0
Probed from Santa Clara, United States
302 Found
Checks
9
4 PASS 3 REVIEW 2 FIX
F
IPv6 Readiness
Action
IPv6 records exist but unreachable
FIX
IPv6 records exist but unreachable
Warning::
IPv6 DNS records exist but server is not reachable
Having AAAA records but an unreachable server is worse than no AAAA — clients may experience delays before falling back to IPv4.
Got: 2607:f8b0:4007:813::2001
Info::
IPv6 connection error
Got: dial tcp6 [2607:f8b0:4007:813::2001]:443: connect: network is unreachable
IPv6 Misconfigured
AAAA Records 2607:f8b0:4007:813::2001 Connection UNREACHABLE

Having AAAA records but an unreachable server is worse than no AAAA — clients may experience delays before falling back to IPv4.

Why this matters

Advertising IPv6 (AAAA records) without a reachable server means IPv6-preferring clients silently fail every connection.

Learn more

Modern browsers prefer IPv6 if AAAA exists (Happy Eyeballs algorithm). If the IPv6 server isn't reachable, browsers fall back to IPv4 — but with seconds of added latency per request. Either fix IPv6 reachability or remove the AAAA records.

Source: RFC 8305 (Happy Eyeballs)

D
CDN & Delivery
Action
No CDN detected
FIX
No CDN detected
Warning::
No CDN detected
A CDN can significantly improve load times for users around the world by caching content at edge nodes closer to them.
No CDN detected

Consider using a CDN to improve global delivery speed and reduce origin load.

B
Redirect Chain
2 redirect(s), 663 ms total
REVIEW
2 redirect(s), 663 ms total
Warning::
2 redirects before reaching final URL
Each redirect adds latency. Try to minimize the chain to 1 hop.
Info::
WWW normalization redirect
Info::
Uses 302 (temporary) redirect
If permanent, use 301 instead.
Got: https://googleblog.com
Info::
Redirect overhead: 663 ms total
Got: 663 ms
Info::
Cross-domain redirect detected

https://googleblog.com

288 ms · HTTP/1.1

302

https://www.blog.google

218 ms · HTTP/1.1

301

https://blog.google/

156 ms · HTTP/1.1 FINAL

#URLStatusTimeProtocolServer
1https://googleblog.com302288 msHTTP/1.1GSE
2https://www.blog.google301218 msHTTP/1.1Google Frontend
3https://blog.google/200156 msHTTP/1.1Google Frontend

See the visual redirect chain in the HTTP Probe tab →

Each redirect adds latency. Try to minimize the chain to 1 hop.

Why this matters

Redirect chain — each hop adds latency; combine into one redirect where possible.

Source: Google Search Central / web.dev

If permanent, use 301 instead.

Why this matters

302 (Found) is for genuinely temporary redirects — if this redirect is permanent, switch to 301 to preserve SEO equity.

Learn more

Search engines treat 302 as temporary, keeping the original URL indexed and not transferring full link equity to the destination. Use 301 (Moved Permanently) for permanent redirects (HTTP→HTTPS, www-vs-non-www, URL restructures).

Source: Google Search Central

B
Crawlability
robots.txt present, no sitemap
REVIEW
robots.txt present, no sitemap
Info::
robots.txt is present
Got: 10240 bytes
Info::
No sitemap.xml found
A sitemap helps search engines discover and index your pages more efficiently.
Info::
robots.txt does not reference a sitemap
Add a 'Sitemap:' directive to robots.txt so search engines can discover your sitemap.

A sitemap helps search engines discover and index your pages more efficiently.

Why this matters

No sitemap.xml — Google relies on crawl-graph discovery alone, slowing indexing of deep or fresh URLs.

Learn more

A sitemap accelerates Google's discovery of new and updated content. Most CMSes auto-generate one; static-site frameworks need a build-step plugin. Reference it from robots.txt and submit in Search Console to confirm Google can fetch it.

Source: sitemaps.org / Google Search Central

Add a 'Sitemap:' directive to robots.txt so search engines can discover your sitemap.

Why this matters

robots.txt omits Sitemap: directive — crawlers must fetch /sitemap.xml by convention; reliable but missing the explicit hint.

Source: sitemaps.org

robots.txt 200 OK
Size 10240 B Sitemaps referenced 0 User-agents Blocking No — crawling allowed






<!DOCTYPE html>
<html class="no-js glue-flexbox glue-app-ready keyword-blog" lang="en-us" data-locale="en-us" data-version="pr20260415-1638">
    <head>
        <meta charset="utf-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <title>The Keyword | Google Product and Technology News and Stories</title>
        <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=1.0, minimum-scale=1.0" />
        <meta name="optimize_experiments" content="[{&#x27;id&#x27;: &#x27;IungncqGT5aYjbKizZW9zw&#x27;, &#x27;signature&#x27;: &#x27;sha256-7597e7f2907d399dd1a119a2744cbaec6dfca99fe1367645bbbbe1aac9cad23f&#x27;}]">

        
  





<!--Article Specific Metadata-->
<meta name="description" content="Get the latest news and stories about Google products, technology and innovation on the Keyword, Google&#x27;s official blog."/>

<!--Open Graph Metadata-->
<meta property="og:type" content="website" />
<meta property="og:title" content="The Keyword"/>

<meta property="og:description" content="Get the latest news and stories about Google products, technology and innovation on the Keyword, Google&#x27;s official blog." />
<meta property="og:image" content="https://blog.google/static/blogv2/images/google-200x200.png?version=pr20260415-1638" />
<meta property="og:site_name" content="blog.google" />
<meta property="og:url" content="https://blog.google/" />

<!--Twitter Card Metadata-->
<meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:url" content="https://blog.google/" />
<meta name="twitter:title" content="The Keyword"/>
<meta name="twitter:description" content="Get the latest news and stories about Google products, technology and innovation on the Keyword, Google&#x27;s official blog." />
<meta name="twitter:image:src" content="https://blog.google/static/blogv2/images/google-200x200.png?version=pr20260415-1638" />
<meta name="twitter:site" content="@google" />

  






<script type="application/ld+json">
{
  "@context" : "https://schema.org",
  "@type" : "WebSite",
  "name" : "The Keyword",
  "description" : "Get the latest news and stories about Google products, technology and innovation on the Keyword, Google&#x27;s official blog.",
  "url" : "https://blog.google/"
}
</script>




        
  <meta name="page" content="2" />
  <meta name="locale" content="en-us" />
  <meta name="published_time" content="2018-05-16T16:32:53.401000+00:00" />
  <meta name="content_type" content="blogv2.homepage" />
  <meta name="tags" content="" />
  <meta name="authors" content="" />



        
        

        
        
  
  
  <style>@keyframes showAndTranslateLeft{0%{left:0;opacity:0}to{left:36px;opacity:1}}@keyframes showAndTranslateRight{0%{opacity:0;right:0}to{opacity:1;right:36px}}@keyframes dash{0%{stroke-dashoffset:187}50%{stroke-dashoffset:46.75;transform:rotate(135deg)}to{stroke-dashoffset:187;transform:rotate(450deg)}}@keyframes loader-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes checkmark{0%{height:0;opacity:0;width:0}40%{height:0;visibility:visible;width:10px}to{opacity:1}}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(2%)}to{opacity:1;transform:translateX(0)}}html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;--google-font-family:"Google Sans",roboto,arial,helvetica;--roboto-font-family:"Google Sans",roboto,arial,helvetica;--roboto-mono-font-family:"Roboto mono",monospace,arial,helvetica;--noto-color-emoji:"Noto Color Emoji",sans-serif;--uni-waze-boing-regular:"WazeBoingRegular";font-family:sans-serif;font-size:18px}body{word-wrap:break-word;background:#fff;color:#5f6368;cursor:auto;display:flex;flex-direction:column;font-family:Google Sans,roboto,arial,helvetica;font-family:var(--roboto-font-family);font-size:1em;font-style:normal;font-weight:300;line-height:1.444;margin:0;min-height:100vh;overflow-x:hidden;padding:0}article,figcaption,figure,footer,header,main,nav,section{display:block}audio,video{display:inline-block;vertical-align:initial}audio:not([controls]){display:none;height:0}[hidden]{display:none}a{background:0 0;color:#1a73e8;-webkit-text-decoration:none;text-decoration:none}a:hover,main{outline:0}a img,img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}button,input,select{color:inherit;font:inherit;margin:0}button{-webkit-appearance:button;cursor:pointer;overflow:visible}button,select{text-transform:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{-webkit-hyphens:none;hyphens:none;line-height:normal}input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;box-sizing:initial}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}*,:after,:before{box-sizing:border-box}div,form,h1,h3,li,p{margin:0;padding:0}h2,ul{padding:0}body:after{content:"x-small";display:none}@media(min-width:600px){body:after{content:"small"}}@media(min-width:1024px){body:after{content:"medium"}}@media(min-width:1440px){body:after{content:"large"}}.h-c-copy,.rich-text,li,p{font-size:14px;letter-spacing:.25px;line-height:1.7142857143}p+p{margin-top:12px}@media(min-width:600px){.h-c-copy,.rich-text,p{font-size:14px;letter-spacing:.25px;line-height:1.7142857143}}@media(min-width:1024px){.h-c-copy,.rich-text,p{font-size:16px;letter-spacing:0;line-height:1.625}p+p{margin-top:16px}}a:visited{color:#7b1fa2}a:focus,a:hover{-webkit-text-decoration:none;text-decoration:none}a:focus{background:#f1f3f4;outline:4px solid rgba(32,33,36,.06)}a:active{outline:2px auto Highlight;outline:5px auto -webkit-focus-ring-color}ul{list-style-position:outside;margin:0 0 20px 20px}ul.h-no-bullet{list-style:none;margin-left:0}ul li ul{margin-bottom:0;margin-left:20px}@media(min-width:600px){li{font-size:14px;letter-spacing:.25px;line-height:1.7142857143}}@media(min-width:1024px){li{font-size:16px;letter-spacing:0;line-height:1.625}}img{-ms-interpolation-mode:bicubic;display:inline-block;height:auto;max-width:100%;vertical-align:middle}select{width:100%}.glue-flexbox .h-c-grid{display:flex;flex-wrap:wrap;margin:0 -2.6515151515%}@media(min-width:600px){.glue-flexbox .h-c-grid{margin:0 -1.0379945163%}}.glue-flexbox .h-c-grid__col{flex:0 1 auto;margin:0 2.6515151515%;width:100%}@media(min-width:600px){.glue-flexbox .h-c-grid__col{margin:0 1.0379945163%}.glue-flexbox .h-c-grid__col--8{flex-basis:64.5906776342%;margin:0 1.0379945163%;width:64.5906776342%}.glue-flexbox .h-c-grid__col--12{flex-basis:97.9240109675%;margin:0 1.0379945163%;width:97.9240109675%}}@media(min-width:1024px){.glue-flexbox .h-c-grid__col-l--3{flex-basis:22.9240109675%;margin:0 1.0379945163%;width:22.9240109675%}.glue-flexbox .h-c-grid__col-l--9{flex-basis:72.9240109675%;margin:0 1.0379945163%;width:72.9240109675%}}.h-c-grid__col--align-middle{-ms-align-self:center;align-self:center}.h-c-eyebrow,h1,h2,h3{color:#202124;font-family:Google Sans,roboto,arial,helvetica;font-family:var(--google-font-family)}h1,h2,h3{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;word-wrap:normal;font-size:32px;font-weight:400;letter-spacing:0;line-height:1.25;text-rendering:optimizeLegibility}@media(min-width:600px){h1{font-size:38px;letter-spacing:0;line-height:1.1578947368}}@media(min-width:1024px){h1{font-size:56px;letter-spacing:-.5px;line-height:1.1785714286}}h2,h3{font-size:24px;line-height:1.3333333333}@media(min-width:600px){h2{font-size:32px;letter-spacing:0;line-height:1.25}}@media(min-width:1024px){h2{font-size:44px;letter-spacing:-.5px;line-height:1.1818181818}}h3{font-size:20px;line-height:1.4}@media(min-width:600px){h3{font-size:24px;letter-spacing:0;line-height:1.3333333333}}@media(min-width:1024px){h3{font-size:32px;letter-spacing:0;line-height:1.25}}.h-c-eyebrow{font-size:12px;font-weight:500;letter-spacing:1.25px;line-height:1.5;text-transform:uppercase}@media(min-width:1024px){.h-c-eyebrow{font-size:14px;letter-spacing:1.5px;line-height:1.5714285714}}.module:after{clear:both;content:"";display:block}.uni-navigation--desktop .uni-main-menu__submenu-item-see-all svg{fill:currentColor;margin-left:8px;width:9px}.uni-navigation--desktop .uni-main-menu__submenu-item-see-all:hover svg{fill:currentColor}.uni-header__hamburguer-button,.uni-newsletter-toast__cta--sub:focus{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.module{margin-bottom:50px!important}@media(min-width:1024px){.module{margin-bottom:60px!important}}.events-off{pointer-events:none}a:focus .focusable{outline:1px dotted #212121;outline:5px auto -webkit-focus-ring-color}.nowrap{white-space:nowrap}.no-border{border-width:0!important}.rich-text>p{font-size:inherit;line-height:inherit}.uni-progressive-image--blur{filter:blur(4px)}.uni-progressive-image--no-blur{filter:blur(0);transition:all .3s cubic-bezier(.6,-.28,.74,.05)!important}h2{margin:0 0 20px}@media(min-width:1024px){h2{margin-bottom:40px}}figcaption,h1,h2,h3{-webkit-hyphens:manual;hyphens:manual}.h-c-eyebrow{display:block}.uni-header .h-c-header__jump-to-content:focus{font-size:16px;font-style:normal;font-weight:500;line-height:24px}.uni-header .h-c-header__jump-to-content:focus,.uni-header__kebab-menu-item,.uni-navigation--desktop .uni-main-menu__submenu-item-label,.uni-navigation--desktop .uni-main-menu__submenu-item-see-all[title^="See all"],.uni-navigation--desktop .uni-main-menu__submenu-link>a{font-family:Google Sans,roboto,arial,helvetica;font-family:var(--google-font-family)}.uni-header__kebab-menu-item,.uni-navigation--desktop .uni-main-menu__submenu-item-see-all[title^="See all"],.uni-navigation--desktop .uni-main-menu__submenu-link>a{font-size:.7777777778rem;font-weight:400;letter-spacing:.0138888889rem}.uni-navigation--desktop .uni-main-menu__submenu-item-label{font-size:.6666666667rem;font-weight:500;letter-spacing:.0555555556rem}.audio-player__content p,.audio-player__content span,.uni-header__site-title>a>div{font-family:Google Sans,roboto,arial,helvetica;font-family:var(--google-font-family)}.uni-header__site-title>a>div{-webkit-font-smoothing:antialias
sitemap.xml No sitemap found

No sitemap found

Adding a sitemap helps search engines discover your pages.

B
TLS Certificate Expiry & Recommendations
59 days until leaf cert expires — 4 issues to address
REVIEW

Certificate validity

59
days left
0d 30d 60d 90d+

Recommended actions

  • Extend HSTS max-age to at least 31536000 (1 year) to meet the preload list criteria
  • Add the preload directive and submit to hstspreload.org once max-age + includeSubDomains are in place
  • Enable DNSSEC on your domain for DNS spoofing protection
  • Enable OCSP stapling on your TLS server to remove a CA roundtrip and protect user privacy
A+
DNS Records
1 A records, 28 ms lookup
PASS
1 A records, 28 ms lookup
Info::
Resolves to 1 IPv4 address(es)
Got: 142.251.215.193
Info::
Single A record — no DNS redundancy
Multiple A records provide failover if one server goes down.
Info::
Has 1 IPv6 (AAAA) record(s)
Got: 2607:f8b0:4007:813::2001
Info::
4 nameserver(s) configured
Got: ns1.google.com, ns4.google.com, ns2.google.com, ns3.google.com
Info::
No MX records — email not configured via DNS
Info::
CAA records not checked
CAA record lookup requires a specialized DNS resolver. This check will be available in a future update.
Info::
SPF record present in TXT
Info::
DNS resolution time: 28 ms
Got: 28 ms
A142.251.215.193
AAAA2607:f8b0:4007:813::2001
CNAME
NSns1.google.com, ns4.google.com, ns2.google.com, ns3.google.com
MX
TXT
google-site-verification=IVUYrVxALCZUyLrhzsxkEjfQ4IpgVIjoa7RVZIyZPyg
SPF v=spf1 -all
facebook-domain-verification=dg1z13tbsgv0yqp7ujy0ksi9mxyado
CAALookup not available with standard resolver
Resolved in 28 ms

Multiple A records provide failover if one server goes down.

Why this matters

Single A record means a single point of failure — if that IP goes down, your site is unreachable until DNS TTL expires.

Learn more

Add multiple A records for round-robin failover, or use a managed DNS provider with health-checked failover (Route 53, Cloudflare, NS1). Short TTL (60-300s) lets clients recover faster on outages.

Source: SRE practice / DNS architecture

CAA record lookup requires a specialized DNS resolver. This check will be available in a future update.

Why this matters

Informational: CAA (Certification Authority Authorization) records weren't checked in this scan.

A+
URL Variants
www/non-www, trailing slash, HTTP→HTTPS
PASS
www/non-www, trailing slash, HTTP→HTTPS
Info::
HTTP correctly 301-redirects to HTTPS

www / non-www

404https://www.googleblog.com/
200https://googleblog.com/

HTTP → HTTPS

301http://googleblog.com/ https://googleblog.com/

Consistent

A
Domain Intelligence
googleblog.com — via MarkMonitor Inc., 24 years, 1 months old, hosted on Google Cloud
PASS
googleblog.com — via MarkMonitor Inc., 24 years, 1 months old, hosted on Google Cloud
Warning::
Domain expires in 73 days
Consider enabling auto-renewal to prevent accidental expiration.
Got: Expires Jun 29, 2026
Info::
DNSSEC is not enabled
DNSSEC protects against DNS spoofing attacks. While not required, enabling DNSSEC adds an additional layer of security. Contact your DNS provider to enable it.
Info::
Registrar: MarkMonitor Inc.
Warning::
Registrar lock is NOT enabled
The domain can be transferred without an unlock step. Enable registrar lock (clientTransferProhibited) in your registrar's control panel to protect against unauthorized or accidental transfers.
Info::
Hosting: Google Cloud
Got: AS15169
Domain expiry

13 days

June 29, 2026

SSL certificate

59 days

Issued by Google Trust Services

Domain age

24 years, 1 months

Registered June 29, 2002

DNSSEC

Not enabled

Protects against DNS spoofing

Hosting

Google Cloud

ASN AS15169

142.251.218.161

Registrar

MarkMonitor Inc.

Unlocked 4 NS records
Expiry timeline
Today
+1 year
Domain expiry SSL expiry Danger zone (≤30 days)
Recommended actions
  • Renew the domain or enable auto-renewal to prevent accidental expiry
  • Enable DNSSEC to protect visitors from DNS spoofing
  • Enable registrar lock (clientTransferProhibited) to block unauthorized domain transfers
Registrar MarkMonitor Inc.
Created June 29, 2002 (24 years, 1 months ago)
Expires June 29, 2026 (2 months)
Last Updated May 28, 2025
Name Servers ns1.google.com, ns2.google.com, ns3.google.com, ns4.google.com
DNSSEC Not enabled
Hosting
IP Address 142.251.218.161
ASN AS15169 (GOOGLE - Google LLC, US)
Provider Google Cloud
Data source: rdap (0.2s)

Consider enabling auto-renewal to prevent accidental expiration.

Why this matters

Domain expiry approaching — renew immediately and ensure auto-renew + alerting are configured.

Source: ICANN renewal policy

DNSSEC protects against DNS spoofing attacks. While not required, enabling DNSSEC adds an additional layer of security. Contact your DNS provider to enable it.

Why this matters

Without DNSSEC, an attacker who can poison your DNS can hijack your domain — and SSL certs alone don't stop them.

Learn more

DNSSEC adds cryptographic signatures to DNS records, preventing forged responses from poisoning resolver caches. Without it, an attacker who controls the network path can redirect your domain to a malicious server before any HTTPS handshake happens. Most modern registrars (Cloudflare, Google Domains, Route 53) enable it with one toggle.

Source: ICANN / RFC 4033

The domain can be transferred without an unlock step. Enable registrar lock (clientTransferProhibited) in your registrar's control panel to protect against unauthorized or accidental transfers.

Why this matters

Without registrar lock, an attacker who phishes your registrar credentials can transfer the domain in minutes — total brand hijack.

Learn more

Registrar lock (clientTransferProhibited, clientUpdateProhibited, clientDeleteProhibited) requires extra verification before any transfer/update/delete. Every major registrar offers it free. Combined with 2FA on your registrar account, it's the strongest defense against domain hijacking.

Source: ICANN / domain-security best practice

A+
HTTP Probe Timing
Total 84 ms — DNS, TCP, TLS, TTFB, content transfer breakdown
PASS
DNS Lookup DNS Lookup — time to resolve the domain name to an IP address.
20 ms
TCP Connect TCP Connect — time to establish a TCP connection to the server.
2 ms
TLS Handshake TLS Handshake — time to complete the HTTPS encryption handshake.
19 ms
Time to First Byte Time to First Byte — how long the server takes to respond with the first byte of data.
84 ms
Total Time Total request time from DNS lookup through full response.
85 ms

Connection waterfall

DNS Lookup 20 ms TCP Connect 2 ms TLS Handshake 19 ms Server Processing 43 ms Content Transfer 0 ms
All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.

Send Feedback