5分钟部署OpenWrt自启功能,测试镜像开箱即用

5分钟部署OpenWrt自启功能,测试镜像开箱即用

1. 引言:为何需要开机自启动脚本

在嵌入式网络设备管理中,OpenWrt因其高度可定制性和强大的软件生态被广泛应用于路由器、网关等场景。然而,在实际使用过程中,我们常常需要某些服务或命令在系统启动时自动运行,例如配置网络策略、启动监控脚本或初始化硬件设备。

本文将围绕“测试开机启动脚本”这一目标,介绍如何在OpenWrt系统中快速部署自启动功能,并确保所提供的测试镜像具备开箱即用的特性。通过本文指导,你可以在5分钟内完成配置,无需额外调试,直接验证脚本执行效果。

2. 方法一:使用/etc/rc.local实现简易自启

对于大多数轻量级任务,修改/etc/rc.local是最简单且兼容性最好的方式。该文件在系统初始化流程末期执行,适合运行一次性命令或启动用户级服务。

2.1 编辑rc.local文件

首先,登录到OpenWrt系统的终端(可通过SSH或串口),执行以下命令打开rc.local文件:

vi /etc/rc.local

如果你更习惯使用nano编辑器,也可以安装并使用它:

opkg update opkg install nano nano /etc/rc.local

2.2 添加自定义启动命令

在编辑器中,找到exit 0这一行,并在它之前插入你需要执行的命令。例如,创建一个测试文件以确认脚本已运行:

echo "OpenWrt boot script executed at $(date)" > /tmp/boot_test.log touch /tmp/initialized

完整示例内容如下:

#!/bin/sh # Put your custom commands here that should be executed once # the system has booted successfully. echo "OpenWrt boot script executed at $(date)" > /tmp/boot_test.log touch /tmp/initialized exit 0

注意:所有自启动命令必须位于exit 0之前,否则不会被执行。

2.3 保存并退出编辑器

  • 使用vi:按下ESC键,输入:wq,回车保存。
  • 使用nano:按Ctrl+O写入文件,Enter确认,再按Ctrl+X退出。

2.4 验证文件执行权限

确保/etc/rc.local具备可执行权限,否则系统可能跳过执行:

chmod +x /etc/rc.local

你可以通过以下命令检查权限是否正确:

ls -l /etc/rc.local

输出应包含-rwxr-xr-x权限标识。

2.5 测试与验证

重启系统以验证脚本是否生效:

reboot

重启完成后,再次登录并检查/tmp/boot_test.log是否生成:

cat /tmp/boot_test.log

如果看到类似以下输出,则说明脚本成功执行:

OpenWrt boot script executed at Mon Apr 5 10:20:30 UTC 2025

3. 方法二:通过/etc/init.d创建标准启动服务

当需求更复杂,比如需要支持startstoprestart操作,或希望脚本随系统服务管理机制统一控制时,推荐使用 OpenWrt 的 init.d 脚本系统。

3.1 创建自定义 init.d 脚本

/etc/init.d/目录下创建一个新的脚本文件,例如命名为myscript

vi /etc/init.d/myscript

3.2 编写标准 init 脚本结构

输入以下内容作为模板,实现基本的启动逻辑:

#!/bin/sh /etc/rc.common # 启动优先级,数字越大越晚启动 START=99 # 描述信息(可选) USE_PROCD=0 start() { echo "Starting myscript at $(date)" >> /tmp/myscript.log mkdir -p /tmp/myapp echo "Service initialized" > /tmp/myapp/status } stop() { echo "Stopping myscript at $(date)" >> /tmp/myscript.log rm -f /tmp/myapp/status }

说明: -START=99表示该服务在大多数系统服务之后启动,适合依赖网络或其他服务的场景。 -USE_PROCD=0表示使用传统 shell 脚本模式;若设为1,则需配合 procd 守护进程使用更复杂的守护进程管理。

3.3 设置执行权限

保存脚本后,赋予其可执行权限:

chmod +x /etc/init.d/myscript

3.4 注册并启用服务

为了让脚本在每次开机时自动运行,必须将其注册为启用状态:

/etc/init.d/myscript enable

此命令会在/etc/rc.d/目录下创建符号链接,如S99myscript,表示系统启动时会调用该脚本的start函数。

3.5 手动测试脚本功能

在不重启的情况下,可以手动启动脚本来验证其行为:

/etc/init.d/myscript start

查看日志确认输出:

cat /tmp/myscript.log

预期输出:

Starting myscript at Mon Apr 5 10:25:12 UTC 2025

还可以尝试停止和重启:

/etc/init.d/myscript stop /etc/init.d/myscript restart

3.6 查看服务启用状态

列出当前所有启用的服务,确认myscript已注册:

ls /etc/rc.d/S* | grep myscript

若返回S99myscript,则表示已正确启用。

4. 镜像预置建议:实现“开箱即用”

为了使“测试开机启动脚本”镜像真正达到开箱即用的目标,建议在镜像构建阶段就完成以下操作:

4.1 预置rc.local或 init.d 脚本

在制作固件镜像时,提前将所需的启动脚本写入对应路径:

  • 将定制化的rc.local放入/etc/目录
  • 或者预置/etc/init.d/myscript并设置好权限

4.2 自动启用服务

在镜像构建脚本中加入自动启用命令:

/etc/init.d/myscript enable

这样用户刷机后无需任何干预,服务即可在首次启动时自动运行。

4.3 包含必要依赖

如果脚本依赖特定工具(如curljqnmap等),应在镜像中预装这些包:

opkg update opkg install curl jq

或者在脚本中添加判断逻辑,避免因缺少组件导致失败:

which curl > /dev/null || { echo "curl not found, please install first" exit 1 }

4.4 提供日志反馈机制

建议所有自启动脚本都将关键事件记录到日志文件中,便于排查问题。例如统一写入/tmp/boot.log

logger -t myscript "Service started successfully"

或直接写文件:

echo "$(date): Script started" >> /tmp/boot.log

5. 常见问题与避坑指南

5.1 脚本未执行?检查这几个点

问题原因解决方案
文件无执行权限使用chmod +x添加权限
rc.local中命令在exit 0之后移动命令至exit 0
脚本路径错误或不存在检查文件是否存在于正确位置
依赖命令未安装确保所需二进制文件已预装

5.2 日志无法写入/tmp

虽然/tmp是内存文件系统,通常可写,但在极少数精简版镜像中可能受限。建议:

  • 使用logger命令写入系统日志
  • 或将日志重定向至持久化存储(如挂载的U盘)

5.3 多个脚本启动顺序冲突?

使用/etc/init.d方式时,通过调整START=数值控制顺序:

  • START=10:早期启动(如硬件初始化)
  • START=50:中期(网络配置前)
  • START=99:晚期(依赖网络的服务)

6. 总结

本文详细介绍了两种在OpenWrt系统中实现开机自启动脚本的方法:

  • 方法一(/etc/rc.local:适用于简单命令注入,配置快捷,适合快速验证。
  • 方法二(/etc/init.d脚本):符合OpenWrt标准服务规范,支持启停管理,更适合生产环境。

结合“测试开机启动脚本”镜像的实际需求,建议在镜像构建阶段预置完整的 init.d 脚本并自动启用,从而实现真正的开箱即用体验。同时,通过合理的日志记录和权限设置,确保脚本能稳定、可靠地在每次启动时执行。

掌握这些技巧后,无论是用于自动化部署、远程设备初始化,还是开发调试,都能大幅提升效率。


获取更多AI镜像

想探索更多AI镜像和应用场景?访问 CSDN星图镜像广场,提供丰富的预置镜像,覆盖大模型推理、图像生成、视频生成、模型微调等多个领域,支持一键部署。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1165654.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hunyuan-MT-7B-WEBUI法律场景:涉外合同双语对照智能生成

Hunyuan-MT-7B-WEBUI法律场景:涉外合同双语对照智能生成 1. 引言 随着全球化进程的不断加速,跨国企业之间的商业合作日益频繁,涉外合同作为国际商务活动的重要法律文书,其准确性和专业性直接影响到交易双方的权利义务。传统上&a…

verl实战体验:构建智能代理全过程分享

verl实战体验:构建智能代理全过程分享 1. 引言:智能代理系统的演进与verl的定位 随着大型语言模型(LLMs)在自然语言理解与生成能力上的持续突破,如何让模型具备更复杂的任务执行能力成为研究热点。传统的监督微调和单…

Emotion2Vec+ Large入门必看:9种情感识别原理与置信度解析

Emotion2Vec Large入门必看:9种情感识别原理与置信度解析 1. 引言:语音情感识别的技术演进与应用价值 随着人机交互技术的不断发展,传统基于文本或指令的交互方式已难以满足用户对自然化、情感化沟通的需求。语音作为最直接的人类表达媒介之…

职场试用多款 AI PPT 工具,真实对比后我为何更常用轻竹

文章目标生成一篇用于搜索引擎收录的轻竹办公推荐文章,核心关键词为 AI PPT、AI生成PPT、AIPPT、文本生成PPT、Word/PDF生成PPT、网址生成PPT、PPT生成演讲稿。文章结构标题:职场试用多款AI PPT工具,真实对比后我为何更常用轻竹 引言&#xf…

一人公司,疑云四起

一个人成立一家公司,不用花费多少成本,不用跟同事钩心斗角。在某个风景如画的海岛买个别墅,指挥一群AI创造以亿万计的财富。人生至此,夫复何求?这个瑰丽画面,应该能切中大部分人对生活与创业的美好想象。从…

一键部署PhoneAgent,Open-AutoGLM让手机自动化落地

一键部署PhoneAgent,Open-AutoGLM让手机自动化落地 1. 技术背景与核心价值 随着移动设备在日常生活和工作中的深度渗透,用户对高效、智能的手机操作方式提出了更高要求。传统手动操作模式在面对重复性任务(如比价购物、信息收集&#xff09…

matlab simulink电机foc观测器模型,采用龙贝格观测器+PLL进行无传感器控制

matlab simulink电机foc观测器模型,采用龙贝格观测器PLL进行无传感器控制,其利用 PMSM 数学模型构造观测器模型,根据输出的偏差反馈信号来修正状态变量。 当观测的电流实现与实际电流跟随时,利用估算的反电势进行pll计算转子位置…

BGE-M3实战:技术文档智能搜索

BGE-M3实战:技术文档智能搜索 1. 引言 在企业级知识管理场景中,技术文档的高效检索是提升研发效率的关键环节。传统的关键词匹配方法难以应对语义多样性和上下文复杂性,而单一的嵌入模型又往往无法兼顾不同检索需求。BGE-M3 作为由 FlagAI …

三菱Fx3U三轴定位控制程序:包含脉冲同步运行、多种运行模式、梯形图与St语言混合编程及动态码...

三菱Fx3U三轴定位控制程序,其中两轴为脉冲输出同步运行360度转盘,3轴为工作台丝杆。 1.本程序结构清晰,有公共程序,原点回归,手动点动运行,手动微动运行。 报警程序,参数初始化程序等。 2.自动程…

Vetur项目工程化搭建:从依赖安装到运行

从零搭建一个现代化 Vue 开发环境:Vetur 工程化实战指南 你有没有遇到过这样的场景?刚接手一个 Vue 项目,打开 .vue 文件时模板没有补全、 /components 路径标红、改完代码热更新卡顿三秒……明明装了 Vetur 插件,为什么“智能…

探索考虑需求响应的调频模型在Simulink中的实现

调频模型simulink 考虑需求响应的调频模型,将需求响应参与调频的过程分为两阶段,第一阶段主要用来快速求解频率最低点,第二阶段用来求解频率稳定值,有具体的对应参考资料 在电力系统领域,频率稳定至关重要,…

蹲在自家菜园子里盯着蔫了吧唧的黄瓜苗,我突然意识到传统农业该升级了。摸出兜里的STM32F103C8T6开发板,咱们今天来折腾个能自动伺候植物的智慧大棚

基于物联网技术的智慧农业温棚系统,由STM32F103c8t6,温湿度传感器,烟雾传感器,光照传感器,蜂鸣器模块,电机模块组成。 搭配阿里云平台,4G上阿里云,手机App。 电子资料(代…

PaddlePaddle-v3.3迁移指南:从其他框架平滑过渡的操作步骤

PaddlePaddle-v3.3迁移指南:从其他框架平滑过渡的操作步骤 1. 引言 1.1 技术背景与迁移需求 随着深度学习技术的快速发展,越来越多的企业和开发者面临从传统框架(如 TensorFlow、PyTorch)向更高效、易用且国产化支持更强的框架…

Live Avatar提示词工程:高质量prompt编写模板分享

Live Avatar提示词工程:高质量prompt编写模板分享 1. 技术背景与应用价值 近年来,数字人技术在虚拟主播、在线教育、智能客服等领域展现出巨大潜力。阿里联合高校推出的Live Avatar项目,作为开源的高质量数字人生成模型,为开发者…

时间序列预测模型大盘点:从经典到进阶

[matlab]10种经典的时间序列预测模型 本文演示了 10 种不同的经典时间序列预测方法,它们是 1) 自回归 (AR) 2) 移动平均线 3) 自回归移动平均线 4) 自回归积分移动平均线 (ARIMA) 5) 季节性自回归积分移动平均线 (SARIMA) 6) 具有外生回归量的季节性自回归综合移动平…

STM32步进电机S型加减速程序源码与分析

stm32步进电机S型加减速程序源码与详细分析,步进电机在许多自动化设备中都有着广泛应用,而实现其平稳的启动、运行和停止至关重要,S型加减速控制算法就能很好地满足这一需求。今天咱就来唠唠基于STM32的步进电机S型加减速程序。 1. 原理简述 …

STM32步进电机S型加减速算法源码及详细分析(适用于stm32f103)

stm32步进电机加减速代码 stm32f103 stm32步进电机S型加减速程序源码与详细分析,资料为算法实现以及算法的相关讲解,例程中有stm32f103步进电机S型加减速的完整工程代码,对步进电机s型加减速控制很有帮助。搞电机控制的朋友应该都懂&#xf…

Qwen2.5-0.5B-Instruct快速上手:三步完成本地部署

Qwen2.5-0.5B-Instruct快速上手:三步完成本地部署 1. 引言 随着大模型技术的普及,越来越多开发者希望在本地或边缘设备上部署轻量级AI对话系统。Qwen/Qwen2.5-0.5B-Instruct 作为通义千问系列中最小、最快的指令微调模型,为这一需求提供了理…

Wan2.2从零开始:手把手教你在云端生成第一条AI视频

Wan2.2从零开始:手把手教你在云端生成第一条AI视频 你是不是也曾经看着别人用AI生成的旅行短片,心里羡慕得不行?那些画面流畅、配乐动听、仿佛专业团队制作的视频,其实背后并不神秘。今天我要带你用最简单的方式,在完…

MinerU图表理解教程:从图片到结构化数据的转换步骤

MinerU图表理解教程:从图片到结构化数据的转换步骤 1. 引言 在现代办公与科研场景中,大量的信息以非结构化的形式存在于PDF文档、PPT幻灯片、扫描件和学术论文中。如何高效地从中提取出可编辑、可分析的结构化数据,成为提升工作效率的关键挑…