systemd管理网络应用
采用systemd-networkd管理网卡
主网卡eth0的配置文件/etc/systemd/network/20-eth0.network,静态配置时内容示例如下:
[Match] Name=eth0 [Network] Address=192.168.10.111/ DNS=8.8.8.8 DNS=8.8.4.4 [Route] Gateway=192.168.10.1 Metric=
动态配置时内容为:
[Match] Name=eth0 [Network] DHCP=yes [DHCP] RouteMetric=
无线网卡的配置文件/etc/systemd/network/21-wireless.network,一般设置为动态IP即可,即该文件内容保持不变。
[Match] Name=wlan0 [Network] DHCP=yes [DHCP] RouteMetric=
无线网卡的应用服务程序为wpa_supplicant,其systemd配置文件为/lib/systemd/system/wpa_supplicant.service,内容如下,保持不变。
[Unit] Description=WPA supplicant Before=network.target [Service] Type=simple ExecStart=/sbin/wpa_supplicant -Dnl80211 -iwlan0 -c /etc/wpa_supplicant.conf ExecReload=/sbin/wpa_supplicant -Dnl80211 -iwlan0 -c /etc/wpa_supplicant.conf RestartSec= Restart=on-failure [Install] WantedBy=multi-user.target Alias=dbus-fi.epitest.hostap.WPASupplicant.service
无线网卡上网方式的配置文件为/etc/wpa_supplicant.conf,样例如下:
ctrl_interface=/var/run/wpa_supplicant
update_config=
network={
scan_ssid=
ssid="test"
psk=""
key_mgmt=WPA-PSK
pairwise=CCMP
}
pppoe集成到systemd中,需配置文件/etc/ppp/pppoe.conf和/etc/ppp/chap-secrets、/etc/ppp/pap-secrets。
# cat /etc/ppp/pppoe.conf DEMAND=no DNSTYPE=SERVER PEERDNS=yes DEFAULTROUTE=yes CONNECT_TIMEOUT= CONNECT_POLL= PING="." CF_BASE=`basename $CONFIG` PIDFILE="/var/run/$CF_BASE-pppoe.pid" SYNCHRONOUS=no CLAMPMSS= LCP_INTERVAL= LCP_FAILURE= PPPOE_TIMEOUT= FIREWALL=NONE LINUX_PLUGIN= PPPOE_EXTRA="" PPPD_EXTRA="" ETH="eth0" USER="test" # cat /etc/ppp/chap-secrets "test" * "" # cat /etc/ppp/pap-secrets "test" * ""
systemd服务配置文件/lib/systemd/system/pppoe.service内容如下(保持不变)。
# cat /lib/systemd/system/pppoe.service [Unit] Description=PPP over ethernet After=network-online.target systemd-networkd.service Wants=network-online.target systemd-networkd.service [Service] Type=forking ExecStart=/usr/sbin/pppoe-start ExecReload=/usr/sbin/pppoe-stop;/usr/sbin/pppoe-start ExecStop=-/usr/sbin/pppoe-stop ExecStopPost=-ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf Restart=on-failure [Install] WantedBy=multi-user.target
static、dhcp、wifi、pppoe方式的切换操作步骤如下:
网络部分使用前部署
需安装wpa_supplicant应用程序,并设置该应用开机启动。
apt-get install wpasupplicant systemctl enable wpa_supplicant
修改wpa_supplicant的systemd配置文件/lib/systemd/system/wpa_supplicant.service内容如下(内容保持不变):
[Unit] Description=WPA supplicant Before=network.target [Service] Type=simple ExecStart=/sbin/wpa_supplicant -Dnl80211 -iwlan0 -c /etc/wpa_supplicant.conf ExecReload=/sbin/wpa_supplicant -Dnl80211 -iwlan0 -c /etc/wpa_supplicant.conf RestartSec= Restart=on-failure [Install] WantedBy=multi-user.target Alias=dbus-fi.epitest.hostap.WPASupplicant.service
增加无线网卡的配置文件/etc/systemd/network/21-wireless.network。
[Match] Name=wlan0 [Network] DHCP=yes [DHCP] RouteMetric=
pppoe部分需要额外配置内核及安装pppoe且增加pppoe服务配置文件。
Device Drivers ->
Network device support ->
<M> ppp(point-to-point protocol) support
<M> PPP BSD-Compress compression
<M> PPP Deflate compression
[*] PPP filtering
<M> PPP MPPE compression (encryption)
[*] PPP multilink support
<M> PPP over Ethernet
<M> PPP support async serial ports
<M> PPP support for sync tty ports
pppoe安装及服务配置文件:
# apt install pppoe # cat /lib/systemd/system/pppoe.service [Unit] Description=PPP over ethernet After=network-online.target systemd-networkd.service Wants=network-online.target systemd-networkd.service [Service] Type=forking ExecStart=/usr/sbin/pppoe-start ExecReload=/usr/sbin/pppoe-stop;/usr/sbin/pppoe-start ExecStop=-/usr/sbin/pppoe-stop ExecStopPost=-ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf Restart=on-failure [Install] WantedBy=multi-user.target
2) eth0动态上网:
修改/etc/systemd/network/20-eth0.network内容为:
[Match] Name=eth0 [Network] DHCP=yes [DHCP] RouteMetric=
之后执行如下命令:
systemctl stop pppoe systemctl restart systemd-networkd ifconfig wlan0 down systemctl restart systemd-resolved ls -al /etc/resolv.conf | grep systmed >/dev/null || ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf
3) eth0静态上网:
根据配置的IP、netmask、Gateway、DNS适当修改/etc/systemd/network/20-eth0.network内容。
[Match] Name=eth0 [Network] Address=192.168.10.111/ DNS=8.8.8.8 DNS=8.8.4.4 [Route] Gateway=192.168.10.1 Metric=
之后执行如下命令:
systemctl stop pppoe systemctl restart systemd-networkd ifconfig wlan0 down systemctl restart systemd-resolved ls -al /etc/resolv.conf | grep systmed >/dev/null || ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf
4) 无线上网:
根据ssid、psk、key_mgmt、pairwise合理修改/etc/wpa_supplicant.conf。
ctrl_interface=/var/run/wpa_supplicant
update_config=
network={
scan_ssid=
ssid="test"
psk=""
key_mgmt=WPA-PSK
pairwise=CCMP
}
之后执行如下命令:
systemctl stop pppoe systemctl restart systemd-networkd systemctl restart wpa_supplicant ifconfig eth0 down systemctl restart systemd-resolved ls -al /etc/resolv.conf | grep systmed >/dev/null || ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf
5)pppoe上网:
根据用户名和密码合理修改/etc/ppp/pppoe.conf和/etc/ppp/chap-secrets、/etc/ppp/pap-secrets,其中/etc/ppp/pppoe.conf只需要修改用户名及USER。
# cat /etc/ppp/pppoe.conf DEMAND=no DNSTYPE=SERVER PEERDNS=yes DEFAULTROUTE=yes CONNECT_TIMEOUT= CONNECT_POLL= PING="." CF_BASE=`basename $CONFIG` PIDFILE="/var/run/$CF_BASE-pppoe.pid" SYNCHRONOUS=no CLAMPMSS= LCP_INTERVAL= LCP_FAILURE= PPPOE_TIMEOUT= FIREWALL=NONE LINUX_PLUGIN= PPPOE_EXTRA="" PPPD_EXTRA="" ETH="eth0" USER="test" # cat /etc/ppp/chap-secrets "test" * "" # cat /etc/ppp/pap-secrets "test" * ""
之后运行如下命令:
systemctl restart systemd-networkd ifconfig wlan0 down systemctl restart pppoe ifconfig eth0 0.0.0.0 && route del default; route add default dev ppp0
上网方式切换时间统计
-
切换方式
切换后成功连通时间
static -> wifi
约8s
dhcp -> wifi
约18s
others
5s内
注:不同网络环境或测试条件下,时间可能有差距。上述测试环境基于北京网络。
上网方式切换后网络连通的测试方法
上网方式
切换后连通测试方法
static
Ping网关
dhcp
可正确获取到动态分配的IP
wifi
可正确获取到动态分配的IP
pppoe
有虚拟网卡ppp0且可获取IP
开机启动时网络设计
断电重启或reboot后,不同上网方式网卡配置和路由不同,需要根据上网方式来正确配置系统。
在/etc/wan_way下保存当前上网方式,可取值:static、dhcp、wifi、pppoe,在/etc/rc.local中增加网络初始化脚本/usr/local/bin/init_networking后台执行,以配置不同上网方式的网络。
#!/bin/sh
wan_way=$(cat /etc/certusnet_conf/wan_way) case $wan_way in "dhcp" | "static" ) ifconfig wlan0 down ls -al /etc/resolv.conf | grep systmed >/dev/null || ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf echo "dhcp or static" ;; "wifi") ifconfig eth0 down ls -al /etc/resolv.conf | grep systmed >/dev/null || ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf echo "wifi" ;; "pppoe") ifconfig wlan0 down systemctl restart pppoe echo "pppoe" ifconfig eth0 0.0.0.0 num= while [ $num -lt ] do num=$(($num+)) pppoe-status | grep -w inet >/dev/null && { echo "pppoe success after $num *10s" num= } done sleep route del default ; route add default dev ppp0 ;; *) echo "not dhcp, static, pppoe or wifi" ;; esac exit
目前测试发现问题
采用DHCP方式上网,插拔网线时配置其他设备该网关动态IP,此网关不能获取新的IP。
参考:
systemd管理网络应用的更多相关文章
- CentOs7下systemd管理知识要点
centOs7的一个巨大的变动就是用systemd取代了原来的System V init.systemd是一个完整的软件包,安装完成后有很多物理文件组成,大致分布为,配置文件位于/etc/system ...
- Ubuntu 18.04 使用Systemd管理MySQL 5.6
转自:https://blog.csdn.net/skykingf/article/details/45225981 如何用Systemd管理 general 包安装的MySQL呢? 首先看看yum安 ...
- dockerd启动配置_修改IP和systemd管理
docker采用CS架构,dockerd是管理后台进程,默认的配置文件为/etc/docker/daemon.json(--config-file可以指定非默认位置). 一个完整的daemon.jso ...
- linux任务计划 chkconfig工具 systemd管理服务 unit介绍 target介绍
linux任务计划 任务计划:特定时间备份数据,重启服务,shell脚本,单独的命令等等. 任务计划配置文件:cat /etc/crontab [root@centos7 ~]# cat /etc/c ...
- 简述systemd的新特性及unit常见类型分析、使用systemd管理编译安装的nginx
1. systemd新特性 并行处理(同时启动)所有服务. 基于依赖关系定义的服务控制逻辑 系统状态快照 按需激活进程,只有第一次被访问时才会真正启动: 2. systemd的常见unit类型 Ser ...
- linux任务计划cron、chkconfig工具、systemd管理服务、unit和target介绍
第8周第1次课(5月14日) 课程内容: 10.23 linux任务计划cron10.24 chkconfig工具10.25 systemd管理服务10.26 unit介绍10.27 target介绍 ...
- Linux centos7 linux任务计划cron、chkconfig工具、systemd管理服务、unit介绍、 target介绍
一.linux任务计划cron crontab -u -e -l -r 格式;分 时 日 月 周 user command 文件/var/spool/corn/username 分范围0-59,时范 ...
- Linux 使用 Systemd 管理进程服务
转载自:https://mp.weixin.qq.com/s/e-_PUNolUm22-Uy_ZjpuEA systemd 介绍 systemd是目前Linux系统上主要的系统守护进程管理工具,由于i ...
- systemd管理进程
systemd很强大的管理工具,这里简单用来管理一个进程: [Unit]Description=Imges Compress Server [Service]Type=simpleExecStart= ...
随机推荐
- WSAAsyncSelect模型中,FD_WRITE事件什么时候触发?
当一个套接字连接被建立上时(包括客户端的connect(),connectex()等和服务器端的accept接收到后创建的新套接字),这时会触发FD_WRITE,以后就可以用send(),WSASen ...
- SharePoint CAML In Action——Part II
在SharePoint中,相对于Linq to SharePoint而言,CAML是轻量化的.当然缺点也是显而易见的,"Hard Code"有时会让你抓狂.在实际场景中,经常会根据 ...
- nginx访问日志,错误日志参数说明
说明: nginx日志主要有两种:访问日志.错误日志.其中访问日志记录客户端访问nginx的每一个请求,包含用户地域来源.跳转来源.使用终端.某个URL访问量等信息,访问日志格式可以自定义:错误日志则 ...
- Python 文件 isatty() 方法
概述 Python 文件 isatty() 方法检测文件是否连接到一个终端设备,如果是返回 True,否则返回 False. 语法 isatty() 方法语法如下: fileObject.isatty ...
- 第二篇:呈现内容_第三节:CompositeControl呈现
一.CompositeControl的呈现过程 CompositeControl派生自WebControls,重写了Render(HtmlTextWriter writer)方法.在调用基类WebCo ...
- Linux中SFTP命令
sftp和ftp是两种协议是不同的,sftp是ssh内含的协议,只要sshd服务器启动了,它就可用,它本身不需要ftp服务器启动. 1.常用登陆方式: 格式:sftp <user>@< ...
- MySQL中NULL与空字符串
一些刚刚接触MySQL的孩子,经常会错误的认为NULL与空字符串’ ’是相同的.这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的.NULL是指没有值,而”则表示值是存在的,只不过是个 ...
- Eclipse 不能build, pom文件上面有叉叉 解决办法
Error message: [html] view plaincopy execution not covered by lifecycle configuration: org.apache. ...
- 【Unity】7.5 移动设备输入
分类:Unity.C#.VS2015 创建日期:2016-04-21 一.简介 在iOS和Android系统中,操作都是通过触摸来完成的.Input类中对触摸操作的方法或变量如下图所示: 通过GetT ...
- C#中自定义属性的例子
自定义属性的作用 有时候我们需要给一个类或者类中的成员加上一些属性或者附加信息,让类或者变量的功能更明确可控制的细粒度更高,打个简单的比方:数据库里面的一张表,表中的每一个字段都有很多属性,如是否主键 ...