要建立一个安全linux服务器就首先要了解Linux环境下和网络服务相关的配置文件的含义及如何进行安全的配置。在linux系统中,TCP/IP网络是通过若干个文本文件进行配置的,也许你需要编辑这些文件来完成联网工作,但是这些配置文件大都可以通过配置命令linuxconf(其中网络部分的配置可以通过netconf命令来实现)命令来实现。下面介绍基本的TCP/IP网络配置文件。
Itn7Kl _cra_(b * /etc/conf.modules文件
cm^:3(yYX 该配置文件定义了各种需要在启动时加载的模块的参数信息。这里主要着重讨论关于网卡的配置。在使用linux做网关的情况下,Linux服务器至少需要配置两块网卡。为了减少启动时可能出现的问题,linux内核不会自动检测多个网卡。对于没有将网卡的驱动编译到内核而是作为模块动态载入的系统若需要安装多块网卡,应该在"conf.modules"文件中进行相应的配置。
*h6Lh]7 若设备驱动被编译为模块(内核的模块):对于PCI设备,模块将自动检测到所有已经安装到系统上的设备;对于ISA卡,则需要向模块提供IO地址,以使模块知道在何处寻找该卡,这些信息在“/etc/conf.modules”中提供。
g}HB|$P7 例如,我们有两块ISA总线的3c509卡,一个IO地址是0x300,另一个是0x320。编辑conf.modules文件如下:
F&?55@b alias eth0 3c509
{B^V_TX2 alias eth1 3c509
u%n6!Zx options 3c509 io=0x300,0x320
9+<%74|, 这是说明3c509的驱动程序应当分别以eth0或eth1的名称被加载(alias eth0,eth1),并且它们应该以参数io=0x300,0x320被装载,来通知驱动程序到哪里去寻找网卡,其中0x是不可缺少的。
$B6CLWB 对于PCI卡,仅仅需要alias命令来使ethN和适当的驱动模块名关联,PCI卡的IO地址将会被自动的检测到。对于PCI卡,编辑conf.modules文件如下:
@pq#? alias eth0 3c905
.Y B}w alias eth1 3c905
HsrIw 若驱动已经被编译进了内核:系统启动时的PCI检测程序将会自动找到所有相关的网卡。ISA卡一般也能够被自动检测到,但是在某些情况下,ISA卡仍然需要做下面的配置工作:
c"qaULY 在"/etc/lilo.conf"中增加配置信息,其方法是通过LILO程序将启动参数信息传递给内核。对于ISA卡,编辑lilo.conf文件,增加如下内容:
E+ wd9/; append=" ether="0,0,eth0 ether="0,0,eth1"
f4.k%| ] 注:先不要在lilo.conf中加入启动参数,测试一下你的ISA卡,若失败再使用启动参数。
lR]z8& 如果用传递启动参数的方法,eth0和eth1将按照启动时被发现的顺序来设置。
g$C-G5/bjD * /etc/HOSTNAME文件
1n}q6oa= 该文件包含了系统的主机名称,包括完全的域名,如:deep.openarch.com。
c 32IO&W4 * /etc/sysconfig/network-scripts/ifcfg-ethN文件
.Cv0Ze 在RedHat中,系统网络设备的配置文件保存在“/etc/sysconfig/network-scripts”目录下,ifcfg-eth0包含第一块网卡的配置信息,ifcfg-eth1包含第二块网卡的配置信息。
S;a'@5 下面是“/etc/sysconfig/network-scripts/ifcfg-eth0”文件的示例:
K"~Tk`[0Q DEVICE=eth0
_ 4:@+{ IPADDR=208.164.186.1
QP/6N9/ NETMASK=255.255.255.0
[^wEKRt& NETWORK=208.164.186.0
_hP siZY9 BROADCAST=208.164.186.255
E({+2}=1 ONBOOT=yes
u6&<Bv BOOTPROTO=none
r(sQI#
P USERCTL=no
"-aak )7w 若希望手工修改网络地址或在新的接口上增加新的网络界面,可以通过修改对应的文件(ifcfg-ethN)或创建新的文件来实现。
JNhHQvi\ DEVICE=name name表示物理设备的名字
w`Q"m x* IPADDR=addr addr表示赋给该卡的IP地址
0Y rdu,c NETMASK=mask mask表示网络掩码
RiHOX&-7 NETWORK=addr addr表示网络地址
Wn;B ~ BROADCAST=addr addr表示广播地址
a^yBtb~,P ONBOOT=yes/no 启动时是否激活该卡
lZT9 SDtS none:无须启动协议
h{zE;!+)D bootp:使用bootp协议
@\-i3EhR dhcp:使用dhcp协议
J6x#c`Y USERCTL=yes/no 是否允许非root用户控制该设备
yn&AMq
]o * /etc/resolv.conf文件
ftBbO8e 该文件是由域名解析器(resolver,一个根据主机名解析IP地址的库)使用的配置文件,示例如下:
]3.Un,F search openarch.com
Cj~45)r nameserver 208.164.186.1
v(ABZNIn nameserver 208.164.186.2
Q`$Q(/ “search domainname.com”表示当提供了一个不包括完全域名的主机名时,在该主机名后添加domainname.com的后缀;“nameserver”表示解析域名时使用该地址指定的主机为域名服务器。其中域名服务器是按照文件中出现的顺序来查询的。
LW?Zd= * /etc/host.conf文件
LxqK@Q<B 该文件指定如何解析主机名。linux通过解析器库来获得主机名对应的IP地址。下面是一个“/etc/host.conf”的示例:
,(aOTFQS order bind,hosts
7U=|>)Q0s multi on
~ou1{NS ospoof on
kOfq6[JC “order bind,hosts”指定主机名查询顺序,这里规定先使用DNS来解析域名,然后再查询“/etc/hosts”文件(也可以相反)。
?f1PQ “multi on”指定是否“/etc/hosts”文件中指定的主机可以有多个地址,拥有多个IP地址的主机一般称为多穴主机。
!eb}jL “nospoof on”指不允许对该服务器进行IP地址欺骗。IP欺骗是一种攻击系统安全的手段,通过把IP地址伪装成别的计算机,来取得其它计算机的信任。
P'o:Vhm_H * /etc/sysconfig/network文件
cG|)z<Z 该文件用来指定服务器上的网络配置信息,下面是一个示例:
\BB(0Ah+t NETWORK=yes
M6(o J* RORWARD_IPV4=yes
bu`8QQ"C HOSTNAME=deep.openarch.com
Z4S0{:XY GAREWAY=0.0.0.0
eIVCg-l} GATEWAYDEV=
OkSJob NETWORK=yes/no 网络是否被配置;
Z2z"K<Z W FORWARD_IPV4=yes/no 是否开启IP转发功能
7%rSo^t,L HOSTNAME=hostname hostname表示服务器的主机名
/Mq]WXq[V GAREWAY=gw-ip gw-ip表示网络网关的IP地址
D>& ;K{! GAREWAYDEV=gw-dev gw-dw表示网关的设备名,如:etho等
Vp3
9`m-W 注意:为了和老的软件相兼容,“/etc/HOSTNAME”文件应该用和HOSTNAME=hostname相同的主机名。
eF8!}|*N * /etc/hosts文件
npcB+6 当机器启动时,在可以查询DNS以前,机器需要查询一些主机名到IP地址的匹配。这些匹配信息存放在/etc/hosts文件中。在没有域名服务器情况下,系统上的所有网络程序都通过查询该文件来解析对应于某个主机名的IP地址。
uQy5t:! 下面是一个“/etc/hosts”文件的示例:
%9.]
bd|%F IP Address Hostname Alias
KX*Hev'K 127.0.0.1 Localhost Gate.openarch.com
$`q8-+{ 208.164.186.1 gate.openarch.com Gate
a
}6Fj&hj ………… ………… ………
KM$5ZbCF: 最左边一列是主机IP信息,中间一列是主机名。任何后面的列都是该主机的别名。一旦配置完机器的网络配置文件,应该重新启动网络以使修改生效。使用下面的命令来重新启动网络:/etc/rc.d/init.d/network restart
?VM# Nf\ * /etc/inetd.conf文件
Dd+ f,$ 众所周知,作为服务器来说,服务端口开放越多,系统安全稳定性越难以保证。所以提供特定服务的服务器应该尽可能开放提供服务必不可少的端口,而将与服务器服务无关的服务关闭,比如:一台作为www和ftp服务器的机器,应该只开放80和25端口,而将其他无关的服务如:finger auth等服务关掉,以减少系统漏洞。
%(4G[R[ 而inetd,也叫作“超级服务器”,就是监视一些网络请求的守护进程,其根据网络请求来调用相应的服务进程来处理连接请求。inetd.conf则是inetd的配置文件。inetd.conf文件告诉inetd监听哪些网络端口,为每个端口启动哪个服务。在任何的网络环境中使用linux系统,第一件要做的事就是了解一下服务器到底要提供哪些服务。不需要的那些服务应该被禁止掉,最好卸载掉,这样黑客就少了一些攻击系统的机会。查看“/etc/inetd.conf”文件,了解一下inetd提供哪些服务。用加上注释的方法(在一行的开头加上#号),禁止任何不需要的服务,再给inetd进程发一个SIGHUP信号。
~$g$31/ 第一步:把文件的许可权限改成600。
tPO\ e] [root@deep]# chmod 600 /etc/inetd.conf
ESOuDD2< 第二步:确信文件的所有者是root。
/m,0H)w1 [root@deep]# stat /etc/inetd.conf
qX'w}nJ}H} 第三步:编辑“inetd.conf”文件(vi /etc/inetd.conf),禁止所有不需要的服务,如:ftp、telnet、shell、login、exec、talk、ntalk、imap、pop-2、pop-3、finger、auth,等等。如果你觉得某些服务有用,可以不禁止这些服务。但是,把这些服务禁止掉,系统受攻击的可能性就会小很多。改变后的“inetd.conf”文件的内容如下面所示:
+3VDapfin # To re-read this file after changes, just do a 'killall -HUP inetd'
7 mulNq #
x<)%Gs}tb #echo stream tcp nowait root internal
S312h'K
j #echo dgram udp wait root internal
a/@<KnT #discard stream tcp nowait root internal
Sz0M8fYT] #discard dgram udp wait root internal
[BS3y`c #daytime stream tcp nowait root internal
y^; =+Z #daytime dgram udp wait root internal
uA;3R\6? #chargen stream tcp nowait root internal
wK8/`{B9 #chargen dgram udp wait root internal
/>fP )56* #time stream tcp nowait root internal
'BT}'qN #time dgram udp wait root internal
T-7'#uB.m #
3Rid1;L0U # These are standard services.
OHnHSb'?\ #
$cO"1mu #ftp stream tcp nowait root /usr/sbin/tcpd in.ftpd -l -a
aubmA0w #telnet stream tcp nowait root /usr/sbin/tcpd in.telnetd
<}pwFl8C) #
%
'>S9Ja3 # Shell, login, exec, comsat and talk are BSD protocols.
!O$ */7 #
a!"81*&4# #shell stream tcp nowait root /usr/sbin/tcpd in.rshd
W(*:8}m,p #login stream tcp nowait root /usr/sbin/tcpd in.rlogind
e_J_rx #exec stream tcp nowait root /usr/sbin/tcpd in.rexecd
]pLQ;7f7D #comsat dgram udp wait root /usr/sbin/tcpd in.comsat
+Ux)m4}j #talk dgram udp wait root /usr/sbin/tcpd in.talkd
NLDmZra #ntalk dgram udp wait root /usr/sbin/tcpd in.ntalkd
=J.)xDx* #dtalk stream tcp wait nobody /usr/sbin/tcpd in.dtalkd
oRM EC7!A0 #
od>DSn3T # Pop and imap mail services et al
y:!MWZ #
x&3!z[m@@ #pop-2 stream tcp nowait root /usr/sbin/tcpd ipop2d
{]ZZ] #pop-3 stream tcp nowait root /usr/sbin/tcpd ipop3d
`n8) o %E9 #imap stream tcp nowait root /usr/sbin/tcpd imapd
8$avPD3jx #
<i'4EnO # The Internet UUCP service.
bAeN>~WvY #
SsjO1F #uucp stream tcp nowait uucp /usr/sbin/tcpd /usr/lib/uucp/uucico -l
-B2>~#L #
cOUsbxYTD # Tftp service is provided primarily for booting. Most sites
u(JC 4w' # run this only on machines acting as "boot servers." Do not uncomment
52B
ye # this unless you *need* it.
hCO*gtA)M #
oS)0,p #tftp dgram udp wait root /usr/sbin/tcpd in.tftpd
zypZ3g{vz #bootps dgram udp wait root /usr/sbin/tcpd bootpd
gf+Kr02~ #
5EIhCbA # Finger, systat and netstat give out user information which may be
ErF;5ec # valuable to potential "system crackers." Many sites choose to disable
_<5 o1 # some or all of these services to improve security.
;VS;),h/ #
<FH3ePz #finger stream tcp nowait root /usr/sbin/tcpd in.fingerd
Ygn"7 #cfinger stream tcp nowait root /usr/sbin/tcpd in.cfingerd
2F-!SI #systat stream tcp nowait guest /usr/sbin/tcpd /bin/ps -auwwx
lj.z> #netstat stream tcp nowait guest /usr/sbin/tcpd /bin/netstat -f inet
BQf}S
+ #
87EI<\mP # Authentication
);$Uf!v4 #
'{kNXCnZ #auth stream tcp nowait nobody /usr/sbin/in.identd in.identd -l -e -o
]+[ NX)= #
P]2M # End of inetd.conf
1?HUXN#, 注意:改变了“inetd.conf”文件之后,别忘了给inetd进程发一个SIGHUP信号(killall –HUP inetd)。
eif<aG5 [root@deep /root]# killall -HUP inetd
} oJ+2OepN 第四步:
wP1dPl_j:0 为了保证“inetd.conf”文件的安全,可以用chattr命令把它设成不可改变。把文件设成不可改变的只要用下面的命令:
~fsAPIQ [root@deep]# chattr +i /etc/inetd.conf
0TSj]{[ 这样可以避免“inetd.conf”文件的任何改变(意外或是别的原因)。一个有“i”属性的文件是不能被改动的:不能删除或重命名,不能创建这个文件的链接,不能往这个文件里写数据。只有系统管理员才能设置和清除这个属性。如果要改变inetd.conf文件,你必须先清除这个不允许改变的标志:
!-r@_tn| [root@deep]# chattr -i /etc/inetd.conf
mLD0Lu_Ob3 但是对于诸如sendmail,named,www等服务,由于它们不象finger,telnet等服务,在请求到来时由inet守护进程启动相应的进程提供服务,而是在系统启动时,作为守护进程运行的。而对于redhat linux,提供了一个linuxconfig命令,可以通过它在图形界面下交互式地设置是否在启动时运行相关服务。也可以通过命令来设置是否启动时启动某个服务,如:[root@deep]# chkconfig –level 35 named off
zsI0Q47\ 具体命令可以参考man chkconfig的说明。linux网络服务器配置基础(下)
T4T_32`XR * /etc/hosts.allow文件
'9GHmtdO, 但是对于telnet、ftp等服务,如果将其一同关闭,那么对于管理员需要远程管理时,将非常不方便。linux提供另外一种更为灵活和有效的方法来实现对服务请求用户的限制,从而可以在保证安全性的基础上,使可信任用户使用各种服务。Linux提供了一个叫TCP wrapper的程序。在大多数发布版本中该程序往往是缺省地被安装。利用TCP wrapper你可以限制访问前面提到的某些服务。而且TCP wrapper的记录文件记录了所有的企图访问你的系统的行为。通过last命令查看该程序的log,管理员可以获知谁曾经或者企图连接你的系统。
kgK7 T 在/etc目录下,有两个文件:hosts.deny hosts.allow 通过配置这两个文件,你可以指定哪些机器可以使用这些服务,哪些不可以使用这些服务。
,*0>CBJvv 当服务请求到达服务器时,TCP wrapper就按照下列顺序查询这两个文件,直到遇到一个匹配为止:
xk86?2b{) 1.当在/etc/hosts.allow里面有一项与请求服务的主机地址项匹配,那么就允许该主机获取该服务
mKZ?H$E%% 2.否则,如果在/etc/hosts.deny里面有一项与请求服务的主机地址项匹配,就禁止该主机使用该项服务。
O7j$bxk/^ 3.如果相应的配置文件不存在,访问控制软件就认为是一个空文件,所以可以通过删除或者移走配置文件实现对清除所有设置。在文件中,空白行或者以#开头的行被忽略,你可以通过在行前加#实现注释功能。
J{$C}8V 配置这两个文件是通过一种简单的访问控制语言来实现的,访问控制语句的基本格式为:
!.L%kw7z 程序名列表:主机名/IP地址列表。
[7]p\'j 程序名列表指定一个或者多个提供相应服务的程序的名字,名字之间用逗号或者空格分割,可以在inetd.conf文件里查看提供相应服务的程序名:如上面的文件示例中,telent所在行的最后一项就是所需的程序名:in.telnetd。
|LKhT4rE 主机名/IP地址列表指定允许或者禁止使用该服务的一个或者多个主机的标识,主机名之间用逗号或空格分隔。程序名和主机地址都可以使用通配符,实现方便的指定多项服务和多个主机。
H's67E/>* linux提供了下面灵活的方式指定进程或者主机列表:
-]5dD VSO 1.一个以"."起始的域名串,如.amms.ac.cn,那么
www.amms.ac.cn就和这一项匹配
8x'rNb 2.以"."结尾的IP串如202.37.152.那么IP地址包括202.37.152.的主机都与这一项匹配。
df#DKV: 3.格式为n.n.n.n/m.m.m.m表示网络/掩码,如果请求服务的主机的IP地址与掩码的位与的结果等于n.n.n.n,那么该主机与该项匹配。
pw:<a2. 4.ALL表示匹配所有可能性
yyk[oH-Q 5.EXPECT表示除去后面所定义的主机。如:list_1 EXCEPT list_2 表示list_1主机列表中除去List_2所列出的主机
(|ga#%iI 6.LOCAL表示匹配所有主机名中不包含"."的主机
r0QjCFSF= 上面的几种方式只是linux提供的方式中的几种,但是对于我们的一般应用来说是足够了。我们通过举几个例子来说明这个问题:
|x{:GWq 例一:我们只希望允许同一个局域网的机器使用服务器的ftp功能,而禁止广域网上面的ftp服务请求,本地局域网由202.39.154.、202.39.153.和202.39.152.三个网段组成。
X=(8t2 在hosts.deny文件中,我们定义禁止所有机器请求所有服务:
Pf)<