各位小伙伴在使用elfboard开发板的过程中,必然会有拷贝文件到开发板中的这个操作,通常可以通过u盘进行拷贝,但是为了更方便的传输文件,还可以通过搭建网络服务的方式进行文件传输,下面给小伙伴们介绍一些常用的网络服务的搭建和使用。
首先ubuntu的网络模式需要设置为桥接模式,电脑主机、ubuntu主机、开发板三者的ip要处于同一网段,且ubuntu主机要能上外网,同时还要关闭ubuntu和windows防火墙(关闭ubuntu防火墙:sudo ufw disable)。
本文中使用的三者的ip分别如下:
电脑主机ip:192.168.0.64
ubuntu主机ip:192.168.0.51
开发板ip:192.168.0.232
然后参照以下的操作步骤就可以进行网络服务的搭建和使用。
tftp服务搭建
tftp(trivial file transfer protocol,简单文件传输协议),是tcp/ip协议族中用来在客户机和服务器之间进行简单文件传输的协议,开销很小。tftp通常用于内核调试。在嵌入式linux开发过程中,内核调试是其中一个基础、重要的环节。调试内核通常是与 bootloader配合使用,只需在bootloader中实现了网卡驱动和tftp客户端,就可以使用tftp进行传输内核。使用tftp协议传输文件,还需要在主机安装tftp服务端,可以在 linux系统下实现,也可以在windows系统下实现,下面在linux(ubuntu)系统下安装tftp服务端进行测试。
1.安装服务器、客户端和守护进程
elf@ubuntu:~$ sudo apt-get install tftp-hpa tftpd-hpa xinetd
2.服务器配置
首先,在/home/elf目录下建一个tftpboot,并把属性改成任意用户可读写:
elf@ubuntu:~$ mkdir tftpboot elf@ubuntu:~$ chmod 777 tftpboot
然后,进入目录 /etc/xinetd.d/,并在其中新建文件tftp,把指定的内容加入到tftp文件中:
elf@ubuntu:~$ cd /etc/xinetd.d/ elf@ubuntu:~$ sudo vim tftp
添加以下内容到tftp文件:
service tftp { disable = no 138 socket_type = dgram protocol = udp wait = yes user = elf server = /usr/sbin/in.tftpd server_args = -s /home/elf/tftpboot -c per_source = 11 cps = 100 2 }
最后,修改配置文件/etc/default/tftpd-hpa:
elf@ubuntu:~$ sudo vim /etc/default/tftpd-hpa
修改为:
tftp_username=tftp tftp_directory=/home/elf/tftpboot tftp_address=0.0.0.0:69 tftp_options=--secure -l -c -s
注意:将“tftp_directory” 改为新建tftpboot目录所在的路径。
3. 重新启动服务
elf@ubuntu:~$ sudo /etc/init.d/xinetd reload [ ok ] reloading xinetd configuration (via systemctl): xinetd.service. elf@ubuntu:~$ sudo /etc/init.d/xinetd restart [ ok ] restarting xinetd (via systemctl): xinetd.service. elf@ubuntu:~$ sudo /etc/init.d/tftpd-hpa restart [ ok ] restarting tftpd-hpa (via systemctl):tftpd-hpa.service.
4. 测试服务器
测试一下,在/tftpboot文件夹下新建立一个文件 :
elf@ubuntu:~/tftpboot$ touch abc
进入另外一个文件夹:
elf@ubuntu:~/tftpboot$ cd /home/ elf@ubuntu:/home$ sudo tftp 192.168.0.51 //192.168.0.51为本机ip tftp> get abc tftp> quit elf@ubuntu:/home$ ls abc elf
如果可以下载abc文件说明服务器已经安装成功。
nfs服务搭建
在嵌入式linux开发中,需要在linux主机编写程序代码,然后编译程序,生成的二进制程序文件要传输到目标机上才能调试、运行。那么如何更快、更便捷地传输文件,提高开发工作的效率呢?nfs无疑是最好的选择。通过nfs服务,主机将用户指定的目录通过网络共享给目标机(和windows的文件网络共享类似)。目标机可以直接运行存放于linux主机共享目录下的二进制程序,这样调试程序时十分方便、高效。
nfs即网络文件系统(network file-system),可以通过网络让不同机器、不同系统之间可以实现文件共享。通过nfs,可以访问远程共享目录,就像访问本地磁盘一样。
1. ubuntu下搭建nfs服务器的方法
软件下载安装:
elf@ubuntu:~$ sudo apt-get install nfs-kernel-server nfs-common portmap
创建nfs的目录为nfs_rootfs,并在该目录下新建测试文件test;
elf@ubuntu:~$ mkdir nfs_rootfs elf@ubuntu:~$ cd nfs_rootfs/ elf@ubuntu:~/nfs_rootfs$ touch test elf@ubuntu:~/nfs_rootfs$ ls test
修改配置文件:
elf@ubuntu:~/nfs_rootfs$ sudo vim /etc/exports
在文件中添加以下配置:
/nfs_rootfs *(rw,sync,no_root_squash,no_subtree_check) /home/elf/nfs_rootfs *(rw,sync,no_root_squash,no_subtree_check)
重启配置文件和服务:
elf@ubuntu:~/nfs_rootfs$ sudo exportfs -rv elf@ubuntu:~/nfs_rootfs$ sudo /etc/init.d/rpcbind restart elf@ubuntu:~/nfs_rootfs$ sudo /etc/init.d/nfs-kernel-server restart
2. 验证
在开发板上验证nfs服务器,执行完以下命令将nfs服务器挂载到开发板的/mnt目录:
root@elf1:~# mount -t nfs4 -o vers=4 172.16.0.51:/home/elf/nfs_rootfs /mnt/
挂载成功后,查看/mnt目录,会看到刚才解压的文件系统:
root@elf1:~# ls /mnt/ test
ssh服务搭建
ssh为secure shell的缩写,由ietf的网络小组(network working group)所制定的建立在应用层基础上的安全协议。ssh是较可靠,专为远程登录会话和其他网络服务提供安全性的协议,利用ssh协议可以有效防止远程管理过程中的信息泄露问题。ssh最初是unix系统上的一个程序,后来又迅速扩展到其他操作平台,目前为止,几乎所有unix平台,包括hp-ux、linux、aix、solaris、digital unix、irix等,都可运行。
1. 在系统开发过程中经常会遇到下列情形
(1)linux主机不在本地,但又要使用或者维护这台计算机;
(2)一个嵌入式linux产品不方便接调试串口,需要进行维护;
(3)在远程机器和本地机器之间进行文件传输。
如果远程目标系统已经开启了ssh服务,通过ssh可以轻松解决以上问题。使用ssh服务,一方面需要在远程系统上安装ssh服务,另一方面要在本地系统上安装ssh客户端,常见的ssh客户端有 putty、ssh secure shell client 等。
2. ssh有以下几个知识要点
(1)ssh是安全的加密协议,用于远程连接linux服务器;
(2)ssh默认端口是22号端口,安全协议版本sshv2,除了sshv2版本之外还有sshv1版本(有漏洞,不安全);
(3)ssh服务端主要包含两个服务功能ssh远程连接和sftp服务;
(4)linux ssh客户端包含ssh远程连接命令以及远程拷贝scp命令等。
3. 安装ssh
(1)在ubuntu(linux主机)终端键入以下指令,安装ssh服务:
elf@ubuntu:/$ sudo apt-get install ssh
(2)启动ssh服务:
elf@ubuntu:/$ sudo service ssh start
(3)查看ssh服务的状态:
elf@ubuntu:/$ sudo service ssh status ● ssh.service - openbsd secure shell server loaded: loaded (/lib/systemd/system/ssh.service; enabled; vendor preset: enabled) active: active (running) since mon 2021-08-23 17:19:57 cst; 45s ago main pid: 7383 (sshd) tasks: 1 (limit: 2292) cgroup: /system.slice/ssh.service └─7383 /usr/sbin/sshd -d 8月 23 17:19:57 ubuntu systemd[1]: starting openbsd secure shell server... 8月 23 17:19:57 ubuntu sshd[7383]: server listening on 0.0.0.0 port 22. 8月 23 17:19:57 ubuntu sshd[7383]: server listening on :: port 22. 8月 23 17:19:57 ubuntu systemd[1]: started openbsd secure shell server.
(4)关闭ssh服务:
elf@ubuntu:/$ sudo service ssh stop
(5)测试方法:
在windows主机通过putty访问linux系统,打开putty界面,使用ssh登录,ip设置linux主机的ip,端口号默认为22。
第一次登录,会提示如下警告,点击“是”即可:
登录时,输入用户名与密码完成登录。
关于网络服务搭建和使用的相关操作就介绍到这里,希望本篇文章能够帮助大家在学习嵌入式开发的过程中提供帮助。
回顾:无人驾驶技术在2016年的七大事件
数字集成电路的四大性能检测技巧
燃料电池种类有哪些?
BigchainDB区块链技术和分布式数据库的主要优点分析
IDC预计2020年5G手机出货量将占智能手机总出货量的8.9%达到1.235亿部
常用的网络服务搭建和使用
TensorFlow宣布开源TXF的一个重要组件:“数据验证”
中科院与电科大微电子学院正式签署“联合培养教育基地” 协议
燧原科技正式发布第二代推理产品“云燧i20”
我国网络提速降费工作的重点方向是什么
SM15133EK 恒流LED驱动芯片 明微电子
采用JN5139模块的无线网络技术实现船艇消防安全监测系统的设计
C语言函数参数关于传值和传指针有什么区别?
三星S6edge+外观设计解读
新思考:以“新物联”提速新基建
文心一言APP与澳门签署战略合作!打造“AI+旅游”澳门样本
电子芯闻早报:中国第一芯将浮出水面 小米VR今日发布
智慧城市出现比以往更智能的购物方式?
沃尔沃计划在瑞典舍夫德工厂开始生产电动机
什么是Ansible