分享
 
 
 

Unix远程命令调用的实现

王朝system·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

计算机网络的发展虽然十分迅速,但当前网络资源利用率却比较低。网络中相同资源的重复安装和配置增加了许多不必要的运营成本,如何有效地利用网络中有限的资源实现协同工作是十分现实的问题。本文介绍一种Unix系统远程命令调用机制,它不是常规意义上的telnet功能,而是一种更为快捷方便的利用NFS协议建立起来的on命令操作,并在此基础上实现了丰富的远程控制功能,可广泛地应用于局域网和广域网。

系统要求 ● 客户端和远程系统需同时运行Unix系统,HP-UX、Sun Solaris等均可; ● 客户端设置为NFS服务器,远程系统设置为NFS客户机,这样可将客户端环境及工作目录仿真到远程系统,利用远程系统丰富的资源,执行命令并将结果返回到客户端; ● 通过inetd服务进程在远程系统配置好rexd服务,通过RPC(Remote Process Control),响应客户端运行的on命令远程调用请求; ● 实现远程调用的用户要在两端系统中拥有相同的UserID和GroupID; ● 客户端只能以普通用户而非超级用户(root)执行on命令操作; ● 在利用该机制进行软件开发时,两端操作系统版本号要保持一致,否则会导致生成的二进制代码不兼容的问题。 实现原理 用户在客户端本地执行“on host command”实现在远程主机上进行命令调用的功能。远程主机收到on命令调用请求后自动由inetd服务进程启动rexd进程。如果请求包中附带的UserID在远程主机中存在,则以该用户执行相应命令,否则出错退出。 命令执行期间rexd自动将客户端工作环境仿真到远程系统上,并通过NFS协议自动将其工作目录临时挂接到远程系统的特定目录下。命令执行完毕输出结果返回到客户端后,用户工作目录自动卸载,rexd进程也自动退出。所有这一切后台操作对用户而言都是透明的。 设置步骤 本文以HP-UX 10.20为例介绍远程调用的具体实现过程(在其他Unix系统上,如SCO OpenServer上同样调试通过)。以下配置均需超级用户(root)执行。 1.远程系统 设置并启动NFS客户机 : # vi /etc/rc.config.d/nfs.conf nfs.client=1 # /sbin/init.d/nfs.client start 设置并启动rexd后台服务程序,自动响应客户端远程调用请求: # vi /etc/inetd.conf rpc stream tcp nowait root /usr/sbin/rpc.rexd 100017 1 rpc.rexd # inetd -c 2.客户端系统 设置并启动NFS服务器: # vi /etc/rc.config.d/nfs.conf nfs.server=1 # /sbin/init.d/nfs.server start 假设远程主机名为server,将本地资源授权给远程系统: # vi /etc/exports / -root = server # exportfs -ua # exportfs -a 这样一来,当远程系统rpc.rexd收到客户端on远程调用请求时,自动检查客户端配置情况,如授权许可则通过NFS协议将客户端用户工作目录自动挂接到 /usr/spool/rexd/rexdXXXXXX,其中XXXXXX是运行rexd的进程序列号。以上任何一个环节出错都会导致远程调用失败并返回相应错误信息。 命令调用 on 命令只允许以普通用户执行,格式如下: on [ -i | -n ] [ -d ] hostname [command] 例如: on -i server on server ls -l /home/yyf 其中: ● -i: 表示交互式操作; ● -n: 命令执行期间无需输入参数; ● -d: 调试模式; ● hostname: 远程主机名; ● command: 要执行的命令,如果省略则进入一个交互式的shell提示符下,以后发送的每一个命令都将在远程主机仿真的用户工作目录下执行(如/var/spool/rexd/rexda00756/home/yyf)。 安全考虑 ● 为最大限度地保护本地文件系统,以防止非法存取,客户端设置/etc/exports时应通过授权给确定的远程主机普通用户而非超级用户操作,明确只能在指定的远程主机上调用命令。如: /home -rw = host1:host2 /usr -rw = host3 ● 在远程系统上编辑安全设置文件: /var/adm/inetd.sec 仅限制在特定的客户机上执行on命令调用。 ● 清理远程系统中不必要的普通用户,防止客户端任意用户执行远程命令调用。 ● 在远程系统上启动rpc.rexd服务进程时带上 -r 参数,增强对客户端系统的安全检查,或带上 -l logfile参数将每次远程调用请求信息(包括诊断、警告、出错等)记入特定日志文件,供管理员定期监控分析。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有