快速搭建BIND服务,并实现解析

公司有测试需求,当连接一个网络后自动会进入产品的测试环境,所以搭建了一个DNS解析服务,来完成此需求。

参考:http://blog.chinaunix.net/uid-30149335-id-5069146.html   找了个教程参考了一下,然后根据自己需求更改  

一、安装BIND

yum install -y bind
cp /etc/named.conf /etc/named.conf.bak  
>/etc/named.conf
vim /etc/named.conf 

加入如下配置:

options {
    directory "/var/named";
};

zone "." IN  {
    type hint;
    file "named.ca";
};

zone "localhost" IN {
    type master;
    file "localhost.zone";
};

zone "0.0.127.in-addr.arpa" IN {
    type master;
    file "named.local";
};
chown named /etc/named.conf        #如果属组是named可以不改
cd /var/named/
dig -t NS . > named.ca
vim localhost.zone //加入
@                   IN      SOA     localhost.  admin.localhost.     (
                                                                        2013081601
                                                                        1H
                                                                        10M
                                                                        7D
                                                                        1D
                                                                           )
@                   IN          NS          localhost.
localhost.          IN          A           127.0.0.1

vim named.local //加入

 
$TTL 86400
@                    IN      SOA     localhost.  admin.localhost.      (
                                                                        2013081601
                                                                        1H
                                                                        10M
                                                                        7D
                                                                        1D
                                                                        )
@                    IN          NS          localhost.
1                    IN          PTR         localhost

rndc-confgen -r /dev/urandom -a  // 这一步是生成 rndc.key, 如果没有这个key namd 是启动不了的 ####话说我也没测试到底能不能启动。。。

检测配置是否有问题: named-checkconf   

netstat -lnp  |grep named  // 查看一下named进程是否监听了53端口

/etc/init.d/named start   #看看能不能起来,没起来的话根据报错去解决,起来的话就能正常解析了

二、增加一个域名(zone) 备:这就是我的需求,需要把产品的域名解析到我们的测试机上,增加一个域名解析

vim /etc/named.conf   ##请根据自己的域名及IP更改

zone "hotel.test.com" IN {
    type master;
    file "hotel.test.com.lan";
};

zone "10.168.192.in-addr.arpa" IN {
    type master;
    file "10.168.192.db";
};

cd /var/named/

vi hotel.test.com

$TTL    86400
@        IN    SOA   ns.hotel.test.com. root.hotel.test.com. (
               2007041501   ;Serial
               3600         ;Refresh
               1800         ;Retry
               604800       ;Expire
               86400        ;Minimum TTL

)
               IN    NS     ns.hotel.test.com.
               IN    A       192.168.10.10
               IN    MX 10   ns.hotel.test.com.
 
ns             IN    A       192.168.10.10

vi 10.168.192.db

$TTL    86400
@       IN    SOA  ns.hotel.test.com. root.hotel.test.com. (
              2007041501     ;Serial
              3600           ;Refresh
              1800           ;Retry
              604800         ;Expire
              86400          ;Minimum TTL
)
              IN        NS    ns.hotel.test.com.
 
              IN        PTR   hotel.test.com.
              IN        A     255.255.255.0
 
17            IN        PTR   ns.hotel.test.com.

  

把本机DNS改成自己的,然后dig测试一下

[root@TBJ named]# dig hotel.test.com

; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.47.rc1.el6_8.3 <<>> hotel.test.com
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 34986
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 1, ADDITIONAL: 1

;; QUESTION SECTION:
;hotel.test.com.			IN	A

;; ANSWER SECTION:
hotel.test.com.		86400	IN	A	192.168.10.10

;; AUTHORITY SECTION:
hotel.test.com.		86400	IN	NS	ns.hotel.test.com.

;; ADDITIONAL SECTION:
ns.hotel.test.com.	86400	IN	A	192.168.10.10

;; Query time: 0 msec
;; SERVER: 115.182.63.152#53(115.182.63.152)
;; WHEN: Thu Feb  9 17:44:51 2017

  

完事。

 

 

 

转载于:https://www.cnblogs.com/liuquan/p/6383225.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在C语言中搭建一个多进程并发的Web服务器是实现Web应用的一种常见方式。这种方式的主要优点是能够处理多个客户端的请求,并且能够实现并发处理,提高了服务器的性能。 实现一个多进程的Web服务器基本步骤如下: 1. 创建一个父进程,用于监听指定的网络端口,并接受客户端的连接请求。 2. 父进程接收到客户端的连接请求后,创建一个子进程来处理该请求。 3. 子进程负责接收和解析客户端的HTTP请求,并根据请求的内容生成相应的HTTP响应。 4. 子进程将生成的HTTP响应发送给客户端,完成请求处理后,子进程可以自行退出。 5. 父进程继续监听指定网络端口,接受下一个客户端的连接请求。 通过多进程的方式,可以实现同时处理多个客户端请求的能力并提高并发处理能力。父进程只负责接受连接请求并创建子进程,而子进程则负责具体的请求处理。不同的子进程之间相互独立,互不影响,可以同时处理多个请求。 需要注意的是,多进程的方式可能会导致一些资源的浪费,比如每个子进程都需要单独的内存空间和资源。另外,也要注意处理子进程的退出和异常情况,以及进程间的通信和同步问题。 总之,通过使用C语言搭建多进程并发的Web服务器,可以实现高性能的Web应用服务端,有效地处理多个客户端的请求,提供更好的用户体验。 ### 回答2: C语言通过使用多进程来实现Web服务器的并发是一种常见的方法。这种方法基于操作系统提供的进程控制功能,可以同时处理多个客户端的请求。下面是一个使用C语言构建具有多进程并发功能的Web服务器的示例: 首先,我们需要使用C语言中的系统调用函数(如fork()和exec())来创建子进程。父进程负责监听客户端请求,而子进程负责处理请求并向客户端发送响应。 在主程序中,我们需要创建一个主进程,用于监听客户端的连接请求。主进程使用socket函数创建一个TCP连接,然后使用bind和listen函数将其绑定到一个特定的端口上,并开始监听客户端的连接请求。 一旦有客户端连接请求到达,主进程使用accept函数来接受该连接请求,并创建一个子进程来处理它。子进程通过调用fork函数来复制主进程的地址空间,并可以继续执行与主进程相同的代码。 在子进程中,我们需要使用exec函数来执行一个新的程序,比如一个CGI脚本或者是处理静态文件的函数。在这个过程中,子进程与客户端进行通信,接收并处理请求并再次发送响应。 当子进程完成处理后,它会关闭与客户端的连接,并通过exit函数退出。父进程会继续监听其他客户端的连接请求,并创建新的子进程来处理它们。 通过这种方式,我们可以实现一个基于C语言的多进程并发的Web服务器。这种方法可以提供快速的响应速度,允许服务器同时处理多个客户端请求。但是,它也会消耗更多的系统资源,并且在高并发情况下可能会导致系统负载过重。因此,在实际应用中,我们需要根据具体情况选择最合适的并发模型来构建Web服务器。 ### 回答3: C语言搭建Web服务实现多进程并发主要有以下几个步骤: 1. 创建Socket:首先,我们需要使用Socket函数创建一个服务器端的套接字,指定服务器端监听的IP地址和端口号。 2. 绑定Socket:使用bind函数将服务器端套接字与指定的IP地址和端口号进行绑定。 3. 监听连接请求:使用listen函数开始监听来自客户端的连接请求。 4. 接受连接请求:使用accept函数等待并接受客户端的连接请求,当有客户端请求连接时,accept函数将返回一个新的套接字。 5. 创建子进程:当接受到客户端的连接请求后,使用fork函数创建一个子进程,子进程将负责与该客户端进行通信。 6. 子进程处理请求:在子进程中,使用recv函数接收来自客户端的HTTP请求,并根据请求的内容生成相应的HTTP响应。 7. 发送响应:使用send函数将生成的HTTP响应发送给客户端。 8. 关闭连接:在通信结束后,关闭子进程中的套接字,并终止子进程的执行。 9. 父进程继续监听:父进程在子进程处理完请求并关闭套接字后,继续监听其他客户端的连接请求,重复上述步骤。 通过以上步骤,我们就可以使用C语言搭建一个能够实现多进程并发的Web服务器。每个接收到的客户端请求都会创建一个独立的子进程进行处理,从而实现了并发处理多个客户端请求的能力。这种方式可以提高服务器的并发性能,同时确保每个客户端请求都能够得到及时的响应。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值