CentOS6 上 NIS 设置

2024-03-24 10:48
文章标签 设置 centos6 nis

本文主要是介绍CentOS6 上 NIS 设置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先配置好网络,设定主机名,使各节点处于同一子网内,可以连通。
仍以 n01, n02, n03 为例,其中 n01 上装nis服务器,其他两个为客户端。

服务器端:

    1. 安装服务器软件 
       yum install ypserv   # 依赖 portmap
    2. 设置 time-stream 和 time-dgram 服务的启动状态并设为开机启动
       chkconfig time-stream on
       chkconfig time-dgram on
       chkconfig xinetd on
       service xinetd restart
       (如果没有这两个服务应先装 xinetd。以前好像是 time-dgram 和 time-stream 服务)
    3. 设置 NIS 域名
       nisdomainname mynis  # 假设nis域名叫 mynis
       echo '/bin/nisdomainname mynis' >> /etc/rc.local
       echo 'NISDOMAIN=mynis'  >> /etc/sysconfig/network  # 这句到底有什么用不清楚,没有似乎也行
    4. 设置 ypserv 服务的配置文件 /etc/ypserv.conf, 比如
       127.0.0.0/255.255.255.0  : * : * : none
       192.168.1.0/255.255.255.0 : * : * : none
       *    : * : * : deny
       其实不做修改,默认的就能用。
    5. 添加安全配置文件 /var/yp/securenets
       host 127.0.0.1
       255.255.255.0 192.168.1.0   # 指定允许的网段
    6. 启动NIS服务器(启动之前需检查 rpcbind/portmap 服务是否启动)
       service rpcbind status
       service ypserv start
       service yppasswdd start
       chkconfig ypserv on
       chkconfig yppasswdd on
    7. 构建 NIS 数据库
       /usr/lib/yp/ypinit -m 或 /usr/lib64/yp/ypinit -m
       如果不添加“从服务器”,按 ctrl-D 结束即可
    8. 重启服务
       service ypserv restart
       service yppasswd restart
    9. 关闭防火墙 (如需开启防火墙,需单独配置以固定服务端口)
       service iptables stop
       

客户端:

    1. 设置 NIS 域名
       nisdomainname mynis  # 假设nis域名叫 mynis
       echo '/bin/nisdomainname mynis' >> /etc/rc.local
    2. 设置 /etc/yp.conf 配置文件
       echo "domain mynis server n01" >> /etc/yp.conf
    3. 设置 /etc/nsswitch.conf 文件,以指定通过 nis 进行身份认证
       passwd:  files nis
       shadow:  files nis
       group:   files nis
       hosts:   files nis dns
       其他默认即可
    4. 启动 ypbind 服务
       service rpcbind status
       service ypbind start
       chkconfig ypbind on

当一切正常启动后,就可以用 yptest 进行测试了,如果输出到 Test 9: yp_all 且只有一项错误,即
Test 3: yp_match
WARNING: No such key in map (Map passwd.byname, key nobody)
的话, 则不用管它,说明一切正常,NIS 可以正常使用了。此时在服务器上新建个用户并设好密码后,在客户端 就能以此用户登录了。


创建用户后重新到 /var/yp 下 make 更新数据库即可
客户端无论是用 passwd 还是用 yppasswd 修改密码,结果都一样,即通过 yppasswdd 服务修改的是NIS服务器上 的密码。但在服务器端,如果只通过 passwd 修改密码,客户端密码暂时没有修改,需通过 root 在 /var/yp 下  make 一下更新数据库才有效;如果在服务器端用 yppasswd 修改密码,则客户端即时生效。
   
补充:在客户端上,如果我是用 system-config-authentication 设置的nis身份认证的话,则是上面说的, 
passwd 与 yppasswd 效果一样。 但另一个客户节点上我直接修改 /etc/nsswitch.conf 文件,却只能用 
yppasswd 修改,用 passwd 修改时提示错误 passwd: Authentication token manipulation error。而最初说的 服务器端 passwd 与 yppasswd 效果不一致,其前提是服务器上未启用nis身份认证,如果只是通过修改 
/etc/nsswitch.conf 启用的话,依然如此,但如果通过 system-config-authentication 启用nis认证的话,则  passwd 与 yppasswd 效果便一致了(这说的只是服务器上普通用户自己修改密码,如果是root帮普通用户修改密 码的话,passwd <user> 修改的依然不是nis密码,yppasswd <user> 修改的才是 nis 密码)。经确认后,通过  system-config-authentication 设置和直接修改 /etc/nsswitch.conf 确实不同,前者必定多做了写操作,使得  passwd 与 yppasswd 效果一致。

centos6 中,原来的 portmap 服务由 rpcbind 服务取代(protmap包改名为rpcbind包)。若 rpcbind 服务重启 了,ypxxx 的服务最好也重启一下。比如服务器上已经启动了 ypserv 服务,然后又用 system-config- authentication 设置nis身份认证的话,在启用时会遇到重启 ypbind 服务失败。因为它重启了 rpcbind,却没有 重启 ypserv 和 yppasswdd,所以手动重启下  ypserv 和 yppasswdd 再重启 ypbind 就可以了。


===========================================

最初是在 virtualbox 虚拟机上做的实验,结果遇到一系列莫名其妙的问题,后来发现应该是虚拟机网络不稳定造成的,导致本来没问题的操作也出现了问题。还成 vmware 就没事了,看来 virtualbox 跟 vmware 比差距还是很大的。遇到的问题如下:

可能是由于 virtualbox 虚拟机的网络不稳定,本来客户机上 yptest 成功了,但过一会
再 yptest 由不行了,再重启 ypbind 服务也启动不了。如果这时先重启一下 network 服务
再重启 ypbind 服务就又能 yptest 了,只不过很快又会坏掉,莫名其妙!

   客户端启动 ypbind 服务失败:
   Listening for an NIS domain server..YPBINDPROC_DOMAIN: Domain not bound
   (这时 ypbind 服务已经启动只是不能正常工作,反而导致前台响应迟缓,最好先关掉)
   发现重启一下 network 服务再重启 ypbind 方可
   /etc/init.d/ypbind  stop
   /etc/init.d/network restart
   /etc/init.d/ypbind  start



http://home.ustc.edu.cn/~hchunhui/tips.html

这篇关于CentOS6 上 NIS 设置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/841371

相关文章

Java实现为PDF设置背景色和背景图片

《Java实现为PDF设置背景色和背景图片》在日常的文档处理中,PDF格式因其稳定性和跨平台兼容性而广受欢迎,本文将深入探讨如何利用Spire.PDFforJava库,以简洁高效的方式为你的PDF文档... 目录库介绍与安装步骤Java 给 PDF 设置背景颜色Java 给 PDF 设置背景图片总结在日常的

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

Java利用Spire.XLS for Java设置Excel表格边框

《Java利用Spire.XLSforJava设置Excel表格边框》在日常的业务报表和数据处理中,Excel表格的美观性和可读性至关重要,本文将深入探讨如何利用Spire.XLSforJava库... 目录Spire.XLS for Java 简介与安装Maven 依赖配置手动安装 JAR 包核心API介

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)