Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2118111
  • 博文数量: 220
  • 博客积分: 8531
  • 博客等级: 中将
  • 技术积分: 4976
  • 用 户 组: 普通用户
  • 注册时间: 2007-07-18 13:33
文章分类

全部博文(220)

文章存档

2017年(1)

2015年(1)

2014年(5)

2013年(6)

2012年(6)

2011年(30)

2010年(37)

2009年(53)

2008年(41)

2007年(40)

分类: LINUX

2008-06-17 17:26:12

环境是:DC5SP2 X86
BIND:9.2.4到9.4.2
采用的升级步骤如下:

1.登录到应用服务器,切换到root用户。
2. 关闭named服务
命令:#/etc/init.d/named stop
3. 安装BIND升级包
命令:# tar xvfz bind-9.4.2.tar.gz
# cd bind-9.4.2
# ./configure --prefix=/usr/local/named --sysconfdir=/etc/ --localstatedir=/var --enable-threads
# make
# make install
4.生成/etc/rndc.conf
#cd /usr/local/named/sbin
#rndc-confgen>/etc/rndc.conf
5.生成/etc/named.conf文件
# cd /etc
#tail -10 rndc.conf | head -9 | sed s/#\ //g >>named.conf
6.从rndc.conf中提取rndc.key
#cat rndc.conf | head -5 >rndc.key
7.编辑/etc/init.d/named启动,用/usr/local/named/sbin替换/usr/sbin,
-u named删除
8. 恢复bind配置文件名称 命令:#tar xzvf /root/bind_backup.tar.gz -C /
9. 重新启动即可。
# service named restart
#service named status


    这个过程基本上没有问题,但是在测试环境(以前没有运行过bind)是一切正常的,但是在一个正是环境(一直运行这老版本的bind)却有问题,在最后启动named的时候,报错,日志显示:

Jul 17 16:18:08 hanode1 named[6206]: starting BIND 9.4.2 -t /var/named/chroot
Jul 17 16:18:08 hanode1 named[6206]: found 1 CPU, using 1 worker thread
Jul 17 16:18:08 hanode1 named[6206]: loading configuration from '/etc//named.conf'
Jul 17 16:18:08 hanode1 named[6206]: /etc//named.conf:6: change directory to '/var/named' failed: permission denied
Jul 17 16:18:08 hanode1 named[6206]: /etc//named.conf:6: parsing failed
Jul 17 16:18:08 hanode1 named[6206]: loading configuration: permission denied
Jul 17 16:18:08 hanode1 named[6206]: exiting (due to fatal error)

Jul 17 16:23:37 hanode1 named[6488]: starting BIND 9.4.2 -t /var/named/chroot
Jul 17 08:23:37 hanode1 named[6488]: found 1 CPU, using 1 worker thread
Jul 17 08:23:37 hanode1 named[6488]: loading configuration from '/etc//named.conf'
Jul 17 08:23:37 hanode1 named[6488]: none:0: open: /etc//named.conf: permission denied
Jul 17 08:23:37 hanode1 named[6488]: loading configuration: permission denied
Jul 17 08:23:37 hanode1 named[6488]: exiting (due to fatal error)
Jul 17 16:23:37 hanode1 named: named start failed


    看了看/var/named的权限是没有问题的阿,的确挺奇怪。
    现在需要分析问题,从哪入手呢?有俩个办法,第一个是让/etc/init.d/named打出详细的执行信息,是脚本级调试;第二是用strace跟踪,调试级的,不到万不得已不用,因为很难看懂。
    采用第一种方式,修改/etc/init.d/named第一行,在/bin/bash后面加-x参数,这样就可以打出详细信息:
  1. + initlog -q -c '/usr/local/named/sbin/named -t /var/named/chroot'
  2. + '[' 1 -eq 0 ']'
  3. + failure 'named start'
  4. + rc=1
  5. + '[' -z '' ']'
  6. + initlog -q -n /etc/init.d/named -s 'named start' -e 2
  7. + '[' color '!=' verbose -a -z '' ']'
  8. + echo_failure
  9. + '[' color = color ']'
  10. + echo -en '\033[60G'
    看来问题就在这个地方,/usr/local/named/sbin/named -t /var/named/chroot这个命令返回了非零值,所以有问题,手工测试了一下,的确返回1。
    在另一个使用系统默认bind的测试环境试了一下这个命令,返回的确是0。那看来就在/var/named/chroot了。
采用比较彻底的方式:
  1. mv /var/named/chroot /var/named/chroot.bak
  2. mkdir /var/named/chroot
  3. cp -rav /var/named/chroot.bak/etc /var/named/chroot
  4. cp -rav /var/named/chroot.bak/dev /var/named/chroot
  5. cp -rav /var/named/chroot.bak/var /var/named/chroot
  6. chown root.named -R /var/named/chroot
  7. /etc/init.d/named start
    先将原来的chroot改名,然后新建,再原来chroot里面的三个目录拷回来,启动正常。

    问题的原因在哪呢?

  1. [root@hanode1 named]# ls chroot.bak/
  2. dev etc proc var
  3. [root@hanode1 named]# ls chroot.bak/proc/
  4. 1 2617 2887 3047 41 6658 diskstats iomem locks partitions sysvipc
  5. 1471 2621 2930 314 42 acpi dma ioports mdstat pci tty
  6. 1849 2673 2947 3164 5 asound driver irq meminfo scsi uptime
  7. 188 2688 2956 3216 5713 buddyinfo execdomains kallsyms misc self version
  8. 1896 2728 2965 3715 5817 bus fb kcore modules slabinfo vmstat
  9. 1900 2729 2966 3889 5885 cmdline filesystems key-users mounts stat
  10. 2 2741 3 39 5887 cpuinfo fs keys mpt swaps
  11. 21 2742 302 4 6011 crypto ide kmsg mtrr sys
  12. 22 2751 3046 40 6511 devices interrupts loadavg net sysrq-trigger
  13. [root@hanode1 named]#
    不知为何,用户环境中/var/named/chroot里面多了一个proc目录,而且这个目录跟/proc是一模一样的,无法删除。可能named启动的时候,需要对此目录做一些操作,但是由于这个proc目录而出现一些问题。至于这个proc是如何产生的,有待推敲。

    在网上找到一个解释:
  1. /var/named/chroot/proc 這個是由 /proc 掛入來使用的。
  2. /proc 是行程相關資訊虛擬目錄,因為 named 有設定 chroot 環境运作,所以使用 mount -t proc proc /var/named/chroot/proc 方式掛入一份提供讓 named 可以於該環境正常运作使用。

阅读(2943) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~