内核版本:6.1
系统:只读bulidroot
1、遇到问题
使用rk原厂sdk包 ,实现rv1126b适配的快启,bulidroot文件系统为增强型只读的,开启ssh功能无法生成私钥 ,导致功能异常。报错截图如下所示:
2、解决办法
2.1 menuconfig启动构建时生成密钥
进入 Target packages -> Networking applications -> openssh
选择后保存,可以整体编译或者局部编译openssh
make menuconfig
make savedefconfig
//保存并重新编译
make openssh-rebuild
2.2 配置必要的运行时目录
- 构建时修改:在 Buildroot 中,将该文件的修改放在 board/<yourcompany>/<yourproject>/rootfs-overlay/etc/ssh/sshd_config 路径下。这样它会自动覆盖打包进镜像。
- 确认overlay路径:进入System configuration --->Root filesystem overlay directories
fs-overlay/
└── etc/
├── ssh/
│ └── sshd_config # SSH 主配置文件
└── init.d/
├── S40sshd_setup # SSH 环境设置脚本
以上为整理配置结构,需要先新建对应目录,使用命令如下:
mkdir -p fs-overlay/etc/ssh
mkdir -p fs-overlay/etc/init.d
2.2.1 配置sshd_config文件
vim sshd_config
# OpenSSH精简配置 - 兼容嵌入式系统
Port 22
AddressFamily inet
ListenAddress 0.0.0.0
# 主机密钥路径
HostKey /etc/ssh/ssh_host_rsa_key
HostKey /etc/ssh/ssh_host_ecdsa_key
HostKey /etc/ssh/ssh_host_ed25519_key
# 认证设置
PermitRootLogin yes
PasswordAuthentication yes
PubkeyAuthentication yes
PermitEmptyPasswords no
# 禁用不支持的功能
# PrintLastLog no # 注释掉,旧版本不支持
# UsePAM no # 注释掉,Buildroot通常不启用PAM
ChallengeResponseAuthentication no
UsePrivilegeSeparation yes
# 日志
SyslogFacility AUTH
LogLevel INFO
# 客户端保活
ClientAliveInterval 30
ClientAliveCountMax 3
# 禁用不必要功能
X11Forwarding no
PrintMotd no
# 子系统
Subsystem sftp /usr/libexec/sftp-server
# 性能优化
UseDNS no
Compression delayed
2.2.2 创建启动脚本S40sshd_setup
vim S40sshd_setup
chmod +x S40sshd_setup
#!/bin/sh
# S40sshd_setup - 在SSH服务启动前设置环境
case "$1" in
start)
echo "Setting up SSH environment (before sshd starts)..."
# 1. 创建必需目录(必须在ssh服务启动前完成)
# 2. 检查主机密钥是否存在
echo "Checking SSH host keys..."
if [ ! -f /etc/ssh/ssh_host_rsa_key ]; then
echo "ERROR: SSH host keys not found in /etc/ssh/"
echo "Make sure 'install server keys' is enabled in Buildroot"
# 不要尝试生成密钥,因为文件系统只读
else
echo "SSH host keys found, setting permissions..."
# 设置正确的权限
chmod 600 /etc/ssh/ssh_host_*_key 2>/dev/null || true
chmod 644 /etc/ssh/ssh_host_*_key.pub 2>/dev/null || true
chmod 755 /etc/ssh 2>/dev/null || true
fi
# 3. 确保运行时目录存在
mkdir -p /var/run/sshd
mkdir -p /var/lock/subsys
echo "SSH environment setup complete."
;;
stop)
# 停止时无需特别操作
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
;;
esac
exit 0
~
以上配置好后,需要编译打包进文件系统
./build.sh rootfs
./build.sh firmware
3、调试验证
编译后的系统烧写到板卡上,查看启动log或者使用ps查看进程情况
检查密钥
ls -la /etc/ssh/
hexdump -C /etc/ssh/ssh_host_rsa_key | head -5
使用winscp客户端验证,输入自己设置的用户名和密码