Configuração virtual do nginx (host virtual)

O que é hospedagem na web?
Host virtual é uma tecnologia especial de software e hardware. Ele pode dividir cada computador da rede em vários hosts virtuais. Cada host virtual pode fornecer serviços www para o exterior de forma independente, para que um host possa fornecer várias webs para o mundo exterior. Os serviços são independentes de cada host virtual e não afetam uns aos outros.

[Falha na transferência da imagem do link externo, o site de origem pode ter um mecanismo anti-leeching, é recomendado salvar a imagem e carregá-la diretamente (img-yA01vk4n-1598623023772) (assets / 1561605672295.png)]

Nginx pode implementar configuração de host virtual, nginx oferece suporte a três tipos de configuração de host virtual.
1. Host virtual baseado no nome de domínio (server_name para distinguir aplicativo de host virtual: site externo)
2. Host virtual baseado em ip (um host está vinculado a vários endereços IP)
3. Host virtual baseado em porta (porta para distinguir virtual Aplicativo host: site interno da empresa, histórico de gerenciamento de site externo

1. Hospedagem virtual baseada no nome de domínio

1. Configure máquinas virtuais diferenciadas por nomes de domínio

[root@localhost ~]# cat /etc/nginx/nginx.conf
worker_processes  4;

#error_log  logs/error.log;
worker_rlimit_nofile 102400;


events {
    
    
    worker_connections  1024;
}


http {
    
    
    include       mime.types;
    default_type  application/octet-stream;
    
    server {
    
    
        listen       80;
        server_name  web.testpm.com;
        location / {
    
    
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate	2k;
        	}
        }
    
    server {
    
    
        listen       80;
        server_name  web.1000phone.com;
        location / {
    
    
            root   /1000phone/html;
            index  index.html index.htm;
        	}
        }
}

2. Crie um arquivo de índice para a máquina virtual cujo nome de domínio é web.1000phone.com

[root@localhost ~]# mkdir -p /1000phone/html
[root@localhost ~]# vim /1000phone/html/index.html
<html>
<p>
this is my 1000phone
</p>
</html>

3. Recarregue o arquivo de configuração

# 如果编译安装的执行
[root@nginx]# /usr/local/nginx/sbin/nginx -s reload
# 如果 yum 安装的执行
[root@nginx]# nginx -s reload

4. Configure o mapeamento da rota
no lado do cliente . Adicione duas linhas ao arquivo C: \ Windows \ System32 \ drivers \ etc \ hosts (linux: / etc / hosts)

10.0.105.199 web.testpm.com
10.0.105.199 web.1000phone.com

5. Visita de teste

Entrada do navegador: http://web.testpm.com/

Entrada do navegador: http://web.1000phone.com/

2. Host virtual baseado em IP

[root@localhost ~]# ip a 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:17:f1:af brd ff:ff:ff:ff:ff:ff
    inet 10.0.105.199/24 brd 10.0.105.255 scope global dynamic ens33
       valid_lft 81438sec preferred_lft 81438sec
    inet6 fe80::9d26:f3f0:db9c:c9be/64 scope link 
       valid_lft forever preferred_lft forever
[root@localhost ~]# ifconfig ens33:1 10.0.105.201/24  #要保证添加的IP没有被使用(给网卡再添加一个ip)
[root@localhost ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 10.0.105.199  netmask 255.255.255.0  broadcast 10.0.105.255
        inet6 fe80::9d26:f3f0:db9c:c9be  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:17:f1:af  txqueuelen 1000  (Ethernet)
        RX packets 9844  bytes 1052722 (1.0 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 5567  bytes 886269 (865.4 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

ens33:1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 10.0.105.201  netmask 255.255.255.0  broadcast 10.0.105.255
        ether 00:0c:29:17:f1:af  txqueuelen 1000  (Ethernet)

2、配置通过ip区分的虚拟机
[root@localhost ~]# cat /etc/nginx/nginx.conf
user  root;
worker_processes  4;

#error_log  logs/error.log;
worker_rlimit_nofile 102400;


events {
    
    
    worker_connections  1024;
}


http {
    
    
    include       mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    server {
    
    
        listen       10.0.105.199:80;
        server_name  web.testpm.com;
        location / {
    
    
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate	2k;
        }
        
     server {
    
    
        listen       10.0.105.201:80;
        server_name  web.testpm.com;
        location / {
    
    
            root   /1000phone/html/;
            index  index.html index.htm;
        	}
        }
}
3、重新加载配置文件
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
4、 测试访问
浏览器输入:http://10.0.105.199
浏览器输入:http://10.0.105.201
5、补充
-- 删除绑定的vip
[root@localhost ~]# ifconfig ens33:1 10.0.105.201/24 down
重启一下nginx
[root@localhost ~]# systemctl restart nginx

1. Verifique o IP e encontre o segmento de rede
2. Ifconfig ens33: 1 192.168.49.148/24 Adicione ip à
placa de rede
3. Ifconfig visualize a placa de rede 4. Edite o arquivo de configuração /etc/nginx/nginx.conf Insira dois endereços IP antes da porta de escuta
5. Recarregue o arquivo de configuração nginx (reinicie o nginx se houver um cache (systemctl restart nginx))
6. Visite ip curl 192.168.49.144
curl 192.168.49.148 (IP adicionado)

3. Host virtual baseado em porta

Um IP

[root@localhost ~]# cat /etc/nginx/nginx.conf
user  root;
worker_processes  4;

worker_rlimit_nofile 102400;


events {
    
    
    worker_connections  1024;
}


http {
    
    
    include       mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';


    sendfile        on;

    keepalive_timeout  65;


    server {
    
    
        listen       80;
        server_name  web.testpm.com;
        location / {
    
    
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate	2k;
        }
        
    
     server {
    
    
        listen       8080;
        server_name  web.1000phone.com;
        location / {
    
    
            root   /1000phone/html/;
            index  index.html index.htm;
        	}
        }
}

Recarregue o arquivo de configuração:

[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload

Visita de teste:
entrada do navegador: http://web.testpm.com/
entrada do navegador: http://web.1000phone.com:8080

Acho que você gosta

Origin blog.csdn.net/weixin_49844466/article/details/108287524
Recomendado
Clasificación