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

相关文章

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

mtu设置多少网速最快? 路由器MTU设置最佳网速的技巧

《mtu设置多少网速最快?路由器MTU设置最佳网速的技巧》mtu设置多少网速最快?想要通过设置路由器mtu获得最佳网速,该怎么设置呢?下面我们就来看看路由器MTU设置最佳网速的技巧... 答:1500 MTU值指的是在网络传输中数据包的最大值,合理的设置MTU 值可以让网络更快!mtu设置可以优化不同的网

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

如何Python使用设置word的页边距

《如何Python使用设置word的页边距》在编写或处理Word文档的过程中,页边距是一个不可忽视的排版要素,本文将介绍如何使用Python设置Word文档中各个节的页边距,需要的可以参考下... 目录操作步骤代码示例页边距单位说明应用场景与高级用China编程途小结在编写或处理Word文档的过程中,页边距是一个

linux服务之NIS账户管理服务方式

《linux服务之NIS账户管理服务方式》:本文主要介绍linux服务之NIS账户管理服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、所需要的软件二、服务器配置1、安装 NIS 服务2、设定 NIS 的域名 (NIS domain name)3、修改主