记录一次vxworks下使用NFS组件的过程
问题:有三块CPU都运行vxworks6.9,现在想要CPU3做server,CPU1-2通过NFS访问CPU3上的文件
补充:使用防火墙可能会影响NFS访问,目前我还没有找到解决办法。。。
下面是过程,本文采用nfs v3版本, 仅记录使用过程,不涉及详细的知识点讲解,可以在workbench里帮助文档中搜索 NFS 关键字查看详细的帮助文档,如下图:

1、在vxworks镜像工程配置里添加NFS组件:
打开镜像的配置文件,搜索 INCLUDE_CORE_NFS_SERVER ,定位到组件处,把 Core NFS client 、 NFS server 、 NFS server V3 、 NFS v3 client 四个组件都添加引用,如下图所示:

2、在代码里调用相关接口:
(1) server端调用
server端直接调用 nfsExport 接口即可,该接口的原形如下:
STATUS nfsExport
(
char * directory, /* Directory to export - FS must support NFS */
int id, /* ID number for file system */
BOOL readOnly, /* TRUE if file system is exported read-only */
int options /* Reserved for future use - set to 0 */
)
其中:directory 表示server端想要挂出去的文件目录; id使用0即可表示系统随机分配; readOnly设置为TRUE时表示NFS只读; options填写0预留。
(2) client端调用
client端需要依次调用 hostAdd 和 nfsMount 两个接口,其原形如下:
STATUS hostAdd
(
char *hostName, /* host name */
char *hostAddr /* host addr in standard Internet format */
)
STATUS nfsMount
(
const char *host, /* name of remote host */
const char *fileSystem, /* name of remote directory to mount */
const char *localName /* local device name for remote dir */
)
其中:hostAdd接口第一个参数表示server端主机的名字(不知道server主机的名字时,可在server主机上调用 whoami 函数查看),第二个参数表示server端的IP地址(点分十进制形式的字符串); nfsMount接口第一个参数同上,表示server端主机的名字, 第二个参数表示server端用于NFS的文件目录(与nfsExport的第一个参数值需相同), 第三个参数表示将NFS挂载到本地后的目录标识。
以上两步即可使用nfs,下边看一个demo:
该demo函数运行成功后,在CPU1-2上访问 /mmc0:0/nfs_local_dir 即等同于访问CPU3上的 /mmc0:0/nfs_host_dir
#include "nfs/mountd.h"
#include "nfs/nfsCommon.h" #define NFS_LOCAL_DIR "/mmc0:0/nfs_local_dir"
#define NFS_HOST_DIR "/mmc0:0/nfs_host_dir" void nfsFuncInit(int slot_flag, int cpu_flag)
{
char cpu12_host_name[] = {'\0'};
char cpu3_host_name[] = {'\0'};
char cpu3_host_ip[] = {}; memset(cpu12_host_name, , );
memset(cpu3_host_name, , );
memset(cpu3_host_ip, , ); strcpy(cpu12_host_name, "HostCpu_");
strcpy(cpu3_host_name, "HostCpu3_"); /*- 左系 */
if((0x00u == (uint8_t)slot_flag) || (0x02u == (uint8_t)slot_flag))
{
strcat(cpu3_host_name, "L");
strcat(cpu12_host_name, "L");
strcpy(cpu3_host_ip, "192.168.200.5");
}
else
{
strcat(cpu3_host_name, "R");
strcat(cpu12_host_name, "R");
strcpy(cpu3_host_ip, "192.168.200.6");
} /*- 是CPU3,做server */
if( == cpu_flag)
{
/*- 设置本地名称 */
if(ERROR == iam(cpu3_host_name, NULL))
{
printf("Error: set iam host name(%s) failed. --- %s \n", cpu3_host_name, strerror(errnoGet()));
} printf("\n====== Local machine name is: ");
whoami();
printf("\n"); if(ERROR == nfsExport(NFS_HOST_DIR, , TRUE, ))
{
printf("Error: NFS export %s Failed --- %s.\n",NFS_HOST_DIR, strerror(errnoGet()));
}
else
{
printf("====== OK: NFS export OK (%s)\n", NFS_HOST_DIR);
}
}
else if(( == cpu_flag) || ( == cpu_flag))
{
if ( == cpu_flag)
{
strcat(cpu12_host_name, "");
if(ERROR == iam(cpu12_host_name, NULL))
{
printf("Error: Set iam host name(%s) failed. --- %s \n", cpu12_host_name, strerror(errnoGet()));
}
}
else
{
strcat(cpu12_host_name, "");
if(ERROR == iam(cpu12_host_name, NULL))
{
printf("Error: Set iam host name(%s) failed. --- %s \n", cpu12_host_name, strerror(errnoGet()));
}
} printf("\n====== Local machine name is: ");
whoami();
printf("\n"); if(ERROR == hostAdd(cpu3_host_name, cpu3_host_ip))
{
printf("Error: NFS host Add failed. (HostName:%s, ip:%s) --- %s\n", cpu3_host_name, cpu3_host_ip, strerror(errnoGet()));
}
else
{
printf("====== OK: NFS hostAdd ok (HostName:%s, ip:%s)\n", cpu3_host_name, cpu3_host_ip); taskDelay(sysClkRateGet()*); /* 这里有延时,否则client端查询不到server端的export */ nfsExportShow(cpu3_host_name); if(ERROR == nfsMount(cpu3_host_name, NFS_HOST_DIR, NFS_LOCAL_DIR))
{
printf("Error: NFS mount failed. %s,%s,%s --- %s\n", cpu3_host_name, NFS_HOST_DIR, NFS_LOCAL_DIR, strerror(errnoGet()));
}
else
{
printf("====== OK: NFS mount ok\n");
nfsDevShow();
cd(NFS_LOCAL_DIR);
}
}
}
else
{
printf("Error: Unknown cpu id:%d\n",cpu_flag);
}
}
下面再简列几个常用的调试函数(这几个函数在demo里都有使用):
whoami : 查看本机的名称
iam : 设置本机的名称
nfsExportShow: 查看server上export的目录(这个接口是在client端调用的)
nfsDevShow : 查看当前的nfs设备(这个接口也是在client端调用的)
nfsHelp : nfs相关帮助信息
netHelp : net相关帮助信息
以上。需了解详细信息,可在帮助文档中搜索 NFS 、 nfsCommon 等关键字查看。
码完收工!
(吐槽一下CSDN的博客:登录很慢,我本来发在那里的,点击发布卡了半天,最后啥也没了,浪费我时间。。。)
记录一次vxworks下使用NFS组件的过程的更多相关文章
- VxWorks下USB驱动总结2
3:USBD驱动详解 这一部分将要描述USBD(USB Host Driver)的典型应用.例如初始化,client注册,动态连接注册,设备配置,数据传输,同时还探讨了USBD内部设计的关键特性.这部 ...
- ubuntu 14.04LTS 环境下配置NFS服务
简言之,NFS(Network FileSystem,网络文件系统)用于在不同机器,不同操作系统之间通过网络互相分享各自的文件.NFS设计之初就是为了在不同的系统间使用,所以它的通讯协议设计与主机及操 ...
- CentOS 5.5 下安装Countly Web Server过程记录
CentOS 5.5 下安装Countly Web Server过程记录 1. 系统更新与中文语言包安装 2. 基本环境配置: 2.1. NodeJS安装 依赖项安装 yum -y install g ...
- 从后台绑定数据到ligerui 的comboBox下拉框组件
这次来记录一下ligerUI的comboBox下拉框组件,ligerUI的API里也有相关描写叙述,上面都是前台写死数据,然后显示在组件中,我这次要说的是将后台的数据绑定到下拉框组件中,废话不多说. ...
- vxWorks下dosFs文件系统的创建
.cdromFs:允许系统从按照ISO9660标准文件系统格式化的CD-ROM上读取设备: 通常文件系统驱动位于磁盘(块存取)设备驱动和IO系统之间,这一点在VxWorks中也不例外,但它在此基础上扩 ...
- Linux下的NFS快速配置教程与安全策略
[51CTO专稿]在Linux下实现文件共享有多种方式,NFS就是其中之一.网络文件系统(NFS)协议是由Sun MicroSystem在20世纪80年代为了提供对共享文件的远程访问而设计和实现的.该 ...
- Java多线程21:多线程下的其他组件之CyclicBarrier、Callable、Future和FutureTask
CyclicBarrier 接着讲多线程下的其他组件,第一个要讲的就是CyclicBarrier.CyclicBarrier从字面理解是指循环屏障,它可以协同多个线程,让多个线程在这个屏障前等待,直到 ...
- 自绘制HT For Web ComboBox下拉框组件
传统的HTML5的下拉框select只能实现简单的文字下拉列表,而HTforWeb通用组件中ComboBox不仅能够实现传统HTML5下拉框效果,而且可以在文本框和下拉列表中添加自定义的小图标,让整个 ...
- CentOS6.5下搭建NFS文件服务器
本文参考这里 CentOS下搭建NFS服务器总结 环境介绍: 1. 服务器: 192.168.0.100 2. 客户机: 192.168.0.101 安装软件包: 服务器和客户机都要安装nfs 和 r ...
随机推荐
- 【Leetcode】【简单】【1. 两数之和】【JavaScript】
题目描述 1. 两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能 ...
- Java 基础 - Collection集合通用方法及操作/ArrayList和LinkedList的差别优势 /弃用的Vector
Collection的笔记: /**存储对象考虑使用: * 1.数组, ①一旦创建,其长度不可变!② 长度难于应对实际情况 * 2.Java集合, ①Collection集合: 1.set: 元素无序 ...
- 【简易DFS/BFS+标记搜索次序的数组】zznu-2025 : 简单环路
2025 : 简单环路 时间限制:1 Sec 内存限制:128 MiB提交:145 答案正确:41 提交 状态 编辑 讨论区 题目描述 有一个N x M 大小的地图,地图中的每个单元包含一个大写字母. ...
- spring lookup method 注入
lookup method注入是spring动态改变bean里方法的实现.方法执行返回的对象,使用spring内原有的这类对象替换,通过改变方法返回值来动态改变方法.内部实现为使用cgl ...
- Nginx 配置参数中文说明
Nginx配置参数中文详细说明: #定义Nginx运行的用户和用户组 user www www; # #nginx进程数,建议设置为等于CPU总核心数. worker_processes ; # #全 ...
- Http 缓存剖析
缓存一直是前端优化的主战场, 利用好缓存就成功了一半. 本篇从http请求和响应的头域入手, 让你对浏览器缓存有个整体的概念. 最终你会发现强缓存, 协商缓存 和 启发式缓存是如此的简单. 导读 浏览 ...
- 详解es6中Proxy代理对象的作用
在es6中新添加了Proxy,那么它有什么作用啊?Proxy本意为代理,而es6中的Proxy也就是代理对象,那么代理对象感觉听起来很模糊,在这里就解释一下Proxy代理对象的作用. Proxy的主要 ...
- tomcat——web.xml
本机tomcat位置:D:\tomcat7\apache-tomcat-7.0.61 web.xml web工程的部署描述文件.在web工程中此文件并不是必须有的. 位置:D:\tomcat7\apa ...
- Find a multiple POJ - 2356 【鸽巢原理应用】
Problem DescriptionThe input contains N natural (i.e. positive integer) numbers ( N <= 10000 ). E ...
- Oracle - 特殊字符问题
Oracle更新表字段或者查询表字段时内容中含有特殊字符&的解决方法 现象 解决方式 1. 字符串拼接 UPDATE T_MENU_INFO SET menu_code='/ABeptjk/g ...