Redhat Linux下Bind的快速安装
[ 2006/12/25 22:30 | by ipaddr ]
1.使用光盘自带的软件包,安装以下包:
bind
bind-utils
bind-libs
(rpm -i xxx.rpm)
2.
将named服务设置为自启动
(使用ntsysv,chkconfig等工具)
3.
假设你需要解析bcomcn.com,如下操作:
cd /var/named
cp localdomain.zone bcomcn.zone
vi bcomcn.zone
[code]
$TTL 86400
@ IN SOA ns.bcomcn.com. root.bcomcn.com. (
200612230 ; Serial
28800 ; Refresh
14400 ; Retry
3600000 ; Expire
86400 ) ; Minimum
IN NS ns.bcomcn.com.
IN MX 10 mail.bcomcn.com.
ns.bcomcn.com. IN A 192.168.1.5
mail.bcomcn.com. IN A 192.168.1.5
www.bcomcn.com. IN A 192.168.1.5
[/code]
注意,主机名后面带"点"的,表示是一个完整主机,不带点的,表示还要加上当前域名,比如:mail.bcomcn.com. = mail
cp localdomain.zone 192.zone
vi 192.zone
[code]
$TTL 86400
@ IN SOA localhost. root.bcomcn.com. (
200612230 ; Serial
28800 ; Refresh
14400 ; Retry
3600000 ; Expire
86400 ) ; Minimum
IN NS localhost.
5 IN PTR www.bcomcn.com.
[/code]
4.修改/etc/named.conf,加入:
[code]
zone "bcomcn.com" IN {
type master;
file "bcomcn.zone";
allow-update { none; };
};
zone "1.168.192.in-addr.arpa" IN {
type master;
file "192.zone";
allow-update { none; };
};
[/code]
启动named,将本机的DNS服务器设置为本机,用nslookup,或其它工具检测:
nslookup
> set type=mx
> bcomcn.com
(可以查看/var/log/message检查named是否正确启动,是否加载某个Domain的解析.)>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
bind
bind-utils
bind-libs
(rpm -i xxx.rpm)
2.
将named服务设置为自启动
(使用ntsysv,chkconfig等工具)
3.
假设你需要解析bcomcn.com,如下操作:
cd /var/named
cp localdomain.zone bcomcn.zone
vi bcomcn.zone
[code]
$TTL 86400
@ IN SOA ns.bcomcn.com. root.bcomcn.com. (
200612230 ; Serial
28800 ; Refresh
14400 ; Retry
3600000 ; Expire
86400 ) ; Minimum
IN NS ns.bcomcn.com.
IN MX 10 mail.bcomcn.com.
ns.bcomcn.com. IN A 192.168.1.5
mail.bcomcn.com. IN A 192.168.1.5
www.bcomcn.com. IN A 192.168.1.5
[/code]
注意,主机名后面带"点"的,表示是一个完整主机,不带点的,表示还要加上当前域名,比如:mail.bcomcn.com. = mail
cp localdomain.zone 192.zone
vi 192.zone
[code]
$TTL 86400
@ IN SOA localhost. root.bcomcn.com. (
200612230 ; Serial
28800 ; Refresh
14400 ; Retry
3600000 ; Expire
86400 ) ; Minimum
IN NS localhost.
5 IN PTR www.bcomcn.com.
[/code]
4.修改/etc/named.conf,加入:
[code]
zone "bcomcn.com" IN {
type master;
file "bcomcn.zone";
allow-update { none; };
};
zone "1.168.192.in-addr.arpa" IN {
type master;
file "192.zone";
allow-update { none; };
};
[/code]
启动named,将本机的DNS服务器设置为本机,用nslookup,或其它工具检测:
nslookup
> set type=mx
> bcomcn.com
(可以查看/var/log/message检查named是否正确启动,是否加载某个Domain的解析.)>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
Qmail的Maildir++补丁的小错误
[ 2006/12/25 22:18 | by ipaddr ]
好久没有用过qmail了,近日安装一台qmail邮件服务器,在一阵Patch,make setup check后出错,编译不通过!提示如下:
[code]
overmaildirquota.c:32: warning: data definition has no type or storage class
overmaildirquota.c:33: error: parse error before '}' token
overmaildirquota.c:36: error: redefinition of `ret_value'
overmaildirquota.c:32: error: `ret_value' previously defined here
overmaildirquota.c:36: warning: data definition has no type or storage class
overmaildirquota.c:37: error: parse error before '}' token
make: *** [overmaildirquota.o] Error 1
[/code]
语法错误,这问题有点奇怪,之前用Redhat9安装,没出现过此类问题.
网上搜了一下,发现原来是某些gcc加强了语法的检测,以前允许定义字符串常量跨行,现在跨行的话,必须使用\,
而在Maildir++的补丁的overmaildirquota.c里面,有这么一行:
[code]
static const char rcsid[]="$Id: overquota.c,v 1.0 2002/06/09 16:21:05 mr
sam Exp $";
[/code]
在mr后面就换行了,CentOS4.4的gcc 编译不通过,
你需要改成:
[code]
static const char rcsid[]="$Id: overquota.c,v 1.0 2002/06/09 16:21:05 mrsam_patchByIpaddr Exp $";
[/code]
(删除后面的回车,将字符串常量改成一行即可.)
再次编译通过.>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
[code]
overmaildirquota.c:32: warning: data definition has no type or storage class
overmaildirquota.c:33: error: parse error before '}' token
overmaildirquota.c:36: error: redefinition of `ret_value'
overmaildirquota.c:32: error: `ret_value' previously defined here
overmaildirquota.c:36: warning: data definition has no type or storage class
overmaildirquota.c:37: error: parse error before '}' token
make: *** [overmaildirquota.o] Error 1
[/code]
语法错误,这问题有点奇怪,之前用Redhat9安装,没出现过此类问题.
网上搜了一下,发现原来是某些gcc加强了语法的检测,以前允许定义字符串常量跨行,现在跨行的话,必须使用\,
而在Maildir++的补丁的overmaildirquota.c里面,有这么一行:
[code]
static const char rcsid[]="$Id: overquota.c,v 1.0 2002/06/09 16:21:05 mr
sam Exp $";
[/code]
在mr后面就换行了,CentOS4.4的gcc 编译不通过,
你需要改成:
[code]
static const char rcsid[]="$Id: overquota.c,v 1.0 2002/06/09 16:21:05 mrsam_patchByIpaddr Exp $";
[/code]
(删除后面的回车,将字符串常量改成一行即可.)
再次编译通过.>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
1) lsof abc.txt 显示开启文件abc.txt的进程
2) lsof -i :22 知道22端口现在运行什么程序
3) lsof -c nsd 显示nsd进程现在打开的文件
4) lsof -g gid 显示归属gid的进程情况
5) lsof +d /usr/local/ 显示/usr/local目录下被进程开启的文件
6) lsof +D /usr/local/ 同上,但是会搜索目录下的目录,时间较长
7) lsof -d 4 显示使用fd为4的进程
8) lsof -i [i] 用以显示符合条件的进程情况
语法: lsof -i[46] [protocol][@hostname|hostaddr][:service|port]
46 --> IPv4 or IPv6
protocol --> TCP or UDP
hostname --> Internet host name
hostaddr --> IPv4位置
service --> /etc/service中的 service name (可以不只一个)
port --> 端口号 (可以不只一个)
例子: TCP:25 - TCP and port 25
@1.2.3.4 - Internet IPv4 host address 1.2.3.4
tcp@ohaha.ks.edu.tw:ftp - TCP protocol host:ohaha.ks.edu.tw service name:ftp
9) lsof -n 不将IP转换为hostname,缺省是不加上-n参数
例子: lsof -i tcp@ohaha.ks.edu.tw:ftp -n
10) lsof -p 12 看进程号为12的进程打开了哪些文件
11) lsof +|-r [t] 控制lsof不断重复执行,缺省是15s刷新
-r,lsof会永远不断的执行,直到收到中断信号
+r,lsof会一直执行,直到没有档案被显示
例子:不断查看目前ftp连接的情况:lsof -i tcp@ohaha.ks.edu.tw:ftp -r
12) lsof -s 列出打开文件的大小,如果没有大小,则留下空白
13) lsof -u username 以UID,列出打开的文件
--------------
补充
--------------
查看某进程ID所打开的所有文件
lsof -p pid
lsof -i :portnum
另外一个常用命令就是通过netstat查看所有监听的端口:
netstat -lnp
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
2) lsof -i :22 知道22端口现在运行什么程序
3) lsof -c nsd 显示nsd进程现在打开的文件
4) lsof -g gid 显示归属gid的进程情况
5) lsof +d /usr/local/ 显示/usr/local目录下被进程开启的文件
6) lsof +D /usr/local/ 同上,但是会搜索目录下的目录,时间较长
7) lsof -d 4 显示使用fd为4的进程
8) lsof -i [i] 用以显示符合条件的进程情况
语法: lsof -i[46] [protocol][@hostname|hostaddr][:service|port]
46 --> IPv4 or IPv6
protocol --> TCP or UDP
hostname --> Internet host name
hostaddr --> IPv4位置
service --> /etc/service中的 service name (可以不只一个)
port --> 端口号 (可以不只一个)
例子: TCP:25 - TCP and port 25
@1.2.3.4 - Internet IPv4 host address 1.2.3.4
tcp@ohaha.ks.edu.tw:ftp - TCP protocol host:ohaha.ks.edu.tw service name:ftp
9) lsof -n 不将IP转换为hostname,缺省是不加上-n参数
例子: lsof -i tcp@ohaha.ks.edu.tw:ftp -n
10) lsof -p 12 看进程号为12的进程打开了哪些文件
11) lsof +|-r [t] 控制lsof不断重复执行,缺省是15s刷新
-r,lsof会永远不断的执行,直到收到中断信号
+r,lsof会一直执行,直到没有档案被显示
例子:不断查看目前ftp连接的情况:lsof -i tcp@ohaha.ks.edu.tw:ftp -r
12) lsof -s 列出打开文件的大小,如果没有大小,则留下空白
13) lsof -u username 以UID,列出打开的文件
--------------
补充
--------------
查看某进程ID所打开的所有文件
lsof -p pid
lsof -i :portnum
另外一个常用命令就是通过netstat查看所有监听的端口:
netstat -lnp
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>