Blurring the Line: Performance and Security
Blurring the Line: Performance and Security
Learn about distributed denial of service attacks, complete with graphs and traceroutes, and read a helpful updated diagram of the author's performance iceberg.
Join the DZone community and get the full member experience.Join For Free
Maintain Application Performance with real-time monitoring and instrumentation for any application. Learn More!
Many factors can impact the user experience of a website or mobile app including bad code, bad architecture, infrastructure, external factors such as fiber cut, government interference (invisible hand), and CDN and DNS providers issues.
Unfortunately, we now have to add another reason: Security.
Per Google: A Distributed Denial of Service (DDoS) attack is an attempt to make an online service unavailable by overwhelming it with traffic from multiple sources. They target a wide variety of important resources, from banks to news websites, and present a major challenge to making sure people can publish and access important information.
We hear about massive DDoS attacks that are impacting brands, taking down critical services and infrastructure on what seems like a daily basis.
If your business relies on your website or app, it’s important to have a strong understanding of this very real security threat. There are two kinds of DDOS attacks:
External and Malicious
Recently, one of the properties we monitor suffered from one of these attacks. As is the case in many of these attacks, the pattern of the attack was very interesting: Two small incidents occurred to probe before the big one that eventually took the site down for eight hours.
There are many ways of protecting yourself from a DDoS, but it really boils down to having enough capacity to handle the load and ensure that the real users can still access your services. This is why many CDN players have launched web application firewall (WAF) at the edge while protecting the origin.
Other methods include deploying solutions like Prolexic, a leader in this space now acquired by Akamai, which basically routes traffic to their data centers and applies scrubbing science to stop the bad guys.
The challenge with this is making sure that valid traffic is not scrubbed. This also happened this past week with one of our customers; some of our IPs were either whitelisted or blacklisted at different time which seems a bit odd (as shown below).
Traceroute after being blacklisted:
1 12 ms 5 ms 11 ms 18.104.22.168
2 <1 ms <1 ms <1 ms 22.214.171.124
3 <1 ms <1 ms <1 ms 126.96.36.199
4 <1 ms <1 ms 4 ms ae24-166.lon11.ip4.gtt.net[188.8.131.52]
5 1 ms 2 ms 1 ms ae-9.r00.londen10.uk.bb.gin.ntt.net[184.108.40.206]
6 2 ms 2 ms 5 ms ae-15.r02.londen03.uk.bb.gin.ntt.net[220.127.116.11]
7 10 ms 2 ms 2 ms ae-2.r02.londen01.uk.bb.gin.ntt.net[18.104.22.168]
8 2 ms 2 ms 2 ms ae-1.r03.londen01.uk.bb.gin.ntt.net[22.214.171.124]
9 2 ms 2 ms 2 ms 126.96.36.199
10 2 ms 2 ms 2 ms unknown.prolexic.com[188.8.131.52]
11 7 ms 2 ms 2 ms unknown.prolexic.com[184.108.40.206]
12 2 ms 8 ms 13 ms 220.127.116.11
13 * * * Timed Out
14 * * * Timed Out
15 * * * Timed Out
16 * * * Timed Out
It’s extremely important to make sure you deploy solutions to ensure that your DDoS protection systems are not causing reachability problems for real users, since my IP address in our UK office went to the cyber dump at the same time:
1 192.168.64.1 (192.168.64.1) 1.001 ms 4.125 ms 0.836 ms
2 10.43.10.1 (10.43.10.1) 1.245 ms 1.369 ms 2.440 ms
3 18.104.22.168 (22.214.171.124) 1.477 ms 2.005 ms 3.264 ms
4 126.96.36.199 (188.8.131.52) 2.450 ms 3.104 ms 2.575 ms
5 xe0-0-0-pr2.lon.router.colt.net (184.108.40.206) 2.956 ms 4.010 ms 4.095 ms
6 220.127.116.11 (18.104.22.168) 6.260 ms 5.151 ms 4.639 ms
7 unknown.prolexic.com (22.214.171.124) 3.594 ms 3.757 ms
unknown.prolexic.com (126.96.36.199) 3.666 ms
8 unknown.prolexic.com (188.8.131.52) 9.877 ms
unknown.prolexic.com (184.108.40.206) 8.500 ms 16.638 ms
9 unknown.prolexic.com (220.127.116.11) 25.894 ms
18.104.22.168 (22.214.171.124) 20.651 ms 23.919 ms
Internal and Self-Inflicted via Trusted Party
With all of the third parties that a site must deploy these days, another DDoS vector is internal. A trusted third party has a bug and does an auto-refresh or auto-reload and creates an infinite loop, thus a self-inflicted DDoS.
This is what happened to a few big sites last summer during Velocity 2015 (bad timing) where a third-party tag was setting a reload to the entire page and causing a loop. The incident lasted about four hours.
We all know that the customer experience defines the product. I have often said that the new marketing mix includes a fifth ‘P,’ for Performance.
The events of last week reminded me that security attacks and the counter measures deployed can also have a huge impact to this customer experience and I will be updating my infamous performance iceberg I have been using since the late ’90s.
Some Closing Thoughts
Back at Doubleclick in 2002, after hiring one of our best CSOs Dr Rey Leclerc, discussions started around performance, monitoring, and security and where they really fit in an organization. Many organizations lack a single group in charge of performance monitoring at the macro level. We were the few in 1999 to establish a group dedicated to quality of experience; but in 2016, we still have not clearly defined a function that owns performance both horizontally (IT working with marketing, for example) and vertically ( integrating performance with agile dev teams).
If performance is going to be this critical to a company where it defines its brand, its revenue success, and product adoption, is it not time to elevate this function the same way we have CSO, Red Team and Blue Team, and have individuals and teams whose sole mission is to monitor, baseline, benchmark report, and enforce performance policies while reporting to a C-level?
Performance is a journey not a destination; it’s never done the same way as Security!
Published at DZone with permission of Mehdi Daoudi , DZone MVB. See the original article here.
Opinions expressed by DZone contributors are their own.