Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    What is the biggest attack in GBPS you stopped

    Scheduled Pinned Locked Moved General pfSense Questions
    737 Posts 33 Posters 816.9k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • S Offline
      Supermule Banned
      last edited by

      Same install but now a port forward to port 80.

      As soon as 1 cpu (nr.4) hots 100%, I get packetloss and GW goes offline.

      There is NOTHING different done except a port forward. (HTTP). Total load is actually LOWER than with all ports blocked.

      traffic.PNG
      traffic.PNG_thumb
      vmware.PNG
      vmware.PNG_thumb
      lan2wan.PNG
      lan2wan.PNG_thumb

      1 Reply Last reply Reply Quote 0
      • S Offline
        Supermule Banned
        last edited by

        CONCLUSION:

        As soon as you have a working port forward (NOT DISABLED) to a server behind and pfSense needs to route it, youre dead.

        Even at limited SYN Proxy state enabled and only 3mbit traffic passing through and states never reaches above 10%. Disabling every service on the firewall and still dead.

        If you dont have a portforward, then its fine but that misses the main reason for having this setup….. IMHO.

        Its definately FreeBSD/PF related and I dont believe its in the ESF code unless they alter the Packet Filter code.

        I would be glad if anyone would run a base OpenBSD/FreeBSD with PF enabled as a frontend so we can continue testing.

        1 Reply Last reply Reply Quote 0
        • F Offline
          firewalluser
          last edited by

          @Supermule, tell me, is the script posted in this thread the one causing the problem you see?

          If so, does it also cause the problem you describe here? https://forum.pfsense.org/index.php?topic=87571.msg492268#msg492268

          It seems like we are going around in circles at this stage this is why I ask.

          Its also like CMB says here https://forum.pfsense.org/index.php?topic=87571.msg493401#msg493401
          "DDoS is hell on stateful firewalls is the basic summary of this thread. It's not specific to anything in any particular firewall."

          The very nature of any stateful firewall will cause an increase in resource use like you are seeing.

          With this is mind, what can you do to limit your exposure [edit] of to [/edit] the weakness of a stateful firewall?

          Lots of suggestions here
          http://www.cisco.com/web/about/security/intelligence/guide_ddos_defense.html

          Some users who might be hosting a website that is providing services/products only to punters in their own country, can limit access to the ip addresses to those assigned. If its something being offered further afield like to a continent, then rinse and repeat the above but with all the continents ip address blocks.

          If its something flogged globally, then consider a website sat behind the TLD specific to that country, ie if in the UK then a website assigned to a .co.uk could help, but then you'd need something to redirect the originating ip address to the correct country domain. This approach can lesson but not eradicate 100% a DDOS attack of sorts.

          Perhaps having something that temporarily disables the port forward in realtime when the CPU activity reaches a threshold might be a way around the problem to avoid taking out the firewall if the other tuning options like increasing the default states et al doesnt work.

          Either way, theres lots of ways to skin the cat!

          Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

          Asch Conformity, mainly the blind leading the blind.

          1 Reply Last reply Reply Quote 0
          • S Offline
            Supermule Banned
            last edited by

            @firewalluser:

            @Supermule, tell me, is the script posted in this thread the one causing the problem you see?

            It can be altered to do so.

            If so, does it also cause the problem you describe here? https://forum.pfsense.org/index.php?topic=87571.msg492268#msg492268

            Yes. It takes more bandwith to do it. Limiting bandwith will make pfsense survive with no ports open.

            It seems like we are going around in circles at this stage this is why I ask.

            Its also like CMB says here https://forum.pfsense.org/index.php?topic=87571.msg493401#msg493401
            "DDoS is hell on stateful firewalls is the basic summary of this thread. It's not specific to anything in any particular firewall."

            The very nature of any stateful firewall will cause an increase in resource use like you are seeing.

            With this is mind, what can you do to limit your exposure [edit] of to [/edit] the weakness of a stateful firewall?

            This takes down a stateless setup as well with 15mbit of traffic. So its not related to the states.

            Some users who might be hosting a website that is providing services/products only to punters in their own country, can limit access to the ip addresses to those assigned. If its something being offered further afield like to a continent, then rinse and repeat the above but with all the continents ip address blocks.

            If its something flogged globally, then consider a website sat behind the TLD specific to that country, ie if in the UK then a website assigned to a .co.uk could help, but then you'd need something to redirect the originating ip address to the correct country domain. This approach can lesson but not eradicate 100% a DDOS attack of sorts.

            Perhaps having something that temporarily disables the port forward in realtime when the CPU activity reaches a threshold might be a way around the problem to avoid taking out the firewall if the other tuning options like increasing the default states et al doesnt work.

            It doesnt matter. The states itself is not the issue. Increase it and you wont hit the limit. As soon as you port forward, its dead. But then you cant host anything behind it.

            Either way, theres lots of ways to skin the cat!

            IMHO there is no cat to skin currently. As stated, if you port forward, youre dead.

            1 Reply Last reply Reply Quote 0
            • F Offline
              firewalluser
              last edited by

              @Supermule:

              It doesnt matter. The states itself is not the issue. Increase it and you wont hit the limit. As soon as you port forward, its dead. But then you cant host anything behind it.

              This behaviour which takes down stateless & stateful fw's is seen with that script posted in the msg link below?

              https://forum.pfsense.org/index.php?topic=91856.msg523649#msg523649

              Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

              Asch Conformity, mainly the blind leading the blind.

              1 Reply Last reply Reply Quote 0
              • S Offline
                Supermule Banned
                last edited by

                https://forum.pfsense.org/index.php?topic=91856.msg523921#msg523921

                1 Reply Last reply Reply Quote 0
                • H Offline
                  Harvy66
                  last edited by

                  @firewalluser:

                  @Supermule, tell me, is the script posted in this thread the one causing the problem you see?

                  If so, does it also cause the problem you describe here? https://forum.pfsense.org/index.php?topic=87571.msg492268#msg492268

                  It seems like we are going around in circles at this stage this is why I ask.

                  Its also like CMB says here https://forum.pfsense.org/index.php?topic=87571.msg493401#msg493401
                  "DDoS is hell on stateful firewalls is the basic summary of this thread. It's not specific to anything in any particular firewall."

                  The very nature of any stateful firewall will cause an increase in resource use like you are seeing.

                  With this is mind, what can you do to limit your exposure [edit] of to [/edit] the weakness of a stateful firewall?

                  Lots of suggestions here
                  http://www.cisco.com/web/about/security/intelligence/guide_ddos_defense.html

                  Some users who might be hosting a website that is providing services/products only to punters in their own country, can limit access to the ip addresses to those assigned. If its something being offered further afield like to a continent, then rinse and repeat the above but with all the continents ip address blocks.

                  If its something flogged globally, then consider a website sat behind the TLD specific to that country, ie if in the UK then a website assigned to a .co.uk could help, but then you'd need something to redirect the originating ip address to the correct country domain. This approach can lesson but not eradicate 100% a DDOS attack of sorts.

                  Perhaps having something that temporarily disables the port forward in realtime when the CPU activity reaches a threshold might be a way around the problem to avoid taking out the firewall if the other tuning options like increasing the default states et al doesnt work.

                  Either way, theres lots of ways to skin the cat!

                  DDOS attacks can't be stopped because it's trying to shove 100Gb/s down a 1Gb pipe. Lots of different IPs does not a DDOS make. 3Mb of traffic hitting a 10Gb firewall is not what anyone in their right mind would call a DDOS. If a firewall dies, it's because of a slow path that is definitely not O(1).

                  Packets hitting the firewall should trigger an O(1) to see if the state exists, if it does, pass, if it does not, go to next check
                  Packets not passed should trigger an O(n) to compare the new state against firewall rules. If good, add and pass, else block
                  These two I can't see being an issue without some absurdly crazy firewall rules.

                  NAT sits in there somewhere, not sure where, and possibly some other routing related stuff

                  Whatever is going on, if I take the 30Mb/s that I saw SuperMule take down my firewall with, and assume I only have one CPU, then it's taking over 100k clock cycles per packet. Since I have a quad core and all 4 cores were getting hosed, and the packets were actually quite large, it was more like 1mil clockcycles per packet. Since my system was not keeping up, that means it was worse than 1mil/packet.

                  I'm not sure what kind of slow path warrants 1mil cycles to decide what to do with a packet. 1mil cycles is a lot of work. You can encrypt 2.3mil bits with AES. Another way to put it. 1Gb/s over SMB was about 0.5% cpu on my old 2.67ghz cpu, which once translated down to 1mhz(1mil cycles per second), then into 1500 byte packets, is about 780 packets per second. In the time PFSense processes one of these packets, my Windows box could have transferred 780 packets via SMB.

                  The funny thing is it isn't the number of states. SuperMule did an attack that hit a forwarded port, which means the states were being created. It was up against the 4mil state limit, yes CPU was higher than normal, but the system was perfectly stable. A similar attack against blocked ports resulted in the same thing, everything was fine. PFSense does handle lots of blocked traffic just fine. Whatever is going on is triggering something other than just blocking traffic.

                  Lets make an analogy. If normal person stands on scale and it says they weigh 75 tons, you don't ask them to take off their shoes. That's about the same magnitude difference.

                  1 Reply Last reply Reply Quote 0
                  • H Offline
                    Harvy66
                    last edited by

                    I was just thinking, when my 4mil states are full up and the firewall is trying to expire states and whatever is done, scanning 4mil states could be a bit of work. I wonder how the attack would do if the state table was made to something small, like 10k states. Expiring states may require an O(n) scan when lots of states are made about the same time.

                    Another thought is I have "Firewall Adaptive Timeouts"(System->Advanced->Firewall/NAT) set to 4mil states, which means by the time my state table gets full, states are being expired instantly. If expiration causes a full scan of at least triggers often, then creating states quickly and just as quickly expiring them may be the cause. I don't know. Just a thought.

                    That could explain why it takes a few tens of seconds before I started to feel the hurt of the attack, the issue didn't full trigger until the state table got full.

                    edit: more thoughts

                    I wonder if I set the target expiration to 4mil, but set the max to something larger. I'm not sure what PFSense/FreeBSD has to do when the table gets full, it may trigger a bad code path. Maybe I should have the table set to something like 5mil max states, but leave the adaptive timeout to 4mil.

                    edit2:

                    If the issue is an issue involving states, a good test to make an extreme could be to try a few combinations. 1mil max states with a target of 10k, should never get much past 10k, but shouldn't hit the max state limit. 10k max with 10k target, 10k max with no adaptive, etc.

                    1 Reply Last reply Reply Quote 0
                    • F Offline
                      firewalluser
                      last edited by

                      @supermule So whats different with your setup then compared to what I have setup?

                      edit:
                      CPU Microcode perhaps? My VM is running on an AMD CPU which has some bugs affecting threading performance, all the others affected who have posted are running Intel CPU's iirc so maybe thats why I dont see the problem?

                      edit2: This might also be a factor especially considering the vmware point which I've had to tweak as its possible to get the time to drift on vm's.
                      http://en.wikipedia.org/wiki/HPET

                      Anyone know if HPET is built into the pfsense builds?
                      http://www.freebsd.org/cgi/man.cgi?query=hpet&apropos=0&sektion=0&manpath=FreeBSD+9-current&format=html

                      Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

                      Asch Conformity, mainly the blind leading the blind.

                      1 Reply Last reply Reply Quote 0
                      • F Offline
                        firewalluser
                        last edited by

                        @Harvy66:

                        I was just thinking, when my 4mil states are full up and the firewall is trying to expire states and whatever is done, scanning 4mil states could be a bit of work. I wonder how the attack would do if the state table was made to something small, like 10k states. Expiring states may require an O(n) scan when lots of states are made about the same time.

                        Another thought is I have "Firewall Adaptive Timeouts"(System->Advanced->Firewall/NAT) set to 4mil states, which means by the time my state table gets full, states are being expired instantly. If expiration causes a full scan of at least triggers often, then creating states quickly and just as quickly expiring them may be the cause. I don't know. Just a thought.

                        That could explain why it takes a few tens of seconds before I started to feel the hurt of the attack, the issue didn't full trigger until the state table got full.

                        edit: more thoughts

                        I wonder if I set the target expiration to 4mil, but set the max to something larger. I'm not sure what PFSense/FreeBSD has to do when the table gets full, it may trigger a bad code path. Maybe I should have the table set to something like 5mil max states, but leave the adaptive timeout to 4mil.

                        You get 1 packet come in which causes x-number-of-lines-of-code to run & some memory spaces to be filled up.

                        Consider the time it takes for 1 packet to be processed by the fw, then add the time for the state to expire and before long you could easily fill up the available/free ram and also swamp the cpu by getting it to run x-number-of-lines-of-code per incoming packet, by having some code assigned to 1 core dominating the CPU especially if some threaded code has a higher priority than other code.

                        What if you could throttle the packets coming in before the states were processed? Would that prevent the firewall from crashing/hanging?

                        Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

                        Asch Conformity, mainly the blind leading the blind.

                        1 Reply Last reply Reply Quote 0
                        • A Offline
                          almabes
                          last edited by

                          @firewalluser:

                          What if you could throttle the packets coming in before the states were processed? Would that prevent the firewall from crashing/hanging?

                          Isn't that the core idea of "a DDoS shouldn't be dealt with by the firewall, but upstream?"

                          1 Reply Last reply Reply Quote 0
                          • T Offline
                            tim.mcmanus
                            last edited by

                            @firewalluser:

                            @supermule So whats different with your setup then compared to what I have setup?

                            edit:
                            CPU Microcode perhaps? My VM is running on an AMD CPU which has some bugs affecting threading performance, all the others affected who have posted are running Intel CPU's iirc so maybe thats why I dont see the problem?

                            edit2: This might also be a factor especially considering the vmware point which I've had to tweak as its possible to get the time to drift on vm's.
                            http://en.wikipedia.org/wiki/HPET

                            Anyone know if HPET is built into the pfsense builds?
                            http://www.freebsd.org/cgi/man.cgi?query=hpet&apropos=0&sektion=0&manpath=FreeBSD+9-current&format=html

                            Just to note; I was running bare metal with the same predictable results, I posted my machine specs in this thread, but will append them to my signature.

                            jimp or cmb made a recommendation on this thread somewhere about tuning pfSense settings to better handle DDOS.

                            I know that with the default state limit of 394000, the UI and most every other service seems to lock up, but system utilization under top is minimal at best.  The screen shot I posed of the console shows the system utilization with a 394K state table.  Increasing the state table makes the box responsive, but the interface being attacked stops responding with 4Mbit of attack traffic.

                            1 Reply Last reply Reply Quote 0
                            • T Offline
                              tim.mcmanus
                              last edited by

                              I think I have an idea where the issue may be:  interrupts

                              This console screen shot is very telling:

                              The system start throttling interrupts, but the CPU utilization for interrupts is conspicuously a fixed 25.0%.  Either the code handling interrupts has come challenges or the system has throttled the CPU utilization for interrupts at 25%, and its hit that limit and cannot process any more.

                              Does anyone know if interrupt CPU limits are adjustable, and where can this be done?  According to the console shot, I have some additional headroom I could allocate to interrupts to see if that helps.

                              See this thread with a similar set of symptoms in 2011:  https://forum.pfsense.org/index.php?topic=38589.msg198765#msg198765

                              1 Reply Last reply Reply Quote 0
                              • F Offline
                                firewalluser
                                last edited by

                                @almabes:

                                @firewalluser:

                                What if you could throttle the packets coming in before the states were processed? Would that prevent the firewall from crashing/hanging?

                                Isn't that the core idea of "a DDoS shouldn't be dealt with by the firewall, but upstream?"

                                Yes & no.

                                We have our internet feeds, we know what speed and amount of data we can get from it, ie some of it might be fast fibre but with a 10GB data limit, so is it up to us to ensure the fw can handle the speed of the data arriving surely? It also depends on what services the network provider provides to us for the money we pay for that internet feed, although depending on what country you are in, then the spooks may also have a hand in what arrives at your fw as well.

                                Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

                                Asch Conformity, mainly the blind leading the blind.

                                1 Reply Last reply Reply Quote 0
                                • F Offline
                                  firewalluser
                                  last edited by

                                  http://en.wikipedia.org/wiki/Interrupt_storm

                                  "In operating systems, an interrupt storm is an event during which a processor receives an inordinate number of interrupts that consume the majority of the processor's time. Interrupt storms are typically caused by hardware devices that do not support interrupt rate limiting."

                                  It doesnt seem unlike what I described earlier https://forum.pfsense.org/index.php?topic=91856.msg523964#msg523964 especially when considering chips are just running code stored in the chip instead of on the hard drive, ie like a BIOS and some Intel NIC's which provide some network processing capabilties unlike say a USB nic running on a rpi.  ;)

                                  Might be able to gleam some info & solutions from these links.
                                  https://forums.freebsd.org/threads/tp-link-tl-wn781nd-version-2-works-with-10-1-but-with-one-caveat.49667/
                                  2014

                                  https://forums.freebsd.org/threads/interrupt-storm-detected-on-irq10.17192/
                                  2010

                                  http://lists.freebsd.org/pipermail/freebsd-questions/2011-August/232647.html
                                  "Interrupt storms (an olde but a goode)" Bit like Rootkits which alot of people forgot about.

                                  https://forums.freebsd.org/threads/intel-dq77kb-high-interrupt-rate-when-using-hdmi.39210/
                                  2013

                                  https://forums.freenas.org/index.php?threads/getting-lots-if-interrupt-storm-on-irq16.3425/
                                  2011

                                  http://freebsd.1045724.n5.nabble.com/how-to-fix-quot-interrupt-storm-quot-td3819772.html
                                  2009

                                  http://daemonforums.org/showthread.php?t=500
                                  2008

                                  Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

                                  Asch Conformity, mainly the blind leading the blind.

                                  1 Reply Last reply Reply Quote 0
                                  • F Offline
                                    firewalluser
                                    last edited by

                                    Whats on IRQ 267 out of interest?

                                    Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

                                    Asch Conformity, mainly the blind leading the blind.

                                    1 Reply Last reply Reply Quote 0
                                    • T Offline
                                      tim.mcmanus
                                      last edited by

                                      @firewalluser:

                                      Whats on IRQ 267 out of interest?

                                      irq267: em1:rx 0                3529974        22

                                      em1 is my WAN2 interface.

                                      Intel 82574L Gigabit Ethernet Controller.

                                      1 Reply Last reply Reply Quote 0
                                      • H Offline
                                        Harvy66
                                        last edited by

                                        Interrupts are almost entirely due to packets per second, it's how the hardware talks to the OS. Complete guess, but I would assume(assumptions can be dangerous) that interrupts would not be high because of anything the firewall is doing, only because of lots of packets.

                                        1 Reply Last reply Reply Quote 0
                                        • H Offline
                                          hda
                                          last edited by

                                          @Harvy66:

                                          …
                                          If the issue is an issue involving states, a good test to make an extreme could be to try a few combinations. 1mil max states with a target of 10k, should never get much past 10k, but shouldn't hit the max state limit.

                                          But if still the back-off rate is to low ?

                                          Something other to test flushing states when storm, ../ Firewall Adaptive Timeouts :
                                          Leave [adaptive.start] at the default (60%), but set [adaptive.end] to the value 101% of your maxstates (i.s.o. the default 120%)
                                          As can be calculated, then the ultimate 5% (>95% maxstates) adapts much stronger flushing than the default setting.

                                          Hypothesis: if adaptation stronger with limit -> 0, then pfSense hardly chokes. True || False. ?

                                          1 Reply Last reply Reply Quote 0
                                          • F Offline
                                            firewalluser
                                            last edited by

                                            @Harvy66:

                                            Interrupts are almost entirely due to packets per second, it's how the hardware talks to the OS. Complete guess, but I would assume(assumptions can be dangerous) that interrupts would not be high because of anything the firewall is doing, only because of lots of packets.

                                            https://www.freebsd.org/doc/en_US.ISO8859-1/books/arch-handbook/smp-design.html

                                            " FreeBSD deals with interrupt handlers by giving them their own thread context. Providing a context for interrupt handlers allows them to block on locks. To help avoid latency, however, interrupt threads run at real-time kernel priority. Thus, interrupt handlers should not execute for very long to avoid starving other kernel threads. In addition, since multiple handlers may share an interrupt thread, interrupt handlers should not sleep or use a sleepable lock to avoid starving another interrupt handler."

                                            HW Interrupts will be different to sw interrupts, in that hw interrupts will be treated as more important than most but not all sw interrupts.

                                            https://www.freebsd.org/cgi/man.cgi?query=swi&apropos=0&sektion=9
                                            "These functions are used to register and schedule software interrupt handlers.  Software interrupt handlers are attached to a software interrupt thread, just as hardware interrupt handlers are attached to a hardware interrupt thread. Multiple handlers can be attached to the same thread. Software interrupt handlers can be used to queue up less critical processing inside of hardware interrupt handlers so that the work can be done at a later time.  Software interrupt threads are different from other kernel threads in that they are treated as an interrupt thread. This means that time spent executing these threads is counted as interrupt time, and that they can be run via a lightweight context switch."

                                            Windows is not immune to them either, its all in the drivers to a certain extent. https://msdn.microsoft.com/en-us/library/windows/hardware/ff540586%28v=vs.85%29.aspx

                                            So in some respects any basic nic with little or no processing capabilities will rely more on the OS to do the packet processing and because computers are just glorified clockwork turk machines, so the OS is less likely to get out of shape with a basic nic as everything will just run like clockwork ignoring those electrons at the socket the OS is physically incapable of processing due to being tied up elsewhere, unlike with a smart nic which has various builtin processing capabilities which whilst making the packet processing quicker then causes a flood upstream in the OS itself. Its like CPU caches (L1,L2 & L3) can be a boon or a hindrance in certain circumstances as well.

                                            With that in mind, some basic cheap nics ie realtek might actually be less hassle compared to say an intel nic when solving this sort of problem and will explain why some expensive hw in amateur hands can cause some embarrassment with customers advised to go with the latest and greatest. As the trend is generally for greater more sophisticated hack attempts so this sort of thing will only become more common and with the trend to employ younger talent straight out of uni, so the experience is lost and the cycles repeat considering the timescales of things like syn floods (1990's), rootkits (1990's) and interrupt storms (1990's) all of which were seen in the dos days before life became hidden behind gui's.

                                            Capitalism, currently The World's best Entertainment Control System and YOU cant buy it! But you can buy this, or some of this or some of these

                                            Asch Conformity, mainly the blind leading the blind.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.