linux系统安装后的优化操作

简介: 系统安装后需进行初始化配置、安全加固和参数调优。先分析后脚本部署应用组件后根据组件不同调整

**生产环境中的使用原则:系统安装的应用程序包越少,服务器就越稳定。**

*基础优化*

1. 配置网络自启动

cat > /etc/sysconfig/network-scripts/ifcfg-eth0 <<EOF
DEVICE=eth0
BOOTPROTO=static
IPV6INIT=no
IPV6_AUTOCONF=yesONBOOT=yesIPADDR=172.16.10.10
NETMASK=255.255.255.0
GATEWAY=172.16.10.254
TYPE=Ethernet
PEERDNS=yes# 允许DHCP获得的dns覆盖本地的DNSUSERCTL=no  # 不允许普通用户修改网卡EOF
cat >> /etc/resolv.conf << EOF
nameserver 114.114.114.114
EOF

2. 更新yum源为国内镜像 (要求可连接公网,内网可配置内部源)

#Yum源更换为国内阿里源yum install wgettelnet-ymv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget-O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
wget-O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
rpm -ivh http://dl.Fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-8.noarch.rpm
#yum重新建立缓存yum clean all && yum makecache


3. 关闭不必要的服务

for serv in` systemctl list-unit-files | grep enabled|awk '{print $1}'`;do systemctl disable $serv ;done
for serv in autovt@.service crond.service getty@.service irqbalance.service kdump.service microcode.service rsyslog.service sshd.service sysstat.service systemd-readahead-collect.service systemd-readahead-drop.service systemd-readahead-replay.service tuned.service lvm2-lvmetad.socket lvm2-lvmpolld.socket default.target multi-user.target runlevel2.target runlevel3.target runlevel4.target ;do systemctl enable $serv;done


4. 关闭防火墙和selinux

systemctl disable firewalld
sed-i's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config

5. 修改history记录

sed-i's@^HISTSIZE=1000@HISTSIZE=100@' /etc/profile
sed-i'/^HISTSIZE/a\HISTTIMEFORMAT="%F %T `whoami` "' /etc/profile


6. 定时同步服务器时间(要求可联网,或配置内网web为时间服务器)

yum -y install ntp
/usr/sbin/ntpdate cn.pool.ntp.org
echo"* 4 * * * /usr/sbin/ntpdate cn.pool.ntp.org > /dev/null 2>&1" >> /var/spool/cron/root
systemctl  restart crond.service


7. 关闭IPv6网络(当前部分环境要求适配IPv6不选)

sed-i's@GRUB_CMDLINE_LINUX="@GRUB_CMDLINE_LINUX="ipv6.disable=1 @' /etc/default/grub
grub2-mkconfig -o /boot/grub2/grub.cfg
cat >> /etc/sysctl.conf << EOF
net.ipv6.conf.all.disable_ipv6 =1net.ipv6.conf.default.disable_ipv6 =1EOF
/sbin/sysctl -p


8. 调整最大文件打开数

echo"ulimit -SHn 102400" >> /etc/rc.local
cat >> /etc/security/limits.conf << EOF
*           soft   nofile       655350*           hard   nofile       655350EOF


9. 关闭磁盘I/O功能(分布式存储磁盘建议可选)

#原理:存放多个小文件的目录无需记录访问时间atime,关闭以减少写磁盘I/Oecho"dev/sdb1 /bigData                   xfs     noatime,nodiratime        0 0" >> /etc/fstab


10. 增加sudo权限用户(前提用户已存在)

#原理:给一个本地已有用户授权不输密码即可sudo权限操作sed-i'/^root/a\dengzz ALL=(ALL) NOPASSWD:ALL' /etc/sudoers


11. 修改SSH登录配置

#原理:关闭GSSAPI反解析关闭SSH反向查询解决连接慢;禁止root远程登录禁止空密码登录提高安全性sed-i's/^GSSAPIAuthentication yes$/GSSAPIAuthentication no/' /etc/ssh/sshd_config
sed-i's@#PermitRootLogin yes@PermitRootLogin no@' /etc/ssh/sshd_config
sed-i's@#PermitEmptyPasswords no@PermitEmptyPasswords no@' /etc/ssh/sshd_config
sed-i's/#UseDNS yes/UseDNS no/' /etc/ssh/sshd_config
systemctl  restart sshd

12.修改字符集

# 设置为中文localectl set-locale LANG=zh_CN.UTF-8
source /etc/locale.conf
# 设置为英文localectl set-locale LANG=en_US.utf8
source /etc/locale.conf
# 查看当前字符集echo$LANG


*系统性能*

13.内核参数(部署应用不同优化不同)

# 注意CentOS 6 中,配置文件参数都在这个文件中;CentOS7中,可以配置参数在该文件中,也可以根据提示将参数配置在其他文件中。cat >> /etc/sysctl.conf << EOF
# 值为0,说明禁止进行IP转发;如果是1,则说明IP转发功能已经打开net.ipv4.ip_forward =0# 多网卡接收多播net.ipv4.conf.default.rp_filter =1net.ipv4.conf.default.accept_source_route =0# 验证设置kernel.sysrq =0kernel.core_uses_pid =1# 开启SYN Cookies,当出现SYN 等待队列溢出时,启用cookies 来处理,开启也就不需要维护半开连接状态了,进而也就没有了半连接数的限制。net.ipv4.tcp_max_syn_backlog失效net.ipv4.tcp_syncookies =1# 确定一个消息队列的容量。该参数的取值存储在消息队列标识符结构的某个域中,用于确定是否存在着对新消息进行排队的空间。msgmnb 值可以动态修改,默认为16384。修改其取值会影响到所有新的消息队列的容量。用户可以通过 Msgctl()系统调用来增加现有消息队列的容量kernel.msgmnb =65536# 限制进程可以发送的消息长度。该参数由 Msgsnd()函数加以应用。如果待发送消息的长度超过该值,则返回一个错误。该参数可以在运行时调整kernel.msgmax =65536# 最大共享内存段大小。取物理内存大小的一半,单位为字节(此处为8G)kernel.shmmax =8589934592# 整个系统共享内存段的最大数目kernel.shmmni =4096# 可以使用的共享内存的总量kernel.shmall =4294967296# 每个信号对象集的最大信号对象数;系统范围内最大信号对象数;每个信号对象支持的最大操作数;系统范围内最大信号对象集数kernel.sem =25032000100128# timewait 的数量,默认是180000net.ipv4.tcp_max_tw_buckets =204800# web 应用中listen 函数的backlog 默认会给我们内核参数的net.core.somaxconn 限制到128,而nginx 定义的NGX_LISTEN_BACKLOG 默认为511,所以有必要调整这个值net.core.somaxconn =262144# 该参数标识是否启用选择性确认SACKS选项。默认值为1(true)net.ipv4.tcp_sack =1# 设置tcp/ip会话的滑动窗口大小是否可变。参数值为布尔值,为1时表示可变,为0时表示不可变。tcp/ip通常使用的窗口最大可达到 65535 字节,对于高速网络,该值可能太小,这时候如果启用了该功能,可以使tcp/ip滑动窗口大小增大数个数量级,从而提高数据传输的能力net.ipv4.tcp_window_scaling =1# tcp_rmem:min表示为TCP socket预留用于接收缓冲的最小内存数量,default为TCP socket预留用于接收缓冲的缺省内存数量,max用于TCP socket接收缓冲的内存最大值net.ipv4.tcp_rmem =4096873804194304# tcp_wmem:min表示为TCP socket预留用于发送缓冲的内存最小值,default为TCP socket预留用于发送缓冲的缺省内存值,max用于TCP socket发送缓冲的内存最大值net.ipv4.tcp_wmem =4096163844194304# 系统套接字写默认缓冲区net.core.wmem_default =8388608# 系统套接字读默认缓冲区net.core.rmem_default =8388608# 系统套接字读最大缓冲区net.core.rmem_max =16777216# 系统套接字写最大缓冲区net.core.wmem_max =16777216# 每个网络接口接收数据包的速率比内核处理这些包的速率快时,允许送到队列的数据包的最大数目net.core.netdev_max_backlog =262144# 统中最多有多少个TCP 套接字不被关联到任何一个用户文件句柄上。如果超过这个数字,孤儿连接将即刻被复位并打印出警告信息。这个限制仅仅是为了防止简单的DoS 攻击,不能过分依靠它或者人为地减小这个值,更应该增加这个值(如果增加了内存之后)net.ipv4.tcp_max_orphans =3276800# 记录的那些尚未收到客户端确认信息的连接请求的最大值。对于有128M 内存的系统而言,缺省值是1024,小内存的系统则是128,调大这个值可以预防遭到DoS攻击时无法建立ssh远程登录连接net.ipv4.tcp_max_syn_backlog =262144# 时间戳可以避免序列号的卷绕。一个1Gbps 的链路肯定会遇到以前用过的序列号。时间戳能够让内核接受这种“异常”的数据包。这里需要将其关掉net.ipv4.tcp_timestamps =0# 为了打开对端的连接,内核需要发送一个SYN 并附带一个回应前面一个SYN 的ACK。也就是所谓三次握手中的第二次握手。这个设置决定了内核放弃连接之前发送SYN+ACK 包的数量net.ipv4.tcp_synack_retries =1# 在内核放弃建立连接之前发送SYN包的数量,内核默认重试5次net.ipv4.tcp_syn_retries =1# 启用timewait 快速回收net.ipv4.tcp_tw_recycle =1# 开启重用。允许将TIME-WAIT sockets 重新用于新的TCP 连接net.ipv4.tcp_tw_reuse =1# 确定 TCP 栈应该如何反映内存使用;每个值的单位都是内存页(通常是 4KB)net.ipv4.tcp_mem =94500000915000000927000000# 如果套接字由本端要求关闭,这个参数决定了它保持在FIN-WAIT-2 状态的时间。对端可以出错并永远不关闭连接,甚至意外当机。缺省值是60 秒。2.2 内核的通常值是180 秒,3你可以按这个设置,但要记住的是,即使你的机器是一个轻载的WEB 服务器,也有因为大量的死套接字而内存溢出的风险,FIN- WAIT-2 的危险性比FIN-WAIT-1 要小,因为它最多只能吃掉1.5K 内存,但是它们的生存期长些net.ipv4.tcp_fin_timeout =15# 当keepalive 起用的时候,TCP 发送keepalive 消息的频度。缺省是2 小时net.ipv4.tcp_keepalive_time =15# 允许系统打开的端口范围net.ipv4.ip_local_port_range =102465000# 系统中所允许的文件句柄最大数目fs.file-max =204800# 禁用ICMP协议(可选)net.ipv4.icmp_echo_ignore_all =1EOF
/sbin/sysctl -preboot
目录
相关文章
|
5天前
|
算法 Linux 调度
深入理解Linux内核调度器:从基础到优化####
本文旨在通过剖析Linux操作系统的心脏——内核调度器,为读者揭开其高效管理CPU资源的神秘面纱。不同于传统的摘要概述,本文将直接以一段精简代码片段作为引子,展示一个简化版的任务调度逻辑,随后逐步深入,详细探讨Linux内核调度器的工作原理、关键数据结构、调度算法演变以及性能调优策略,旨在为开发者与系统管理员提供一份实用的技术指南。 ####
24 4
|
8天前
|
缓存 资源调度 安全
深入探索Linux操作系统的心脏——内核配置与优化####
本文作为一篇技术性深度解析文章,旨在引领读者踏上一场揭秘Linux内核配置与优化的奇妙之旅。不同于传统的摘要概述,本文将以实战为导向,直接跳入核心内容,探讨如何通过精细调整内核参数来提升系统性能、增强安全性及实现资源高效利用。从基础概念到高级技巧,逐步揭示那些隐藏在命令行背后的强大功能,为系统管理员和高级用户打开一扇通往极致性能与定制化体验的大门。 --- ###
29 9
|
8天前
|
算法 Unix Linux
深入理解Linux内核调度器:原理与优化
本文探讨了Linux操作系统的心脏——内核调度器(Scheduler)的工作原理,以及如何通过参数调整和代码优化来提高系统性能。不同于常规摘要仅概述内容,本摘要旨在激发读者对Linux内核调度机制深层次运作的兴趣,并简要介绍文章将覆盖的关键话题,如调度算法、实时性增强及节能策略等。
|
11天前
|
机器学习/深度学习 负载均衡 算法
深入探索Linux内核调度机制的优化策略###
本文旨在为读者揭开Linux操作系统中至关重要的一环——CPU调度机制的神秘面纱。通过深入浅出地解析其工作原理,并探讨一系列创新优化策略,本文不仅增强了技术爱好者的理论知识,更为系统管理员和软件开发者提供了实用的性能调优指南,旨在促进系统的高效运行与资源利用最大化。 ###
|
10天前
|
监控 网络协议 算法
Linux内核优化:提升系统性能与稳定性的策略####
本文深入探讨了Linux操作系统内核的优化策略,旨在通过一系列技术手段和最佳实践,显著提升系统的性能、响应速度及稳定性。文章首先概述了Linux内核的核心组件及其在系统中的作用,随后详细阐述了内存管理、进程调度、文件系统优化、网络栈调整及并发控制等关键领域的优化方法。通过实际案例分析,展示了这些优化措施如何有效减少延迟、提高吞吐量,并增强系统的整体健壮性。最终,文章强调了持续监控、定期更新及合理配置对于维持Linux系统长期高效运行的重要性。 ####
|
10天前
|
安全 网络协议 Linux
Linux操作系统的内核升级与优化策略####
【10月更文挑战第29天】 本文深入探讨了Linux操作系统内核升级的重要性,并详细阐述了一系列优化策略,旨在帮助系统管理员和高级用户提升系统的稳定性、安全性和性能。通过实际案例分析,我们展示了如何安全有效地进行内核升级,以及如何利用调优技术充分发挥Linux系统的潜力。 ####
30 1
|
13天前
|
人工智能 算法 大数据
Linux内核中的调度算法演变:从O(1)到CFS的优化之旅###
本文深入探讨了Linux操作系统内核中进程调度算法的发展历程,聚焦于O(1)调度器向完全公平调度器(CFS)的转变。不同于传统摘要对研究背景、方法、结果和结论的概述,本文创新性地采用“技术演进时间线”的形式,简明扼要地勾勒出这一转变背后的关键技术里程碑,旨在为读者提供一个清晰的历史脉络,引领其深入了解Linux调度机制的革新之路。 ###
|
25天前
|
关系型数据库 MySQL Linux
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
207 3
|
29天前
|
监控 Linux 云计算
Linux操作系统在云计算环境中的实践与优化###
【10月更文挑战第16天】 本文探讨了Linux操作系统在云计算环境中的应用实践,重点分析了其在稳定性、安全性和高效性方面的优势。通过具体案例,阐述了Linux如何支持虚拟化技术、实现资源高效分配以及与其他开源技术的无缝集成。文章还提供了针对Linux系统在云计算中的优化建议,包括内核参数调整、文件系统选择和性能监控工具的应用,旨在帮助读者更好地理解和应用Linux于云计算场景。 ###
36 3
|
3月前
|
监控 算法 网络协议
在Linux中,如何进行网络资源的优化?
在Linux中,如何进行网络资源的优化?