From Fedora Project Wiki

Revision as of 21:17, 9 November 2008 by Herlo (talk | contribs) (added logs from the class)

Fedora Classroom - Firewall Basics - Kevin Fenzi - Sunday, November 9, 2008

IRC Log of the Class

 20:00 -!- nirik changed the topic of #fedora-classroom to: Fedora Classroom -
 Introduction - See https://fedoraproject.org/wiki/Communicate/IRC/Classroom
 for more info
 20:00 <@nirik> Welcome everyone to the Fedora classroom.
 20:00 <@nirik> Just a few opening comments before we start...
 20:01 <@nirik> If you have questions about fedora topics not related to a
 currently running class, #fedora is open for them...
 20:01 <@nirik> if you would like some social chatting with other fedora
 users, #fedora-social is available for that.
 20:02 <@nirik> that said, lets go ahead and dive into the first class for
 today.
 20:02 -!- nirik changed the topic of #fedora-classroom to: Fedora Classroom -
 Firewall Basics with your teacher nirik - See
 https://fedoraproject.org/wiki/Communicate/IRC/Classroom for more info
 20:02 <@nirik> First, a bit of history:
 20:03 <@nirik> The Linux kernel has had a number of firewall
 systems... ipfwadm,
 ipchains and now currently something called netfilter
 20:04 <@nirik> Netfilter has improved on the past implementations quite
 a lot and
 is very flexable.
 20:04 <@nirik> So, lets back up a step and ask: What is a firewall?
 20:04 <@nirik> Basically it's a system to allow you to manage your machines
 interaction with the network
 20:05 < neverho0d> the wall from bricks or concrete to prevent fire to
 spread ;)
 20:05 <@nirik> neverho0d: yes, or the metal in a car to prevent the
 engine from
 leaking anything like a fire into the passenger part of a car.
 20:06 < neverho0d> :)
 20:06 <@nirik> Netfilter is able to do filtering, inspecting, translating,
 modifying, tracking, limiting and logging (and possibly things I am
 forgetting)
 to network packets that hit your machine.
 20:06 <@nirik> Lets go over some concepts before we look at some rules
 20:07 <@nirik> "chains" are sets of rules that are examined in order.
 20:07 <@nirik> You can define your own, or just use some standard ones that
 netfilter provides you.
 20:07 <@nirik> The standard set is: PREROUTING, INPUT, FORWARD, OUTPUT,
 POSTROUTING
 20:08 <@nirik> "tables" are sets of chains. The standard ones are:
 filter, nat, mangle
 20:09 <@nirik> filter is the set that most people use and know. nat is for
 Network Address Translation. mangle is to modify packets.
 20:09 <@nirik> "targets" are used in rules. This tells netfilter what to
 do if
 a packet matches that rule.
 20:09 <@nirik> example targets are: ACCEPT, DROP, QUEUE, RETURN, LOG,
 many others.
 20:10 <@nirik> Here's a simple diagram of how the packets flow:
 20:10 <@nirik>
 http://www.netfilter.org/documentation/HOWTO//packet-filtering-HOWTO-6.html
 20:10 <@nirik> and a more complex one:
 20:10 <@nirik> http://www.aptalaska.net/~jclive/IPTablesFlowChart.pdf
 20:11 <@nirik> basically packets arrive, get tested for the prerouting
 rules, a
 decision is made if they are going to be routed somewhere else or handled
 locally.
 20:11 <@nirik> then if local, they pass thru input and back out output
 and postrouting.
 20:11 <@nirik> if non local, they pass thru forwarding.
 20:12 <@nirik> So, all thats pretty complicated sounding, but it's not so
 bad for most cases.
 20:12 <@nirik> Fedora by default stores your firewall ruleset in
 /etc/sysconfig/iptables.
 20:13 <@nirik> depending on if you customized it on install or not, it
 likely looks like:
 http://fpaste.org/paste/8806
 20:13 <@nirik> any questions so far? Or shall I go over the simple default
 set there?
 20:14 < erinlea80> the rules read from the bottom up?
 20:14 <@nirik> erinlea80: good question. In that file you will note that they
 use '-A' that tells the iptables command to "append" the rule to the chain.
 20:15 <@nirik> so, it will add each rule to the end...
 20:15 < zcat> When/Why was the old RH-something chain removed?
 20:15 <@nirik> chains are evaluated from top to bottom.
 20:15 <@nirik> zcat: in f9 I think. or possibly f8.
 20:16 <@nirik> so, to this example, you can see "*filter" says this is in
 the filter table.
 20:16 <@nirik> then it lists the INPUT/FORWARD/OUTPUT chains and what
 rules they contain.
 20:16 <@nirik> INPUT and FORWARD have no rules.
 20:16 < nuonguy> this is all at the IP level, right?  Doesn't matter
 whether the app uses TCP or UDP, right?
 20:17 < domg472_> what iptables command can i use to not append, because
 if i append it will be below the reject line and be rejected?
 20:17 <@nirik> nuonguy: good question. Yes, this is at the IP
 level. netfilter can filter on any protocol.... tcp/udp/icmp/gre/etc/
 20:17 <@nirik> domg472_: you can use -I to insert or -R to replace a
 existing rule. see 'man iptables' for more info.
 20:17 < domg472_> thanks
 20:18 < domg472_> why cant it manage raw ?
 20:18 <@nirik> Also, the iptables service has a 'save' target. So you can
 use the command line to setup your rules, and then 'service iptables save'
 will save it to /etc/sysconfig/iptables
 20:18 < nuonguy> and the syntax you're discussing today covers only
 netfilter, right?
 20:19 <@nirik> nuonguy: correct. All the older versions are no longer
 in use...
 20:19 < nuonguy> ic, thanks
 20:19 <@nirik> domg472_: raw in what context? there is a 'raw' table.
 20:19 < domg472_> like dhcp broadcasts?
 20:20 <@nirik> yes, you can match on broadcasts just fine. ;)
 20:20 < jds2001> that's just udp to a broadcast address.
 20:20 < domg472_> ok thanks
 20:20 <@nirik> ok, I'd like to mention some administration tools available,
 and then perhaps go on to some examples of a few things...
 20:21 <@nirik> first of all there is 'system-config-firewall'. Those of
 you on fedora machines right now, might want to pull it up and look at it.
 20:21 <@nirik> it's gotten a lot more flexable that it used to be, and
 can setup many of the common things people want to do with their firewalls.
 20:23 <@nirik> I don't have any screenshots handy, but I will say to try
 it out if you get the chance.
 20:23 <@nirik> Fedora also includes a number of other firewall configurator
 programs: firestarted, fwbuilder, and shorewall to name a few.
 20:24 <@nirik> ok, shall we move on to a few examples?
 20:24 < GnuBoi> are these all gui for netfilter
 20:24 < jds2001> screenshot at http://jstanley.fedorapeople.org/firewall.png
 for those not on fedora boxen.
 20:25 <@nirik> GnuBoi: I think some of them can do command
 line. system-config-firewall has a console mode, but it's not as powerfull.
 20:25 <@nirik> jds2001: thanks.
 20:25 < domg472_> arent they all interfaces to netfilter?
 20:25 <@nirik> domg472_: correct.
 20:26 <@nirik> they are all frontends that try and help you make iptables
 rules.
 20:26 <@nirik> you can of course just bypass them all and make your own,
 but the frontends make it easier since you don't need to remember syntax
 or figure out how to do some things.
 20:27 <@nirik> for at least system-config-firewall it will continue to write
 to /etc/sysconfig/iptables, so you can always look at what rules it's adding.
 20:28 < domg472_> is system-config-firewall still very activly maintained?
 20:28 < domg472_> can i expect improvements?
 20:28 <@nirik> yes. It's improved a lot in recent releases... but of course
 more is always good.
 20:28 < domg472_> thanks
 20:29 <@nirik> lets talk a bit about NAT.
 20:30 <@nirik> NAT is Network Address Translation. It's the ability for
 your machine with the netfilter firewall to re-write packets to allow for
 machines using it as a gateway.
 20:30 <@nirik> netfilter has SNAT and DNAT. Source NAT and Destination NAT.
 20:31 <@nirik> SNAT is used to re-write outgoing packets to appear to come
 from the firewall machine and then re-write the responses so the reply
 goes back to the machine that sent it.
 20:31 <@nirik> A subset of that is what many people know as Masquerade.
 20:32 <@nirik> a SNAT rule might look like: "iptables -t nat -A POSTROUTING
 -s 10.1.1.8 -o dsl -j SNAT --to-source xxx.xxx.xxx.xxx'
 20:33 <@nirik> that says use the nat table, Append a rule to the POSTROUTING
 chain, match anything with a source of 10.1.1.8 (an internal machine)
 thats going out (-o) the dsl interface and make it use xxx.xxx.xxx.xx
 external address.
 20:33 < domg472_> are theres rules for when to use -o or -d, or -i or -s
 or can you jut use them mixed?
 20:33 <@nirik> so, the 10.1.1.8 machine could go out to the internet, the
 firewall would re-write those packets to appear to come from xxx.xxx.xxx.xxx
 and then take replies and send them back to 10.1.1.8
 20:34 <@nirik> domg472_: yes, there are rules. It depends on what table
 and such... iptables will give you an error if you use one that doesn't
 make sense in that context.
 20:34 < domg472_> thanks
 20:35 <@nirik> another type of NAT is DNAT... this is forwarding something
 in from the outside net to an internal machine and back out.
 20:35 <@nirik> so for example you wish to forward ssh on the firewall to
 an internal machine:
 20:35 <@nirik> iptables -t nat -A PREROUTING -d 192.168.1.100 -p tcp -m
 tcp --dport 22 -j DNAT --to-destination 10.1.1.104
 20:36 < SSlater> So source and destination are relative to the local
 machine(s)?
 20:36 <@nirik> if a ssh port tcp packet comes in for 192.168.1.100 (an
 external ip) send it to 10.1.1.104 and handle the translation.
 20:36 <@nirik> SSlater: yes.
 20:36 <@nirik> SSlater: the machine with the firewall on it.
 20:36 < SSlater> thx
 20:36 < domg472_> so basicly DNAT is the nat tables input and SNAT is the
 nat tables output?
 20:37 <@nirik> domg472_: yes, note that one is used in POSTROUTING and
 the other in PREROUTING.
 20:37 < domg472_> DNAT is postrouting?
 20:38 <@nirik> domg472_: other way. DNAT is PRE and SNAT is POST
 20:38 < domg472_> thanks
 20:39 <@nirik> ok, I'd like to touch a bit on connection tracking.
 20:39 < AndyCap> MASQUERADE may be better than SNAT for people with
 dynamic ipaddresses,
 20:39 <@nirik> One nice thing that netfilter has is a connection tracking
 setup. Some products call this "statefull packet inspection".
 20:40 <@nirik> AndyCap: oh, quite right. MASQUERADE is a subset of SNAT,
 where you don't need to give it the source ip you want to nat, it figures
 it out based on the interface IP address.
 20:40 < domg472_> thats the only difference?
 20:40 <@nirik> an example of that might be "iptables -t nat -A POSTROUTING
 -o cable -j MASQUERADE" ie, anything out the cable interface masquerade.
 20:41 <@nirik> the downside for MASQ is that if your interface goes down
 it forgets all connections over it.
 20:41 <@nirik> so, if you get the same IP it's better to use SNAT, or your
 connections will get dropped.
 20:41 <@nirik> when you get a new lease for example.
 20:42 <@nirik> so, back to connections. There are a number of connection
 tracking modules, the default is a general purpose one called "ip_conntrack".
 20:43 <@nirik> Basically this allows the firewall to know when packets
 are related to an existing connection.
 20:43 <@nirik> back in that simple default firewall we saw:
 20:43 <@nirik> -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
 20:44 <@nirik> that says to accept anything that is part of an already
 established or related connection.
 20:44 <@nirik> so, for example if you ssh into that machine, the inital
 ssh is allowed via:
 20:44 <@nirik> -A INPUT -m state --state NEW -m tcp -p tcp --dport 22
 -j ACCEPT
 20:44 <@nirik> and after that any packets that are related to that connection
 are allowed via the ESTABLISHED,RELATED rule.
 20:45 <@nirik> if you would like to look at your connections, you can take
 a look at /proc/net/nf_conntrack.
 20:46 <@nirik> There is also a package called conntrack-tools in Fedora
 that will let you list, examine, or manipulate the connection tracking rules.
 20:47 <@nirik> and you can match on all kinds of state in the connection
 tracking info.
 20:47 <@nirik> any questions on connection tracking?
 20:47 < domg472_> is the [ASSURED] related to conntrack?
 20:47 < nuonguy> yes, what do you mean by 'related'?
 20:48 < erinlea80> related as in passive ftp transfers with high num. random
 port assignments?
 20:48 < domg472_> why do i see if only in my tcp connection and not a
 udp connection?
 20:48 < domg472_> it*
 20:48 < domg472_> i have an irc connection that is assured nd a ntp connect
 that doesnt have the assured tag
 20:48 <@nirik> nuonguy: related means it's a new connection, but it's
 related to an existing one. Ftp transfers, icmp traffic, etc.
 20:49 <@nirik> domg472_: it means it shouldn't be expired... it's still
 active.
 20:49 < domg472_> thanks
 20:49 <@nirik> the ntp is probibly a request thats finished and waiting
 to be expired from tracking.
 20:50 <@nirik> ftp is a weird protocol. It has it's own connection tracking
 module... ip_conntrack_ftp (and another one for nat: ip_nat_ftp)
 20:50 < domg472_> i never got that to work
 20:50 < domg472_> with pasv
 20:50 < zcat> nirik, will you touch on logging/troubleshooting, since it
 doesn't log by default
 20:50 <@nirik> zcat: yeah, was on the list, but I see we are running low
 on time. :)
 20:51 <@nirik> To help in troubleshooting there is a LOG target.
 20:51 <@nirik> LOG is a non terminating rule. This means it matches,
 runs and then goes on to the next rule like nothing happened.
 20:52 <@nirik> So, you can add LOG rules in to see where things are and
 what the packets look like.
 20:52 < domg472_> if you append a log like it will log rejected packets?
 20:52 <@nirik> Heres an example line from a LOG match:
 20:52 <@nirik> DROPPING packet: IN=test OUT= MAC= SRC=172.17.17.254
 DST=172.17.17.255 LEN=188 TOS=0x00 PREC=0x00 TTL=64 ID=0 DF PROTO=UDP
 SPT=631 DPT=631 LEN=168
 20:53 <@nirik> domg472_: only if it's right before the reject rule. The
 reject rule will match and stop processing the chain at that point...
 20:53 <@nirik> so you need to add LOG before any rule you want to see
 20:53 < domg472_> oh beforeso you cannot append
 20:53 < domg472_> thanks
 20:54 <@nirik> so, you might want a LOG and a REJECT at the end of each
 chain. That will tell you if it got to there.
 20:54 <@nirik> also, it's often a good idea to have an explicit DROP or
 REJECT at the end for that reason.
 20:55 < zcat> domg472_, yeah, being able to insert at an offset from the
 last rule would be handy
 20:55 <@nirik> and as with many things it's good to have a 'if it's not
 explicitly allowed, reject it'
 20:55 < SSlater> like a default DROP policy?
 20:55 <@nirik> you can add a index to -I, but then you need to know how
 many rules you have -1 to insert it in the right place.
 20:55 <@nirik> SSlater: yes.
 20:56 <@nirik> Note that each of the standard chains have a default policy
 you can set. This is what happens if NOTHING in that chain matches.
 20:56 < domg472_> why does the default configuration allow by default on
 less rejected instead of deny by default unleass allowed?
 20:56 <@nirik> you can however not log those actions.
 20:57 <@nirik> domg472_: it shouldn't. You mean the example I posted?
 20:57 < domg472_> yes
 20:57 < domg472_> it accepts by default
 20:58 < kanarip> domg472_, the default has a policy of ACCEPT, but explicitly
 REJECTs in the last rule of the RH-INPUT-Firewall chain because REJECT is
 an invalid policy target
 20:58 < domg472_> why not deny by default
 20:58 < erinlea80> as the default, non-matching rule, is DROP or REJECT
 the pref. method? Is it best to simply not send a response?
 20:58 <@nirik> domg472_: because then you cannot log that it dropped. In
 that case there is no LOG, but you would have to change it more to add one.
 20:58 < domg472_> thanks
 20:58 <@nirik> erinlea80: there are different schools of thought on that.
 20:58 <@nirik> it depends on what your needs are.
 20:59 < kanarip> erinlea80, if you REJECT you're still giving some form
 of information, some people do not want that and choose DROP
 20:59 <@nirik> if you REJECT someone knows the machine is up and there. DROP
 doesn't tell them that. DROP means they hit a timeout, which might be
 anoying.
 20:59 < SSlater> There was abig debate on Fedora -list about that.
 20:59  * nirik sees we are out of time. Happy to answer more questions in
 #fedora or the like...
 20:59 < domg472_> reject returns a nice informative message right?
 21:00 <@nirik> domg472_: it does.
 21:00 < zcat> DROP'ing, or "stealth", causes annoying timeouts. REJECT'ing
 is immediate, but gives you away, if that matters.
 21:00 < erinlea80> it resets the connection?
 21:00 < kanarip> when you're ready nirik ;-)
 21:00 < erinlea80> :)
 21:00 < kanarip> it's 21:00 UTC
 21:00 < erinlea80> Thanks nirik!
 21:00 < domg472_> thanks nirik
 21:00 < zcat> kudos
 21:00 < SSlater> Thanks nirik!
 21:00 < Bugz_> Thanks nirik
 21:00 < thomasj> awesome, thanks nirik
 21:00 < erinlea80> :)
 21:00 < kanarip> so all of you are going to hang around for the Creating
 a Fedora Remix session? ;-)
 21:00 < N3LRX> Good job nirik
 21:01 < neverho0d> thank you nirik!
 21:01 < erinlea80> Woohoo remix!
 21:01 < GnuBoi> now fedora remix