Cas d'entrée du serveur d'équilibrage de charge Nginx

不言
Libérer: 2023-03-23 08:42:02
original
1382 Les gens l'ont consulté


J'ai récemment eu le temps d'étudier nginx et j'ai fait un cas d'introduction simple.

Introduction :

Nginx (moteur x) est un serveur Web léger et un serveur proxy inverse et de messagerie (IMAP/POP3) serveur proxy.

Le mode serveur d'accès client normal est l'accès direct. Avec le serveur nginx, nous pouvons déployer la même application sur différents serveurs. améliore considérablement les capacités de concurrence, réduit la pression sur le serveur et améliore les performances.

Mode d'accès normal :



NginxMode d'accès :


Avantages :

En tant que serveur Web : Par rapport à Apache, Nginx utilisent moins de ressources, prennent en charge davantage de connexions simultanées et reflètent une efficacité plus élevée, ce qui fait que Nginx est particulièrement populaire auprès des fournisseurs d'hébergement Web. Capable de prendre en charge des réponses allant jusqu'à 50 000 connexions simultanées, grâce à Nginx pour avoir choisi epoll et kqueue pour nous En tant que modèle de développement.

En tant que serveur d'équilibrage de charge : Nginx les deux en interne Prend directement en charge Ras et PHP, et peut également prendre en charge une utilisation externe en tant que HTTP serveur proxy Effectuer des services. Nginx est écrit en C , quelle que soit la surcharge des ressources système ou L'efficacité d'utilisation du CPU est bien meilleure que celle de Perlbal .

En tant que serveur proxy de messagerie : Nginx est également un très bon serveur proxy de messagerie (l'un des premiers objectifs du développement de ce produit était également en tant que serveur proxy de messagerie Serveur proxy de messagerie), Last.fm décrit une expérience réussie et merveilleuse.

Nginx L'installation est très simple, et le fichier de configuration est très concis (il prend également en charge la syntaxe perl ), BugsTrès peu de serveurs : Nginx le démarrage est particulièrement facile et presque possible7*24 Fonctionne sans interruption, pas besoin de redémarrer même s'il fonctionne plusieurs mois. Vous pouvez également mettre à niveau la version du logiciel sans interrompre le service.

Installation :

a les versions Linux et windows Vous devez essentiellement installer celles correspondantes. Je prends windows comme exemple :

Téléchargez le package d'installationhttp://nginx.org/en/download. html

Décompressez, cliquez sur nginx.exe pour exécuter pour démarrer le service, saisissez localhost dans le navigateur (écoute par défaut 127.0.0.1:80) L'entrée dans la page suivante indique que le serveur nginx a démarré avec succès.


Démo :

J'en ai construit une moi-mêmespringboot est un projet simple déployé sur différents ports (peut être déployé sur différents serveurs). Afin de faciliter les tests, j'ai fait une distinction simple entre le contenu de sortie :


Détails de configuration :

Remarque : conf/nginx.conf est le fichier de configuration par défaut de nginx . Vous pouvez également utiliser nginx -c pour spécifier votre fichier de configuration

#运行用户
#user  nobody;
#启动进程,通常设置成和cpu的数量相等
worker_processes  1;

#全局错误日志
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#PID文件,记录当前启动的nginx的进程ID
#pid        logs/nginx.pid;

#工作模式及连接数上限
events {
    worker_connections  1024;
}

#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
    #设定mime类型(邮件支持类型),类型由mime.types文件定义
    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"';

    #access_log  logs/access.log  main;

    #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
    #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
    sendfile        on;
    #tcp_nopush     on;

    #连接超时时间
    keepalive_timeout  65;

    #gzip压缩开关
    #gzip  on;
	
    #设定负载均衡的服务器列表(或者一个反向代理服务器,一个的话不需要分配权重)
    upstream hello_server {
        #weigth参数表示权值,权值越高被分配到的几率越大
        server 127.0.0.1:8888   weight=1;
        server 127.0.0.1:8899   weight=3;
    }

    server {
        #监听80端口,80端口是知名端口号,用于HTTP协议
	listen       80;
	#定义使用localhost访问
        server_name  localhost;

        #编码格式
	charset utf-8;

        #access_log  logs/host.access.log  main;
		
	#反向代理的路径,location 后面设置映射的路径
	#对所有请求进行负载均衡请求(和upstream绑定)
        location / {
            root        /root;                 #定义服务器的默认网站根目录位置
            index       index.html index.htm;  #定义首页索引文件的名称
            proxy_pass  http://hello_server;   #请求转向hello_server 定义的服务器列表

            #以下是一些反向代理的配置(可选择性配置)
            #proxy_redirect off;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
            proxy_set_header X-Forwarded-For $remote_addr;
            proxy_connect_timeout 90;          #nginx跟后端服务器连接超时时间(代理连接超时)
            proxy_send_timeout 90;             #后端服务器数据回传时间(代理发送超时)
            proxy_read_timeout 90;             #连接成功后,后端服务器响应时间(代理接收超时)
            proxy_buffer_size 4k;              #设置代理服务器(nginx)保存用户头信息的缓冲区大小
            proxy_buffers 4 32k;               #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
            proxy_busy_buffers_size 64k;       #高负荷下缓冲大小(proxy_buffers*2)
            proxy_temp_file_write_size 64k;    #设定缓存文件夹大小,大于这个值,将从upstream服务器传
            
            client_max_body_size 10m;          #允许客户端请求的最大单文件字节数
            client_body_buffer_size 128k;      #缓冲区代理缓冲用户端请求的最大字节数
        }

}
Copier après la connexion

Après la configuration, redémarrez nginx Serveur, accédez à localhost :

commande de redémarrage : nginx -s reload

Vous accédez toujours au serveur nginx(localhost), mais vous accédez réellement à celui déployéspringbootprojet(localhost:8899). Actualisez encore quelques fois et vous verrez l'image ci-dessous, indiquant que les services déployés sur les deux ports ont été accédés.


Remarque : Les valeurs de poids attribuées par les deux services sont différentes, donc Bonjour le monde b apparaît !!!(Accéder réellement à localhost:8899) est plus probable, et bonjour le monde a !!!(L'accès réel à localhost:8888) est moins probable. Vous pouvez modifier vous-même la valeur d'autorisation et la tester plusieurs fois !

Résumé :

NginxCommandes communes :



Recommandations associées :

Utilisez Nginx pour éviter les requêtes inter-domaines ajax

Le mécanisme de proxy inverse nginx résout les problèmes croisés front-end problèmes de domaine


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal