1、什么是nsswithch.conf(服务搜索顺序)文件呢?数据库
nsswitch.conf(name service switch configuration,名字服务切换配置)文件位于/etc目录下,由它规定经过哪些途径以及按照什么顺序以及经过这些途径来查找特定类型的信息,还能够指定某个方法奏效或失效时系统将采起什么动做。服务器
Nsswitch.conf中的每一行配置都指明了如何搜索信息,每行配置的格式以下:
Info: method[[action]] [method[[action]]...]
其中,info指定该行所描述的信息的类型,method为用来查找该信息的方法,action是对前面的method返回状态的响应。action要放在方括号里。网络
2、nsswitch.conf的工做原理函数
当须要提供nsswitch.conf文件所描述的信息的时候,系统将检查含有适当info字段的配置行。它按照从左向右的顺序开始执行配置行中指定的方法。在默认状况下,若是找到指望的信息,系统将中止搜索。若是没有指定action,那么当某个方法未能返回结果时,系统就会尝试下一个动做。有可能搜索结束都没有找到想要的信息。测试
一、信息(Info).net
Nsswitch.conf文件一般控制着用户(在passwd中)、口令(在shadow中)、主机IP和组信息(在group中)的搜索。下面的列表描述了nsswitch.conf文件控制搜索的大多数信息(Info项)的类型。dns
automount:rpc |
自动挂载(/etc/auto.master和/etc/auto.misc)get |
bootparams:域名 |
无盘引导选项和其余引导选项(参见bootparam的手册页) |
ethers: |
MAC地址 |
group: |
用户所在组(/etc/group),getgrent()函数使用该文件 |
hosts: |
主机名和主机号(/etc/hosts),gethostbyname()以及相似的函数使用该文件 |
networks: |
网络名及网络号(/etc/networks),getnetent()函数使用该文件 |
passwd: |
用户口令(/etc/passwd),getpwent()函数使用该文件 |
protocols: |
网络协议(/etc/protocols),getprotoent()函数使用该文件 |
publickey: |
NIS+及NFS所使用的secure_rpc的公开密钥 |
rpc: |
远程过程调用名及调用号(/etc/rpc),getrpcbyname()及相似函数使用该文件 |
services: |
网络服务(/etc/services),getservent()函数使用该文件 |
shadow: |
映射口令信息(/etc/shadow),getspnam()函数使用该文件 |
aiases: |
邮件别名,sendmail()函数使用该文件 |
files: |
搜索本地文件,如/etc/passwd和/etc/hosts |
nis: |
搜索NIS数据库,nis还有一个别名,即yp |
dns: |
查询DNS(只查询主机) |
compat: |
passwd、group和shadow文件中的±语法(参见本节后面的相关内容) |
STATUS: |
STATUS的取值以下: NOTFOUND:方法已经执行,可是并无找到待搜索的值。 默认的动做是continue。 SUCCESS:方法已经执行,而且已经找到待搜索的值,没有返回错误。默认动做是return。 UNAVAIL:方法失败,缘由是永久不可用。举例来讲,所需的文件不可访问或者所需的服务器可能停机。默认的动做是continue。 TRYAGAIN:方法失败,缘由是临时不可用。举例来讲,某个文件被锁定,或者某台服务器超载。默认动做是continue。 |
action: |
action的取值以下: return:返回到调用例程,带有返回值,或者不带返回值。 continue:继续执行下一个方法。任何返回值都会被下一个方法找到的值覆盖。 |
示例: |
举例来讲,下面这行取自nsswitch.conf文件,它的做用是让系统首先使用DNS来搜索给定主机的IP地址。DNS方法后面的动做项是测试该方法所返回的状态是否为“非(!)UNAVAIL”。 hosts dns [!UNAVAIL=return] files 若是DNS方法没有返回UNAVAIL(!UNAVAIL),也就是说DNS返回SUCCESS、NOTFOUND或者TRYAGAIN,那么系统就会执行与该STATUS相关的动做(return)。其结果就是,只有在DNS服务器不可用的状况下才会使用后面的方法(files)。 若是DNS服务器并非不可用(两次否认以后就是“可用”),那么搜索返回域名或者报告未找到域名。只有当服务器不可用的时候,搜索才会使用files方法(检查本地的/etc/hosts文件)。 |