Proteggi resolv.conf dal DHCP su FreeBSD 10

Se si esegue il proprio resolver o si desidera utilizzarne uno da un provider di terze parti, è possibile che il /etc/resolv.conffile venga sovrascritto da DHCP. Esistono diversi modi per risolvere questo problema. Dal momento che probabilmente vorrai riavviare per assicurarti che le tue modifiche si attacchino, e dato che in primo luogo sarai monkeying con le impostazioni di rete, ti consiglio vivamente di farlo su un'istanza di prova e / o al di fuori del picco ore.

Ora, quindi, ecco tre metodi, dal peggiore al migliore. Nota che tutti i metodi in questa guida sono stati scritti per FreeBSD 10. Gli utenti Linux possono fare riferimento a questa guida .

Metodo 1: utilizzare le impostazioni dell'interfaccia statica

Nei miei test limitati, ciò si traduce in tempi di avvio leggermente più veloci poiché non è necessario attendere che DHCP assegni le impostazioni di rete. Tuttavia, ho visto menzionare in diversi documenti Vultr che l'utilizzo delle impostazioni dell'interfaccia statica è disapprovato e che si dovrebbe attenersi al DHCP. Presumo che abbiano una buona ragione per questo e quindi ho continuato a usare DHCP da solo. Tuttavia, se decidi di percorrere questa strada, segui i passaggi seguenti.

  • Determinare l'IP del server, la maschera di rete e l'IP del gateway.
  • Modifica /etc/rc.confper utilizzare questi valori anziché DHCP.
  • Riavvia per testare le impostazioni.

Determina IP / maschera di rete / gateway

Supponendo che l'interfaccia sia vtnet0, eseguire le seguenti operazioni:

ifconfig vtnet0 | grep inet

Questo dovrebbe fornirti l'indirizzo IP e la maschera di rete per il tuo server:

inet 10.10.10.10 netmask 0xffffff00 broadcast 10.10.10.255

A FreeBSD piace usare hex per la maschera di rete. Quanto sopra si converte in 255.255.255.0se sei curioso. Puoi trovare una tabella utile qui , ma non temere: puoi semplicemente copiare l'indirizzo esadecimale nei tuoi file di configurazione (o convertirlo in decimale se preferisci).

Puoi trovare il gateway in vari modi. Eccone uno:

route get default | grep gateway restituirà qualcosa sulla falsariga di:

gateway: 10.10.10.1

Modifica /etc/rc.confcon nuovi valori

Dotato di IP, maschera di rete e gateway, è ora il momento di aggiungerli alla configurazione del sistema. Consiglio vivamente di eseguire il backup di questo file prima di apportare qualsiasi modifica, in quanto renderà molto più semplice annullare in caso di errori. Ora apri /etc/rc.confnel tuo editor preferito e apporta le seguenti modifiche:

# Comment out this line:
# ifconfig_vtnet0="dhcp"

# Add these lines:
defaultrouter="10.10.10.1"
ifconfig_vtnet0="inet 10.10.10.10 netmask 0xffffff00"

Ovviamente, dovresti essere sicuro di sostituire il tuo IP reale, la maschera di rete e il gateway per i miei ovvi falsi.

Riavvia e prova

Riavviare il server utilizzando shutdown -r nowe assicurarsi che venga ripristinato correttamente. Esegui tutti i test che ritieni necessari per assicurarti che tutto funzioni correttamente. Se la rete non è accessibile, accedi tramite console e ripristina le modifiche. Se tutto va bene, a questo punto puoi mettere qualunque cosa ti piaccia resolv.confsenza temere che venga cancellata.

Se per qualsiasi motivo non riesci a riavviare, questo dovrebbe funzionare, ma farei davvero un corretto riavvio se fossi in te:

service netif restart && service routing restart

Metodo 2: Rendi resolv.confimmutabile

Questo è un po 'un trucco, ma è facilmente la soluzione più rapida. Non lo consiglio perché non posso garantire che questo non causerà qualche stranezza in futuro quando eseguirai l'aggiornamento a una nuova versione del sistema operativo e dhclient probabilmente si lamenterà di un mucchio. Detto questo, chflags schg /etc/resolv.confè sufficiente un semplice . Il file è ora completamente protetto da scrittura, anche da root. Puoi verificare in questo modo:

vultr [~]# chflags schg /etc/resolv.conf
vultr [~]# ls -ol /etc/resolv.conf
-rw-r--r--  1 root  wheel  schg 50 Nov 29 06:28 /etc/resolv.conf
vultr [~]# echo "so very untouchable" >> /etc/resolv.conf
/etc/resolv.conf: Operation not permitted.

Annulla con: chflags noschg /etc/resolv.conf

Metodo 3: dite educatamente a FreeBSD di lasciare da sole le vostre impostazioni

Questo è di gran lunga il modo più pulito e corretto per farlo. Esistono due approcci che puoi adottare:

Configurazione dhclient

Prendiamo l'esempio dall'alto e diciamo che tutto ciò che vuoi fare è inserire il tuo nameserver personalizzato resolv.confe non vuoi perderlo ogni volta che DHCP fa la sua cosa. Nel mio caso, voglio usare il risolutore di cache che ho installato che è in ascolto su localhost, quindi modifico /etc/dhclient.conf(che probabilmente sarà vuoto a parte i commenti) e aggiungo quanto segue:

interface "vtnet0" {
    supersede domain-name-servers 127.0.0.1;
}

Ciò consentirà a dhclient di fare tutto il resto necessario, ma quando il server DHCP gli invia un elenco di server dei nomi da utilizzare, il tuo sostituirà (come in, sostituirà completamente) quelli che offre. Se preferisci integrare (anziché sostituire) quelli offerti, puoi "aggiungere" o "anteporre" invece di "sostituire", a seconda dei casi.

Per inciso, se hai bisogno di più di un server personalizzato, specificali in questo modo:

supersede domain-name-servers 127.0.0.1, 127.0.0.2;

Dopo aver apportato le modifiche, riavvia dhclientper renderle immediatamente effettive:

service dhclient restart vtnet0

Esamina il tuo /etc/resolv.confe dovresti trovarlo ora ha i tuoi server dei nomi personalizzati.

Al momento della stesura di questo documento, i nameserver sono l'unica cosa che il server DHCP di Vultr abbia mai inserito nel mio resolv.conf, e l'unica cosa che mi è piaciuto personalizzare. Tuttavia, se dovessi mai avere la precedenza su qualsiasi altra impostazione, consulta l'eccellente manuale per un elenco completo:

man 5 dhclient.conf

Ci sono ottimi esempi in fondo che dovrebbero darti un'idea di cosa puoi fare. In cima alla mia testa, posso immaginare che potresti voler aggiungere qualcosa come supersede domain-name "example.com";se normalmente avessi una linea come quella nella tua resolv.conf. Ancora una volta, consultare i documenti.

Configurazione resolvconf

Questa è la soluzione più semplice se vuoi solo che tu resolv.confsia lasciato solo. Per il manuale:

resolvconf manages resolv.conf(5) files from multiple sources, such as DHCP and VPN clients

La sua configurazione risiede /etc/resolvconf.conf, che probabilmente non esiste sul tuo sistema, quindi sentiti libero di crearlo. Per rendere il tuo resolv.confimmutabile, aggiungi questo:

# prevent all updates to resolv.conf:
resolv_conf="/dev/null"

Se usi unboundcome risolutore di cache locale, questa è la linea che aggiunge (insieme ad alcuni per sé). Questo è fondamentalmente ingannevole resolvconfnel pensare che ti /etc/resolv.conftrovi /dev/null. Qualcosa di leggermente meno cattivo, ma ugualmente efficace, sarebbe:

# disable resolvconf from running any subscribers:
resolvconf="NO"

Se vuoi fare qualcosa di più sofisticato della semplice disattivazione, le pagine man sono disponibili resolvconfe resolvconf.confhanno molte informazioni.



Leave a Comment

Come installare Blacklistd su FreeBSD 11.1

Come installare Blacklistd su FreeBSD 11.1

Introduzione Qualsiasi servizio connesso a Internet è un potenziale bersaglio di attacchi di forza bruta o accesso ingiustificato. Esistono strumenti come fail2ba

Installa OpenBSD 5.6 con la crittografia del disco completo

Installa OpenBSD 5.6 con la crittografia del disco completo

Questo tutorial ti mostrerà come configurare OpenBSD 5.6 con un disco completamente crittografato sul tuo VPS Vultr. Una nota sulla parte di crittografia: la maggior parte dei datacenter intorno a th

Come usare Sudo su Debian, CentOS e FreeBSD

Come usare Sudo su Debian, CentOS e FreeBSD

Luso di un utente sudo per accedere a un server ed eseguire comandi a livello di root è una pratica molto comune tra Linux e Unix Systems Administrator. Luso di un sud

Installa TaskServer (taskd) su FreeBSD 11

Installa TaskServer (taskd) su FreeBSD 11

Usi un sistema diverso? TaskWarrior è uno strumento di gestione del tempo open source che è un miglioramento dellapplicazione Todo.txt e dei suoi cloni. A causa di th

Come installare osTicket su FreeBSD 12

Come installare osTicket su FreeBSD 12

Usi un sistema diverso? osTicket è un sistema di ticket di supporto clienti open source. Il codice sorgente di osTicket è ospitato pubblicamente su Github. In questo tutorial

Installa Varnish 5 con Nginx su FreeBSD 11

Installa Varnish 5 con Nginx su FreeBSD 11

Varnish è un server cache open source che memorizza il contenuto da un server Web. È installato di fronte a un server Web come Apache o Nginx. La cache

Come installare Osclass su FreeBSD 12

Come installare Osclass su FreeBSD 12

Usi un sistema diverso? Osclass è un progetto open source che ti consente di creare facilmente un sito classificato senza alcuna conoscenza tecnica. È sourc

Come installare Wiki.js su FreeBSD 11

Come installare Wiki.js su FreeBSD 11

Usi un sistema diverso? Wiki.js è unapp wiki moderna, gratuita e open source, costruita su Node.js, MongoDB, Git e Markdown. Il codice sorgente di Wiki.js è publicl

Come installare Directus 6.4 CMS su un FPS VPS di FreeBSD 11

Come installare Directus 6.4 CMS su un FPS VPS di FreeBSD 11

Usi un sistema diverso? Directus 6.4 CMS è un sistema di gestione dei contenuti senza testa (CMS) potente e flessibile, gratuito e open source che fornisce agli sviluppatori

Mailserver semplice con Postfix, Dovecot e setaccio su FreeBSD 10

Mailserver semplice con Postfix, Dovecot e setaccio su FreeBSD 10

Questo tutorial ti mostrerà come ottenere un semplice server di posta su FreeBSD 10, con Postfix come MTA, Dovecot come MDA e Sieve per lordinamento della posta - tutto su un

Costruisci il tuo server di posta con FreeBSD 11

Costruisci il tuo server di posta con FreeBSD 11

Gestire il proprio server di posta elettronica può essere abbastanza gratificante. Sei responsabile dei tuoi dati. Ti consente anche una maggiore flessibilità con le tue opzioni di consegna. però

Crea file di scambio su FreeBSD 10

Crea file di scambio su FreeBSD 10

Immediatamente, i server Vultr FreeBSD non sono configurati per includere lo spazio di scambio. Se la tua intenzione è per unistanza cloud usa e getta, probabilmente non ne hai bisogno

Come ridimensionare un disco in FreeBSD

Come ridimensionare un disco in FreeBSD

Il sistema operativo FreeBSD utilizza UFS (Unix File System) per il suo file system delle partizioni di root; altrimenti noto come freebsd-ufs In caso di aggiornamento

Come installare Flarum Forum su FreeBSD 12

Come installare Flarum Forum su FreeBSD 12

Usi un sistema diverso? Flarum è un software di forum di prossima generazione gratuito e open source che rende divertente la discussione online. Il codice sorgente di Flarum è ospitato o

Come installare Selfoss RSS Reader su un FPS VPS di FreeBSD 11

Come installare Selfoss RSS Reader su un FPS VPS di FreeBSD 11

Usi un sistema diverso? Selfoss RSS Reader è un reade self-hosted gratuito e open source basato su Web, streaming live, mashup, feed di notizie (RSS / Atom)

Come installare Craft CMS su FreeBSD 12

Come installare Craft CMS su FreeBSD 12

Usi un sistema diverso? Introduzione Craft CMS è un CMS open source scritto in PHP. Il codice sorgente di Craft CMS è ospitato su GitHub. Questa guida ti mostrerà

Come installare il forum NodeBB su FreeBSD 12

Come installare il forum NodeBB su FreeBSD 12

Usi un sistema diverso? NodeBB è un software per forum basato su Node.js. Utilizza socket Web per interazioni istantanee e notifiche in tempo reale. Il nodo B

Installa eSpeak su FreeBSD 12

Installa eSpeak su FreeBSD 12

Usi un sistema diverso? ESpeak può generare file audio di sintesi vocale (TTS). Questi possono essere utili per molte ragioni, come la creazione della tua Torino

Come installare LimeSurvey CE su FreeBSD 12

Come installare LimeSurvey CE su FreeBSD 12

Usi un sistema diverso? LimeSurvey è un software di sondaggio open source scritto in PHP. Il codice sorgente di LimeSurvey è ospitato su GitHub. Questa guida ti mostrerà

Come installare ProcessWire CMS 3.0 su un VPS FAMP di FreeBSD 11

Come installare ProcessWire CMS 3.0 su un VPS FAMP di FreeBSD 11

Usi un sistema diverso? ProcessWire CMS 3.0 è un sistema di gestione dei contenuti (CMS) semplice, flessibile e potente, gratuito e open source. ProcessWire CMS 3.

Lintelligenza artificiale può combattere con un numero crescente di attacchi ransomware?

Lintelligenza artificiale può combattere con un numero crescente di attacchi ransomware?

Gli attacchi ransomware sono in aumento, ma l'intelligenza artificiale può aiutare ad affrontare l'ultimo virus informatico? L'intelligenza artificiale è la risposta? Leggi qui sai è AI boone o bane

ReactOS: è questo il futuro di Windows?

ReactOS: è questo il futuro di Windows?

ReactOS, un sistema operativo open source e gratuito è qui con l'ultima versione. Può essere sufficiente alle esigenze degli utenti Windows moderni e abbattere Microsoft? Scopriamo di più su questo vecchio stile, ma un'esperienza del sistema operativo più recente.

Rimani connesso tramite lapp desktop WhatsApp 24*7

Rimani connesso tramite lapp desktop WhatsApp 24*7

Whatsapp ha finalmente lanciato l'app desktop per utenti Mac e Windows. Ora puoi accedere facilmente a Whatsapp da Windows o Mac. Disponibile per Windows 8+ e Mac OS 10.9+

In che modo lintelligenza artificiale può portare lautomazione dei processi al livello successivo?

In che modo lintelligenza artificiale può portare lautomazione dei processi al livello successivo?

Leggi questo per sapere come l'intelligenza artificiale sta diventando popolare tra le aziende di piccole dimensioni e come sta aumentando le probabilità di farle crescere e dare un vantaggio ai loro concorrenti.

Laggiornamento del supplemento macOS Catalina 10.15.4 sta causando più problemi che risolverli

Laggiornamento del supplemento macOS Catalina 10.15.4 sta causando più problemi che risolverli

Recentemente Apple ha rilasciato macOS Catalina 10.15.4 un aggiornamento supplementare per risolvere i problemi, ma sembra che l'aggiornamento stia causando più problemi che portano al bricking delle macchine mac. Leggi questo articolo per saperne di più

13 strumenti commerciali per lestrazione dei dati dai Big Data

13 strumenti commerciali per lestrazione dei dati dai Big Data

13 strumenti commerciali per l'estrazione dei dati dai Big Data

Che cosè un file system di journaling e come funziona?

Che cosè un file system di journaling e come funziona?

Il nostro computer memorizza tutti i dati in un modo organizzato noto come file system di journaling. È un metodo efficiente che consente al computer di cercare e visualizzare i file non appena si preme search.https://wethegeek.com/?p=94116&preview=true

Singolarità tecnologica: un lontano futuro della civiltà umana?

Singolarità tecnologica: un lontano futuro della civiltà umana?

Man mano che la scienza si evolve a un ritmo rapido, assumendo gran parte dei nostri sforzi, aumentano anche i rischi di sottoporci a una singolarità inspiegabile. Leggi, cosa potrebbe significare per noi la singolarità.

Uno sguardo a 26 tecniche di analisi dei Big Data: Parte 1

Uno sguardo a 26 tecniche di analisi dei Big Data: Parte 1

Uno sguardo a 26 tecniche di analisi dei Big Data: Parte 1

Limpatto dellintelligenza artificiale nella sanità 2021

Limpatto dellintelligenza artificiale nella sanità 2021

L'intelligenza artificiale nell'assistenza sanitaria ha compiuto grandi passi avanti negli ultimi decenni. Pertanto, il futuro dell'IA in sanità continua a crescere giorno dopo giorno.