本帖最后由 翠花儿 于 2021-8-21 09:58 编辑
整个移植过程是比较简单的,而且我们没有做任何协议方面的了解,只是“配置”+“编译”就完成了整个工作,现在大家应该对移植开源软件有了基本的了解。本章节使用的资料已经放到了开发板网盘资料中,路径为:11_Linux系统开发进阶\75_章节_移植ssh服务使用资料。 入门视频教程中,给 Windows 系统安装了 ssh 客户端,给 Ubuntu 安装了 ssh 服务器,这样就可以通过ssh 在 Windows 和虚拟机 Ubuntu 之间传输文件。其实在开发板上也是可以移植和安装 ssh 服务器,这样就可以通过网络,在 Windows 和开发板之间传输文件。 我们要完成的目标是能够通过 ssh 在开发板在 Windows 和开发板之间传输文件,当然也是可以使用 ssh 控制台。 这个实验比前面的“串口文件传输工具”教程在工程(实用性)上是更加有用的,假如在 实际的产品中,运行的是根文件系统,没有界面,如果数据需要在开发板和 Windows 传输数据,对于普通用户来说,是一个很好的选择,操作起来比较简单,只需要登陆然后直接将文件拖来拖去即可。 这个实验的难度要比“串口文件传输工具”要大一点,ssh 服务器需要依赖其他的库文件,所以需要开发者先移植完成所有依赖的库文件,最后才能移植 ssh 服务器。 1 SSH 官网和下载地址 本小节的地址在作者没有代理的情况下,测试可用。 OpenssL 下载官网地址,如下所示。就是罗永浩捐过 100 万的那个开源组织。 https://www.openssl.org/source/ OpenssL 的 github 下载地址,如下所示。 https://github.com/openssl/openssl ssh 开源组织官网地址,如下所示。 http://www.openssh.com/ HXng KXng(o 用 X 替代,以防文档上传之后被屏蔽)的 ssh 下载地址,测试可以用, 如下所示。 https://openbsd.hk/pub/OpenBSD/OpenSSH/portable/ zlib 官网地址,如下所示。 2 详细移植过程 源码使用迅为下载好的,编译器使用“arm-2009q3”。 作者是在 “/home/topeet/project/ssh-arm/”目录下,放三个需要移植的文件,移植文件的安装目录是“/home/topeet/project/ssh-arm/”目录下的“install”文件夹。install下新建两个文件夹“openssl-0.9.8h”和“zlib-1.2.3”,后面编译之后需要安装到这个目录下。 2.1 移植 Zlib Ø 从迅为提供的资料中拷贝“zlib-1.2.3.tar.gz”到 Ubuntu 系统,使用命令“tar -vxf zlib-1.2.3.tar.gz”解压,得到“zlib-1.2.3”文件夹,使用命令“cd zlib-1.2.3”进入“zlib-1.2.3”文件夹,如下图 Ø 接着使用命令“./configure --prefix=/home/topeet/project/ssh-arm/install/zlib-1.2.3”,设置配置文件,如下图所示。 Ø 使用命令“vim Makefile”修改编译参数,将所有 gcc 修改为“arm-none-linux-gnueabi-gcc”,如下图所示。 Ø 接着使用编译命令“make”,如图所示。 Ø 执行make 无报错后,接着使用安装命令“make install”,如下图所示。 Ø 现在已经安装好了zlib库,在后面编译 SSH 的时候,需要用到 zlib 库,作者这里的路径是“/home/topeet/project/ssh-arm/install”,后面配置的时候需要对应生成的库文件,如下图所示。 Ø 这部分移植其实就是修改了编译器,修改编译器之后编译出的文件和不修改编译出来的文件是不一样的。在移植过程中,可能因为没有将编译器配置为目标系统的编译器,那么编译出来的一定运行不了。这里可以通过 linux 的 strings 命令查看非文本文件中的可读内容(libz.a),通常可以和 grep 命令搭配使用。 如下图所示,使用命令“strings -a /home/topeet/project/ssh-arm/install/zlib- 1.2.3/lib/libz.a”可以查看到所有可读信息,可读信息比较多,可以保存为文本再查看,使用 命令“strings -a /home/topeet/project/ssh-arm/install/zlib-1.2.3/lib/libz.a > log.my”重定位一下输出即可。 这里需要用到的命令是“strings -a /home/topeet/project/ssh-arm/install/zlib- 1.2.3/lib/libz.a | grep “GCC””,如下图所示。 如上图所示,可以看到编译器版本是“2009q3-67-4.4.1”的,说明这个库是使用我们设置的编译编译的,编译出的库文件当然也是 arm 上使用的。 2.2 移植 Openssl Ø 接着来移植 openssl 库,拷贝“openssl-0.9.8h.tar.gz”到 Ubuntu 系统,使用命令 “tar -vxf openssl-0.9.8h.tar.gz”解压,得到“openssl-0.9.8h”文件夹,使用命令“cd openssl-0.9.8h”进入“openssl-0.9.8h”文件夹,如下图所示。 Ø 接着使用命令“./Configure linux-elf-arm -DB_ENDIAN linux:'arm-none-linux- gnueabi-gcc' --prefix=/home/topeet/project/ssh-arm/install/openssl-0.9.8h”配置编译文件, 如下图所示。 配置完成,如下图所示。 Ø 使用编译命令“make”编译完成,如下图所示。 Ø 最后使用安装命令“make install”,编译完成,如下图所示。 如下图所示,可以看到生成了后面移植 ssh 需要的对应的库文件。 和前面 libz.a 小节类似,可以使用命令查看一下编译出来的文件到底有没有配置正确。 2.3 移植 SSHØ 接着来移植 openssh,拷贝“openssh-4.6p1.tar.gz”到 Ubuntu 系统,使用命令“tar -vxf openssh-4.6p1.tar.gz”解压,得到“openssh-4.6p1”文件夹,使用命令“cd openssh-4.6p1/”进入“openssh-4.6p1”文件夹,如下图所示。 Ø 这里看一下 ssh 的 configure 的帮助文件,如下图所示,使用“ ./configure --help”。 ssh 的 configure 文件中需要配置的参数 --host 表示编译出来要运行的平台 --with-libs 表示需要的额外的库文件; --with-zlib 表示库文件 zlib 的 instal 路径 l; --with-ssl-dir 表示 OpenSSl 文件的 install 路径; --disable-etc-default-login 表示不使用当前环境变量的编译器,所以后面配置参数时,最后直接配置 CC 和 AR 这两个编译器; CC 表示设置使用的编译器; AR 表示设置使用的编译器的路径(蛮奇怪,配置文件中似乎没有这个参数,用户可以执 行验证下)。 Ø 接着使用配置命令,命令比较长,作者使用颜色给大家分段: ./configure --host=arm-none-linux --with-libs --with-zlib=/home/topeet/project/ssh-arm/install/zlib-1.2.3 --with-ssl-dir=/home/topeet/project/ssh-arm/install/openssl-0.9.8h --disable-etc-default-login CC=/usr/local/arm/arm-2009q3/bin/arm-none-linux-gnueabi-gcc AR=/usr/local/arm/arm-2009q3/bin/arm-none-linux-gnueabi-ar 配置编译文件,如下图所示。 配置完成,如下图所示 Ø 使用编译命令“make”,编译完成,如下图所示 Ø 编译完成,最后肯定是需要安装到开发板上的,如下图所示。最后在目录下 “/home/topeet/project/ssh-arm/openssh-4.6p1”有这几个二进制文件“scp 、sftp 、ssh、 sshd、ssh-add、ssh-agent、ssh-keygen、ssh-keyscan”需要安装到开发板上。最终编译出来的二进制文件,可以使用 file 命令查看文件属性,如下图所示,使用命令“file scp”,可以看到“scp”文件是 32 位 ARM 上使用的可执行文件 3 安装测试 3.1 基本文件的安装 Ø 在文件系统busybox上新建“/usr/libexec“、“/usr/local/etc ”、“/usr/local/bin ”三个目录,使用命令“mkdir -p /usr/libexec /usr/local/etc /usr/local/bin”,如下图所示。 Ø 在虚拟机 Ubuntu 上,将 openssh-6.6p1 下的生成“scp 、sftp、ssh、sshd、ssh- add、ssh-agent、ssh-keygen、ssh-keyscan”可执行文件拷贝到文件系统“/usr/local/bin”目录下,拷贝完成,如下图所示。 Ø 将“moduli、ssh_config、sshd_config”拷贝到开发板的“/usr/local/etc”目录下, 拷贝完成,如下图所示。 Ø 将“sftp-server、ssh-keysign”拷贝到开发板的“/usr/libexec”目录下,拷贝完成, 如下图所示。 3.2 生成 Key 文件,并安装 Ø 使用“ssh-keygen”生成个四个 key 文件“ssh_host_rsa_key”“ssh_host_dsa_key” “ssh_host_ecdsa_key”和“ssh_host_ed25519_key”。 ① 在虚拟机 Ubuntu 控制台,“/home/topeet/project/ssh-arm/openssh-4.6p1”目录下,使用命令“ssh-keygen -t rsa -f ssh_host_rsa_key -N ""”,可以生成“ssh_host_rsa_key ”文件 ② 接着使用剩下的三条命令: ssh-keygen -t dsa -f ssh_host_dsa_key -N "" ssh-keygen -t ecdsa -f ssh_host_ecdsa_key -N "" ssh-keygen -t dsa -f ssh_host_ed25519_key -N "" 执行完成之后,将生成的“ssh_host_rsa_key”“ssh_host_dsa_key”“ssh_host_ecdsa_key”和 “ssh_host_ed25519_key”文件,拷贝到文件系统的“/usr/local/etc/”目录下,然后将其权限 修改为 600,如下图所示。 3.3 修改目标板密钥文件 在文件系统中,使用命令“vi /etc/passwd”,打开 ssh 密钥文件,在 “/etc/passwd”文件底行添加以下内容: sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin 添加完成之后,如下图所示,然后保存,密钥文件修改完成。 3.4 测试 作者的开发板链接路由器,PC 机的 Windows 系统也是链接路由器,所以首先要确保开发板和 PC 机是可以 Ping 通的,也就是设置在同一网段,修改文件系统的/etc/eth0-setting文件。 作者的 PC 的 IP 为:192.168.123.224,如下图所示。 开发板的 IP 为:192.168.123.150,/etc/eth0-setting文件已经修改过。 Ø 将文件系统打包,烧写到开发板上 Ø 使用 ping 命令测试,如下图所示,网络通畅,另外按键“Ctrl”+c 可以结束 ping 动作 Ø 接着在开发板上新建 root 账户,如下图所示,使用命令“passwd root”,它会提示输入密码,需要重复输入两次以防输错。 Ø 然后在开发板上运行 sshd 二进制文件,使用命令“/usr/local/bin/sshd”,提示如下图 再去Ubuntu查看下ssh可执行文件,file sshd Ø 在串口控制台输入 ln -sv /lib/ld-2.19-2014.08-1-git.so /lib/ld-linux.so.3 建立软链接,如下图所示: Ø 然后使用工具 ssh 测试是否和 PC 联通能否正常通信,如图 75.3.4.8所示,使用命令 “/usr/local/bin/ssh 192.168.123.224”,这里的 IP 是作者 PC 的 IP。 Ø 控制台输入“/usr/local/bin/sshd”虽然报错了,但是不影响使用。如果提示缺少动态库,前面的库文件如果拷贝不全,可能出现这种问题,如果用户使用迅为电子的根文件系统,经过测试各种文件都拷贝没有错误,一般是不会提示缺少什么库的。 Ø 接着在 PC 上使用 ssh 工具连接开发板,使用方法和连接 Ubuntu 上的 ssh 类似,如下图所示。 Ø 然后传一个文件测试下,如下图所示。 说明成功完成了文件传输移植工作。 ssh 控制台也是可以使用的,登陆方法和 PC 连接虚拟机 Ubuntu 的 ssh 一 样。 另外在安装部分,也可以将其拷贝到文件系统的源码中对应目录,重新打包编译,生成直接支持 ssh 的镜像。 到这里,部分用户可能会有疑惑,第一个人是如何知道 ssh 需要这两个库文件的呢?首先,开发 ssh 软件的大神,做了这个东西会提供编译和使用 demo,这样就有了基础的英文移植文档,然后慢慢的会有中文版的,接着 ssh 流传开了之后,通过网络搜索 ssh 移植到 arm的方法的文档和博客,就随处可见了。 当然,假如将来大家工作有移植的需求,找不到中文教程,需要直接使用某个开源软件的 demo,首先就需要英文过关,然后还需要有移植的基础知识。在编译的过程中,它会提示缺少各种库,通过编译,也是可以一步一步找出依赖库的。
|