Comment sécuriser FreeBSD avec le pare-feu PF

Ce tutoriel vous montrera comment protéger votre serveur FreeBSD à l'aide du pare-feu OpenBSD PF. Nous supposerons que vous avez une installation propre de FreeBSD déployée par Vultr sans aucun utilisateur ajouté. Nous ferons d'autres choses en plus de la configuration du pare-feu qui durcira également la sécurité de notre serveur FreeBSD. Avant la configuration du pare-feu, nous installerons certains packages car l'installation par défaut de FreeBSD est livrée avec un ensemble minimal d'outils et de packages (ce qui est correct), pour nous faciliter le travail.

Le shell par défaut dans FreeBSD est /bin/sh. Il s'agit d'un shell de base sans fonctions d'auto-complétion. Nous utiliserons quelque chose de mieux. Nous allons installer zsh.

Tout d'abord, installez ces packages:

# pkg install zsh gnuls
The package management tool is not yet installed on your system.
Do you want to fetch and install it now? [y/N]: y
Bootstrapping pkg from pkg+http://pkg.FreeBSD.org/freebsd:10:x86:64/latest, please wait...
...

GNULS est le lsprogramme de Linux. Nous voulons juste avoir la même lscommande sous Linux et FreeBSD.

Ajoutez un utilisateur normal au système: (remplacez john par votre nom d'utilisateur et n'oubliez pas d'ajouter l'utilisateur au groupe de roues)

# adduser
Username: john
Full name: John Doe
Uid (Leave empty for default): 
Login group [john]: 
Login group is john. Invite john into other groups? []: wheel
Login class [default]: 
Shell (sh csh tcsh zsh rzsh nologin) [sh]: zsh
Home directory [/home/john]: 
Home directory permissions (Leave empty for default): 
Use password-based authentication? [yes]: 
Use an empty password? (yes/no) [no]: 
Use a random password? (yes/no) [no]: 
Enter password: 
Enter password again: 
Lock out the account after creation? [no]: 
Username   : john
Password   : *****
Full Name  : John Doe
Uid        : 1001
Class      : 
Groups     : john wheel
Home       : /home/john
Home Mode  : 
Shell      : /usr/local/bin/zsh
Locked     : no
OK? (yes/no): yes
adduser: INFO: Successfully added (john) to the user database.
Add another user? (yes/no): no
Goodbye!

Créez un fichier de configuration zsh:

# ee /home/your-username/.zshrc

Copiez ceci dans votre fichier .zshrc:

PS1="<%U%m%u>$[%B%1~%b]%(#.#.$) "

bindkey -e
alias su='su -m'
alias du='du -h -d0'
alias df='df -h'
alias l=less
alias ll='gnuls --color=always -l'
alias ls='gnuls --color=always'
alias pkg_ver='pkg version -v -l "<" | > upgrade'

export EDITOR=ee

autoload -U colors && colors
autoload -U promptinit && promptinit
autoload -U compinit && compinit

# History settings
SAVEHIST=1000
HISTSIZE=1000
HISTFILE=~/.history
setopt histignoredups appendhistory

Exécutez cette commande: (remplacez john par votre nom d'utilisateur)

chown john:john /home/john/.zshrc

Maintenant, connectez-vous au serveur FreeBSD avec votre nom d'utilisateur et changez le mot de passe root par défaut:

<vultr>[~]$ su
Password:
<vultr>[~]# passwd 
Changing local password for root
New Password:
Retype New Password:
<vultr>[~]# 

Nous n'avons pas besoin de sendmail. Arrêtez et désactivez ce service:

<vultr>[~]# /etc/rc.d/sendmail stop
Stopping sendmail.
Waiting for PIDS: 7843.
sendmail_submit not running? (check /var/run/sendmail.pid).
Stopping sendmail_msp_queue.
Waiting for PIDS: 7846.

Ensuite, nous allons changer notre fichier rc.conf pour avoir l'air plus naturel:

# ee /etc/rc.conf

Changez-le pour ressembler à ceci:

#----------- NETWORKING ------------------------------------------------#
hostname="ceph.domain1.com" # replace ceph.domain1.com with your domain
ifconfig_vtnet0="dhcp"
static_routes=linklocal
route_linklocal="-net 169.254.0.0/16 -interface vtnet0"

#--------- SERVICES BSD LOCAL ----------------------------------------#
sshd_enable="YES"
ntpd_enable="YES"

#pf_enable="YES"
#pf_rules="/etc/firewall"
#pf_flags=""
#pflog_enable="YES"              
#pflog_logfile="/var/log/pflog"  
#pflog_flags=""    

sendmail_enable="NONE"
sendmail_submit_enable="NO"
sendmail_outbound_enable="NO"
sendmail_msp_queue_enable="NO"

Modifier le /etc/hostsfichier:

# ee /etc/hosts

Ajoutez votre adresse IP et votre nom d'hôte:

::1                     localhost localhost.ceph ceph
127.0.0.1               localhost localhost.ceph ceph
108.61.178.110          ceph.domain1.com       ceph

Définir le fuseau horaire:

# bsdconfig

Chaque fois que vous le pouvez, désactivez l'accès à distance pour l'utilisateur root. La plupart des attaques sur SSH tenteront d'accéder via le compte d'utilisateur root. Connectez-vous toujours avec votre nom d'utilisateur puis suà root. Seuls les utilisateurs du wheelgroupe peuvent surooter. C'est pourquoi nous avons ajouté notre utilisateur au groupe de roues.

Désactiver la connexion root:

# ee /etc/ssh/sshd_config

Décommentez cette ligne:

PermitRootLogin no

Redémarrer:

# reboot

Une fois le redémarrage terminé, vous verrez un message comme celui-ci dans la console Vultr:

time correction of 3600 seconds exceeds sanity limit (1000); set clock manually to
correct UTC time.

C'est pourquoi nous devons corriger l'horloge manuellement. Suivez ces commandes, d'abord supour rooter:

$ su
Password:
# ntpdate 0.europe.pool.ntp.org

Maintenant, nous allons configurer le pare-feu. OpenBSD PF est inclus dans le noyau FreeBSD, vous n'avez donc pas besoin d'installer de paquet.

Avec l' eeéditeur, créez un fichier /etc/firewall:

# ee /etc/firewall

Insérez ceci: (remplacez toutes les adresses IP par les vôtres)

#######################################################################
me="vtnet0"                
table <bruteforcers> persist    
table <trusted> persist file "/etc/trusted"
icmp_types = "echoreq"          
junk_ports="{ 135,137,138,139,445,68,67,3222 }"
junk_ip="224.0.0.0/4"           

set loginterface vtnet0           
scrub on vtnet0 reassemble tcp no-df random-id

# ---- First rule obligatory "Pass all on loopback"
pass quick on lo0 all           

# ---- Block junk logs
block quick proto { tcp, udp } from any to $junk_ip 
block quick proto { tcp, udp } from any to any port $junk_ports

# ---- Second rule "Block all in and pass all out"
block in log all                
pass out all keep state         

############### FIREWALL ###############################################
# ---- Allow all traffic from my Home
pass quick proto {tcp, udp} from 1.2.3.4 to $me keep state

# ---- block SMTP out 
block quick proto tcp from $me to any port 25

# ---- Allow incoming Web traffic
pass quick proto tcp from any to $me port { 80, 443 } flags S/SA keep state

# ---- Allow my team member SSH access 
pass quick proto tcp from 1.2.3.5 to $me port ssh flags S/SA keep state

# ---- Block bruteforcers
block log quick from <bruteforcers>

# ---- Allow SSH from trusted sources, but block bruteforcers
pass quick proto tcp from <trusted> to $me port ssh \
flags S/SA keep state \
(max-src-conn 10, max-src-conn-rate 20/60, \
overload <bruteforcers> flush global)

# ---- Allow ICMP 
pass in inet proto icmp all icmp-type $icmp_types keep state
pass out inet proto icmp all icmp-type $icmp_types keep state

Créez un /etc/trustedfichier. Dans ce fichier, nous mettrons les IP auxquelles nous "faisons confiance".

# ee /etc/trusted

Ajoutez des IP:

# Hosting
1.2.0.0/16

# My friends
1.2.4.0/24

Maintenant, une explication. Les ports indésirables et les adresses IP indésirables ne sont que quelques ports / IP que nous ne voulons pas voir dans les journaux. Nous l'avons fait avec cette règle:

# ---- Block junk logs
block quick proto { tcp, udp } from any to $junk_ip 
block quick proto { tcp, udp } from any to any port $junk_ports

Ce ne sont que des valeurs par défaut et vous n'avez pas à vous en préoccuper:

icmp_types = "echoreq"                                            
set loginterface vtnet0           
scrub on vtnet0 reassemble tcp no-df random-id
pass quick on lo0 all
block in log all                
pass out all keep state

Cette règle bloque le trafic SMTP sortant de votre serveur (qui est la valeur par défaut sur Vultr).

# ---- block SMTP out 
block quick proto tcp from $me to any port 25

Sauf que bruteforcersle reste est assez simple.

# ---- Allow SSH from trusted sources, but block bruteforcers
pass quick proto tcp from <trusted> to $me port ssh \
flags S/SA keep state \
(max-src-conn 10, max-src-conn-rate 20/60, \
overload <bruteforcers> flush global)

Bruteforcers dit simplement: Autoriser à partir des adresses IP <approuvées> vers le port 22, mais seules 10 connexions simultanées peuvent être établies à partir d'une adresse IP source. Si elle est supérieure à 10, bloquez cette IP et placez-la dans les table bruteforcers. Il en va de même pour la règle 20/60. Cela signifie un maximum de 20 connexions en 60 secondes.

Activer le pare-feu:

# ee /etc/rc.conf

Décommentez ces lignes:

pf_enable="YES"
pf_rules="/etc/firewall"
pf_flags=""
pflog_enable="YES"
pflog_logfile="/var/log/pflog"
pflog_flags=""

Redémarrer:

# reboot 

Si vous avez tout fait correctement, vous pourrez vous connecter et le pare-feu sera activé. Vous n'avez pas besoin de redémarrer chaque fois que vous modifiez le /etc/firewallfichier. Faites juste:

# /etc/rc.d/pf reload

Découvrez qui essaie de se connecter à votre serveur en temps réel:

# tcpdump -n -e -ttt -i pflog0

Afficher l'historique:

# tcpdump -n -e -ttt -r /var/log/pflog

Voyez si vous avez quelqu'un dans la table bruteforcers:

# pfctl -t bruteforcers -T show

Et c'est tout. Vous avez réussi à implémenter le pare-feu PF sur le serveur FreeBSD!


Tags: #BSD

Leave a Comment

Comment installer Blacklistd sur FreeBSD 11.1

Comment installer Blacklistd sur FreeBSD 11.1

Introduction Tout service connecté à Internet est une cible potentielle dattaques par force brute ou daccès injustifié. Il existe des outils comme fail2ba

Comment installer la pile Apache, MySQL et PHP (FAMP) sur FreeBSD 12.0

Comment installer la pile Apache, MySQL et PHP (FAMP) sur FreeBSD 12.0

Introduction Une pile FAMP, qui est comparable à une pile LAMP sous Linux, est une collection de logiciels open source qui sont généralement installés ensemble t

Comment installer Osclass sur FreeBSD 12

Comment installer Osclass sur FreeBSD 12

Vous utilisez un système différent? Osclass est un projet open source qui vous permet de créer facilement un site classé sans aucune connaissance technique. Son sourc

Comment installer Wiki.js sur FreeBSD 11

Comment installer Wiki.js sur FreeBSD 11

Vous utilisez un système différent? Wiki.js est une application wiki moderne gratuite et open source basée sur Node.js, MongoDB, Git et Markdown. Le code source de Wiki.js est public

Comment installer lalbum photo Lychee 3.1 sur un VPS FBS FreeBSD 11

Comment installer lalbum photo Lychee 3.1 sur un VPS FBS FreeBSD 11

Vous utilisez un système différent? Lychee 3.1 Photo Album est un outil de gestion de photos simple et flexible, gratuit et open source qui fonctionne sur un serveur VPS. Il installe

Installer Fork CMS sur FreeBSD 12

Installer Fork CMS sur FreeBSD 12

Vous utilisez un système différent? Fork est un CMS open source écrit en PHP. Le code source de Forks est hébergé sur GitHub. Ce guide vous montrera comment installer Fork CM

Créer un fichier déchange sur FreeBSD 10

Créer un fichier déchange sur FreeBSD 10

Par défaut, les serveurs Vultr FreeBSD ne sont pas configurés pour inclure lespace de swap. Si votre intention est pour une instance de cloud jetable, vous navez probablement pas besoin

Comment redimensionner un disque dans FreeBSD

Comment redimensionner un disque dans FreeBSD

Le système dexploitation FreeBSD utilise UFS (Unix File System) pour son système de fichiers de partitions racine; autrement connu sous le nom de freebsd-ufs En cas de mise à niveau

Comment installer Selfoss RSS Reader sur un VPS FBS FreeBSD 11

Comment installer Selfoss RSS Reader sur un VPS FBS FreeBSD 11

Vous utilisez un système différent? Selfoss RSS Reader est un lecteur Web gratuit et open source auto-hébergé à usages multiples, diffusion en direct, mashup, flux de nouvelles (RSS / Atom)

Comment installer Matomo Analytics sur FreeBSD 11

Comment installer Matomo Analytics sur FreeBSD 11

Vous utilisez un système différent? Matomo (anciennement Piwik) est une plate-forme danalyse open source, une alternative ouverte à Google Analytics. La source Matomo est hébergée o

Comment activer TLS 1.3 dans Nginx sur FreeBSD 12

Comment activer TLS 1.3 dans Nginx sur FreeBSD 12

Vous utilisez un système différent? TLS 1.3 est une version du protocole TLS (Transport Layer Security) qui a été publiée en 2018 en tant que norme proposée dans la RFC 8446

Comment installer le CMS Backdrop sur un VPS FBS FreeBSD 11

Comment installer le CMS Backdrop sur un VPS FBS FreeBSD 11

Vous utilisez un système différent? Backdrop CMS 1.8.0 est un système de gestion de contenu (CMS) simple et flexible, adapté aux mobiles, gratuit et open source qui nous permet

Comment installer ImpressPages CMS 5.0 sur un VPS FBS FreeBSD 11

Comment installer ImpressPages CMS 5.0 sur un VPS FBS FreeBSD 11

Vous utilisez un système différent? ImpressPages CMS 5.0 est un système de gestion de contenu (CMS) simple et efficace, gratuit et open source, convivial et basé sur MVC

Comment installer le forum NodeBB sur FreeBSD 12

Comment installer le forum NodeBB sur FreeBSD 12

Vous utilisez un système différent? NodeBB est un logiciel de forum basé sur Node.js. Il utilise des sockets Web pour des interactions instantanées et des notifications en temps réel. Le NodeB

Installez eSpeak sur FreeBSD 12

Installez eSpeak sur FreeBSD 12

Vous utilisez un système différent? ESpeak peut générer des fichiers audio de synthèse vocale (TTS). Ceux-ci peuvent être utiles pour de nombreuses raisons, telles que la création de votre propre Turin

Comment installer LimeSurvey CE sur FreeBSD 12

Comment installer LimeSurvey CE sur FreeBSD 12

Vous utilisez un système différent? LimeSurvey est un logiciel denquête open source écrit en PHP. Le code source de LimeSurvey est hébergé sur GitHub. Ce guide vous montrera

Comment installer Monica sur FreeBSD 12

Comment installer Monica sur FreeBSD 12

Vous utilisez un système différent? Monica est un système de gestion des relations personnelles open source. Considérez-le comme un CRM (un outil populaire utilisé par les équipes

Comment installer Automad CMS sur FreeBSD 12

Comment installer Automad CMS sur FreeBSD 12

Vous utilisez un système différent? Automad est un système de gestion de contenu (CMS) basé sur des fichiers open source et un moteur de modèle écrit en PHP. Le code source Automad i

Installer Akaunting sur FreeBSD 12

Installer Akaunting sur FreeBSD 12

Vous utilisez un système différent? Introduction Akaunting est un logiciel de comptabilité gratuit, open source et en ligne conçu pour les petites entreprises et les indépendants. Cest moi

Choix dun système dexploitation: CentOS, Ubuntu, Debian, FreeBSD, CoreOS ou Windows Server

Choix dun système dexploitation: CentOS, Ubuntu, Debian, FreeBSD, CoreOS ou Windows Server

Cet article fournit un bref résumé des systèmes dexploitation du serveur proposés en tant que modèles sur Vultr. CentOS CentOS est une version open source de RHEL (Re

Comment générer des clés SSH?

Comment générer des clés SSH?

Découvrez comment générer une clé SSH pour accéder à votre serveur sans mot de passe. Suivez nos étapes faciles à comprendre pour créer et ajouter des clés SSH.

Créer un serveur de messagerie avec hMailServer sous Windows

Créer un serveur de messagerie avec hMailServer sous Windows

Découvrez comment créer un serveur de messagerie avec hMailServer sous Windows pour recevoir des e-mails facilement.

LIA peut-elle lutter contre un nombre croissant dattaques de ransomware

LIA peut-elle lutter contre un nombre croissant dattaques de ransomware

Les attaques de ransomware sont en augmentation, mais l'IA peut-elle aider à lutter contre le dernier virus informatique ? L'IA est-elle la réponse ? Lisez ici, sachez que l'IA est un boone ou un fléau

ReactOS : est-ce lavenir de Windows ?

ReactOS : est-ce lavenir de Windows ?

ReactOS, un système d'exploitation open source et gratuit est ici avec la dernière version. Cela peut-il suffire aux besoins des utilisateurs de Windows modernes et faire tomber Microsoft ? Découvrons-en plus sur cet ancien style, mais une expérience de système d'exploitation plus récente.

Restez connecté via lapplication de bureau WhatsApp 24 * 7

Restez connecté via lapplication de bureau WhatsApp 24 * 7

Whatsapp a finalement lancé l'application de bureau pour les utilisateurs Mac et Windows. Vous pouvez désormais accéder facilement à Whatsapp depuis Windows ou Mac. Disponible pour Windows 8+ et Mac OS 10.9+

Comment lIA peut-elle faire passer lautomatisation des processus au niveau supérieur ?

Comment lIA peut-elle faire passer lautomatisation des processus au niveau supérieur ?

Lisez ceci pour savoir comment l'intelligence artificielle devient populaire parmi les petites entreprises et comment elle augmente les probabilités de les faire grandir et de donner à leurs concurrents un avantage.

La mise à jour du supplément macOS Catalina 10.15.4 cause plus de problèmes quelle nen résout

La mise à jour du supplément macOS Catalina 10.15.4 cause plus de problèmes quelle nen résout

Récemment, Apple a publié macOS Catalina 10.15.4, une mise à jour supplémentaire pour résoudre les problèmes, mais il semble que la mise à jour cause davantage de problèmes, ce qui entraîne le bridage des machines mac. Lisez cet article pour en savoir plus

13 outils commerciaux dextraction de données de Big Data

13 outils commerciaux dextraction de données de Big Data

13 outils commerciaux d'extraction de données de Big Data

Quest-ce quun système de fichiers de journalisation et comment fonctionne-t-il ?

Quest-ce quun système de fichiers de journalisation et comment fonctionne-t-il ?

Notre ordinateur stocke toutes les données d'une manière organisée connue sous le nom de système de fichiers de journalisation. C'est une méthode efficace qui permet à l'ordinateur de rechercher et d'afficher des fichiers dès que vous appuyez sur la recherche.https://wethegeek.com/?p=94116&preview=true

Singularité technologique : un futur lointain de la civilisation humaine ?

Singularité technologique : un futur lointain de la civilisation humaine ?

Alors que la science évolue à un rythme rapide, prenant le pas sur une grande partie de nos efforts, les risques de nous soumettre à une Singularité inexplicable augmentent également. Lisez, ce que la singularité pourrait signifier pour nous.