关于脚本

服务器使用之前,都需要先配置静态IP,那就将这种简单重复的工作,交给脚本来处理吧,让我们运维有更多的时间喝茶看报刷微博

脚本使用

  1. sh ssh.sh ip.txt
    1. ssh.sh 为脚本的名称,自行设定,不是固定项
    2. ip.txt 为ip、密码、主机名的记录文件,文件名称可以自行设定,不是固定项,内容格式如下:
192.168.72.46 123.com k8s-01
192.168.72.47 123.com k8s-02
192.168.72.48 123.com k8s-03
192.168.72.49 123.com k8s-04
192.168.72.50 123.com k8s-05
  • 注:ip、密码、主机名之间的间距为一个空格,脚本内的切割命令,指定的分隔符也是一个空格,请注意文本格式

注意项目

  1. 此脚本配置了单向免密
  2. 此脚本配置了hosts解析
  3. 此脚本修改了hostname
  4. 此脚本会重启网卡服务
  5. 此脚本会用到 expect ,请提前安装
  6. 此脚本目前适用于 susecentosredhat发行版,其他发行版,后面继续更新(我的测试环境是suse 12 sp3、centos 7.7、redhat 7、fedora 32)
  7. 此脚本会删除脚本所在目录下的所有.template结尾的文件,建议脚本放到干净的目录执行
  8. 此脚本内定义了以下固定变量,请根据自身情况进行修改:
    1. CARDNAME为网卡名称( ip a 或者 ifconfig 查看)
    2. GATEWAY 为网关,CentOS网卡配置文件内的DNS1默认为和网关IP一致
    3. NETMAST 为子网掩码前缀
    4. domain_template 函数内,写了几个常用的国内dns服务器,可以自行修改或删减

脚本正文

#!/usr/bin/env bash
PWD=$(cd $(dirname $0) ; pwd)
FILENAME=$1
CARDNAME='eth0'
GATEWAY='192.168.72.2'
NETMASK='24' # 检查linux发行版,suse和centos的网卡配置文件所在目录是不一样的
function check_os (){
RELEASE=$(grep PRETTY_NAME /etc/os-release | awk -F '"' '{print $2}' | awk '{print $1}')
if [ ${RELEASE} == "SUSE" ]
then
printf "[\e[0;35mINFO\e[0m]\e[0;35mYour system is ${RELEASE}\e[0m\n"
ifcfg_dir='/etc/sysconfig/network'
fi
if [ ${RELEASE} == "CentOS" ] || [ ${RELEASE} == "Red" ] || [ ${RELEASE} == "Fedora" ]
then
printf "[\e[0;35mINFO\e[0m]\e[0;35mYour system is ${RELEASE}\e[0m\n"
ifcfg_dir='/etc/sysconfig/network-scripts/'
fi
} # 检查ip.txt文件是否创建了,以及执行方式是否正确
function check_file (){
if [ ! -n "${FILENAME}" ]; then
printf "[\e[0;31mERROR\e[0m]\e[0;35m No host ip address account file supplied !!!\e[0m\n"
printf "[\e[0;35mUsage\e[0m] $0 [\e[0;35mip.txt\e[0m]\n"
exit 1
fi IPADDRESS=()
PASSWORDS=()
HOSTNAMES=() while read line
do
ip_addres=$(echo ${line} | cut -d " " -f1)
pass_word=$(echo ${line} | cut -d " " -f2)
host_name=$(echo ${line} | cut -d " " -f3) IPADDRESS[${#IPADDRESS[*]}]=${ip_addres}
PASSWORDS[${#PASSWORDS[*]}]=${pass_word}
HOSTNAMES[${#HOSTNAMES[*]}]=${host_name} done < ${FILENAME}
} # 配置ssh免密
function ssh_auth () {
[ -d /root/.ssh ] && mv /root/.ssh{,.bak.`date +%F`}
ssh-keygen -t rsa -P "" -f /root/.ssh/id_rsa -q > /dev/null 2>&1 for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]}
pass_word=${PASSWORDS[$i]} printf "[\e[0;35mINFO\e[0m]\e[0;35m${ip_addres}\e[0m\n"
expect -c "
spawn ssh-copy-id -i /root/.ssh/id_rsa.pub root@${ip_addres}
expect {
\"*yes/no*\" {send \"yes\r\"; exp_continue}
\"*assword*\" {send \"${pass_word}\r\"; exp_continue}
\"*assword*\" {send \"${pass_word}\r\";}
}"
done
} # 创建hosts文件模板
function hosts_template () {
for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]}
host_name=${HOSTNAMES[$i]} echo "${ip_addres} ${host_name}" >> ${PWD}/hosts.template
done
printf "[\e[0;35mINFO\e[0m]\e[0;35mhosts_template Completed\e[0m\n"
} # 生成网卡配置文件模板
function ifcfg_template () {
if [ ${RELEASE} == "SUSE" ]
then
for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]} sed -e "s%^IPADDR=.*%IPADDR=\'${ip_addres}/${NETMASK}\'%g" \
/etc/sysconfig/network/ifcfg-${CARDNAME} \
> ${PWD}/ifcfg-${CARDNAME}-${ip_addres}.template
done
printf "[\e[0;35mINFO\e[0m]\e[0;35mifcfg_template Completed\e[0m\n"
fi if [ ${RELEASE} == "CentOS" ] || [ ${RELEASE} == "Red" ] || [ ${RELEASE} == "Fedora" ]
then
cat > ${PWD}/ifcfg-${CARDNAME}.template <<EOF
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="none"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
NAME="${CARDNAME}"
DEVICE="${CARDNAME}"
ONBOOT="yes"
IPADDR=""
PREFIX=""
GATEWAY=""
DNS1=""
EOF
for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]} sed -e "s%^IPADDR=.*%IPADDR=\"${ip_addres}\"%g" \
-e "s%^PREFIX=.*%PREFIX=\"${NETMASK}\"%g" \
-e "s%^GATEWAY=.*%GATEWAY=\"${GATEWAY}\"%g" \
-e "s%^DNS1=.*%DNS1=\"${GATEWAY}\"%g" \
-e "s%^DEVICE=.*%DEVICE=\"${CARDNAME}\"%g" \
-e "s%^NAME=.*%NAME=\"${CARDNAME}\"%g" ${PWD}/ifcfg-${CARDNAME}.template \
> ${PWD}/ifcfg-${CARDNAME}-${ip_addres}.template
done
printf "[\e[0;35mINFO\e[0m]\e[0;35mifcfg_template Completed\e[0m\n"
fi
} # 生成网关配置文件模板
function ifroute_template () {
if [ ${RELEASE} == "SUSE" ]
then
echo "default ${GATEWAY} - ${CARDNAME}" > ${PWD}/ifroute-${CARDNAME}.template
fi
printf "[\e[0;35mINFO\e[0m]\e[0;35mifroute_template Completed\e[0m\n"
} # 生成DNS配置文件模板
function domain_template () {
cat > ${PWD}/resolv.conf.template <<EOF
nameserver 101.6.6.6
nameserver 223.5.5.5
nameserver 119.29.29.29
nameserver 180.76.76.76
nameserver 114.114.114.114
EOF
printf "[\e[0;35mINFO\e[0m]\e[0;35mdomain_template Completed\e[0m\n"
} # 分发模板文件到其他节点
function scp_template () {
for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]}
host_name=${HOSTNAMES[$i]} if [ ${RELEASE} == "SUSE" ]
then
scp ${PWD}/hosts.template ${ip_addres}:/etc/ > /dev/null
scp ${PWD}/ifcfg-${CARDNAME}-${ip_addres}.template ${ip_addres}:${ifcfg_dir}/ifcfg-${CARDNAME} > /dev/null
scp ${PWD}/ifroute-${CARDNAME}.template ${ip_addres}:${ifcfg_dir}/ifroute-${CARDNAME} > /dev/null
scp ${PWD}/resolv.conf.template ${ip_addres}:/etc/ > /dev/null
ssh root@${ip_addres} "cat /etc/hosts.template >> /etc/hosts && rm -f /etc/hosts.template"
ssh root@${ip_addres} "cat /etc/resolv.conf.template >> /etc/resolv.conf && rm -f /etc/resolv.conf.template"
ssh root@${ip_addres} "hostnamectl set-hostname --static ${host_name}"
printf "[\e[0;35mINFO\e[0m]\e[0;35m${ip_addres} scp_template Completed\e[0m\n"
fi if [ ${RELEASE} == "CentOS" ] || [ ${RELEASE} == "Red" ] || [ ${RELEASE} == "Fedora" ]
then
scp ${PWD}/hosts.template ${ip_addres}:/etc/ > /dev/null
scp ${PWD}/ifcfg-${CARDNAME}-${ip_addres}.template ${ip_addres}:${ifcfg_dir}/ifcfg-${CARDNAME} > /dev/null
scp ${PWD}/resolv.conf.template ${ip_addres}:/etc/ > /dev/null
ssh root@${ip_addres} "cat /etc/hosts.template >> /etc/hosts && rm -f /etc/hosts.template"
ssh root@${ip_addres} "cat /etc/resolv.conf.template >> /etc/resolv.conf && rm -f /etc/resolv.conf.template"
ssh root@${ip_addres} "hostnamectl set-hostname --static ${host_name}"
printf "[\e[0;35mINFO\e[0m]\e[0;35m${ip_addres} scp_template Completed\e[0m\n"
fi
done } # 重启network服务
function restart_network () {
if [ ${RELEASE} == "SUSE" ]
then
for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]} ssh root@${ip_addres} "systemctl restart network && \
ping www.baidu.com -c 1 | awk 'NR == 2'"
printf "[\e[0;35mINFO\e[0m]\e[0;35m${ip_addres} restart_network Completed\e[0m\n"
done
fi if [ ${RELEASE} == "CentOS" ] || [ ${RELEASE} == "Red" ] || [ ${RELEASE} == "Fedora" ]
then
for ((i = 0; i < ${#IPADDRESS[@]}; i++))
do
ip_addres=${IPADDRESS[$i]} ssh root@${ip_addres} "systemctl restart NetworkManager && \
ping www.baidu.com -c 1 | awk 'NR == 2'"
printf "[\e[0;35mINFO\e[0m]\e[0;35m${ip_addres} restart_network Completed\e[0m\n"
done
fi
} function main () {
check_os
check_file
hosts_template
ifcfg_template
ifroute_template
domain_template
ssh_auth
scp_template
restart_network
rm -f ${PWD}/*.template
} main

shell脚本批量配置多台主机静态ip的更多相关文章

  1. 一键配置树莓派wifi、静态ip等

    系统老是被我玩坏,重新烧录系统后配置又太麻烦,用shell脚本一键配置一下wifi和静态IP #!/bin/bash touch /media/fanghaoyu/boot/ssh echo &quo ...

  2. shell脚本批量ssh登陆主机并执行命令

    shell脚本批量ssh登陆主机并执行命令 今天在客户现场遇到了这个问题,客户没有管理工具,无法批量登陆主机下发命令,几个个C段啊,让我一个一个登陆,.................. 所以写了个s ...

  3. Linux shell脚本 批量创建多个用户

    Linux shell脚本 批量创建多个用户 #!/bin/bash groupadd charlesgroup for username in charles1 charles2 charles3 ...

  4. Shell 脚本批量创建数据库表

    使用 Shell 脚本批量创建数据表 系统:Centos6.5 64位 MySQL版本:5.1.73 比如下面这个脚本: #!/bin/bash #批量新建数据表 for y in {0..199}; ...

  5. shell脚本批量执行命令----必需判断上一步执行结果--没有捷径

    # 注意:shell脚本批量执行命令,不能只写一个函数,然后把所有命令复制进去,之前试过这样是不行的.必须要有一个判断命令执行成功与否的语句 # 简单的命令可以不加结果判断符号,但是遇到解压包.sed ...

  6. shell脚本批量开启防火墙端口

    # 注意:shell脚本批量执行命令,不能只写一个函数,然后把所有命令复制进去,之前试过这样是不行的.必须要有一个判断命令执行成功与否的语句 # 简单的命令可以不加结果判断符号,但是遇到解压包.sed ...

  7. linux系统配置文件或shell脚本批量注释

    1. 配置文件批量注释 1.1 批量注释 ① 进入命令行模式,按ctrl + v进入 visual block模式,键盘上下箭头选中多行,把需要注释的行标记起来 ② 按大写字母I,再输入注释符:# ③ ...

  8. ubuntu Server 设置主机静态 ip地址

    ubuntu Server 设置主机静态 ip地址 1:先输入 ifconfig 查看当前网络配置 2:然后关闭 eth0 网卡 sudo ifdown eth0 3:配置静态ip sudo vim ...

  9. CentOS7Linux中自动化运维工具Ansible的安装,以及通过模块批量管理多台主机

    使用自动化运维工具Ansible集中化管理服务器 Ansible概述 Ansible是一款为类Unix系统开发的自由开源的配置和自动化工具.它用Python写成,类似于saltstack和Puppet ...

随机推荐

  1. Hive分区表和桶表的使用

    原文链接: https://www.toutiao.com/i6766897068138037763/?group_id=6766897068138037763 我们看官网文档中这个地方 我们先创建好 ...

  2. Linux环境下的Docker的安装和部署、学习二

    DockerFile体系结构(保留字指令) FROM:基础镜像,当前新镜像是基于哪个镜像的 MAINTAINER:镜像维护者的姓名和邮箱地址 RUN:容器构建时需要运行的命令 EXPOSE:当前容器对 ...

  3. shell基础知识查缺补漏

    最近在看<Linux程序设计(第4版)>,其中有一个章节主要讲了shell脚本方面的,内容不细,但是利用较短的篇幅讲的也不少了.对我们自己来说也是一个查缺补漏的过程,所以就写下这篇读书笔记 ...

  4. 【记录一个问题】笔记本ThinkPad X1-Extreme安装ubuntu 18后,更新nvidia显卡驱动后出现显示问题,无法再登录

    如题 更新的过程如下: sudo ubuntu-drivers autoinstall sudo reboot 后续准备在recovery模式中尝试删除驱动.

  5. Python 根据id生成唯一码

    Python 根据id生成唯一码 最近业务中遇到需要分享某个文案,复制文案打开APP需要提取文案中包含的id,但又不想明文暴露id,所以需要对id进行加密,很想让前端来做,可惜多个前端协调起来不方便( ...

  6. unity3d之public变量引发错误

    public变量引发错误 在vs ide中怎么更改也无效 后来发现public里面的值一直不改变,手动改之.

  7. java原码、反码、补码、位运算

    1.对于有符号的数(java中的数都是有符号的) 二进制的最高位是符号位:0表示正数,1表示负数 正数的原码,反码,补码都一样 负数的反码=它的原码符号位不变,其它位取反 负数的补码=它的反码+1 0 ...

  8. 配置kubectl连接多个kubernetes集群

    背景:我们通过会有多个k8s集群,例如集群(cn-k8s)和集群(jp-k8s),那个就需要有一台服务器可以同时访问两个集群,方式:将2个集群的config信息存放到一个文件中,通过使用 kubect ...

  9. C++读写图片文件

    1.C方式 string sourcefilename = "D:\\Logo.jpg"; string destfilename="D:\\Logo1.jpg" ...

  10. VsCode配置C/C++开发环境

    Visual Studio Code(VS Code)是基于 Electron 开发,支持 Windows.Linux 和 macOS 操作系统.内置了对JavaScript,TypeScript和N ...