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

相关文章

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

如何关闭 Mac 触发角功能或设置修饰键? mac电脑防止误触设置技巧

《如何关闭Mac触发角功能或设置修饰键?mac电脑防止误触设置技巧》从Windows换到iOS大半年来,触发角是我觉得值得吹爆的MacBook效率神器,成为一大说服理由,下面我们就来看看mac电... MAC 的「触发角」功能虽然提高了效率,但过于灵敏也让不少用户感到头疼。特别是在关键时刻,一不小心就可能触

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的