Maison  >  Article  >  Opération et maintenance  >  Qu'est-ce que nginx sous Linux

Qu'est-ce que nginx sous Linux

青灯夜游
青灯夜游original
2022-03-09 14:50:433979parcourir

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.

Qu'est-ce que nginx sous Linux

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 :
Quest-ce que nginx sous Linux
Proxy inverse :
Quest-ce que nginx sous Linux
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.

nginx cliquez sur la version pour installer et démarrer le service

1. Installez les plug-ins requis pour le service nginx

yum install -y yum-utils

Quest-ce que nginx sous Linux

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.

Quest-ce que nginx sous Linux
Créez ensuite un fichier nginx.repo :

[nginx]
 name=nginx repo
 baseurl=http://nginx.org/packages/centos/7/$basearch/
 gpgcheck=0
 enabled=1

Installé :

Quest-ce que nginx sous Linux
commande de gestion des services nginx :

systemctl start/stop/restart/status nginx
Quest-ce que nginx sous Linux

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 :
Quest-ce que nginx sous Linux
Après modification, Linux doit être redémarré .
Fichier de configuration nginx :
Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux

Le fichier de configuration que nous modifions souvent à l'avenir est /etc/nginx/conf.d/default.conf :

Quest-ce que nginx sous Linux

Utilisez nginx pour l'équilibrage de charge

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环境变量:
Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux
然后 保存退出 ,在命令行执行 source 命令 编译环境变量文件,让环境变量立刻生效:
Quest-ce que nginx sous Linux
tomcat 启动:Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux
第二步,准备两个tomcat 一个端口号弄成8000 另外一个9000
Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux
第三步,修改nginx的配置文件
没有安装vim,使用vi命令
Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux
然后重启nginx服务:
Quest-ce que nginx sous Linux

nginx支持的负载均衡的策略

轮询策略

默认nginx支持的策略,来了请求之后 排队把请求一个一个的分发出去。

权重策略
Quest-ce que nginx sous Linux
IP_HASH方式

根据 客户端ip地址 固定分配到一台服务器上,以后这个ip来的所有请求 都会只到这一个服务器上。
Quest-ce que nginx sous Linux

使用keepalived 完成 nginx 高可用配置

Quest-ce que nginx sous Linux
上面我们实现的集群方式 可以解决tomcat 服务器单点故障的问题,但是解决不了 nginx服务器单点故障的问题。

解决nginx 单点故障问题,市场上通用的解决方案就是使用keepalived 这种插件。

先安装keepalived服务:
Quest-ce que nginx sous Linux
Quest-ce que nginx sous Linux
下面修改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

创建好这个脚本之后 不要忘记修改文件的权限:

Quest-ce que nginx sous Linux
下面启动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!

Déclaration:
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