DHCP服务器脚本

目录

一、初始化配置

(一)编写脚本

(二)执行脚本

二、DHCP服务器

编写脚本

三、路由配置

编写脚本

四、中继转发


一、初始化配置

(一)编写脚本

复制代码
\[root@localhost \~\]# vim csh.sh
#!/bin/bash
##关闭防火墙
if systemctl status firewalld
then
systemctl disabled --now firewalld
else
echo "防火墙已经关闭"
fi
iptables -F
##关闭SELinux
if \[ \`getenforce\` == 'Disabled' \]
then
echo "SELinux已经关闭"
else
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
fi
##配置IP地址
nics=\`ip a \| awk -F: '/ens/{print $2}' \| grep -v "\^$" \| tr -d ' '\`
echo -e "当前系统中可供配置的网卡有:\\n$nics"
while true
do
​
read -p "请输入要配置的网卡名称:" nic
if ! \[\[ $nics =\~ $nic \]\]
then
continue
fi
read -p "请输入配置网络参数的方式(dhcp\|static):" tp
if \[ $tp == 'dhcp' \]
then
echo "TYPE=Ethernet
BOOTPROTO=$tp
NAME=$nic
DEVICE=$nic
ONBOOT=yes"\> /etc/sysconfig/network-scripts/ifcfg-$nic
ifdown $nic ; ifup $nic
elif \[ $tp == 'static' \]
then
read -p "输入IP地址:" ip
read -p "输入子网掩码:" mask
read -p "输入网关:" gw
read -p "输入dns:" dns
echo "TYPE=Ethernet
BOOTPROTO=static
NAME=$nic
DEVICE=$nic
ONBOOT=yes
IPADDR=$ip
PREFIX=$mask
GATEWAY=$gw
DNS1=$dns" \> /etc/sysconfig/network-scripts/ifcfg-$nic
ifdown $nic ; ifup $nic
else
echo "输入错误"
exit
fi
done
​

(二)执行脚本

二、DHCP服务器

编写脚本

复制代码
#!/bin/bash
config_dhcp(){
echo "subnet 192.168.100.0 netmask 255.255.255.0 {
  range 192.168.100.2 192.168.100.253;
  option domain-name-servers 192.168.100.1;
  option domain-name "internal.example.org";
  option routers 192.168.100.254;
  option broadcast-address 192.168.100.255;
  default-lease-time 600;
  max-lease-time 7200;
}       
subnet 192.168.200.0 netmask 255.255.255.0 { 
 range 192.168.200.2 192.168.100.253;
 option domain-name-servers 192.168.100.1;
 option domain-name "internal.example.org";
 option routers 192.168.200.254; 
option broadcast-address 192.168.200.255; 
default-lease-time 600; max-lease-time 7200; }       
host fantasia {
  hardware ethernet 08:00:07:26:c0:a5;
  fixed-address 192.168.100.100;
}" > /etc/dhcp/dhcpd.conf
systemctl enable --now dhcpd
}
if  ! rpm -q dhcp
then
    config_dhcp
else
    yum install -y dhcp
    config_dhcp
fi

三、路由配置

编写脚本

复制代码
\[root@localhost \~\]# vim csh.sh
#!/bin/bash
##关闭防火墙
if systemctl status firewalld
then
systemctl disabled --now firewalld
else
echo "防火墙已经关闭"
fi
iptables -F
##关闭SELinux
if \[ \`getenforce\` == 'Disabled' \]
then
echo "SELinux已经关闭"
else
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
fi
##配置IP地址
nics=\`ip a \| awk -F: '/ens/{print $2}' \| grep -v "\^$" \| tr -d ' '\`
echo -e "当前系统中可供配置的网卡有:\\n$nics"
while true
do
​
read -p "请输入要配置的网卡名称:" nic
if ! \[\[ $nics =\~ $nic \]\]
then
continue
fi
read -p "请输入配置网络参数的方式(dhcp\|static):" tp
if \[ $tp == 'dhcp' \]
then
echo "TYPE=Ethernet
BOOTPROTO=$tp
NAME=$nic
DEVICE=$nic
ONBOOT=yes"\> /etc/sysconfig/network-scripts/ifcfg-$nic
ifdown $nic ; ifup $nic
elif \[ $tp == 'static' \]
then
read -p "输入IP地址:" ip
read -p "输入子网掩码:" mask
read -p "输入网关:" gw
read -p "输入dns:" dns
echo "TYPE=Ethernet
BOOTPROTO=static
NAME=$nic
DEVICE=$nic
ONBOOT=yes
IPADDR=$ip
PREFIX=$mask \> /etc/sysconfig/network-scripts/ifcfg-$nic
ifdown $nic ; ifup $nic
else
echo "输入错误"
exit
fi
done

路由网卡配置:

ens33:

IPADDR=192.168.100.254

PREFIX=24

ens34:

IPADDR=192.168.200.254

PREFIX=24

四、中继转发

echo "net.ipv4.ip_forword = 1" > /etc/sysctl.conf

sysctl-p

dhcrelay 192.168.100.1

相关推荐
轻松Ai享生活2 小时前
5 节课深入学习Linux Cgroups
linux
白帽黑客沐瑶2 小时前
【网络安全就业】信息安全专业的就业前景(非常详细)零基础入门到精通,收藏这篇就够了
网络·安全·web安全·计算机·程序员·编程·网络安全就业
christine-rr2 小时前
linux常用命令(4)——压缩命令
linux·服务器·redis
三坛海会大神5553 小时前
LVS与Keepalived详解(二)LVS负载均衡实现实操
linux·负载均衡·lvs
東雪蓮☆3 小时前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
qq_264220893 小时前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs
树码小子3 小时前
Java网络编程:(socket API编程:TCP协议的 socket API -- 回显程序的服务器端程序的编写)
java·网络·tcp/ip
乌萨奇也要立志学C++3 小时前
【Linux】进程概念(二):进程查看与 fork 初探
linux·运维·服务器
雨落Liy3 小时前
Nginx 从入门到进阶:反向代理、负载均衡与高性能实战指南
运维·nginx·负载均衡
Yyyy4824 小时前
Nginx负载均衡集群实验步骤
运维·nginx·负载均衡