#每日一记#KaLi添加路由问题,设置开机自启动脚本rc.local文件不存在问题
  

sailyang 3796

{{ttag.title}}
本帖最后由 sailyang 于 2020-12-7 19:23 编辑

由于项目需要,需要在kali上添加一条路由,并且保证重启后仍然生效。经查找发现有两种可行的方法:

1、修改/etc/network/interfaces配置文件,添加一行,如:
up route add -net 10.105.10.0 netmask 255.255.255.255 gw 192.168.1.1 eth0
-net指这是一条网络路由(ip地址主机位为0)
gw指下一跳

2、修改rc.local,添加:route add -net 192.168.114.0/24 dev eth0或
route add -net 192.168.114.0/24 gw 192.168.3.254
那么,为了保证重启仍然生效需要将它写入rc.local配置文件。

第一个方法添加路由后,使用route命令查看路由表;的确是添加了,但实际测试中发现没有起作用,目标仍然不可访问。
第二个方法遇到一个问题,kali把rc.local“ 服务化”了,并没有rc.local配置文件怎么办呢?
解决方法:
vim /etc/systemd/system/rc-local.service
将内容替换为
[Unit]
Description=/etc/rc.local Compatibility
ConditionPathExists=/etc/rc.local

[Service]
Type=forking
ExecStart=/etc/rc.local start
TimeoutSec=0
StandardOutput=tty
RemainAfterExit=yes
SysVStartPriority=99

[Install]
WantedBy=multi-user.target
然后touch /etc/rc.local(正常情况下/etc/rc.local并不是配置文件本身,而是/etc/rc.d/rc.local的软连接;但徒增麻烦不建议那么做)记得赋予执行权限

chmod +x /etc/rc.local
vim /etc/rc.local

添加
#!/bin/bash
# THIS FILE IS ADDED FOR COMPATIBILITY PURPOSES
#
# It is highly advisable to create own systemd services or udev rules
# to run scripts during boot instead of using this file.
#
# In contrast to previous versions due to parallel execution during boot
# this script will NOT be run after all other services.
#
# Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
# that this script will be executed during boot.

exit 0
插入脚本就在exit 0之前即可
重启rc-local服务systemctl restart rc-local.service
设置开机自启动systemctl enable rc-local
我将添加路由的shell命令添加到rc.local之后重启发现,并没有成功添加路由;执行systemctl status rc-local.service发现报错显示“网络未启动”在检查了各种错误之后我断定,是启动优先级没有起作用,无奈曲线解决,在启动脚本里添加sleep命令延迟执行脚本,详见我的shell脚本:
#!/bin/bash
# THIS FILE IS ADDED FOR COMPATIBILITY PURPOSES
#
# It is highly advisable to create own systemd services or udev rules
# to run scripts during boot instead of using this file.
#
# In contrast to previous versions due to parallel execution during boot
# this script will NOT be run after all other services.
#
# Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
# that this script will be executed during boot.
/usr/local/bin/route-eth0
exit 0
/usr/local/bin/route-eth0:
#!/bin/bash
sleep 15s
route add -net 192.168.114.0/24 dev eth0
exit0

打赏鼓励作者,期待更多好文!

打赏
2人已打赏

gqce 发表于 2020-12-8 09:02
  
感谢分享
美好潼年 发表于 2020-12-9 11:25
  
感谢分享,学习了
暗夜星空 发表于 2020-12-12 12:59
  
感谢分享
李会斌 发表于 2021-1-18 09:09
  
11111111111111
小鱼儿 发表于 2023-8-8 19:46
  

感谢分享,有助工作
唐三平 发表于 2023-8-8 19:46
  

感谢分享,有助工作
鲤鲤 发表于 2023-8-8 20:12
  
感谢分享,有助于工作
日出 发表于 2023-8-8 20:13
  
感谢分享,有助于工作
小德 发表于 2023-8-8 20:24
  
感谢分享,有助于工作
发表新帖
热门标签
全部标签>
每日一问
技术盲盒
技术笔记
干货满满
技术咨询
产品连连看
新版本体验
功能体验
标准化排查
自助服务平台操作指引
GIF动图学习
2023技术争霸赛专题
通用技术
运维工具
信服课堂视频
秒懂零信任
技术晨报
用户认证
社区帮助指南
答题自测
深信服技术支持平台
安装部署配置
上网策略
SDP百科
设备维护
每日一记
项目案例
玩转零信任
畅聊IT
专家问答
技术圆桌
在线直播
MVP
网络基础知识
升级
安全攻防
测试报告
日志审计
问题分析处理
流量管理
云计算知识
原创分享
解决方案
sangfor周刊
VPN 对接
SANGFOR资讯
专家分享
技术顾问
信服故事
功能咨询
终端接入
授权
资源访问
地址转换
虚拟机
存储
迁移
加速技术
排障笔记本
产品预警公告
信服圈儿
S豆商城资讯
技术争霸赛
「智能机器人」
追光者计划
答题榜单公布
纪元平台
卧龙计划
华北区拉练
天逸直播
以战代练
山东区技术晨报
文档捉虫活动
齐鲁TV
华北区交付直播
每周精选

本版达人

新手89785...

本周建议达人

新手78183...

本周分享达人