Nginx快速入门:Nginx应用场景、安装与部署(一)

发布时间:2023年12月19日

1. Nginx简介

Nginx 是一个高性能的 HTTP 和反向代理服务器,也是一个非常流行的开源 Web 服务器软件。它是由俄罗斯程序员 Igor Sysoev 开发的,最初是为了解决在高并发场景下的C10k 问题(即一个服务器进程只能处理 10,000 个并发连接)的限制。Nginx 以其高性能、稳定性、丰富的功能集、简单的配置以及低资源消耗而被广泛使用。

nginx为什么能支持大并发?
Nginx 使用一个事件驱动的异步非阻塞 I/O 模型,默认使用 epoll 模型,这使得它在处理大量并发连接时表现非常出色。此外,Nginx 还支持worker进程,可以有效地分配资源并提高性能。

nginx的市场占用率
https://w3techs.com/technologies/cross/web_server/ranking
在这里插入图片描述

nginx官网
http://nginx.org

2. Nginx的应用场景

在企业生产中,nginx的主要应用场景在四个方面:

  • 静态资源服务

用来部署图片、css、html等静态资源

  • 代理服务

作为统一入口或代理入口,进行服务转发、负载均衡等

  • 安全控制

做多个服务的入口,将入口部署ssl证书,以此实现服务的加密控制,而不用在每个后台服务部署证书

  • 代理缓存

将动态请求的资源在nginx中进行缓存,下次请求时直接从nginx获取,就不用再走后台服务,以此提高用户的访问速度

后续我们从上述4个方面对nginx的应用进行逐步学习,如果对nginx有兴趣的同学,可以关注专栏,以及时接收到更新通知。

3. Nginx安装

nginx支持2种部署方式:

  • yum工具安装
  • 安装包安装

以下我们分别讲解

3.1 yum工具安装

1、设置nginx yum源
在官网:https://nginx.org/en/linux_packages.html#RHEL/CentOS中有关于yum源的说明
在这里插入图片描述

所以我们可以创建nginx.repo文件,设置官方yum源,也可以用国内厂商,如阿里云的yum源,这里以官网yum源为例

创建nginx.repo文件:

cd /etc/yum.repos.d/
vim nginx.repo

内容

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

如果是mac m1,需要配置arm架构的镜像源,直接执行如下指令即可,就不用再创建nginx.repo了:

wget http://mirrors.aliyun.com/repo/Centos-altarch-7.repo -O /etc/yum.repos.d/CentOS-Base.repo

2、检查yum源配置完成

yum makecache
yum repolist

这里我以mac m1的执行效果为例,可以看到更新了nginx的yum源
在这里插入图片描述

3、安装nginx

yum install nginx -y

在这里插入图片描述
4、查看nginx版本

nginx -V

在这里插入图片描述

5、启动nginx

nginx

关闭nginx指令

# 强制退出,不管有没有正在处理的请求
nginx -s stop
# 优雅退出,等待正在执行的转发执行完成后再退出
nginx -s quit
# 重启
nginx -s reload

通过yum安装的nginx的默认安装路径为:/etc/nginx,日志文件默认路径为:/var/log/nginx

在这里插入图片描述

3.2 安装包安装

1、准备源码包:https://nginx.org/en/download.html

选择对应的版本下载即可
在这里插入图片描述

2、上传到服务器,并解压

tar xf nginx-1.19.7.tar.gz

3、准备依赖环境

yum install -y openssl-devel pcre-devel gcc

4、添加nginx用户

useradd nginx -m -s /sbin/nologin

5、预编译,在nginx目录下执行

–prefix 指定nginx目录
–sbin-path 指定nginx运行目录
–user 运行程序的用户
–group 运行程序的用户组
–with 需要添加的nginx模块

./configure --prefix=/usr/local/nginx --sbin-path=/bin/ --user=nginx --group=nginx --withhttp_ssl_module --withhttp_stub_status_module --withhttp_gzip_static_module

检查是否安装成功

# 检查上一条命令执行结果,如果是0则执行成功,如果不是0则说明执行失败
echo $?

6、安装nginx

make && make install

7、检查nginx版本

./bin/nginx -V

8、启动nginx

./bin/nginx

9、检查nginx端口

netstat -lntup | grep nginx

在这里插入图片描述

4. nginx访问

nginx的默认端口是80, 如果是虚拟机安装的,记得开通虚拟机的80端口,或者关闭防火墙

# 查询22端口是否开放
firewall-cmd --query-port=80/tcp
# 开启端口
firewall-cmd --add-port=80/tcp --permanent
# 开启后重新加载
firewall-cmd --reload

访问虚拟机ip:80端口即可访问到nginx, 因为http默认80端口,所以可以省略端口访问:

在这里插入图片描述

5. 总结

下一节我们将来学习nginx的目录结构及各类配置文件的作用,并配置一个简单的转发带大家先感受下nginx的使用

文章来源:https://blog.csdn.net/qq_24950043/article/details/134864970
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。