云原生 Nginx安装&配置解析

简介: 【1月更文挑战第8天】云原生 Nginx安装&配置解析

 image.gif编辑

目录

一、Nginx 概述:

1.Nginx 常用功能:

Http代理,反向代理:

负载均衡:

web缓存:

2.Nginx 版本:

3.Nginx 开源版本安装:

可能出现的异常:

4.Nginx 相关命令:

二、Nginx 目录结构:

三、Nginx 多进程模型和基本请求流程:

四、Nginx基础配置:

1.虚拟主机与域名解析:

2.配置虚拟主机(配置Nginx)

3.servername匹配规则:


一、Nginx 概述:

image.gif编辑

1.Nginx 常用功能:

Http代理,反向代理:

       Nginx作为web服务器最常用的功能之一,尤其是反向代理。

image.gif编辑

       Nginx在做反向代理时,提供性能稳定,并且能够提供配置灵活的转发功能。Nginx可以根据不同的正则匹配,采取不同的转发策略,比如图片文件结尾的走文件服务器,动态页面走web服务器,只要你正则写的没问题,又有相对应的服务器解决方案,你就可以随心所欲的玩。并且Nginx对返回结果进行错误页跳转,异常判断等。如果被分发的服务器存在异常,他可以将请求重新转发给另外一台服务器,然后自动去除异常服务器。

负载均衡:

       Nginx提供的负载均衡策略有2种:内置策略和扩展策略。内置策略为轮询,加权轮询,Ip hash。扩展策略,就天马行空,只有你想不到的没有他做不到的啦,你可以参照所有的负载均衡算法,给他一一找出来做下实现。

image.gif编辑

        Ip hash算法,对客户端请求的ip进行hash操作,然后根据hash结果将同一个客户端ip的请求分发给同一台服务器进行处理,可以解决session不共享的问题。

image.gif编辑

web缓存:

       Nginx可以对不同的文件做不同的缓存处理,配置灵活,并且支持FastCGI_Cache,主要用于对FastCGI的动态程序进行缓存。配合着第三方的ngx_cache_purge,对制定的URL缓存内容可以的进行增删管理。

2.Nginx 版本:

系统环境:Linux (CentOS,Ubuntu)

Nginx 开源版本:纯原生

Nginx Plus 商业版本

Openresty:开源版本

Tengine:阿里巴巴开源

3.Nginx 开源版本安装:

       进入Nginx开源官方网站下载页面:

image.gif编辑

       解压安装Nginx:

tar zxvf nginx-1.23.1.tar.gz

image.gif

       进入Nginx目录:

cd nginx-1.23.1/

image.gif

       执行configure脚本:

./configure --prefix=/usr/local/nginx

image.gif

       Nginx是高度自由化的Web服务器,它的功能是由许多模块来支持。如果使用了某个模块,这个模块使用了一些类似zlib或OpenSSL等的第三方库,那么就必须先安装这些软件。Ubuntu下不像在centOS中使用yum直接在线安装,可以使用以下方法。

可能出现的异常:

异常一:

        这一步可能出现异常情况,主要原因是因为缺少相关的环境依赖,可能提示以下错误信息:

image.gif编辑

        这里报错的的主要原因是缺少C语言的编译环境,需要安装gcc,根据不同Linux发行版安装即可:

# centos
yum install -y gcc
# ubuntu
apt install -y gcc

image.gif

       如果提示权限不足,在命令前添加sudo命令。

异常二:

./configure: error: the HTTP rewrite module requires the PCRE library.
You can either disable the module by using --without-http_rewrite_module
option, or install the PCRE library into the system, or build the PCRE library
statically from the source with nginx by using --with-pcre=<path> option.

image.gif

       PCRE库支持正则表达式。如果我们在配置文件nginx.conf中使用了正则表达式,那么在编译Nginx时就必须把PCRE库编译进Nginx,因为Nginx的HTTP模块需要靠它来解析正则表达式。另外,pcre-devel是使用PCRE做二次开发时所需要的开发库,包括头文件等,这也是编译Nginx所必须使用的。可以这样安装:

       缺少pcre-devel依赖,执行安装命令:

# centos
yum install -y pcre pcre-devel
# ubuntu
apt-get install libpcre3 libpcre3-dev

image.gif

异常三:

/configure: error: the HTTP gzip module requires the zlib library.
You can either disable the module by using --without-http_gzip_module
option, or install the zlib library into the system, or build the zlib library
statically from the source with nginx by using --with-zlib=<path> option.

image.gif

       zlib库用于对HTTP包的内容做gzip格式的压缩,如果我们在nginx.conf中配置了gzip on,并指定对于某些类型(content-type)的HTTP响应使用gzip来进行压缩以减少网络传输量,则在编译时就必须把zlib编译进Nginx。zlib-devel是二次开发所需要的库。可以这样安装:

sudo apt-get install zlib1g-dev

image.gif

异常四:

       如果服务器不只是要支持HTTP,还需要在更安全的SSL协议上传输HTTP,那么需要拥有OpenSSL。另外,如果我们想使用MD5、SHA1等散列函数,那么也需要安装它。可以这样安装:

sudo apt-get install openssl libssl-dev

image.gif


       异常解决完成之后执行make:

make

image.gif

     执行make install 安装Nginx:

make install

image.gif

       安装完成之后,进入安装目录:

cd /usr/local/nginx

image.gif

       进入sbin目录,执行nginx脚本文件,启动Nginx服务:

cd sbin

image.gif

sudo ./nginx

image.gif

       进入浏览器,地址栏输入:localhost出现以下页面,Nginx服务启动成功:

image.gif编辑

4.Nginx 相关命令:

./nginx # 启动Nginx服务
./nginx -s stop # 快速停止Nginx服务
./nginx -s quit # 优雅关闭,在关闭之前完成接受的所有连接请求
./nginx -s reload # 重新加载配置

image.gif


二、Nginx 目录结构:

image.gif编辑

注意:文件名中含有_temp的文件目录是在Nginx初始化运行后产生。

    • sbin:存放这Nginx脚本程序,包含启动、停止和重启等。
    • logs:存放Nginx中运行的日志文件
      • nginx.pid:记录当前Nginx运行的进程号

        image.gif编辑

          • html:存放了Nginx静态资源
          • conf:存放Nginx中所有的配置文件,重点nginx.conf,保存了基本的Nginx的配置。

          image.gif编辑


          三、Nginx 多进程模型和基本请求流程:

                 当执行了Nginx的启动脚本(sbin目录下的nginx),这时服务器会启动一个Nginx的Master主进程,这个Master进程会去加载并校验conf目录下的nginx.conf配置文件。如果配置文件没有错误,则会开启多个Worker子进程。

          image.gif编辑

                 Worker进程就会根据配置文件中的配置,去指定的文件目录进行资源的读取。

          image.gif编辑


          四、Nginx基础配置:

                 Nginx配置文件nginx.conf:

          worker_processes  1; # Woker工作进程数量
          # EVENT事件驱动模块:
          events {
              worker_connections  1024;
          }
          # HTTP模块:
          http {
              # include 命令在当前配置文件中引入其他配置文件
              include       mime.types;  # mime.types配置文件中预设了不同文件类型的浏览器解析方式
              # 指定默认的解析方式
              default_type  application/octet-stream;
              # 设置开启零拷贝
              sendfile        on;
              keepalive_timeout  65;
              # server模块:(一个Server就是一个主机)
              server {
                  # 监听端口号
                  listen       80;
                  server_name  localhost;  # 域名,主机名
                  # URI
                  location / {
                      # 相对nginx安装主目录,相对路径
                      root   html;
                      index  index.html index.htm;
                  }
                  # 错误页面
                  error_page   500 502 503 504  /50x.html;
                  location = /50x.html {
                      root   html;
                  }
              }
          }

          image.gif

          image.gif编辑

                 0拷贝是指DMI,数据不需要从内存到CPU到内存,而是直接从内存再到内存

          image.gif编辑

          1.虚拟主机与域名解析:

            • 域名:(英语:Domain Name),又称网域,是由一串用点分隔的名字组成的Internet上某一台计算机或计算机组的名称,用于在数据传输时对计算机的定位标识。
            • DNS:域名系统(英文:Domain Name System,缩写DNS)是互联网的一项服务。它作为将域名IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。DNS使用UDP端口53。当前,对于每一级域名长度的限制是63个字符,域名总长度则不能超过253个字符。
            • IP地址:Internet Protocol Address是指互联网协议地址,又译为网际协议地址。 IP地址是IP协议提供的一种统一的地址格式,它为互联网上的每一个网络和每一台主机分配一个逻辑地址,以此来屏蔽物理地址的差异。

                   由于IP地址具有不方便记忆并且不能显示地址组织的名称和性质等缺点,人们设计出了域名,并通过网域名称系统(DNS,Domain Name System)来将域名和IP地址相互映射,使人更方便地访问互联网,而不用去记住能够被机器直接读取的IP地址数串。

            image.gif编辑

                   在hosts文件中配置本机的域名,Linux的hosts文件在/etc目录下:

            image.gif编辑

            2.配置虚拟主机(配置Nginx)

            worker_processes  1;
            events {
                worker_connections  1024;
            }
            http {
                include       mime.types;
                default_type  application/octet-stream;
                sendfile        on;
                keepalive_timeout  65;
                # 配置虚拟主机:
                server {
                    # 配置虚拟主机的端口号:
                    listen       80;
                    # 配置虚拟主机的地址(IP地址,域名)
                    server_name  www.krian.com;     
                  # 配置请求资源的目录地址
                    location / {
                        # 指定根目录下的html中的index.html文件
                        root   /html;
                        index  index.html index.htm;
                    }
                    error_page   500 502 503 504  /50x.html;
                    location = /50x.html {
                        root   html;
                    }
                }
            }

            image.gif

            配置nginx时,相同的端口号加上相同的主机名会有冲突。

                   编辑完成配置文件后,需要重新加载Nginx的配置文件:

            sudo ./nginx -s reload

            image.gif

                   主要需要事先在根目录下创建html目录,在html目录中创建index.html文件。

            3.servername匹配规则:

              • 当前面的servername被匹配成功之后,后面的servername将不会继续匹配。
              • servername可以配置多个主机地址和域名
              • servername匹配支持 * 通配符
              • servername支持正则表达式匹配
                • 多级域名系统
                • 短网址
                • HTTPDNS
                相关文章
                |
                16天前
                |
                数据采集 消息中间件 监控
                Flume数据采集系统设计与配置实战:面试经验与必备知识点解析
                【4月更文挑战第9天】本文深入探讨Apache Flume的数据采集系统设计,涵盖Flume Agent、Source、Channel、Sink的核心概念及其配置实战。通过实例展示了文件日志收集、网络数据接收、命令行实时数据捕获等场景。此外,还讨论了Flume与同类工具的对比、实际项目挑战及解决方案,以及未来发展趋势。提供配置示例帮助理解Flume在数据集成、日志收集中的应用,为面试准备提供扎实的理论与实践支持。
                25 1
                |
                27天前
                |
                运维 前端开发 应用服务中间件
                LNMP详解(八)——Nginx动静分离实战配置
                LNMP详解(八)——Nginx动静分离实战配置
                28 0
                |
                26天前
                |
                前端开发 应用服务中间件 nginx
                Nginx配置详解Docker部署Nginx使用Nginx部署vue前端项目
                Nginx配置详解Docker部署Nginx使用Nginx部署vue前端项目
                101 0
                |
                3天前
                |
                JavaScript 前端开发 应用服务中间件
                angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
                angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
                10 0
                |
                2天前
                |
                前端开发 JavaScript 应用服务中间件
                前端vue2、vue3去掉url路由“ # ”号——nginx配置(二)
                前端vue2、vue3去掉url路由“ # ”号——nginx配置
                17 0
                |
                3天前
                |
                分布式计算 网络协议 Hadoop
                Hadoop节点扩展配置DNS和主机名解析
                【4月更文挑战第19天】
                11 1
                |
                5天前
                |
                JavaScript IDE 编译器
                TypeScript中模块路径解析与配置:深入剖析与最佳实践
                【4月更文挑战第23天】本文深入探讨了TypeScript中模块路径解析的原理与配置优化,包括相对路径、Node.js模块解析和路径别名。通过配置`baseUrl`、`paths`、`rootDirs`以及避免裸模块名,可以提升开发效率和代码质量。建议使用路径别名增强代码可读性,保持路径结构一致性,并利用IDE插件辅助开发。正确配置能有效降低维护成本,构建高效可维护的代码库。
                |
                5天前
                |
                JSON Java Maven
                Javaweb之SpringBootWeb案例之自动配置以及常见方案的详细解析
                Javaweb之SpringBootWeb案例之自动配置以及常见方案的详细解析
                7 0
                Javaweb之SpringBootWeb案例之自动配置以及常见方案的详细解析
                |
                6天前
                |
                安全 应用服务中间件 网络安全
                SSL原理、生成SSL密钥对、Nginx配置SSL
                现在,你的Nginx虚拟主机应该已经配置了SSL,可以通过HTTPS安全访问。确保在生产环境中使用有效的SSL证书来保护通信的安全性。
                19 0
                |
                8天前
                |
                域名解析 缓存 负载均衡
                Nginx正向代理域名的配置
                Nginx正向代理域名的配置

                热门文章

                最新文章

                推荐镜像

                更多