干货!超实用的 Linux 初始化脚本!

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 咸鱼今天给大家分享一个无论是学习还是工作中都很实用的 Linux 系统初始化脚本,其实就是各种命令的集合。完整代码在文章最后哦
  • 定义相关变量
#环境变量
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin
export PATH

#当前时间
current_time=$(date +%Y%m%d)

#阿里的DNS
dns_server=223.5.5.5 
  • 配置 yum 镜像源
if [[ ! -z `uname -r|grep 'el6'` ]]
    then
    kernel_version=el6
    yum_repo=http://mirrors.aliyun.com/repo/Centos-6.repo
elif [[ ! -z `uname -r|grep 'el7'` ]]
    then
    kernel_version=el7
    yum_repo=http://mirrors.aliyun.com/repo/Centos-7.repo
else
    echo -e "\e[31mUnidentified Kernel version: $(uname -r). Only support for kernel el6/el7\e[0m"
    exit
fi
  • 获取阿里云 yum 镜像源
function add_yum_repo(){
    local item="Add Aliyun Yum Mirrors"
    yum clean all
    cp /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.${current_time} && \
    curl -o /etc/yum.repos.d/CentOS-Base.repo ${yum_repo} > /dev/null 2>&1
    show_result $? "${item}"
    yum makecache
}
  • 判断函数是否执行成功
function show_result(){
    if [ "$1" -eq 0 ]
        then
            echo -e "\e[32m$2 is Success .   [ OK ] \e[0m"
        else
            echo -e "\e[31m$2 is Fail .   [ FAIL ] \e[0m"
    fi
}
  • 写入一行配置
function add_newconfig(){
    local SearchResult=`grep "$1" "$2"`
    if [ -z "${SearchResult}" ]
        then
        echo "$1" >> $2
    fi
}
  • 修改配置
function add_config(){
    local keywords=`echo $1| awk -F "[= ]+" '{print $1}'`
    local SearchResult=`grep "^${keywords}" "$2"`
    if [ -z "${SearchResult}" ] #空为真,非空为假
        then
        echo $1 >> $2
    else
        sed -i "s/^${keywords}.*/$1/" $2
    fi
}
  • 配置系统时区
function config_localtime(){
    local item="Config SH As Location"
    rm -f /etc/localtime
    ln -s  /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    show_result $? "${item}"
}
  • 配置 dns 服务器
function config_dns_addr(){
    local item="Config DNS Address"
    cp /etc/resolv.conf /etc/resolv.conf.${current_time} && \
    echo "nameserver ${dns_server}" > /etc/resolv.conf
    show_result $? "${item}"
}
  • 修改最大文件描述符限制
function maximum_file_dspt(){
    local item="Maximum File Descriptor"
    cp /etc/security/limits.conf /etc/security/limits.conf.${current_time} && \
    echo "*           soft    nofile          100000
*           hard    nofile          100000
*           soft    nproc           65535
*           hard    nproc           65535
*           soft    core            unlimited
*           hard    core            unlimited" > /etc/security/limits.conf
    show_result $? "${item}"
}
  • 关闭系统不需要的服务
function shutdown_nonuse_srv(){
    local item="Shutdown Unused Services"
    if [[ "${kernel_version}" == el6 ]]
            then
        for i in `chkconfig --list | awk '{print $1}'`
            do
            chkconfig --level 2345 $i off > /dev/null 2>&1
            done
        for ii in crond network rsyslog sshd sysstat haldaemon
            do
            chkconfig --level 2345 $ii on > /dev/null 2>&1
            done
        show_result $? "${item}"
    elif [[ "${kernel_version}" == el7 ]]
        then
        systemctl disable postfix > /dev/null 2>&1
        show_result $? "${item}"
    else
        echo -e "\e[31mUnidentified Kernel version: $(uname -r). Only support for kernel el6/el7\e[0m"
    fi
}
  • 内核参数优化相关
function optimize_kel_args(){
    local item="Optimize Kernel Arguments"
    cp /etc/sysctl.conf /etc/sysctl.conf.${current_time} > /dev/null 2>&1
    arch_ratio=$([[ ! -z $(uname -a | grep x86_64) ]] && expr 64 / 32 || expr 32 / 32)
    memory_size=$(free -b| awk 'NR==2{print $2}')
    nf_conntrack_size=$(expr ${memory_size} / 16384 / ${arch_ratio})
    #开启反向路径过滤
    add_config "net.ipv4.conf.default.rp_filter = 1" /etc/sysctl.conf
    add_config "net.ipv4.conf.all.rp_filter = 1" /etc/sysctl.conf
    #处理无源路由包
    add_config "net.ipv4.conf.all.accept_source_route = 0" /etc/sysctl.conf
    add_config "net.ipv4.conf.default.accept_source_route = 0" /etc/sysctl.conf
    #core文件名中添加pid作为扩展名
    add_config "kernel.core_uses_pid = 1" /etc/sysctl.conf
    #开启syn洪水攻击保护
    add_config "net.ipv4.tcp_syncookies = 1" /etc/sysctl.conf
    #修改消息队列长度
    add_config "kernel.msgmnb = 65536" /etc/sysctl.conf
    add_config "kernel.msgmax = 65536" /etc/sysctl.conf
    #修改最大内存共享段大小bytes
    add_config "kernel.shmmax = 68719476736" /etc/sysctl.conf
    add_config "kernel.shmall = 4294967296" /etc/sysctl.conf
    #timewait数量默认18000
    add_config "net.ipv4.tcp_max_tw_buckets = 600" /etc/sysctl.conf
    add_config "net.ipv4.tcp_sack = 1" /etc/sysctl.conf
    add_config "net.ipv4.tcp_window_scaling = 1" /etc/sysctl.conf
    add_config "net.ipv4.tcp_rmem = 4096 87380 16777216" /etc/sysctl.conf
    add_config "net.ipv4.tcp_wmem = 4096 65536 16777216" /etc/sysctl.conf
    add_config "net.core.rmem_default = 8388608" /etc/sysctl.conf
    add_config "net.core.wmem_max = 16777216" /etc/sysctl.conf
    #未收到客户端确认信息连接请求的最大值
    add_config "net.ipv4.tcp_max_syn_backlog = 262144" /etc/sysctl.conf
    #放弃建立连接之前发送的synack包
    add_config "net.ipv4.tcp_syn_retries = 2" /etc/sysctl.conf
    #开启重用,允许time—wait socket 重新用语新的tcp连接
    add_config "net.ipv4.tcp_tw_reuse = 1" /etc/sysctl.conf
    add_config "net.ipv4.tcp_fin_timeout = 1" /etc/sysctl.conf
    #防止简单的ddos攻击
    add_config "net.ipv4.tcp_max_orphans = 3276800" /etc/sysctl.conf
    #启用timewait快速收回
    add_config "net.ipv4.tcp_tw_recycle = 0" /etc/sysctl.conf
    #keeptime启用时tcp发送keepalive消息的频度,默认2h
    add_config "net.ipv4.tcp_keepalive_time = 600" /etc/sysctl.conf
    #允许系统打开的端口范围
    add_config "net.ipv4.ip_local_port_range = 1024 65535" /etc/sysctl.conf
    #资源回收
    add_config "net.ipv4.tcp_tw_recycle = 0" /etc/sysctl.conf
    #路由转发
    add_config "net.ipv4.ip_forward = 1" /etc/sysctl.conf 
    #修改防火墙连接跟踪表大小,默认65535
    add_config "net.netfilter.nf_conntrack_max = ${nf_conntrack_size}" /etc/sysctl.conf
    add_config "net.nf_conntrack_max = ${nf_conntrack_size}" /etc/sysctl.conf
    #解禁ping
    add_config "net.ipv4.icmp_echo_ignore_all = 0" /etc/sysctl.conf
        modprobe bridge
    sysctl -p > /dev/null 2>&1
    show_result $? "${item}"
}
  • 安装常用工具
function install_pkgs(){
    local item="Install Common Pkgs"
    yum -y groupinstall "Development libraries" > /dev/null 2>&1
    yum -y groupinstall "Development tools" > /dev/null 2>&1
    yum -y install sysstat  tree  lrzsz  telnet wget net-tools tcpdump lsof vim ntp > /dev/null 2>&1
    show_result $? "${item}"
}
  • 关闭 SELinux
function shutdown_selinux(){
    local item="Shutdown Selinux "
    setenforce 0 > /dev/null 2>&1
    cp /etc/selinux/config /etc/selinux/config.${current_time} && \
    sed -i 's:SELINUX=enforcing:SELINUX=disabled:g' /etc/selinux/config
    show_result $? "${item}"
}
  • 主函数
function main(){
    echo -e '\033[34;1m开始初始化操作系统中......\033[0m'
    add_yum_repo
    install_pkgs
    config_localtime
    config_dns_addr
    maximum_file_dspt
    shutdown_nonuse_srv
    shutdown_selinux
    optimize_kel_args
    echo -e '\033[34;1m服务器系统初始化已完成!\033[0m'
}

main
相关文章
|
2天前
|
消息中间件 Java Kafka
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
本文介绍了Kafka集群的搭建过程,涵盖从虚拟机安装到集群测试的详细步骤。首先规划了集群架构,包括三台Kafka Broker节点,并说明了分布式环境下的服务进程配置。接着,通过VMware导入模板机并克隆出三台虚拟机(kafka-broker1、kafka-broker2、kafka-broker3),分别设置IP地址和主机名。随后,依次安装JDK、ZooKeeper和Kafka,并配置相应的环境变量与启动脚本,确保各组件能正常运行。最后,通过编写启停脚本简化集群的操作流程,并对集群进行测试,验证其功能完整性。整个过程强调了自动化脚本的应用,提高了部署效率。
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
|
3月前
|
安全 Linux Shell
Linux上执行内存中的脚本和程序
【9月更文挑战第3天】在 Linux 系统中,可以通过多种方式执行内存中的脚本和程序:一是使用 `eval` 命令直接执行内存中的脚本内容;二是利用管道将脚本内容传递给 `bash` 解释器执行;三是将编译好的程序复制到 `/dev/shm` 并执行。这些方法虽便捷,但也需谨慎操作以避免安全风险。
224 6
|
1月前
|
Ubuntu Linux Shell
Linux 系统中的代码类型或脚本类型内容
在 Linux 系统中,代码类型多样,包括 Shell 脚本、配置文件、网络配置、命令行工具和 Cron 定时任务。这些代码类型广泛应用于系统管理、自动化操作、网络配置和定期任务,掌握它们能显著提高系统管理和开发的效率。
|
1月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
2月前
|
运维 Java Linux
【运维基础知识】Linux服务器下手写启停Java程序脚本start.sh stop.sh及详细说明
### 启动Java程序脚本 `start.sh` 此脚本用于启动一个Java程序,设置JVM字符集为GBK,最大堆内存为3000M,并将程序的日志输出到`output.log`文件中,同时在后台运行。 ### 停止Java程序脚本 `stop.sh` 此脚本用于停止指定名称的服务(如`QuoteServer`),通过查找并终止该服务的Java进程,输出操作结果以确认是否成功。
77 1
|
3月前
|
人工智能 监控 Shell
常用的 55 个 Linux Shell 脚本(包括基础案例、文件操作、实用工具、图形化、sed、gawk)
这篇文章提供了55个常用的Linux Shell脚本实例,涵盖基础案例、文件操作、实用工具、图形化界面及sed、gawk的使用。
783 2
|
2月前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
37 0
|
3月前
|
Shell Linux 开发工具
linux shell 脚本调试技巧
【9月更文挑战第3天】在Linux中调试shell脚本可采用多种技巧:使用`-x`选项显示每行命令及变量扩展情况;通过`read`或`trap`设置断点;利用`echo`检查变量值,`set`显示所有变量;检查退出状态码 `$?` 进行错误处理;使用`bashdb`等调试工具实现更复杂调试功能。
|
4月前
|
安全 Linux 开发工具
探索Linux操作系统:从命令行到脚本编程
【8月更文挑战第31天】在这篇文章中,我们将一起潜入Linux操作系统的海洋,从最基础的命令行操作开始,逐步深入到编写实用的脚本。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和实用技能。我们将通过实际代码示例,展示如何在日常工作中利用Linux的强大功能来简化任务和提高效率。准备好了吗?让我们一起开启这段旅程,探索Linux的奥秘吧!
|
4月前
|
Linux
探索Linux操作系统:命令行与脚本编程基础
【8月更文挑战第31天】在这篇文章中,我们将一起踏上一段旅程,深入探索Linux操作系统的奥秘。通过学习命令行的使用和编写简单的脚本,你将能够更高效地与你的计算机进行交流。无论你是新手还是有经验的用户,本文都将为你打开一扇通往Linux世界的大门。准备好了吗?让我们开始吧!