嵌入式调试常常需要做NFS挂载调试,和SSH远程服务器调试。
记录下NFS和SSH远程服务器的搭建过程:
NFS服务器搭建:
1.安装NFS server:
sudo apt-get install nfs-kernel-server
2.配置NFS目录(/etc/exports)
sudo vi /etc/exports
在最后添加 /opt/nfs *(rw,sync,no_root_squash),其中"/opt/nfs"是我的NFS挂载目录。这样就有可以工作,如果需要其他一些配置,
参考如下:
*代表允许所有的网络段访问,rw是可读写权限,sync是资料同步写入内存和硬盘,no_root_squash是Ubuntu nfs客户端分享目录使用者的权限,如果客户端使用的是root用户,那么对于该共享目录而言,该客户端就具有root权限。
nfs常用的参数有:
ro 只读访问
rw 读写访问sync 所有数据在请求时写入共享
async nfs在写入数据前可以响应请求
secure nfs通过1024以下的安全TCP/IP端口发送
insecure nfs通过1024以上的端口发送
wdelay 如果多个用户要写入nfs目录,则归组写入(默认)
no_wdelay 如果多个用户要写入nfs目录,则立即写入,当使用async时,无需此设置。
hide 在nfs共享目录中不共享其子目录
no_hide 共享nfs目录的子目录
subtree_check 如果共享/usr/bin之类的子目录时,强制nfs检查父目录的权限(默认)
no_subtree_check 和上面相对,不检查父目录权限
all_squash 共享文件的UID和GID映射匿名用户anonymous,适合公用目录。
no_all_squash 保留共享文件的UID和GID(默认)
root_squash root用户的所有请求映射成如anonymous用户一样的权限(默认)
no_root_squas root用户具有根目录的完全管理访问权限
anonuid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的UID
anongid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的GID
3.启动服务和验证:
sudo /etc/init.d/portmap restart
sudo /etc/init.d/nfs-kernel-server restart
执行 showmount -e:看到如下说明成功
或者可以使用以下命令把它挂载在本地磁盘上,例如将挂载到/mnt下:
$ sudo mount -t nfs localhost:/opt/nfs /mnt
可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载:
$ sudo umount /mnt
SSH服务器搭建:
1.安装ssh server:
ubuntu默认安装了ssh cliet,需要我们安装ssh server
sudo apt-get install openssh-server
2.配置登录端口和用户授权等:
修改/etc/ssh/sshd_config:
"#PermitRootLogin yes"改为"PermitRootLogin no"
"#Port 22"改为"Port 22"允许使用端口22
添加 AllowUsers xx xx2 xx和xx2等是允许登录的用户列表。
3.启动或重启ssh服务:
sudo /etc/init.d/ssh restart
这时可以通过ssh 127.0.0.1在服务器上测试SSH服务是否正常。