nginx配置基于域名、端口、IP的虚拟主机

1、基于域名的虚拟主机:

  绝大多数企业对外提供服务的网站使用的都是基于域名的主机,通过不同的域名区分不同的虚拟主机。

首先我们进入安装nginxd的目录下:/application/nginx-1.6.3/conf

我们去除掉默认配置文件里的注释和空行并重定向到nginx.conf文件里,同时我们需要配置如下:

egrep -v "#|^$" nginx.conf.default >nginx.conf   //去掉包含#号和空行的内容

[[email protected] conf]# vim nginx.conf
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  www.jyw1.com;
        location / {
            root   html/www;
            index  index.html index.htm;
        }
    }
     server {
        listen       80;
        server_name  bbs.jyw2.com;
        location / {
            root   html/bbs;
            index  index.html index.htm;
         }
     }
}

创建站点目录文件:

mkdir ../html/{www,bbs} -p

[[email protected] conf]# tree ../html/
../html/
├── 50x.html
├── bbs
│   └── index.html
├── index.html
└── www
     └── index.html

为站点目录生成首页并追加内容:

通过hosts来做dns解析

[[email protected] conf]# echo "www.jyw1.com" >../html/www/index.html
[[email protected] conf]# echo "bbs.jyw2.com" >../html/bbs/index.html
[[email protected] conf]# cat ../html/{www,bbs}/index.html
www.jyw1.com
bbs.jyw2.com
[[email protected] conf]# /application/nginx/sbin/nginx -t  #检查语法
nginx: the configuration file /application/nginx-1.6.3/conf/nginx.conf syntax is ok
nginx: configuration file /application/nginx-1.6.3/conf/nginx.conf test is successful
[[email protected] conf]# /application/nginx/sbin/nginx -s reload  #刷新配置
[[email protected] conf]# vi /etc/hosts
[[email protected] conf]# ping www.jyw1.com
PING www.jyw1.com (192.168.43.118) 56(84) bytes of data.
64 bytes from www.jyw1.com (192.168.43.118): icmp_seq=1 ttl=64 time=0.022 ms
64 bytes from www.jyw1.com (192.168.43.118): icmp_seq=2 ttl=64 time=0.020 ms
^C
--- www.jyw1.com ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1280ms
rtt min/avg/max/mdev = 0.020/0.021/0.022/0.001 ms
[[email protected] conf]# ping bbs.jyw2.com
PING bbs.jyw2.com (192.168.43.118) 56(84) bytes of data.
64 bytes from www.jyw1.com (192.168.43.118): icmp_seq=1 ttl=64 time=0.015 ms
64 bytes from www.jyw1.com (192.168.43.118): icmp_seq=2 ttl=64 time=0.020 ms
^C
--- bbs.jyw2.com ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1311ms
rtt min/avg/max/mdev = 0.015/0.017/0.020/0.004 ms
[[email protected] conf]# curl www.jyw1.com
www.jyw1.com
[[email protected] conf]# curl bbs.jyw2.com
bbs.jyw2.com
[[email protected] conf]# 

我是用的windows系统,配置一下host在“C:\Windows\System32\drivers\etc”下的hosts中配置一下域名重定向

192.168.43.118 www.jyw1.com bbs.jyw2.com

然后cmd再ping一下这个域名是否正确指向了这个IP上

打开浏览器,输入www.test.com会得到以下结果,就说明外网访问成功

ok,通过多域名来访问站点,同样也可以一个站点多个域名。

2.基于端口的虚拟主机配置:

  此类型的虚拟主机主要应用于企业内部的网站,需要加端口号才能访问,通过不同的端口来区分不同的虚拟主机,为企业网站安全优化,例如:企业的网站后台,资料共享等。

在前面配置的基于域名的虚拟主机的基础上只需要修改nginx.conf文件,刷新配置即可完成:

修改nginx.conf配置文件

[[email protected] conf]# vim nginx.conf

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       8001;
        server_name  www.jyw1.com;
        location / {
            root   html/www;
            index  index.html index.htm;
        }
    }
     server {
        listen       8002;
        server_name  bbs.jyw2.com;
        location / {
            root   html/bbs;
            index  index.html index.htm;
         }
     }
}

刷新配置,测试结果如下

[[email protected] conf]# /application/nginx/sbin/nginx -t
nginx: the configuration file /application/nginx-1.6.3/conf/nginx.conf syntax is ok
nginx: configuration file /application/nginx-1.6.3/conf/nginx.conf test is successful
[[email protected] conf]# /application/nginx/sbin/nginx -s reload
[[email protected] conf]# curl www.jyw1.com
curl: (7) couldn‘t connect to host
[[email protected] conf]# curl www.jyw1.com:8001
www.jyw1.com
[[email protected] conf]# curl bbs.jyw2.com:8002
bbs.jyw2.com
[[email protected] conf]# 

在windows下测试如下:

ok,既可以对应多个站点,多个端口访问,也可以对应一个站点多个端口访问。

3.基于IP地址虚拟主机:

  通过不同的IP区分不同的虚拟主机,此类型企业应用于比较少,通常用到不通业务流中或者负载均衡上面。

在前面配置的基于域名的虚拟主机的基础上只需要修改nginx.conf文件,刷新配置即可完成:

修改nginx.conf配置文件

[[email protected] conf]# vim nginx.conf

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen      192.168.43.118:80;
        server_name  www.jyw1.com;
        location / {
            root   html/www;
            index  index.html index.htm;
        }
    }
     server {
        listen 192.168.43.88:80;
        server_name  bbs.jyw2.com;
        location / {
            root   html/bbs;
            index  index.html index.htm;
         }
     }
}

修改完配置文件后,我们需要虚拟一块网卡:

ip addr add  //添加

ip addr del 192.168.43.88/24  dev eth0  //删除

临时性网卡: ip addr add 192.168.43.88/24 label eth0:1 dev eth0  或者  ifconfig eth0:1 192.168.43.88/24 up

[[email protected] conf]# ip addr add 192.168.43.88/24 label eth0:1 dev eth0  添加网卡(推荐使用ip addr)
[[email protected] conf]# ifconfig
eth0      Link encap:Ethernet  HWaddr 00:0C:29:01:4D:22
          inet addr:192.168.43.118  Bcast:192.168.43.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe01:4d22/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1100 errors:0 dropped:0 overruns:0 frame:0
          TX packets:664 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:94218 (92.0 KiB)  TX bytes:76354 (74.5 KiB)

eth0:1    Link encap:Ethernet  HWaddr 00:0C:29:01:4D:22
          inet addr:192.168.43.88  Bcast:192.168.43.255  Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
[[email protected] conf]# ip addr del 192.168.43.99/24 dev eth0   删除网卡
[[email protected] conf]# ifconfig
eth0      Link encap:Ethernet  HWaddr 00:0C:29:01:4D:22
          inet addr:192.168.43.118  Bcast:192.168.43.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe01:4d22/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1218 errors:0 dropped:0 overruns:0 frame:0
          TX packets:724 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:103486 (101.0 KiB)  TX bytes:83366 (81.4 KiB)
[[email protected] conf]# 

永久性网卡:

cd /etc/sysconfig/network-scripts/    //进入到网卡配置文件的目录

cp ifcfg-eth0 ifcfg-eth0:1               //拷贝配置文件并重命名

vim ifcfg-eth0:1                           //编辑配置文件

/etc/init.d/network restart           //重启网络服务

图略....

下面我们刷新配置,查看效果:

[[email protected] ~]# /application/nginx/sbin/nginx -t
nginx: the configuration file /application/nginx-1.6.3/conf/nginx.conf syntax is ok
nginx: configuration file /application/nginx-1.6.3/conf/nginx.conf test is successful
[[email protected] ~]# /application/nginx/sbin/nginx -s reload
[[email protected] ~]# curl 192.168.43.88
bbs.jyw2.com
[[email protected] ~]# curl 192.168.43.118
www.jyw1.com
[[email protected] ~]# 

在windows下测试如下:

ok,既可以多个IP对应一个站点,也可以对应多个站点访问。

原文地址:https://www.cnblogs.com/su-root/p/10230994.html

时间: 2024-10-13 02:19:13

nginx配置基于域名、端口、IP的虚拟主机的相关文章

nginx基本域名 端口 IP 的虚拟主机

基于域名 ##nginx并发连接数 processes 乘 connection ## worker_processes 服务进程数,一般和cpu 核心一致即可 worker_processes 1; events { ##一个worker同时服务数量 worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout

源码编译安装LNMP环境及配置基于域名访问的多虚拟主机

实验环境及软件版本: CentOS版本: 6.6(2.6.32.-504.el6.x86_64) apache版本: nginx-1.6.2 mysql版本:  Mysql-5.6.23 php版本:    php-5.6.3 一.关闭防火墙:service iptables stop chkconfig iptables off 二.关闭selinux: sed -i 's/SELINUX=disabled/SELINUX=enforcing/g' /etc/selinux/config in

源码编译安装LAMP环境及配置基于域名访问的多虚拟主机

实验环境及软件版本: CentOS版本: 6.6(2.6.32.-504.el6.x86_64) apache版本: apache2.2.27 mysql版本:  Mysql-5.6.23 php版本:    php-5.3.27 一.关闭防火墙:service iptables stop chkconfig iptables off 二.关闭selinux: sed -i 's/SELINUX=disabled/SELINUX=enforcing/g' /etc/selinux/config

Nginx 配置基于域名的虚拟

编辑配置文件 vi /etc/nginx/nginx.conf user    www www; worker_processes  2; error_log  logs/error.log  notice; events {     worker_connections  1024; } http {     include       mime.types;     default_type  application/octet-stream; log_format  main  '$rem

简单nginx配置基于域名的虚拟主机

user  nginx nginx; worker_processes  8; #error_log  logs/error.log; #error_log  logs/error.log  notice; #error_log  logs/error.log  info; pid        logs/nginx.pid; events { worker_connections  1024; } http { include       mime.types; default_type  a

Nginx配置基于多域名、端口、IP的虚拟主机

原文:https://www.cnblogs.com/ssgeek/p/9220922.html ------------------------------- 1.类型介绍 1.1 基于域名的虚拟主机 所谓基于域名的虚拟主机,意思就是通过不同的域名区分不同的虚拟主机,基于域名的虚拟主机是企业应用最广的虚拟主机类型,几乎所有对外提供服务的网站使用的都是基于域名的主机,例如www.test1.com www.test2.com等 1.2 基于端口的虚拟主机 同理,所谓基于端口的虚拟主机,意思就是通

Apache基于域名、端口、IP的虚拟主机配置(Centos 6.5)

虚拟主机:部署多个站点,每个站点,希望用不同的域名和站点目录,或者是不同的端口,不同的ip,需要虚拟主机功能.一句话,一个http服务要配置多个站点,就需要虚拟主机. 虚拟主机分类:基于域名.基于端口.基于ip:所谓的基于**,就是靠**来区分不同的站点,支持各种混合,N多个虚拟主机. 基于端口的虚拟主机配置如下: 创建环境: 站点目录 域名 /var/html/blog blog.bqh123.com /var/html/bbs bbs.bqh123.com [[email protected

Nginx总结(二)基于ip的虚拟主机配置

前面讲了如何安装配置Nginx,大家可以去这里看看nginx系列文章:https://www.cnblogs.com/zhangweizhong/category/1529997.html 今天要说的是Nginx如何配置虚拟主机. 1. 什么是虚拟主机 虚拟主机是一种特殊的软硬件技术,它可以将网络上的每一台计算机分成多个虚拟主机,每个虚拟主机可以独立对外提供www服务,这样就可以实现一台主机对外提供多个web服务,每个虚拟主机之间是独立的,互不影响的. 如下图: 通过nginx可以实现虚拟主机的

Nginx的配置文件简介及在Nginx中配置基于不同ip的虚拟主机

Nginx的配置文件简介及在Nginx中配置基于不同ip的虚拟主机: #user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; defa