Servidor para o compartilhamento de internet!

1. Servidor para o compartilhamento de internet!

Silas Matos
silasmg

(usa Debian)

Enviado em 20/01/2015 - 20:03h

Pessoal, estou ficando muito desapontado com este problema, segue o cenário:

O servidor está ótimo, compartilhando internet e tudo mais, servidor de arquivos ok, servidor squid ok, dhcp ok, até que então falta luz ou por algum problema tenho que reiniciar ele, pronto, a internet não volta nas estações, funciona apenas no próprio servidor, as estações pegam o IP normalmente do servidor, mas nenhuma delas navega, também não consigo acessar a página do apache no servidor ou o servidor de arquivos, até que do nada, depois de uns minutos e as vezes horas, ele volta ao normal, tudo navegando, tudo funcionando, eu usava um debian 5 que tinha esse problema, agora coloquei outro servidor com debian 7, e continua a mesma lenda, tem algo de errado nos scripts? Modem DSL: 10.0.2.249 no eth0, dispara o dhcp 10.0.2.250 para a placa do servidor, o eth1 está ligado a rede com o endereço 10.0.2.1.

Por favor me ajudem.

script firewall

#!/bin/sh
#

### BEGIN INIT INFO
# Provides: firewall
# Required-Start: $local_fs $remote_fs $network $syslog
# Required-Stop: $local_fs $remote_fs $network $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start firewall at boot time
# Description: Enable service provided by firewall.
### END INIT INFO

iniciar(){
# IP do servidor SQUID
SQUID_SERVER="10.0.2.1"
# Interface que se conecta com a internet
INTERNET="ppp0"
# Interface da rede local
LAN_IN="eth1"
# Porta do SQUID
SQUID_PORT="3128"
# Tempo liberado
t_ip="--timestart 11:50 --timestop 13:30"

# NÃO MODIFIQUE AS LINHAS ABAIXO:
# LIMPAR FIREWALL
iptables -F
iptables -X
iptables -X -t filter
iptables -F -t filter
iptables -t nat -F
iptables -t nat -X
iptables -t mangle -F
iptables -t mangle -X
# CARREGAR MÓDULOS PARA NAT E SUPORTE PARA IP CONTRACK
modprobe ip_conntrack
modprobe ip_conntrack_ftp
modprobe iptable_nat
modprobe tun
# COMPARTILHAMENTO DE INTERNET.
echo 1 > /proc/sys/net/ipv4/ip_forward
echo 1 > /proc/sys/net/ipv4/tcp_syncookies
# DEFINIR POLITICAS DE ACESSO
iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
# ACESSO ILIMITADO AO LOOPBACK
iptables -A INPUT -i lo -j ACCEPT
iptables -A OUTPUT -o lo -j ACCEPT

# LIBERAÇÃO DE PORTAS
iptables -A INPUT -p tcp --dport 22 -j ACCEPT
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
iptables -A INPUT -p tcp --dport 1723 -j ACCEPT
iptables -A INPUT -p tcp --dport 3000 -j ACCEPT
iptables -A INPUT -p tcp --dport 3128 -j ACCEPT
iptables -A INPUT -p tcp --dport 5900 -j ACCEPT
iptables -A INPUT -p tcp --dport 5931 -j ACCEPT
iptables -A INPUT -p tcp --dport 1863 -j ACCEPT
iptables -A INPUT -p udp --dport 1863 -j ACCEPT
iptables -A INPUT -p udp --dport 27015 -j ACCEPT

#bloqueando Ping
iptables -A INPUT -p icmp --icmp-type echo-request -j DROP

#Ultra Surf, Ares, uTorrent, p2p
iptables -A FORWARD -d 65.49.14.0/24 -j LOG --log-prefix "=UltraSurf="
iptables -A FORWARD -d 199.59.162.71 -j LOG --log-prefix "=Ares_Galaxy="
iptables -A FORWARD -d 98.143.146.7 -j LOG --log-prefix "=uTorrent= "
iptables -A FORWARD -m string --algo bm --string "BitTorrent" -j LOG --log-prefix "=uTorrent= "
iptables -A FORWARD -m string --algo bm --string "peer_id=" -j LOG --log-prefix "=uTorrent="
iptables -A FORWARD -m string --algo bm --string "torrent" -j LOG --log-prefix "=uTorrent="
iptables -A FORWARD -m string --algo bm --string "announce" -j LOG --log-prefix "=uTorrent="
iptables -A FORWARD -m string --algo bm --string "tracker" -j LOG --log-prefix "=uTorrent="
iptables -A FORWARD -m string --algo bm --string "find_node" -j LOG --log-prefix "=uTorrent="
iptables -A FORWARD -m string --algo bm --string "info_hash" -j LOG --log-prefix "=uTorrent="
iptables -A FORWARD -m string --algo bm --string "get_peers" -j LOG --log-prefix "=uTorrent="

#BLOQUEAR ENDERECOS DO FACEBOOK
iptables -A FORWARD -m iprange --src-range 10.0.2.5-10.0.2.230 -m string --algo kmp --string "facebook.com" -m time --timestart 12:00 --timestop 13:00 -j ACCEPT
iptables -A INPUT -m iprange --src-range 10.0.2.5-10.0.2.230 -m string --algo kmp --string "facebook.com" -m time --timestart 12:00 --timestop 13:00 -j ACCEPT
iptables -A OUTPUT -m iprange --src-range 10.0.2.5-10.0.2.230 -m string --algo kmp --string "facebook.com" -m time --timestart 12:00 --timestop 13:00 -j ACCEPT

iptables -A INPUT -m string --algo bm --string "facebook.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -m time $t_ip -j ACCEPT
iptables -A OUTPUT -m string --algo bm --string "facebook.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -m time $t_ip -j ACCEPT
iptables -A FORWARD -m string --algo bm --string "facebook.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -m time $t_ip -j ACCEPT

iptables -A INPUT -m string --algo bm --string "facebook.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A OUTPUT -m string --algo bm --string "facebook.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A FORWARD -m string --algo bm --string "facebook.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A INPUT -m string --algo bm --string "youtube.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A OUTPUT -m string --algo bm --string "youtube.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A FORWARD -m string --algo bm --string "youtube.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A INPUT -m string --algo bm --string "plus.google.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A OUTPUT -m string --algo bm --string "plus.google.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP
iptables -A FORWARD -m string --algo bm --string "plus.google.com" -m iprange --src-range 10.0.2.5-10.0.2.231 -j DROP

# PERMITIR UDP, DNS E FTP PASSIVO
iptables -A INPUT -i $INTERNET -m state --state ESTABLISHED,RELATED -j ACCEPT
# DEFINIR ESTE SISTEMA COMO O ROTEADOR PADRÃO PARA O RESTO DA LAN
iptables --table nat --append POSTROUTING --out-interface $INTERNET -j MASQUERADE
iptables --append FORWARD --in-interface $LAN_IN -j ACCEPT
# ACESSO ILIMITADO PELA LAN
iptables -A INPUT -i $LAN_IN -j ACCEPT
iptables -A OUTPUT -o $LAN_IN -j ACCEPT
# NAT PARA A PORTA 80 SOLICITADA PELA LAN PARA A PORTA DO SQUID 3128 ($SQUID_PORT) PROXY TRANSPARENTE
iptables -t nat -I PREROUTING -p tcp -i $LAN_IN --dport 80 -j REDIRECT --to-port 3128
# NAT PARA A PORTA 443 SOLICITADA PELA LAN PARA PORTAS HTTPS
#iptables -t nat -I PREROUTING -p tcp -m multiport -i $LAN_IN --dport 443 -j REDIRECT --to-ports 3128


# REJEITAR O RESTO E CRIAR LOG
iptables -A INPUT -j LOG
iptables -A INPUT -j DROP
echo "Firewall Habilitado"
}
parar(){
iptables -F
iptables -X
iptables -X -t filter
iptables -F -t filter
iptables -t nat -F
iptables -t nat -X
iptables -t mangle -F
iptables -t mangle -X
echo "Firewall desabilidatado"
}
case "$1" in
"start") iniciar ;;
"stop") parar ;;
"restart") parar; iniciar ;;
*) echo "Use os parâmetros start, stop ou restart"
esac


script dhcp:

ddns-update-style none;

option domain-name "example.org";
option domain-name-servers ns1.example.org, ns2.example.org;

default-lease-time 600;
max-lease-time 7200;

log-facility local7;


# Saude

subnet 10.0.0.0 netmask 255.0.0.0 {
option domain-name-servers 10.0.2.1 , 201.10.128.2 , 201.10.120.3;
deny client-updates;
deny unknown-clients;
authoritative;
option routers 10.0.2.1;
range 10.0.2.240 10.0.2.240;
}

#DESKTOPS

host SMS-CPD {
hardware ethernet 44:1E:A1:77:77:0E;
fixed-address 10.0.2.2;
}
host SMS-Compras2 {
hardware ethernet 6c:f0:49:fe:20:57;
fixed-address 10.0.2.3;
}
host SMS-Projetos {
hardware ethernet 44:1e:a1:77:67:92;
fixed-address 10.0.2.49;
}


script interfaces:


# This file describes the network interfaces available on your system
# and how to activate them. For more information, see interfaces(5).

# The loopback network interface
auto lo eth0 eth1 dsl-provider
iface lo inet loopback

# Placa de rede do modem
allow-hotplug eth0
iface eth0 inet dhcp

# Placa da rede local
iface eth1 inet static
address 10.0.2.1
netmask 255.0.0.0
broadcast 10.0.2.255
network 10.0.0.0

iface dsl-provider inet ppp
pre-up /sbin/ifconfig eth0 up # line maintained by pppoeconf
provider dsl-provider


script squid:

#Recommended minimum configuration:
acl all src all
acl manager proto cache_object
acl localhost src 127.0.0.1/32
acl to_localhost dst 127.0.0.0/8 0.0.0.0/32

acl localnet src 10.0.2.0/24 # RFC1918 possible internal network

#
acl SSL_ports port 443 # https
acl SSL_ports port 563 # snews
acl SSL_ports port 873 # rsync
acl Safe_ports port 80 # http
acl Safe_ports port 21 # ftp
acl Safe_ports port 443 # https
acl Safe_ports port 70 # gopher
acl Safe_ports port 210 # wais
acl Safe_ports port 1025-65535 # unregistered ports
acl Safe_ports port 280 # http-mgmt
acl Safe_ports port 488 # gss-http
acl Safe_ports port 591 # filemaker
acl Safe_ports port 777 # multiling http
acl Safe_ports port 631 # cups
acl Safe_ports port 873 # rsync
acl Safe_ports port 901 # SWAT
acl purge method PURGE
acl CONNECT method CONNECT

#Recommended minimum configuration:
http_access allow manager localhost
http_access deny manager
http_access allow purge localhost
http_access deny purge
http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports
http_access allow localhost


# IPs da rede
acl ip_liberados src "/etc/squid/ips/ip_liberados"
acl nonet src "/etc/squid/ips/nonet"

#
# INSIRA NESTE LOCAL SUAS PRÓPRIAS REGRAS.
# RECOMENDA-SE PRIMEIRO FAZER AS LIBERAÇÕES E DEPOIS OS BLOQUEIOS.
#
acl perm_pal url_regex "/etc/squid/permitidos_palavras"
acl perm_url dstdom_regex "/etc/squid/permitidos_sites"
acl perm_dom dstdomain "/etc/squid/permitidos_dominios"
http_access allow perm_pal
http_access allow perm_url
http_access allow perm_dom
#
# LIBRERAR POR HORÁRIO
#
acl sites_intervalo url_regex "/etc/squid/sites_intervalo"
acl intervalo time MTWHF 07:00-08:00
acl intervalo_m time MTWHF 11:50-13:30
http_access allow sites_intervalo intervalo
http_access allow sites_intervalo intervalo_m
#
# LIBERAR RECEPCAO
#
acl sites_nonet url_regex "/etc/squid/sites/sites_nonet"
http_access allow nonet sites_nonet
#
#bloqear sites
#
acl bloq_pal url_regex "/etc/squid/bloqueados_palavras"
acl bloq_url dstdom_regex "/etc/squid/bloqueados_sites"
acl bloq_dom dstdomain "/etc/squid/bloqueados_dominios"
http_access deny bloq_pal !ip_liberados
http_access deny bloq_url !ip_liberados
http_access deny bloq_dom !ip_liberados

# And finally deny all other access to this proxy
http_access allow localnet
http_access deny all

icp_access allow localnet
icp_access deny all

http_port 3128 transparent

hierarchy_stoplist cgi-bin ?

access_log /var/log/squid/access.log squid

#Suggested default:
refresh_pattern ^ftp: 1440 20% 10080
refresh_pattern ^gopher: 1440 0% 1440
refresh_pattern -i (/cgi-bin/|\?) 0 0% 0
refresh_pattern (Release|Packages(.gz)*)$ 0 20% 2880
refresh_pattern . 0 20% 4320

# Don't upgrade ShoutCast responses to HTTP
acl shoutcast rep_header X-HTTP09-First-Line ^ICY.[0-9]
upgrade_http0.9 deny shoutcast

# Apache mod_gzip and mod_deflate known to be broken so don't trust
# Apache to signal ETag correctly on such responses
acl apache rep_header Server ^Apache
broken_vary_encoding allow apache

extension_methods REPORT MERGE MKACTIVITY CHECKOUT

hosts_file /etc/hosts

httpd_suppress_version_string off # suprime a versão do Squid
visible_hostname Proxy Sec. da Saude





  


2. Re: Servidor para o compartilhamento de internet!

Silas Matos
silasmg

(usa Debian)

Enviado em 21/01/2015 - 08:53h

No interfaces eu retirei o seguinte:

eth0 eth1 dsl-provider

onde está:

auto lo eth0 eth1 dsl-provider

E aparentemente voltou ao normal, mas isso 1 dia depois, não sei por qual motivo, mas só hoje quando reiniciei o networking que ele me mostrou um erro dizendo que o eth0 já havia sido configurado, justamente por causa do "auto".

Mas minha dúvida agora é outra, porque quando a discagem é feita pelo pppoeconf (pon dsl-provider), a internet no servidor funciona somente por um tempo, e depois não navega mais, mas nas estações continua funcionando tudo normalmente, somente o servidor não navega, caso eu precise baixar alguma atualização no servidor eu tenho que refazer a discagem com (poff dsl-provider ; pon dsl-provider), fazendo voltar a internet no servidor, mas assim corta momentaneamente a internet nas estações.






Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts