Осигуряване и втвърдяване на ядрото на CentOS 7 със Sysctl

Въведение

Sysctlпозволява на потребителя фина настройка на ядрото, без да се налага да го изгражда отново. Той също така ще приложи промените незабавно, така че сървърът няма да се налага да се рестартира, за да влязат в сила промените. Този урок предоставя кратко въведение sysctlи демонстрира как да го използвате за настройване на специфични части от ядрото на Linux.

Команди

За да започнете да използвате sysctl, прегледайте параметрите и примерите, изброени по-долу.

Параметри

-a : Това ще покаже всички стойности, налични в момента в конфигурацията на sysctl.

-A : Това ще покаже всички стойности, налични в момента в конфигурацията на sysctl, под формата на таблица.

-e : Тази опция ще игнорира грешки за неизвестни ключове.

-p : Използва се за зареждане на конкретна sysctl конфигурация, по подразбиране ще се използва/etc/sysctl.conf

-n : Тази опция ще забрани показването на имената на ключовете при разпечатване на стойностите.

-w : Тази опция е за промяна (или добавяне) на стойности към sysctl при поискване.

Примери

$ sysctl -a
$ sysctl -n fs.file-max
$ sysctl -w fs.file-max=2097152
$ sysctl -p

Така че първо проверяваме стойностите по подразбиране. Ако вашият /etc/sysctl.confе празен, той ще покаже всички ключове и стойности по подразбиране. Второ, ние проверяваме каква е стойността на fs.file-maxи след това задаваме новата стойност на 2097152. Накрая зареждаме новия /etc/sysctl.confконфигурационен файл.

Ако търсите допълнителна помощ, можете да използвате man sysctl.

Осигуряване и втвърдяване на ядрото

За да направим промените постоянни, ще трябва да добавим тези стойности към конфигурационен файл. Използвайте конфигурационния файл, който CentOS предоставя по подразбиране, /etc/sysctl.conf.

Отворете файла с любимия си редактор.

По подразбиране трябва да видите нещо подобно на това.

# sysctl settings are defined through files in
# /usr/lib/sysctl.d/, /run/sysctl.d/, and /etc/sysctl.d/.
#
# Vendors settings live in /usr/lib/sysctl.d/.
# To override a whole file, create a new file with the same in
# /etc/sysctl.d/ and put new settings there. To override
# only specific settings, add a file with a lexically later
# name in /etc/sysctl.d/ and put new settings there.
#
# For more information, see sysctl.conf(5) and sysctl.d(5).

Нека първо подобрим управлението на системната памет.

Ще намалим до минимум количеството размяна, което трябва да направим, ще увеличим размера на манипулаторите на файлове и кеша на inode и ще ограничим изхвърлянията на ядрото.

# Minimizing the amount of swapping
vm.swappiness = 20
vm.dirty_ratio = 80
vm.dirty_background_ratio = 5

# Increases the size of file handles and inode cache & restricts core dumps
fs.file-max = 2097152
fs.suid_dumpable = 0

След това нека настроим оптимизираната производителност на мрежата.

Ще променим размера на входящите връзки и изоставането на входящите връзки, ще увеличим максималното количество буфери на паметта и ще увеличим буферите по подразбиране и максимални буфери за изпращане/получаване.

# Change the amount of incoming connections and incoming connections backlog
net.core.somaxconn = 65535
net.core.netdev_max_backlog = 262144

# Increase the maximum amount of memory buffers
net.core.optmem_max = 25165824

# Increase the default and maximum send/receive buffers
net.core.rmem_default = 31457280
net.core.rmem_max = 67108864
net.core.wmem_default = 31457280
net.core.wmem_max = 67108864

И накрая, ще подобрим общата сигурност на мрежата.

Ще активираме TCP SYN защита на бисквитките, защита от IP спуфинг, игнориране на ICMP заявки, игнориране на заявки за излъчване и регистриране на подправени пакети, пренасочени към източник пакети и пренасочващи пакети. Заедно с това ще деактивираме маршрутизирането на IP източник и приемането на ICMP пренасочване.

# Enable TCP SYN cookie protection
net.ipv4.tcp_syncookies = 1

# Enable IP spoofing protection
net.ipv4.conf.all.rp_filter = 1

# Enable ignoring to ICMP requests and broadcasts request
net.ipv4.icmp_echo_ignore_all = 1
net.ipv4.icmp_echo_ignore_broadcasts = 1

# Enable logging of spoofed packets, source routed packets and redirect packets
net.ipv4.conf.all.log_martians = 1

# Disable IP source routing
net.ipv4.conf.all.accept_source_route = 0

# Disable ICMP redirect acceptance
net.ipv4.conf.all.accept_redirects = 0

Запазете и затворете файла и след това заредете файла с помощта на sysctl -pкомандата.

Заключение

В крайна сметка вашият файл трябва да изглежда подобно на този.

# sysctl settings are defined through files in
# /usr/lib/sysctl.d/, /run/sysctl.d/, and /etc/sysctl.d/.
#
# Vendors settings live in /usr/lib/sysctl.d/.
# To override a whole file, create a new file with the same in
# /etc/sysctl.d/ and put new settings there. To override
# only specific settings, add a file with a lexically later
# name in /etc/sysctl.d/ and put new settings there.
#
# For more information, see sysctl.conf(5) and sysctl.d(5).

# Minimizing the amount of swapping
vm.swappiness = 20
vm.dirty_ratio = 80
vm.dirty_background_ratio = 5

# Increases the size of file handles and inode cache & restricts core dumps
fs.file-max = 2097152
fs.suid_dumpable = 0

# Change the amount of incoming connections and incoming connections backlog
net.core.somaxconn = 65535
net.core.netdev_max_backlog = 262144

# Increase the maximum amount of memory buffers
net.core.optmem_max = 25165824

# Increase the default and maximum send/receive buffers
net.core.rmem_default = 31457280
net.core.rmem_max = 67108864
net.core.wmem_default = 31457280
net.core.wmem_max = 67108864

# Enable TCP SYN cookie protection
net.ipv4.tcp_syncookies = 1

# Enable IP spoofing protection
net.ipv4.conf.all.rp_filter = 1

# Enable ignoring to ICMP requests and broadcasts request
net.ipv4.icmp_echo_ignore_all = 1
net.ipv4.icmp_echo_ignore_broadcasts = 1

# Enable logging of spoofed packets, source routed packets and redirect packets
net.ipv4.conf.all.log_martians = 1

# Disable IP source routing
net.ipv4.conf.all.accept_source_route = 0

# Disable ICMP redirect acceptance
net.ipv4.conf.all.accept_redirects = 0

Увеличете производителността със Z и Zsh на CentOS

Увеличете производителността със Z и Zsh на CentOS

Въведение Работата в Linux системи означава, че човек използва командния ред по-често, отколкото не. Трябва да въвеждате дълги имена на директории отново и отново

Настройте RethinkDB Cluster на CentOS 7

Настройте RethinkDB Cluster на CentOS 7

Въведение RethinkDB е NoSQL база данни, която съхранява данни като JSON документи. Той има супер интуитивен език за заявки и има общодостъпни функции i

Инсталирайте DirectAdmin на CentOS 6 или 7

Инсталирайте DirectAdmin на CentOS 6 или 7

DirectAdmin е собствен уеб-базиран контролен панел, който можете да инсталирате на вашия сървър, който предлага разнообразие от функции за системно администриране. В това

Преглед на процеса на зареждане на CentOS 7 и RHEL 7 и отстраняване на неизправности

Преглед на процеса на зареждане на CentOS 7 и RHEL 7 и отстраняване на неизправности

Тази статия описва процеса на зареждане за системи CentOS/RHEL 7.x. Въпреки че може да остане подобен на предишните издания, с RHEL 7, systemd е в сила

Инсталирайте PostgreSQL на CentOS 7

Инсталирайте PostgreSQL на CentOS 7

Въведение PostgreSQL е най-модерната система за управление на релационни бази данни с отворен код (RDBMS). Той е съвместим със стандартите ANSI SQL:2008

Основи на управлението на потребители на CentOS системи

Основи на управлението на потребители на CentOS системи

Управлението на потребителите може да бъде трудна задача: от ежедневна поддръжка, рискове за сигурността и липса на задълбочена онлайн документация. Тази статия ще ви помогне да започнете

Първоначална настройка на сървър CentOS 7

Първоначална настройка на сървър CentOS 7

Въведение Новоактивиран сървър CentOS 7 трябва да бъде персонализиран, преди да може да се използва като производствена система. В тази статия най-важното

Проверете скоростта на интернет със Speedtest-cli на CentOS

Проверете скоростта на интернет със Speedtest-cli на CentOS

Въведение В този урок добре инсталирайте Speedtest-cli, за да тествате скоростта на мрежата на вашия сървър. Speedtest-cli е интерфейс на командния ред за th

Инсталирайте GUI среда на CentOS 6

Инсталирайте GUI среда на CentOS 6

Управлението на вашия сървър само с SSH може да бъде плашещо. Хубавото за нас е, че Vultr има опция View Console. За да използвате напълно Vultrs VNC конзола

Настройте часова зона и NTP на CentOS 6

Настройте часова зона и NTP на CentOS 6

Въведение За администраторите на сървъри е важно да задават и поддържат правилно времето на сървърите. Неправилно конфигурирано време ще предизвика хаос в рамките на th

Как да инсталирате Foreman на CentOS 7

Как да инсталирате Foreman на CentOS 7

Използване на различна система? Foreman е безплатен инструмент с отворен код, който ви помага с конфигурирането и управлението на физически и виртуални сървъри. Forema

Осигуряване и втвърдяване на ядрото на CentOS 7 със Sysctl

Осигуряване и втвърдяване на ядрото на CentOS 7 със Sysctl

Въведение Sysctl позволява на потребителя фина настройка на ядрото, без да се налага да го изгражда отново. Той също така ще приложи промените незабавно, като по този начин сървърът спечели

Използвайте Nethogs за наблюдение на използването на мрежовата честотна лента

Използвайте Nethogs за наблюдение на използването на мрежовата честотна лента

В този урок ще покрием процеса на инсталиране и използване на nethogs на CentOS 6x x64. nethogs е инструмент за наблюдение на мрежата, който позволява Networ

Инсталирайте CentOS Web Panel (CWP) на CentOS 6

Инсталирайте CentOS Web Panel (CWP) на CentOS 6

CentOS Web Panel или CWP е хостинг контролен панел с отворен код, който е предназначен за бързо и лесно управление на сървър. Той включва всички функции o

Настройте Zarafa и Yaffas на CentOS 6

Настройте Zarafa и Yaffas на CentOS 6

Има много решения, които заменят Microsoft Exchange с решение за Linux, но всички те имаха един проблем, който наистина не ми хареса. Когато получавам

Как да инсталирате и конфигурирате Concourse CI на CentOS 7

Как да инсталирате и конфигурирате Concourse CI на CentOS 7

Използване на различна система? Въведение Непрекъснатата интеграция е практика за разработка на софтуер DevOps, която позволява на разработчиците често да обединяват

Внедряване на Glowing Bear Backend сървър на CentOS 7

Внедряване на Glowing Bear Backend сървър на CentOS 7

Glowing Bear е уеб интерфейс за WeeChat IRC клиента и се стреми да бъде модерен интерфейс. Със своите функции като щракване за споменаване, заместване на емоджита

Как да надстроите CentOS 6 до CentOS 7

Как да надстроите CentOS 6 до CentOS 7

Как да надстроите CentOS 6 до CentOS 7

Защитете TMP и TMPFS на CentOS 6

Защитете TMP и TMPFS на CentOS 6

Временни директории като /tmp, /var/tmp и /dev/shm предлагат платформа за хакери да изпълняват скриптове и програми. Тези злонамерени изпълними файлове се използват t

Активирайте EPEL на CentOS

Активирайте EPEL на CentOS

Фон Fedoras Extra Packages for Enterprise Linux (EPEL) хранилище предоставя възможност за инсталиране на софтуерни пакети, които не са включени в

Възходът на машините: Реални приложения на AI

Възходът на машините: Реални приложения на AI

Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.

DDOS атаки: кратък преглед

DDOS атаки: кратък преглед

Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.

Чудили ли сте се как хакерите печелят пари?

Чудили ли сте се как хакерите печелят пари?

Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.

Революционни изобретения на Google, които ще улеснят живота ви.

Революционни изобретения на Google, които ще улеснят живота ви.

Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.

Еволюция на съхранението на данни – инфографика

Еволюция на съхранението на данни – инфографика

Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.

Функционалности на референтните архитектурни слоеве за големи данни

Функционалности на референтните архитектурни слоеве за големи данни

Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече