dns+nginx实现多虚拟主机
借鉴于朋友的需求,公司需要启用域名访问内部的业务系统,现实情况是内部的业务系统目前使用的是单主机,单nginx多端口的方式再运行,朋友最终想实现启用域名方式问题,且域名不需要用户手工输入端口号
两种思路,一种思路为新增加一台主机使用新增加的主机的nginx反向代理现有的业务系统,另外一直思路是启用nginx的虚拟主机功能。不管是那种思路,都需要配置dns。下文主要描述启用nginx的虚拟主机功能的操作步骤
测试环境
服务器:cetnos 7 1810
Nginx 1.4.2
Dns 使用centos7 1810光盘中携带的bind版本
nginx服务器,dns服务器地址为:172.16.103.8
需求清单,
实现访问aaa.baidu.com,访问的实际位置为172.16.103.8的80端口的nginx html目录中的aaa目录下的index.html,文件内容为aaa.baidu.com
实现访问bbb.baidu.com,访问的实际位置为172.16.103.8的80端口的nginx html目录中的bbb目录下的index.html,文件内容为bbb.baidu.com
参考文章:
https://blog.51cto.com/13525470/2054121
https://blog.csdn.net/qq_39591494/article/details/78857677?tdsourcetag=s_pctim_aiomsg
1,dns配置
挂载光盘
yum install -y bind
修改dns主配置文件
vi /etc/named.conf
12 options {
# options是全局服务器的配置选项,在这里指定的参数,对配置中的任何区域都有效
13 listen-on port 53 { 127.0.0.1; };
# 指定域名服务监听的网络端口,建议写本机IP,不建议写127.0.0.1,如果写127.0.0.1时,其他客户端将无法使用该dns服务器提供的服务,可以写本机的实际IP或者any
14 listen-on-v6 port 53 { ::1; };
15 directory "/var/named";
# 指定named从/var/named目录下读取DNS数据文件
16 dump-file "/var/named/data/cache_dump.db";
# 当执行导出命令时将DNS服务器的缓存数据存储到指定的文件中
17 statistics-file "/var/named/data/named_stats.txt";
# 指定named服务的统计文件,当执行统计命令时会将内存中的统计信息追加到该文件中
18 memstatistics-file "/var/named/data/named_mem_stats.txt";
19 allow-query { localhost; };
# 允许哪些客户端访问DNS服务,此处改为"any",表示任意主机
20
31 recursion yes;
# 开启递归查询
32
33 dnssec-enable yes;
# 开启加密
34 dnssec-validation yes;
# 在递归查询服务器上开启DNSSEC验证
35
36 /* Path to ISC DLV key */
37 bindkeys-file "/etc/named.iscdlv.key";
38
39 managed-keys-directory "/var/named/dynamic";
40
41 pid-file "/run/named/named.pid";
42 session-keyfile "/run/named/session.key";
43 };
44
45 logging {
# named服务的日志文件信息
46 channel default_debug {
47 file "data/named.run";
48 severity dynamic;
49 };
50 };
51 # 每一个zone就是定义一个域的相关信息以及指定了named服务从哪些文件中获得DNS各个域名的数据文件
52 zone "." IN {
# 根(.)域的配置及信息(配置缓存域名服务器,可以自己去了解)
53 type hint;
# 服务器类型
54 file "named.ca";
# 文件路径位置
55 };
56
57 include "/etc/named.rfc1912.zones";
# include代表该文件是子配置文件
58 include "/etc/named.root.key";
添加dns服务器需要解析的区域,添加区域需要修改/etc/named.rfc1912.zones文件
zone "baidu.com" IN {
type master;
file "baidu.com.zone";
allow-update { none; };
};
编辑正向解析区域数据文件
cd /var/named/
cp -p named.localhost baidu.com.zone
vi baidu.com.zone
$TTL 1D
@ IN SOA baidu.com. admin.baidu.com. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS @
A 127.0.0.1
AAAA ::1
aaa IN A 172.16.103.8
bbb IN A 172.16.103.8
重启named服务
systemctl restart named
安装dig客户端,测试解析是否正常
yum install bind-utils
修改本机dns服务器地址
vi /etc/resolv.conf
nameserver=172.16.103.8
测试在本机的dns解析
2,编译安装nginx
传送nginx软件包到/software目录下
[root@localhost software]# tar -zxvf nginx-1.14.2.tar.gz
安装依赖包
yum -y install gcc gcc-c++ autoconf automake pcre-devel openssl openssl-devel
进入解压后的目录,编译安装
[root@localhost software]# cd nginx-1.14.2
[root@localhost nginx-1.14.2]# ./configure --prefix=/usr/local/nginx
[root@localhost nginx-1.14.2]# make & make install
启动nginx服务
[root@localhost nginx-1.14.2]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
查看nginx的监听端口
[root@localhost nginx-1.14.2]# netstat -nutpl |grep nginx
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 5008/nginx: master
如果没有netstat命令,需要安装net-tools,在线安装net-tools的命令为
[root@localhost nginx-1.14.2]# yum install -y net-tools
得知ngxin监听的端口是80,使用浏览器访问两台的80端口上的内容
3,配置nginx的虚拟主机
编辑nginx配置文件,复制server配置项,修改server配置项
vi /usr/local/nginx/conf/nginx.conf
在nginx的html目录下创建aaa目录和bbb目录,并创建index.html文件
重启nginx
cd /usr/local/nginx/sbin/
./nginx -s reload
使用windows客户端做最终测试,windows客户端需要配置dns服务器地址指向172.16.103.8
dns+nginx实现多虚拟主机的更多相关文章
- 第四百零二节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署,uwsgi安装和启动,nginx的安装与启动,uwsgi与nginx的配置文件+虚拟主机配置
第四百零二节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署,uwsgi安装和启动,nginx的安装与启动,uwsgi与nginx的配置文件+虚拟主机配置 软件版本 uwsgi- ...
- Nginx(二):虚拟主机配置
什么是虚拟主机? 虚拟主机使用的是特殊的软硬件技术,它把一台运行在因特网上的服务器主机分成一台台“虚拟”的主机,每台虚拟主机都可以是一个独立的网站,可以具有独立的域名,具有完整的Intemet服务器功 ...
- linux上nginx上配置虚拟主机的相关配置
1.配置主配置: nginx/conf/nginx.conf 2.虚拟主机配置:nginx/conf/extra/learn.weixin.com.conf 配置完后,重启服务器!
- Nginx多站点虚拟主机实现单独启动停止php-fpm、单独控制权限设置
Nginx多站点虚拟主机实现单独启动停止php-fpm.单独控制权限设置 来源:osyunwei.com 作者:qihang01 发表于:2012-08-19 21:26 点击: 说明: 站点1:bb ...
- Nginx中关于虚拟主机的一点冷门知识
一些闲聊 坐标深圳南山. 前两天公司晚上9点过,通知第二天要48小时核酸才能进办公楼.看到消息,已经是9点半多了,走到公司附近的核酸点,是10点过.然后发现那个点人好少,走近了才发现核酸点已经下班了, ...
- 通过ngx-lua来统计Nginx上的虚拟主机性能数据
Web server调研分析 Filed under: Web Server — cmpan @ 2012-10-29 20:38:34 摘要 简单可依赖的架构首先需要有一个简单可依赖的前端WebSe ...
- Nginx如何配置虚拟主机?
注意,该环境是依赖于http://www.php20.com/forum.php?m ... &extra=page%3D1 基础上进行配置.默认不具备这些文件 .下面是增加一个mytest点 ...
- Nginx下配置虚拟主机的三种方法
Nginx下,一个server标签就是一个虚拟主机. 1.基于域名的虚拟主机,通过域名来区分虚拟主机——应用:外部网站 2.基于端口的虚拟主机,通过端口来区分虚拟主机——应用:公司内部网站,外部网站的 ...
- nginx介绍(三) - 虚拟主机
前言 前面提到过, 由nginx来分发请求到tomcat中, 那么怎么来区分这些tomcat呢? 我们一般访问网站的时候, 是不是可以使用 ip : port (127.0.0.1:8080)的方式来 ...
随机推荐
- httprunner开发实践&源码解析
上次作业讲解 排错 控制台查看报错信息 打开代理工具,调试脚本 注释掉其他接口,先跑一个接口 pip uninstall httprunner 修复断言100为int型问题 修复两次登陆问题 报告 p ...
- win10连接mysql提示:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
win10中cmd连接mysql提示:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YE ...
- Python - Context Manager 上下文管理器
什么是上下文管理器 官方解释... 上下文管理器是一个对象 它定义了在执行 with 语句时要建立的运行时上下文 上下文管理器处理进入和退出所需的运行时上下文以执行代码块 上下文管理器通常使用 wit ...
- 鸿蒙内核源码分析(文件句柄篇) | 深挖应用操作文件的细节 | 百篇博客分析OpenHarmony源码 | v69.01
百篇博客系列篇.本篇为: v69.xx 鸿蒙内核源码分析(文件句柄篇) | 深挖应用操作文件的细节 | 51.c.h.o 文件系统相关篇为: v62.xx 鸿蒙内核源码分析(文件概念篇) | 为什么说 ...
- Appium+Python自动化环境搭建-1
前言 appium可以说是做app最火的一个自动化框架,它的主要优势是支持android和ios,另外脚本语言也是支持java和Python. 小编擅长Python,所以接下来的教程是appium+p ...
- php flush() 页面缓冲及时输出 每隔一秒输出页面输出
<?php //方案一 ob_end_clean(); echo str_pad('', 1024); // 设置足够大,大过php.ini的output_buffering设置值 for ($ ...
- 通用JS七
instanceof 在原型链上寻找这个属性的定义 match 正则匹配字符串 Symbol() Symbol()函数不能用作构造函数,与new关键字一起使用.这样做是为了避免创建符号包装对象,像使用 ...
- 解决springboot 配置文件未映射静态资源文件 导致shiro拦截静态资源的问题
---------------------------------------------------------------------------------------------------- ...
- css新增属性之边框
css3新增属性 边框属性 背景属性 文字属性 颜色属性 边框属性 属性 说明 border-radius 设置边框圆角 border-image 设置图像边框 border-shadow 设置边框阴 ...
- 基于Hexo+Github Pages搭建的博客
概念 Github Pages可以被认为是用户编写的.托管在github上的静态网页.使用Github Pages可以为你提供一个免费的服务器,免去了自己搭建服务器和写数据库的麻烦.此外还可以绑定自己 ...