Sous Linux, nginx est un serveur Web HTTP et proxy inverse hautes performances. Il s'agit d'un serveur http, d'un serveur proxy inverse et d'un serveur proxy de messagerie (IMAP/POP3) hautes performances.
L'environnement d'exploitation de ce tutoriel : système linux5.9.8, ordinateur Dell G3.
nginx Qu'est-ce que
Serveur de ressources statiques Apache
nginx est un serveur de ressources statiques proxy inverse.
nginx est un serveur http et un serveur proxy inverse hautes performances développés en langage C. Nginx est un serveur http/proxy inverse et un serveur proxy de messagerie (IMAP/POP3) hautes performances. Développé par le programmeur russe Igor Sysoev, le test officiel de nginx peut prendre en charge 50 000 connexions simultanées, consomme très peu de CPU, de mémoire et d'autres ressources, et fonctionne de manière très stable.
Proxy Forward :
Proxy inverse :
Le proxy inverse est généralement utilisé côté serveur pour distribuer les requêtes et réaliser l'équilibrage de charge.
Scénarios d'application Nginx
1. Nginx est un service http qui peut fournir des services http de manière indépendante. Peut être utilisé comme serveur Web statique.
2. Hôte virtuel. Plusieurs sites Web peuvent être virtualisés sur un seul serveur. Par exemple, un hôte virtuel utilisé par un site Web personnel.
Basé sur des ports, différents terminaux
Basé sur des noms de domaine, différents noms de domaine
3. Proxy inverse, équilibrage de charge. Lorsque le nombre de visites sur le site Web atteint un certain niveau et qu'un seul serveur ne peut pas satisfaire les demandes des utilisateurs, plusieurs clusters de serveurs sont nécessaires et nginx peut être utilisé comme proxy inverse. Et plusieurs serveurs peuvent partager la charge de manière égale, et il n'y aura pas de temps d'arrêt dû à une charge élevée sur un certain serveur et un certain serveur ne sera pas inactif.
1. Installez les plug-ins requis pour le service nginx
yum install -y yum-utils
2 Installez nginx
Il n'y a pas de nginx dans la source officielle de yum, mais nous pouvons. configurez nginx localement. source yam pour implémenter l'installation yum de nginx.
Créez ensuite un fichier nginx.repo :
[nginx] name=nginx repo baseurl=http://nginx.org/packages/centos/7/$basearch/ gpgcheck=0 enabled=1
Installé :
commande de gestion des services nginx :
systemctl start/stop/restart/status nginx
3 , tu dois fermer le service selinux du système d'exploitation linux
selinux est la suite de services de sécurité de linux
Modifiez le fichier vi /etc/selinux/config et modifiez le contenu suivant :
Après modification, Linux doit être redémarré .
Fichier de configuration nginx :
Le fichier de configuration que nous modifions souvent à l'avenir est /etc/nginx/conf.d/default.conf :
Après téléchargement et compression Le package est transféré dans le dossier Linux opt via xftp et décompressé
La première étape consiste à démarrer deux tomcats sur notre serveur Linux
先配置jdk环境变量:
然后 保存退出 ,在命令行执行 source 命令 编译环境变量文件,让环境变量立刻生效:
tomcat 启动:
第二步,准备两个tomcat 一个端口号弄成8000 另外一个9000
第三步,修改nginx的配置文件
没有安装vim,使用vi命令
然后重启nginx服务:
轮询策略
默认nginx支持的策略,来了请求之后 排队把请求一个一个的分发出去。
权重策略
IP_HASH方式
根据 客户端ip地址 固定分配到一台服务器上,以后这个ip来的所有请求 都会只到这一个服务器上。
上面我们实现的集群方式 可以解决tomcat 服务器单点故障的问题,但是解决不了 nginx服务器单点故障的问题。
解决nginx 单点故障问题,市场上通用的解决方案就是使用keepalived 这种插件。
先安装keepalived服务:
下面修改keepalived的配置文件: vim /etc/keepalived/keepalived.conf文件:
global_defs { notification_email { #keepalived如果检测到nginx服务不能用会往这个邮件发信心 test@163.com } #配置邮件服务器的信息 notification_email_from keepalived@localhost smtp_server 127.0.0.1 smtp_connect_timeout 30 router_id LVS_MASTER } #声明一个脚本 vrrp_script chk_http_port { #检测本机nginx的服务是否能用的脚本 这个脚本等下要自己编写 script "/usr/local/src/check_nginx_pid.sh" #每隔多长时间自动调用上述脚本 interval 2 #权重 weight 2 } vrrp_instance VI_1 { #state MASTER #配置当前的nginx服务器是主机还是备机 state BACKUP #配置当前nginx服务是是否非抢占模式 #nopreempt #配置心跳网卡的名称 interface ens33 #所有的keepalived的服务器的虚拟化路由都要一致 virtual_router_id 50 #nginx服务器的初始化权重 priority 100 #心跳连接发送的间隔 advert_int 1 #认证方式和认证密码 要保证所有keepalive的服务器的验证方式和密码都一样 authentication { auth_type PASS auth_pass 1111 } #启用上述脚本 track_script { chk_http_port } virtual_ipaddress { #配置了keeplived服务器之后再访问tomcat集群虚拟的ip地址时多少 192.168.17.222 #虚拟ip } }
下一步,写/usr/local/src/check_nginx_pid.sh这个脚本:
#! /bin/bash A=`ps -C nginx --no-header |wc -l` if [ $A -eq 0 ];then systemctl start nginx if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then killall keepalived fi fi
创建好这个脚本之后 不要忘记修改文件的权限:
下面启动keepalived服务:
systemctl start keepalived
相关推荐:《Linux视频教程》
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!