是时候讲讲NFS客户端和服务器之间反向通道的建立过程了,因为马上就会讲到delegation了。一般情况下,NFS客户端向服务器发送RPC请求,服务器进行处理,这个通道称为正向通道。而delegation需要使用反向通道,当服务器检测到文件冲突后,后向客户端发送RPC请求。客户端接收到请求后释放delegation。与反向通道相关的数据结构是struct nfs4_cb_conn,这个数据结构保存了反向通道中RPC客户端地址、RPC服务器地址等信息,这个数据结构的定义如下:
struct nfs4_cb_conn {
// 这是反向通道中RPC服务器地址,也就是NFS客户端地址
struct sockaddr_storage cb_addr;
// 这是反向通道中RPC客户端地址,也就是NFS服务器地址
struct sockaddr_storage cb_saddr;
// 这是反向通道中RPC服务器地址的长度
size_t cb_addrlen;
// 这是CALLBACK服务的编号 0x40000000
u32 cb_prog;
// NFS客户端中的一个编号,每执行一个SETCLIENTID请求,这个编号加1
// 这是NFS客户端中NFS文件系统的编号,因为NFS客户端可能挂载了多个文件系统
u32 cb_ident; /* minorversion 0 only */
// 这是NFSv4.1中区分不同文件系统的方法
struct svc_xprt *cb_xprt; /* minorversion 1 only */
};
nfs4_cb_conn中cb_ident和cb_xprt的作用相同,都是为了区分NFS客户端挂载的文件系统,只不过cb_ident是NFSv4.0中的方法,cb_xprt是NFSv4.1中的方法。
NFS服务器通过反向通道向NFS客户端发送RPC请求,称为CALLBACK请求,每个CALLBACK请求用数据结构nfs4_callback表示,这个数据结构的定义如下:
struct nfsd4_callback {
// 这是CALLBACK请求使用的一个私有字段,
// 不同的CALLBACK请求中这个字段的值不一样
void *cb_op;
// 向哪个NFS客户端发送CALLBACK请求
struct nfs4_client *cb_clp;
// 每个客户端上可以链接多个CALLBACK请求,这些CALLBACK请求构成了一个链表
struct list_head cb_per_client;
// 这是NFSv4次版本号
u32 cb_minorversion;
// 这里包含了CALLBACK请求的信息,如CALLBACK例程编号,参数,返回值。
struct rpc_message cb_msg;
// 这是CALLBAC