Let's assume you have an Internet connection and you want to share it. There are two main ways to do that.
Internet pc1 1. ----> |router| ---> |switch| --->-< pc2 ..etc Internet 2. ------> |pc1 (router)| --> pc2..etc
I'll explain the second way (it is easier and requires one less machine).
- Install a second network card to the first PC.
- Connect the two PCs using an ethernet cable or a switch. If one of the two computers has a gigabit ethernet card, a regular ethernet cable should work. Otherwise, use crossover cable.
- Let's assume that the first card (with the Internet) is called internet0 and the other one (for the sharing) is called local0. (If those two keep switching at every boot read Udev#Mixed_Up_Devices.2C_Sound.2FNetwork_Cards_Changing_Order_Each_Boot this). The network interface of the client machine will be called local1. The interfaces local0 and local1 will have to be in the same network.
- Configure the second network card with:
- IP: 192.168.0.1
- Netmask: 255.255.255.0
ifconfig local0 192.168.0.1 netmask 255.255.255.0 ifconfig local0 up
- To make this permanent, install netcfg if you don't have it and set up a network profile in /etc/network.d, drawing on the examples in /etc/network.d/examples. Or, put the above lines in /etc/rc.local.
- Enable packet forwarding. To do so, write a "1" to /proc/sys/net/ipv4/ip_forward with:
echo 1 > /proc/sys/net/ipv4/ip_forward
- Edit /etc/sysctl.conf and add this line, which will make the previous change persistant after a reboot.
If you are using ipv6, use these lines:
- Install iptables, enable NAT (needed to share Internet), save and start it.
pacman -S iptables iptables -t nat -A POSTROUTING -o internet0 -j MASQUERADE rc.d save iptables rc.d start iptables
- Add iptables in your DAEMONS array in your /etc/rc.conf so that it is started each time.
- Go to the client PC and set:
- IP: 192.168.0.2
- Netmask: 255.255.255.0
- Gateway: 192.168.0.1
- DNS: The same DNS as the first PC
ifconfig local1 192.168.0.2 netmask 255.255.255.0 ifconfig local1 up route add default gw 192.168.0.1 local1 echo "nameserver <adr of nameserver>" >> /etc/resolv.confYou can figure out the address of the nameserver by looking into the /etc/resolv.conf of PC1, if its Internet connection is already established. If you don't have a nameserver, you can use Google Public DNS which is relatively fast. Its addresses are 188.8.131.52 and 184.108.40.206.
That's it. The client PC should now have Internet.
If you are able to connect the two PCs but cannot send data (for example, if the client PC makes a DHCP request to the server PC, the server PC receives the request and offers an IP to the client, but the client does not accept it, timing out instead), check that you don't have other Iptables rules interfering.