最新资讯

  • nginx cm

nginx cm

2025-05-16 10:00:55 66 阅读

Nginx服务

一、HTTP 属于应用层

  • 80端口对应的服务是Nginx,Apache服务
  • Nginx,Apache服务用的协议是http协议

HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于从万维网(WWW:World Wide Web )服务器传输超文本到本地浏览器的传送协议。

HTTP工作在 TCP/IP协议体系中的TCP协议上,是一个基于 TCP/IP 通信协议来传递数据(HTML 文件、图片文件、查 询结果等)。

1、HTTP 工作原理

HTTP协议工作于客户端-服务端架构上。浏览器作为HTTP客户端通过URL向HTTP服务端(web服务端)发送的请求报文,这个请求报文包含了请求方法、URL协议版本、请求头部和请求数据。服务器以一个状态行作为响应,响应的内容包括协议的版本、成功或错误代码、服务器信息、响应头部和响应数据。

Web服务器有:Nginx,Apache服务器,IIS服务器(Internet Information Services)等。

Web服务器根据接收到的请求后,向客户端发送响应信息。

HTTP默认端口号为80,但是你也可以改为其他端口。
CGI
通用网关接口(Common Gateway Interface/CGI)描述了客户端和服务器程序之间传输数据的一种标准,可以让一个客户端,从网页浏览器向执行在网络服务器上的程序请求数据。CGI 程序可以用任何脚本语言或者是完全独立编程语言实现,只要这个语言可以在这个系统上运行

2、HTTP 消息结构

HTTP是基于客户端/服务端(C/S)的架构模型,通过一个可靠的链接来交换信息,是一个无状态的请求/响应协议。HTTP是无状态协议,意味着服务器不会保留关于客户端或请求的任何信息,每个请求都是独立的,即使是在持久连接(如Keep-Alive)的情况下也是如此。

一个HTTP"客户端"是一个应用程序(Web浏览器或其他任何客户端),通过连接到服务器达到向服务器发送一个或多个HTTP的请求的目的。

一个HTTP"服务器"同样也是一个应用程序(通常是一个Web服务,如Apache Web服务器或IIS服务器等),通过接收客户端的请求并向客户端发送HTTP响应数据。

HTTP使用统一资源标识符(Uniform Resource Identifiers, URI)来传输数据和建立连接。

3、客户端请求消息

HTTP 报文可以分为两类:请求报文(request message)和响应报文(response message),两者的基本报文结构相同。

客户端发送一个HTTP请求到服务器的请求消息包括以下格式:请求行(request line)、请求头部(header)、空行和请求数据四个部分组成,下图给出了请求报文的一般格式。

4、服务器响应消息

HTTP响应也由四个部分组成,分别是:状态行、消息报头、空行和响应正文。

实例

下面实例是一点典型的使用GET来传递数据的实例:

客户端请求:

# curl -v http://www.testpm.cn
Connected to www.testpm.cn (47.244.247.240) port 80 (#0)
> GET /hello.txt HTTP/1.1   # 请求方式与版本协议。
> User-Agent: curl/7.29.0   #用什么客户端访问
> Host: www.testpm.cn  #主机名,域名。主机和端口号,
> Accept: */*  #匹配什么文件类型,“*” 是通用匹配。匹配所有类型

服务端响应:

< HTTP/1.1 200 OK       #请求返回的状态码
< Server: nginx/1.16.0  #请求的服务和版本号
< Date: Thu, 04 Jul 2019 08:19:40 GMT #当前时间,北京时间为GMT+8小时
< Content-Type: text/plain #mime类型,test/plain:普通文本,比如image/png...、video
< Content-Length: 12 #内容的长度
< Last-Modified: Thu, 04 Jul 2019 08:13:25 GMT #最后修改时间
< Connection: keep-alive  #是否支持长连接
< ETag: "5d1db525-c"  #标识,每次访问如果与最开始的值一样返回304否则校验不一致返回200
< Accept-Ranges: bytes #接受的范围单位

输出结果:

hello world
经典面试题(重点)

在浏览器地址栏键入 URL,按下回车之后会经历什么?

浏览器向 DNS 服务器请求解析该 URL 中域名对应的 IP 地址;
解析出 IP 地址后,根据该 IP 地址和默认端口 80,和服务器建立 TCP 连接;
服务器发出读取文件的HTTP请求(URL 中域名后面部分对应的文件),(该请求报文作为 TCP 三次握手的第三个报文的数据发送给服务器);
服务器对浏览器请求作出响应,并把对应的HTML文本发送给浏览器;
释放TCP连接;
浏览器将HTML文档渲染并显示内容;

5、HTTP 请求方法

  • 检查 Web 访问情况

  • curl -I ip地址 向指定的 IP 地址发送 HTTP 请求,仅获取响应的头部信息

  • **curl -v ip地址 **可以看网站的响应主体,展示与服务器之间的详细交互信息

根据HTTP标准,HTTP请求可以使用多种请求方法。

HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法。 

HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。

以下是常见的 HTTP 请求方法(HTTP Request Methods) 及其核心作用、应用场景和特性总结:


1. GET

  • 用途获取资源(只读操作)。
  • 特点
    • 安全(Safe):不会修改服务器资源。
  • 示例
    • 访问网页:GET /index.html
    • 查询用户信息:GET /users/123
  • 注意
    • 参数通过 URL 传递(如 /users?id=123)。
    • 不应用于提交敏感数据(URL 可能被日志记录)。

2. POST

  • 用途提交数据(通常用于创建资源或触发操作)。
  • 示例
    • 提交表单:POST /login(提交用户名密码)。
    • 创建订单:POST /orders(提交订单数据)。

3. PUT

  • 用途替换或更新整个资源(需提供完整数据)。
  • 特点
    • 不安全(Non-Safe):修改资源。
  • 示例
    • 更新用户信息:PUT /users/123(提供完整的用户数据)。

4. DELETE

  • 用途删除指定资源
  • 特点
    • 不安全(Non-Safe):删除资源。
  • 示例
    • 删除文章:DELETE /posts/456

5. PATCH

  • 用途部分更新资源(仅提交需修改的字段)。
  • 特点
    • 不安全(Non-Safe):修改资源。

6. HEAD

  • 用途获取资源的元数据(如响应头,不返回响应体)。
  • 特点
    • 安全(Safe):不修改资源。
  • 示例
    • 检查资源是否存在:HEAD /files/report.pdf
    • 验证缓存有效性(通过 Last-ModifiedETag 头)。

7. OPTIONS

  • 用途查询服务器支持的请求方法
  • 示例
    • 获取 /users 支持的 HTTP 方法:OPTIONS /users
    • 响应头包含:Allow: GET, POST, HEAD

8. TRACE

  • 用途回显客户端请求(用于调试)。

9. CONNECT

  • 用途建立隧道连接(通常用于 HTTPS 代理)。
  • 示例
    • 代理服务器中转 HTTPS 请求:CONNECT example.com:443 HTTP/1.1

总结对比表
方法用途安全幂等请求体支持
GET获取资源✔️✔️
POST提交数据✔️
PUT替换或创建资源✔️✔️
DELETE删除资源✔️
PATCH部分更新资源✔️
HEAD获取元数据✔️✔️
OPTIONS查询支持的方法✔️✔️
TRACE回显请求(调试)✔️✔️
CONNECT建立隧道(如 HTTPS)✔️

核心概念

1. 安全性(Safe Methods)

  • 定义:请求不会修改服务器资源(如 GET、HEAD、OPTIONS)。
  • 意义:允许浏览器预加载或爬虫安全访问。

2. 幂等性(Idempotent Methods)

  • 定义:多次请求效果相同(如 GET、PUT、DELETE)。
  • 意义:网络超时后可安全重试。

掌握 HTTP 请求方法是构建高效、可靠 Web 应用和 API 的基础。正确使用方法可提升安全性、可维护性,并与 RESTful 设计原则保持一致。

6、HTTP 响应头信息

HTTP 响应字段(HTTP Response Headers)是服务器在返回 HTTP 响应时附加的元数据,用于向客户端(如浏览器)传递关于响应的附加信息。以下是常见的 HTTP 响应字段及其作用:


通用字段(General Headers)

  1. Cache-Control
    • 用途:控制缓存行为(如 public, private, max-age, no-cache)。
    • 示例:Cache-Control: max-age=3600(缓存 1 小时)。
  2. Connection
    • 用途:管理网络连接(如 keep-aliveclose)。
    • 示例:Connection: keep-alive(保持长连接)。
  3. Date
    • 用途:响应生成的日期和时间(GMT 格式)。
    • 示例:Date: Tue, 15 Aug 2023 12:00:00 GMT

响应字段(Response Headers)

  1. Status
    • 用途:显示 HTTP 状态码和状态短语(实际由协议行传递,非显式头字段)。
    • 示例:HTTP/1.1 200 OK
  2. Server
    • 用途:标识服务器软件(如 Apache、Nginx)。
    • 示例:Server: nginx/1.18.0
  3. Location
    • 用途:重定向目标 URL(常用于 3xx 状态码)。
    • 示例:Location: https://example.com/new-page
  4. Set-Cookie
    • 用途:向客户端设置 Cookie。
    • 示例:Set-Cookie: sessionId=abc123; Path=/; Secure
  5. Retry-After
    • 用途:客户端应等待多久后重试请求(用于 503 服务不可用)。
    • 示例:Retry-After: 3600(1 小时后重试)。

实体字段(Entity Headers)

  1. Content-Type
    • 用途:响应体的媒体类型(如 text/html, application/json)。
    • 示例:Content-Type: application/json; charset=utf-8
  2. Content-Length
    • 用途:响应体的字节长度。
    • 示例:Content-Length: 1024
  3. Content-Encoding
    • 用途:响应体的压缩方式(如 gzip, br)。
    • 示例:Content-Encoding: gzip
  4. Content-Disposition
    • 用途:指示客户端如何处理内容(如下载文件)。
    • 示例:Content-Disposition: attachment; filename="file.txt"
  5. Last-Modified
    • 用途:资源最后修改时间(用于缓存验证)。
    • 示例:Last-Modified: Tue, 15 Aug 2023 10:00:00 GMT
  6. ETag
    • 用途:资源版本的唯一标识符(用于缓存验证)。
    • 示例:ETag: "33a64df551425fcc55e4d42a148795d9f25f89d4"

安全相关字段(Security Headers)

  1. Strict-Transport-Security (HSTS)
    • 用途:强制使用 HTTPS(防止降级攻击)。
    • 示例:Strict-Transport-Security: max-age=31536000; includeSubDomains
  2. Content-Security-Policy (CSP)
    • 用途:限制页面加载资源的来源(防止 XSS)。
    • 示例:Content-Security-Policy: default-src 'self'
  3. X-Content-Type-Options
    • 用途:禁止浏览器猜测 MIME 类型(防止 MIME 类型嗅探)。
    • 示例:X-Content-Type-Options: nosniff
  4. X-Frame-Options
    • 用途:阻止页面在 中加载(防止点击劫持)。
    • 示例:X-Frame-Options: DENY
  5. Permissions-Policy
    • 用途:控制浏览器功能(如摄像头、地理位置)的访问权限。
    • 示例:Permissions-Policy: geolocation=() (禁用地理位置)。

CORS 相关字段(跨域资源共享)

  1. Access-Control-Allow-Origin
    • 用途:允许跨域请求的源(如 * 或特定域名)。
    • 示例:Access-Control-Allow-Origin: https://example.com
  2. Access-Control-Allow-Methods
    • 用途:允许的 HTTP 方法(如 GET, POST)。
    • 示例:Access-Control-Allow-Methods: GET, POST, OPTIONS

其他常用字段

  1. WWW-Authenticate
    • 用途:定义身份验证方式(用于 401 Unauthorized)。
    • 示例:WWW-Authenticate: Basic realm="Access to site"
  2. Link
    • 用途:定义资源之间的关系(如预加载)。
    • 示例:Link: ; rel=preload; as=style

7、HTTP 状态码

当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头(server header)用以响应浏览器的请求。

HTTP状态码的英文为HTTP Status Code。

下面是常见的HTTP状态码:

  • 200 - 请求成功
  • 301 - 资源(网页等)被永久转移到其它URL
  • 302 - 资源临时移动到新 URL(浏览器不会缓存)
  • 304 - 资源未修改(客户端可使用缓存版本)
  • 403 - 服务器拒绝请求(权限不足),做了访问控制
  • 404 - 请求的资源(网页等)不存在
  • 500及以上 - 内部服务器错误
  • 502,504 - 代理出现了问题,nginx反向代理
  • 503 - 服务器暂时不可用(如维护或过载)

HTTP状态码分类

HTTP状态码由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:


1xx(信息响应)

  • 100 Continue
    • 用途:客户端应继续发送请求的剩余部分(常用于大文件上传前的确认)。
    • 示例:客户端发送 Expect: 100-continue,服务器确认可继续。
  • 101 Switching Protocols
    • 用途:服务器同意切换协议(如从 HTTP 升级到 WebSocket)。
    • 示例:WebSocket 握手时返回此状态码。

2xx(成功响应)

  • 200 OK
    • 用途:请求成功,响应中包含请求的数据(如网页、JSON)。
    • 示例:访问页面或 API 返回数据时常见。
  • 201 Created
    • 用途:资源已成功创建(常见于 POST 请求)。
    • 示例:提交表单后返回新资源的 URL(如 Location: /users/123)。
  • 202 Accepted
    • 用途:请求已接受,但处理尚未完成(异步任务)。
    • 示例:长时间任务(如视频转码)的初始响应。
  • 204 No Content
    • 用途:请求成功,但无返回内容(常见于 DELETE 或 PUT 请求)。
    • 示例:删除资源后返回空响应。
  • 206 Partial Content
    • 用途:部分内容响应(用于分块下载或断点续传)。
    • 示例:视频播放器请求指定字节范围时返回。

3xx(重定向响应)

  • 301 Moved Permanently
    • 用途:资源已永久移动到新 URL(浏览器会缓存重定向)。
    • 示例:网站更换域名时使用 Location: https://new-domain.com
  • 302 Found
    • 用途:资源临时移动到新 URL(浏览器不会缓存)。
    • 示例:临时维护页面跳转。
  • 304 Not Modified
    • 用途:资源未修改(客户端可使用缓存版本)。
    • 触发条件:客户端发送 If-Modified-SinceIf-None-Match 头,服务器验证后返回。
  • 307 Temporary Redirect
    • 用途:临时重定向(强制保持原请求方法,如 POST)。
    • 示例:表单提交时临时跳转。
  • 308 Permanent Redirect
    • 用途:永久重定向(强制保持原请求方法)。
    • 示例:API 路径永久迁移。

4xx(客户端错误)

  • 400 Bad Request
    • 用途:请求格式错误(如参数缺失、JSON 语法错误)。
    • 示例:客户端发送了无效的请求体。
  • 401 Unauthorized
    • 用途:未提供有效身份验证凭证。
    • 示例:访问需要登录的页面时未携带 Token。
  • 403 Forbidden
    • 用途:服务器拒绝请求(权限不足)。
    • 示例:普通用户尝试访问管理员页面。
  • 404 Not Found
    • 用途:请求的资源不存在。
    • 示例:访问的 URL 路径错误或资源已被删除。
  • 405 Method Not Allowed
    • 用途:请求方法不被允许(如对只支持 GET 的接口发送 POST)。
    • 示例:Allow: GET, HEAD 标明支持的 HTTP 方法。
  • 408 Request Timeout
    • 用途:服务器等待请求超时。
    • 示例:客户端上传大文件时网络中断。
  • 409 Conflict
    • 用途:请求与服务器当前状态冲突(如重复提交)。
    • 示例:修改资源时版本号冲突。
  • 413 Payload Too Large
    • 用途:请求体超过服务器限制。
    • 示例:上传文件超过 nginxclient_max_body_size
  • 429 Too Many Requests
    • 用途:客户端请求频率过高。
    • 示例:API 限流时返回 Retry-After: 60

5xx(服务器错误)

  • 500 Internal Server Error
    • 用途:服务器内部错误(未具体说明的通用错误)。
    • 示例:后端代码抛出未捕获的异常。
  • 501 Not Implemented
    • 用途:服务器不支持请求的功能。
    • 示例:客户端请求了服务器未实现的 HTTP 方法。
  • 502 Bad Gateway
    • 用途:网关或代理服务器从上游服务器收到无效响应。
    • 示例:Nginx 作为反向代理时,后端服务崩溃。
  • 503 Service Unavailable
    • 用途:服务器暂时不可用(如维护或过载)。
    • 示例:高流量时返回 Retry-After: 3600
  • 504 Gateway Timeout
    • 用途:网关或代理服务器等待上游响应超时。
    • 示例:后端服务处理时间过长,导致 Nginx 超时。
  • 505 HTTP Version Not Supported
    • 用途:服务器不支持请求的 HTTP 版本。
    • 示例:客户端使用 HTTP/3,但服务器仅支持 HTTP/1.1。

其他特殊状态码

  • 418 I’m a teapot
    • 用途:玩笑状态码(来自 1998 年愚人节 RFC 文档)。
    • 示例:用于测试或幽默场景。
  • 451 Unavailable For Legal Reasons
    • 用途:因法律原因不可访问(如政府审查)。
    • 示例:某些国家/地区限制访问特定内容。

常见应用场景

  1. 调试 API
    • 通过状态码快速定位问题:
      • 400:检查请求参数格式。
      • 401:验证 Token 或 Cookie。
      • 403:检查用户权限。
      • 500:查看服务器日志。
  2. SEO 优化
    • 使用 301 而非 302 重定向以传递页面权重。
    • 避免链式重定向(如多次跳转)影响爬虫效率。
  3. 缓存控制
    • 304 可减少重复传输,提升性能。
    • 结合 Cache-ControlETag 实现高效缓存策略。

二、nginx 进阶基础

1、nginx 介绍

  • 高性能、高并发、高扩展,地址重写,负载均衡,是一个web服务器和反向代理服务器,消耗系统资源低

**Nginx (engine x) 是一个轻量级,高性能的 HTTP 和 反向代理 服务,也是一个IMAP/POP3/SMTP服务。因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。其特点是占有内存少,并发能力强,**事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

在高连接并发的情况下,Nginx是Apache服务器不错的替代品。
创始人伊戈尔·赛索耶夫

2、为什么选择 nginx(优势)

1.高并发,高性能---采用epoll模型监控所有连接,采用异步,非阻塞的的方式实现的请求处理
2.高可靠---可以7*24小时不间断运行
3.可扩展性强--模块化设计,使得添加模块非常的平稳。
4.热部署--可以在不停止服务器的情况下升级nginx
5.BSD许可证--nginx不止开源免费的我们还可以更具实际需求进行定制修改源代码

Nginx 是一个高性能的 Web 和反向代理服务器, 它具有有很多非常优越的特性:

单机环境下参考服务器配置。 并发连接数在7000+ -8000左右。 集群模式20000+

作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢迎。能够支持高达 50,000 个并发连接数的响应。

作为负载均衡服务器:可以进行自定义配置,支持虚拟主机,支持URL重定向。Nginx 既可以在内部直接支持 Rails 和 PHP,也可以支持作为 HTTP代理服务器 对外进行服务。Nginx 用 C 编写, 不论是系统资源开销还是 CPU 使用效率都比 Perlbal 要好的多。

Nginx 安装非常的简单,配置文件 非常简洁(还能够支持perl语法),Bugs非常少的服务器: Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。还能够在不间断服务的情况下进行软件版本的升级。yum安装与编译安装

1、IO多路复用

  • 采用epoll模型监控所有连接,通过IO多路复用的方式,采用异步,非阻塞的的方式实现的请求处理,从而实现高性能、高并发
1、I/O multiplexing【多并发】

第一种方法就是最传统的多进程并发模型 (每进来一个新的I/O流会分配一个新的线程管理。)

第二种方法就是I/O多路复用 (单个线程,通过记录跟踪每个I/O流(sock)的状态,来同时管理多个I/O流 。)

I/O multiplexing 这里面的 multiplexing 指的其实是在单个线程通过记录跟踪每一个Sock(I/O流)的状态来同时管理多个I/O流。发明它的原因,是尽量多的提高服务器的吞吐能力。在同一个线程里面, 通过拨开关的方式,来同时传输多个I/O流

2、nginx基于事件驱动模型实现I/O多路复用
一个请求到来了,nginx使用epoll接收请求的过程是怎样的?
  • epoll.
• epoll 现在是线程安全的。 

• epoll 现在不仅告诉你sock组里面数据,还会告诉你具体哪个sock有数据,你不用自己去找了。

#ngnix会有很多连接进来, 默认采用epoll会把他们都监视起来,然后像拨开关一样,谁有数据就拨向谁,然后调用相应的代码处理。
3、异步,非阻塞

$ pstree |grep nginx
|-+= 81666 root nginx: master process nginx
| |— 82500 nobody nginx: worker process
| — 82501 nobody nginx: worker process

1个master进程,n个work进程
每进来一个request,会有一个worker进程去处理。但不是全程的处理,处理到什么程度呢?处理到可能发生阻塞的地方,比如向上游(后端)服务器转发request,并等待请求返回。那么,这个处理的worker不会这么一直等着,他会在发送完请求后,注册一个事件:“如果upstream返回了,告诉我一声,我再接着干”。于是他就休息去了。这就是异步。此时,如果再有request 进来,他就可以很快再按这种方式处理。这就是非阻塞和IO多路复用。而一旦上游服务器返回了,就会触发这个事件,worker才会来接手,这个request才会接着往下走。这就是异步回调。

我们为什么更喜欢用Nginx 呢,Nginx 相对Apache 有那些有点呢?

- 轻量级,同样是web服务比Apache占用更少的内存及资源

- 静态处理,Nginx 静态处理性能比 Apache 高 3倍以上

- 抗并发,Nginx 处理请求是异步非阻塞的,而Apache则是阻塞型的。在高并发下Nginx 能保持低资源低消耗高性能。

- 高度模块化的设计,编写模块相对简单

3.nginx安装部署和配置管理

1、nginx部署-Yum安装

访问nginx的官方网站:http://www.nginx.org/

Nginx版本类型

Mainline version:   主线版,即开发版

Stable version:       最新稳定版,生产环境上建议使用的版本

Legacy versions:    遗留的老版本的稳定版

Yum安装nginx

配置Yum源的官网:http://nginx.org/en/linux_packages.html

1、配置nginx的Yum源

Installation instructions

Before you install nginx for the first time on a new machine, you need to set up the nginx packages repository. Afterward, you can install and update nginx from the repository.

安装说明

在新计算机上首次安装nginx之前,需要设置nginx软件包存储库。 之后,您可以从存储库安装和更新nginx。

RHEL/CENTOS

Install the prerequisites:

sudo yum install yum-utils -y
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=0
enabled=1
sudo yum install nginx -y
这里我们用稳定版本
[root@nginx-server yum.repos.d]# yum install -y nginx
[root@nginx-server yum.repos.d]# nginx -V    //格式化打印
nginx version: nginx/1.16.0
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) 
built with OpenSSL 1.0.2k-fips  26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-compat --with-file-aio --with-threads --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_mp4_module --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-mail --with-mail_ssl_module --with-stream --with-stream_realip_module --with-stream_ssl_module --with-stream_ssl_preread_module --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie'

[root@nginx-server yum.repos.d]# nginx -v #查看版本号
nginx version: nginx/1.16.0
关闭防火墙和selinux
[root@nginx-server ~]# getenforce 
Enforcing

[root@nginx-server ~]# sed -i '/SELINUX/s/enforcing/disabled/' /etc/selinux/config

[root@nginx-server ~]# systemctl stop firewalld
[root@nginx-server ~]# systemctl disable firewalld
启动并设置开机启动
[root@nginx-server ~]# systemctl start nginx 
[root@nginx-server ~]# systemctl enable nginx 

浏览器输入ip访问:

2、nginx 编译安装与配置使用
1、安装编译环境

yum -y install gcc gcc-c++

2、安装pcre软件包(使nginx支持http rewrite模块)

yum install -y pcre pcre-devel gd-devel

3、安装openssl-devel(使nginx支持ssl)

yum install -y openssl openssl-devel

4、安装zlib

yum install -y zlib zlib-devel

5、创建用户nginx

useradd nginx

passwd nginx

6、安装nginx
[root@localhost ~]# wget http://nginx.org/download/nginx-1.16.0.tar.gz
[root@localhost ~]# tar xzf nginx-1.16.0.tar.gz -C /usr/local/
[root@localhost ~]# cd /usr/local/nginx-1.16.0/
[root@localhost nginx-1.16.0]# ./configure --prefix=/usr/local/nginx --group=nginx --user=nginx --sbin-path=/usr/local/nginx/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/tmp/nginx/client_body --http-proxy-temp-path=/tmp/nginx/proxy --http-fastcgi-temp-path=/tmp/nginx/fastcgi --pid-path=/var/run/nginx.pid --lock-path=/var/lock/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-pcre --with-http_realip_module --with-stream
[root@localhost nginx-1.16.0]# make && make install
7、Nginx 编译参数
# 查看 nginx 安装的模块
[root@localhost ~]#/usr/local/nginx/sbin/nginx -V

--prefix=/usr/local/nginx                        //指向安装目录
--conf-path=/etc/nginx/nginx.conf                //指定配置文件
--http-log-path=/var/log/nginx/access.log        //指定访问日志
--error-log-path=/var/log/nginx/error.log        //指定错误日志
--lock-path=/var/lock/nginx.lock                 //指定lock文件
--pid-path=/run/nginx.pid                        //指定pid文件

--http-client-body-temp-path=/var/lib/nginx/body    //设定http客户端请求临时文件路径
--http-fastcgi-temp-path=/var/lib/nginx/fastcgi     //设定http fastcgi临时文件路径
--http-proxy-temp-path=/var/lib/nginx/proxy         //设定http代理临时文件路径
--http-scgi-temp-path=/var/lib/nginx/scgi           //设定http scgi临时文件路径
--http-uwsgi-temp-path=/var/lib/nginx/uwsgi         //设定http uwsgi临时文件路径

--with-debug                                        //启用debug日志
--with-ipv6                                         //启用ipv6支持
--with-http_ssl_module                              //启用ssl支持
--with-http_stub_status_module                      //获取nginx自上次启动以来的状态
--with-http_realip_module                 //允许从请求标头更改客户端的IP地址值,默认为关
--with-http_auth_request_module           //实现基于一个子请求的结果的客户端授权。如果该子请求返回的2xx响应代码,所述接入是允许的。如果它返回401或403中,访问被拒绝与相应的错误代码。由子请求返回的任何其他响应代码被认为是一个错误。
--with-http_addition_module               //作为一个输出过滤器,支持不完全缓冲,分部分响应请求
--with-http_dav_module                    //增加PUT,DELETE,MKCOL:创建集合,COPY和MOVE方法 默认关闭,需编译开启
--with-http_geoip_module                  //使用预编译的MaxMind数据库解析客户端IP地址,得到变量值
--with-http_gunzip_module                 //它为不支持“gzip”编码方法的客户端解压具有“Content-Encoding: gzip”头的响应。
--with-http_gzip_static_module            //在线实时压缩输出数据流
--with-http_spdy_module                   //SPDY可以缩短网页的加载时间
--with-http_sub_module                    //允许用一些其他文本替换nginx响应中的一些文本
--with-http_xslt_module                   //过滤转换XML请求
--with-mail                               //启用POP3/IMAP4/SMTP代理模块支持
--with-mail_ssl_module                    //启用ngx_mail_ssl_module支持启用外部模块支持

#--with  表示在编译过程中需要给nginx添加的模块
#--without 表示编译nginx时默认该模块是添加进去的当使用这个参数时表示将默认编译的模块移除
8、修改配置文件/etc/nginx/nginx.conf
# 全局参数设置
user nginx;  #设置nginx使用的用户
worker_processes  4;          #设置nginx启动进程的数量,一般设置成与逻辑cpu数量相同 
error_log  logs/error.log;    #指定错误日志 
pid        /var/run/nginx.pid; 
events { 
    worker_connections  1024; #设置一个进程的最大并发连接数 
}
# http 服务相关设置 
http { 
    include      mime.types; #关联mime类型,关联资源的媒体类型
    default_type  application/octet-stream; #根据文件的后缀来匹配相应的MIME类型
    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  /var/log/nginx/access.log  main;    #设置访问日志的位置和格式 
    sendfile          on; #用于开启文件高效传输模式,一般设置为on,若nginx是用来进行磁盘IO负载应用时,可以设置为off,降低系统负载
    tcp_nopush        on;      # 减少网络报文段数量,当有数据时,先别着急发送, 确保数据包已经装满数据, 避免了网络拥塞
    
    gzip              on;      #是否开启gzip压缩,将注释去掉开启 
    keepalive_timeout  65;     #设置长连接的超时时间,请求完成之后还要保持连接多久,
# 虚拟服务器的相关设置 
    server { 
        listen      80;        #设置监听的端口 
        server_name  localhost;        #设置绑定的主机名、域名或ip地址 
        charset koi8-r;        # 设置编码字符 
        location / { 
            root  /var/www/nginx;           #设置服务器默认网站的根目录位置,需要手动创建
            index  index.html index.htm;    #设置默认打开的文档 
            } 
        error_page  500 502 503 504  /50x.html; #设置错误信息返回页面 
        location = /50x.html { 
            root  html;        #这里的绝对位置是/usr/local/nginx/html
        } 
    } 
 }
#1.nginx.conf的组成:nginx.conf一共由三部分组成,分别为:全局块、events块、http块。在http块中又包含http全局块、多个server块。每个server块中又包含server全局块以及多个location块。在统一配置块中嵌套的配置快,各个之间不存在次序关系。

2.Nginx的组成:
nginx的二进制可执行文件----启动关闭,有各个模块编译出来的
nginx.conf配置文件----控制nginx
access.log访问日志--记录每条http请求
error.log 错误日志--定位问题
9、检测nginx配置文件是否正确
[root@localhost ~]# /usr/local/nginx/sbin/nginx -t
[root@localhost ~]# mkdir -p /tmp/nginx
10、启动nginx服务
[root@localhost ~]# /usr/local/nginx/sbin/nginx
11、通过 nginx 命令控制 nginx 服务
# /usr/local/nginx/sbin/nginx  -s  stop 停服务
# /usr/local/nginx/sbin/nginx  -s  reload   刷新配置文件
设置软连接
# ln -s /usr/local/nginx/sbin/nginx  /bin/nginx
重新加载nginx配置文件
# nginx -s reload

nginx -c /path/nginx.conf  	     # 以特定目录下的配置文件启动nginx:
nginx -s reload            	 	 # 修改配置后重新加载生效
nginx -s stop  				 	 # 快速停止nginx
nginx -s quit  				 	 # 正常停止nginx
nginx -t    					 # 测试当前配置文件是否正确
nginx -t -c /path/to/nginx.conf  # 测试特定的nginx配置文件是否正确

#注意:
nginx -s reload 命令加载修改后的配置文件,命令下达后发生如下事件
1. Nginx的master进程检查配置文件的正确性,若是错误则返回错误信息,nginx继续采用原配置文件进行工作(因为worker未受到影响)
2. Nginx启动新的worker进程,采用新的配置文件
3. Nginx将新的请求分配新的worker进程
4. Nginx等待以前的worker进程的全部请求已经都返回后,关闭相关worker进程
5. 重复上面过程,知道全部旧的worker进程都被关闭掉
12、nginx 日志文件详解

​ nginx 日志文件分为 log_formataccess_log 两部分

​ log_format 定义记录的格式,其语法格式为

   log_format        样式名称        样式详情

​ 配置文件中默认有

log_format  main  'remote_addr - remote_user [time_local] "request" '
                  'status body_bytes_sent "$http_referer" '
                  '"http_user_agent" "http_x_forwarded_for"';


4、使用 limit_rate 限制客户端传输数据的速度

1、编辑/etc/nginx/nginx.conf

location / {
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate  2k;  #对每个连接的限速为2k/s
        }
        
        
重启服务
注意要点:
配置文件中的每个语句要以 ; 结尾

5、nginx 虚拟机配置

什么是虚拟主机?

虚拟主机是一种特殊的软硬件技术,它可以将网络上的每一台计算机分成多个虚拟主机,每个虚拟主机可以独立对外提供www服务,这样就可以实现一台主机对外提供多个web服务,每个虚拟主机之间是独立的,互不影响。

nginx可以实现虚拟主机的配置,nginx支持三种类型的虚拟主机配置。

1、基于域名的虚拟主机 (server_name来区分虚拟主机——应用:外部网站)
2、基于ip的虚拟主机, (一块主机绑定多个ip地址)
3、基于端口的虚拟主机 (端口来区分虚拟主机——应用:公司内部网站,外部网站的管理后台)
1、 基于域名的虚拟主机

1、配置通过域名区分的虚拟机

[root@localhost ~]# cat /etc/nginx/nginx.conf
worker_processes  4;

#error_log  logs/error.log;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;
    
    server {
        listen       80;
        server_name  web.testpm.com;
        location / {
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate	2k;
        	}
        }
    
    server {
        listen       80;
        server_name  www.testpm.com;
        location / {
            root   /1000phone/html;
            index  index.html index.htm;
        	}
        }
}

2、 为 域名为 web.1000phone.com 的虚拟机,创建 index 文件

[root@localhost ~]# mkdir -p /1000phone/html
[root@localhost ~]# vim /1000phone/html/index.html
<html>
<p>
this is my 1000phone
</p>
</html>

3、重新加载配置文件

# 如果编译安装的执行
[root@nginx]# /usr/local/nginx/sbin/nginx -s reload
# 如果 yum 安装的执行
[root@nginx]# nginx -s reload

4、客户端配置路由映射

在 C:WindowsSystem32driversetchosts 文件中添加两行(linux:/etc/hosts)
10.0.105.199 web.testpm.com
10.0.105.199 web.1000phone.com

5、 测试访问

浏览器输入:http://web.testpm.com/
浏览器输入:http://web.1000phone.com/
2、 基于ip的虚拟主机
[root@localhost ~]# ip a 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:17:f1:af brd ff:ff:ff:ff:ff:ff
    inet 10.0.105.199/24 brd 10.0.105.255 scope global dynamic ens33
       valid_lft 81438sec preferred_lft 81438sec
    inet6 fe80::9d26:f3f0:db9c:c9be/64 scope link 
       valid_lft forever preferred_lft forever
       
 两种方式添加网卡
[root@localhost ~]# ifconfig ens33:1 10.0.105.201/24
[root@localhost ~]# ip a a 10.0.105.201/24 dev ens33

[root@localhost ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 10.0.105.199  netmask 255.255.255.0  broadcast 10.0.105.255
        inet6 fe80::9d26:f3f0:db9c:c9be  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:17:f1:af  txqueuelen 1000  (Ethernet)
        RX packets 9844  bytes 1052722 (1.0 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 5567  bytes 886269 (865.4 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

ens33:1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 10.0.105.201  netmask 255.255.255.0  broadcast 10.0.105.255
        ether 00:0c:29:17:f1:af  txqueuelen 1000  (Ethernet)

2、配置通过ip区分的虚拟机
[root@localhost ~]# cat /etc/nginx/nginx.conf
user  root;
worker_processes  4;

#error_log  logs/error.log;


events {
    worker_connections  1024;
}


http {
    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"';

    server {
        listen       10.0.105.199:80;
        server_name  web.testpm.com;
        location / {
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate	2k;
        }
        
     server {
        listen       10.0.105.201:80;
        server_name  www.testpm.com;
        location / {
            root   /1000phone/html/;
            index  index.html index.htm;
        	}
        }
}
3、重新加载配置文件
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
4、 测试访问
浏览器输入:http://10.0.105.199
浏览器输入:http://10.0.105.201
5、补充
-- 两种方式删除绑定的vip
[root@localhost ~]# ifconfig ens33:1 10.0.105.201/24 down
[root@localhost ~]# ip a d 10.0.105.201/24 dev ens33  
重启一下nginx
[root@localhost ~]# systemctl restart nginx
3、 基于端口的虚拟主机
[root@localhost ~]# cat /etc/nginx/nginx.conf
user  root;
worker_processes  4;


events {
    worker_connections  1024;
}


http {
    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"';


    sendfile        on;

    keepalive_timeout  65;


    server {
        listen       80;
        server_name  web.testpm.com;
        location / {
            root   /var/www/nginx/;
            index  index.html index.htm;
            limit_rate	2k;
        }
        
    
     server {
        listen       8080;
        server_name  www.testpm.com;
        location / {
            root   /1000phone/html/;
            index  index.html index.htm;
        	}
        }
}
重新加载配置文件:
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
测试访问:
浏览器输入:http://web.testpm.com/
浏览器输入:http://web.1000phone.com:8080

Nginx进阶-常见配置

一、nginx Proxy 反向代理

1、代理原理

反向代理产生的背景:

在计算机世界里,由于单个服务器的处理客户端(用户)请求能力有一个极限,当用户的接入请求蜂拥而入时,会造成服务器忙不过来的局面,可以使用多个服务器来共同分担成千上万的用户请求,这些服务器提供相同的服务,对于用户来说,根本感觉不到任何差别。

反向代理服务的实现:

需要有一个负载均衡设备(即反向代理服务器)来分发用户请求,将用户请求分发到后端正真提供服务的服务器上。服务器返回自己的服务到负载均衡设备。负载均衡设备将服务器的服务返回用户。

2、正/反向代理的区别

正向代理

**正向代理的过程隐藏了真实的请求客户端,服务器不知道真实的客户端是谁,客户端请求的服务都被代理服务器代替请求。**我们常说的代理也就是正向代理,正向代理代理的是请求方,也就是客户端;比如我们要访问youtube,可是不能访问,只能先安装个FQ软件代你去访问,通过FQ软件才能访问,FQ软件就叫作正向代理。
![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/cbda9cf26d164c1bb0e25207efec4ac7.png

反向代理

**反向代理的过程隐藏了真实的服务器,客户不知道真正提供服务的人是谁,客户端请求的服务都被代理服务器处理。反向代理代理的是响应方,也就是服务端;**我们请求www.baidu.com时这www.baidu.com就是反向代理服务器,真实提供服务的服务器有很多台,反向代理服务器会把我们的请求分转发到真实提供服务的各台服务器。Nginx就是性能非常好的反向代理服务器,用来做负载均衡。

访问www.baidu.com是反向代理的过程

两者的区别在于代理的对象不一样
正向代理中代理的对象是客户端,服务器不知道访问的对象是谁

反向代理中代理的对象是服务端,客户端不知道真正提供服务的是谁

3、nginx Proxy 配置

  • # curl -I http://192.168.139.146 看是否正常访问
1、代理模块
ngx_http_proxy_module
2、启用 nginx proxy 代理

环境两台nginx真实服务器

a、nginx-1 启动网站(内容)(作为应用服务器)

nginx-1的ip:10.0.105.199
已经编译安装好,检查nginx是否启动是否可以访问

b、nginx-2 作为代理服务器

nginx-2的ip:10.0.105.202
配置nginx的yum源直接yum安装
启动
编辑nginx的配置文件:
[root@nginx-server ~]# vim /etc/nginx/conf.d/default.conf
server {
    server {
    listen       80;
    server_name  localhost;

    location / {
    proxy_pass http://10.0.105.199:80;
    proxy_redirect default;
    proxy_set_header Host $http_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    proxy_connect_timeout 30;
    proxy_send_timeout 60;
    proxy_read_timeout 60;
    }
}
重新加载nginx配置文件
设置软连接
# ln -s /usr/local/nginx/sbin/nginx  /bin/nginx
[root@nginx-server ~]# nginx -s reload

yum安装页面位置:/usr/share/nginx/html/index.html

c、nginx proxy 具体配置详解

proxy_pass :真实后端服务器的地址,可以是ip也可以是域名和url地址
proxy_redirect :如果真实服务器使用的是的真实IP:非默认端口。则改成IP:默认端口。
proxy_set_header:重新定义或者添加发往后端服务器的请求头
proxy_set_header X-Real-IP $remote_addr;#只记录连接服务器的上一个ip地址信息。
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #通过这个选项可以记录真正客户端机器的ip地址

proxy_connect_timeout::后端服务器连接的超时时间发起三次握手等候响应超时时间
proxy_send_timeout:后端服务器数据回传时间,就是在规定时间之内后端服务器必须传完所有的数据
proxy_read_timeout :nginx接收upstream(上游/真实) server数据超时, 默认60s, 如果连续的60s内没有收到1个字节, 连接关闭。像长连接

注意:proxy_pass http:// 填写nginx-1服务器的地址。

使用PC客户端访问nginx-2服务器地址
浏览器中输入http://10.0.105.202 (也可以是nginx-2服务器的域名)

 成功访问nginx-1服务器页面

观察nginx-1服务器的日志

10.0.105.202 - - [27/Jun/2019:15:54:17 +0800] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36" "10.0.105.207"
10.0.105.202  代理服务器地址
10.0.105.207 客户机地址。
访问成功。 记录了客户机的IP和代理服务器的IP

二、Nginx负载均衡

  • 负载均衡–通过算法将用户的请求平均分配给每一台机器,从而降低单台机器的访问压力,网站响应速度提高了,避免了单节点故障
  • 模块upstream–七层的负载均衡
1、upstream配置

首先给大家说下 upstream 这个配置的,这个配置是写一组被代理的服务器地址,然后配置负载均衡的算法.

upstream testapp { 
      server 10.0.105.199:8081;
      server 10.0.105.202:8081;
    }
 server {
        ....
        location / {         
           proxy_pass  http://testapp;  #请求转向 testapp 定义的服务器列表         
        } 
2、负载均衡算法
upstream 支持6种负载均衡调度算法

1、轮询(默认):每个请求按时间顺序逐一分配到不同的后端服务器;

2、加权轮询:根据权重值来分配,默认服务器权重1,修改了权重值就给权重值大的多分配

3、ip_hash:每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证来自同一ip的请求被打到固定的机器上,可以解决session问题。

4、url_hash:按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。

5、fair:这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。Nginx本身是不支持 fair的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair模块。

6、least_conn:最少连接:优先将请求分发给当前连接数最少的后端服务器。
3、配置实例

1、热备:如果你有2台服务器,当一台服务器发生事故时,才启用第二台服务器给提供服务。服务器处理请求的顺序:AAAAAA突然A挂啦,BBBBBBBBBBBBBB…

upstream myweb { 
      server 172.17.14.2:8080; 
      server 172.17.14.3:8080 backup;  #热备     
    }

2、轮询:nginx默认就是轮询其权重都默认为1,服务器处理请求的顺序:ABABABABAB

upstream myweb { 
      server 172.17.14.2:8080; 
      server 172.17.14.3:8080;      
    }

3、加权轮询:跟据配置的权重的大小而分发给不同服务器不同数量的请求。如果不设置,则默认为1。下面服务器的请求顺序为:ABBABBABBABBABB…

upstream myweb { 
      server 172.17.14.2:8080 weight=1;
      server 172.17.14.3:8080 weight=2;
}

4、ip_hash:nginx会让相同的客户端ip请求相同的服务器。

upstream myweb { 
      server 172.17.14.2:8080; 
      server 172.17.14.3:8080;
      ip_hash;
    }

5、nginx负载均衡配置状态参数

- down,表示当前的server暂时不参与负载均衡。
- backup,预留的备份机器。当其他所有的非backup机器出现故障或者忙的时候,才会请求backup机器,因此这台机器的压力最轻。
- max_fails,允许请求失败的次数,默认为1。当超过最大次数时,返回proxy_next_upstream 模块定义的错误。
- fail_timeout,在经历了max_fails次失败后,暂停服务的时间单位秒。max_fails可以和fail_timeout一起使用。
 upstream myweb { 
      server 172.17.14.2:8080 weight=2 max_fails=2 fail_timeout=2;
      server 172.17.14.3:8080 weight=1 max_fails=2 fail_timeout=1;    
    }

如果你想跟多更深入的了解 nginx 的负载均衡算法,nginx官方提供一些插件大家可以了解下。

4、nginx配置7层协议
  • 用http,upstream模块

举例讲解下什么是7层协议,什么是4层协议。

(1)7层协议

OSI(Open System Interconnection)是一个开放性的通行系统互连参考模型,他是一个定义的非常好的协议规范,共包含七层协议。直接上图,这样更直观些:

好,详情不进行仔细讲解,可以自行百度!

(2)协议配置

这里我们举例,在nginx做负载均衡,负载多个服务,部分服务是需要7层的,部分服务是需要4层的,也就是说7层和4层配置在同一个配置文件中。

准备三台机器:

代理服务IP:10.0.105. --配置本地host解析域名;
后端服务器IP:nginx-a :10.0.105.199/nginx-b:10.0.105.202(yum安装)后端服务器将nginx服务启动
配置代理服务器的nginx配置文件:/etc/nginx/nginx.conf
worker_processes  4;

worker_rlimit_nofile 102400;


events {
    worker_connections  1024;
}


http {
    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        on;
    keepalive_timeout  65;
    gzip  on;

    upstream testweb {
	#ip_hash;
	server 10.0.105.199:80 weight=2 max_fails=2 fail_timeout=2s;
	server 10.0.105.202:80 weight=2 max_fails=2 fail_timeout=2s;
     }
    server {
        listen       80;
        server_name  www.test.com;
        charset utf-8;
        #access_log  logs/host.access.log  main;
        location / {
	    proxy_pass http://testweb;
         proxy_set_header Host $host:$server_port;
         proxy_set_header X-Real-IP $remote_addr;
         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        	}

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        	}
	}
}

202服务器yum安装的创建新的配置文件:

[root@nginx-server ~]# cd /etc/nginx/conf.d/
[root@nginx-server conf.d]# cp default.conf test.conf
[root@nginx-server conf.d]# cat test.conf 
server {
    listen       80;
    server_name  localhost;

    location / {
         root   /usr/share/nginx/html;
         index  index.html index.htm;
    }
}
定义yum安装的页面位置为:/usr/share/nginx/html
[root@nginx-server ~]# nginx -s reload
浏览器测试访问:
http://www.test.com/
nginx 配置后端健康检查模块
nginx自带的针对后端节点健康检查的功能比较简单,通过默认自带的ngx_http_proxy_module 模块和ngx_http_upstream_module模块中的参数来完成,当后端节点出现故障时,自动切换到健康节点来提供访问。但是nginx不能事先知道后端节点状态是否健康,后端即使有不健康节点,负载均衡器依然会先把请求转发给该不健康节点,然后再转发给别的节点,这样就会浪费一次转发,而且自带模块无法做到预警。所以我们可以使用第三方模块 nginx_upstream_check_module模块

nginx_upstream_check_module模块由淘宝团队开发 淘宝自己的 tengine 上是自带了该模块的。我们使用原生Nginx,采用添加模块的方式

获取nginx_upstream_check_module模块

从github上面获取就可以了。

[root@nginx-server ~]# yum install -y unzip

下载模块
[root@nginx-server ~]# wget https://github.com/yaoweibin/nginx_upstream_check_module/archive/refs/heads/master.zip
[root@nginx-server ~]# unzip -d /usr/local/ master.zip

                                  安装补丁:
注意 check版本和Nginx版本要求有限制 1.12以上版本的nginx,补丁为check_1.11.5+.patch 具体参考github
# ls nginx_upstream_check_module-master 可以看版本
# -p0,是“当前路径” -p1,是“上一级路径”
[root@nginx-server ~]# cd /usr/local/nginx-1.22.1/   #进入nginx的解压目录中
[root@nginx-server nginx-1.22.1]# yum install -y patch
[root@nginx-server nginx-1.22.1]# patch -p1 < ../nginx_upstream_check_module-master/check_1.20.1+.patch
[root@nginx-server nginx-1.22.1]# ./configure --prefix=/usr/local/nginx --group=nginx --user=nginx --sbin-path=/usr/local/nginx/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/tmp/nginx/client_body --http-proxy-temp-path=/tmp/nginx/proxy --http-fastcgi-temp-path=/tmp/nginx/fastcgi --pid-path=/var/run/nginx.pid --lock-path=/var/lock/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-pcre --with-http_realip_module --with-stream --add-module=../nginx_upstream_check_module-master/
[root@nginx-server nginx-1.22.1]# make   #重新编译文件, 如果是添加模块只需要make 第一次安装需要make install
[root@nginx-server nginx-1.22.1]# mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak  #将原来的nginx二进制命令备份
[root@nginx-server nginx-1.22.1]# cp objs/nginx /usr/local/nginx/sbin/ #将新生成的命令cp到nginx的命令目录中。

配置健康检查

编译安装:/etc/nginx/nginx.conf
yum安装: /etc/nginx/conf.d/default.conf

http {
upstream app {
        server 192.168.209.128 weight=1;
        server 192.168.209.130 weight=1;
        check interval=5000 rise=2 fall=3 timeout=4000 type=http port=80;
        check_http_send "HEAD / HTTP/1.0

";
        check_http_expect_alive http_2xx http_3xx;
        }
        
server {
        listen       80;
        server_name  localhost;

        location / {
                proxy_pass http://app;
                proxy_redirect default;
                proxy_set_header Host $http_host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }
        location /status {   #开启监控状态页面
                check_status;
                access_log   off;
           }
        }
}


参数解释:
interval:表示每隔多少毫秒向后端发送健康检查包;
rise:表示如果连续成功次数达到2 服务器就被认为是up;
fail:表示如果连续失败次数达到3 服务器就被认为是down;
timeout:表示后端健康请求的超时时间是多少毫秒;
type:表示发送的健康检查包是什么类型的请求;
port: 表示发送检查到后端的服务的端口;
check_http_send:表示http健康检查包发送的请求内容。为了减少传输数据量,推荐采用“head”方法;
check_http_expect_alive:指定HTTP回复的成功状态,默认认为2XX和3XX的状态是健康的;

浏览器查看访问状态

5、4层协议方法(扩展)
  • 用tcp,使用stream模块

(2)4层协议

TCP/IP协议

之所以说TCP/IP是一个协议族,是因为TCP/IP协议包括TCP、IP、UDP、ICMP、RIP、SMTP、ARP、TFTP等许多协议,这些协议一起称为TCP/IP协议。

从协议分层模型方面来讲,TCP/IP由四个层次组成:网络接口层、网络层、传输层、应用层。

nginx在1.9.0的时候,增加了一个 stream 模块,用来实现四层协议(网络层和传输层)的转发、代理、负载均衡等。stream模块的用法跟http的用法类似,允许我们配置一组TCP或者UDP等协议的监听.

配置案例:

#4层tcp负载 
stream {
   upstream ssh_01 {
     server 192.168.209.129:22;
        }
 
   server {
    listen 6666;
    proxy_pass ssh_01;
    proxy_timeout 60s;
    proxy_connect_timeout 30s;
        }
}

#注意:stream块是与http块同一级别

#ssh 本机ip -p6666  
6.经典面试题

nginx中有两个server 一个是a.com 一个是b.com 现在访问c.com 返回的是哪个页面,(定义友好返回页面)

1. 匹配 server_name:Nginx 优先检查请求的Host头(此处为c.com),并尝试匹配配置中的 server_name。由于配置中只有a.com和b.com的server块,没有匹配项。
2. 默认server块:若未匹配到任何server_name,Nginx会选择监听相同端口且标记为`default_server`的 server块。若未显式指定default_server,则默认选择第一个定义的server块。
3.设置了地址重写,根据规定进行相应的返回

配置案例
server {
    listen 80 default_server;
    server_name _;
    return 444;  # 关闭连接或返回自定义错误页
}

三、nginx 会话保持

nginx会话保持主要有以下几种实现方式。

1、ip_hash
ip_hash使用源地址哈希算法,将同一客户端的请求总是发往同一个后端服务器,除非该服务器不可用。
ip_hash语法:
upstream backend {
    ip_hash;
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com down;
}
ip_hash简单易用,但有如下问题:
当后端服务器宕机后,session会丢失;
来自同一局域网的客户端会被转发到同一个后端服务器,可能导致负载失衡;
2、sticky_cookie_insert—而是基于cookie实现
  • 使用sticky_cookie_insert模块
使用sticky_cookie_insert,这会让来自同一客户端的请求被传递到一组服务器的同一台服务器。与ip_hash不同之处在于,它不是基于IP来判断客户端的,而是基于cookie来判断。(需要引入第三方模块才能实现)---sticky模块。因此可以避免上述ip_hash中来自同一局域网的客户端和前段代理导致负载失衡的情况。

语法:

编译安装sticky模块,#给yum安装的nginx添加模块
[root@nginx-server ~]# yum install -y pcre* openssl* gcc gcc-c++ make 安装编译环境
[root@nginx-server ~]# wget  https://bitbucket.org/nginx-goodies/nginx-sticky-module-ng/get/08a395c66e42.zip  #下载sticky模块
[root@nginx-server ~]# nginx -v
nginx version: nginx/1.18.0
# systemctl stop nginx
[root@nginx-server ~]# wget  http://nginx.org/download/nginx-1.18.0.tar.gz #下载yum安装nginx对应版本的源码包
[root@nginx-server ~]# yum install -y unzip #安装解压工具
[root@nginx-server ~]# unzip 08a395c66e42.zip #解压模块包
[root@nginx-server ~]# mv nginx-goodies-nginx-sticky-module-ng-08a395c66e42/ nginx-sticky-module-ng/
[root@nginx-server ~]# tar xzvf nginx-1.18.0.tar.gz -C /usr/local/ #解压nginx的源码包
[root@nginx-server ~]# cd /usr/local/nginx-1.18.0/
[root@nginx-server nginx-1.18.0]# nginx -V #查看yum安装nginx所有模块
[root@nginx-server nginx-1.18.0]# ./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-compat --with-file-aio --with-threads --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_mp4_module --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-mail --with-mail_ssl_module --with-stream --with-stream_realip_module --with-stream_ssl_module --with-stream_ssl_preread_module --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie' --add-module=/root/nginx-sticky-module-ng
[root@nginx-server nginx-1.18.0]# make && make install

配置基于cookie会话保持
[root@nginx-server nginx-1.18.0]#cd /etc/nginx
#vim nginx.conf 
[root@nginx-server conf.d]# vim upstream.conf
upstream qfedu {
        server 192.168.198.143;
        server 192.168.198.145;
        sticky;
}

[root@nginx-server conf.d]# vim proxy.conf
server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
    # root   html;  默认参数
    # index  index.html index.htm;
            
        proxy_pass http://qfedu;
        proxy_redirect default;
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }

}
[root@nginx-server conf.d]# nginx -t 
[root@nginx-server conf.d]# nginx -s reload


或者:
upstream qfedu {
        server 192.168.198.143;
        server 192.168.198.145;
        sticky expires=1h domain=testpm.com path=/;
}


说明:
expires:设置浏览器中保持cookie的时间 
domain:定义cookie的域 
path:为cookie定义路径

浏览器测试访问

注意:使用后端服务器自身通过相关机制保持session同步,如:使用数据库、redis、memcached 等做session复制

四、nginx 实现动静分离

  • 动态分离好处:动态页面和静态页面由不同的服务器来解析,加快解析速度,降低单个服务器的压力,提升整个网站的响应速度

为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。 简单来说,就是使用正则表达式匹配过滤,然后交个不同的服务器。

1、准备环境

准备一个nginx代理 两个http 分别处理动态和静态。

expires功能说明---(为客户端配置缓存时间),主要用于图片类

  nginx缓存的设置可以提高网站性能,对于网站的图片,尤其是新闻网站,图片一旦发布,改动的可能是非常小的,为了减小对服务器请求的压力,提高用户浏览速度,我们可以通过设置nginx中的expires,让用户访问一次后,将图片缓存在用户的浏览器中,且时间比较长的缓存。

原理:当nginx设置了expires后,例如设置为:expires 10d; 那么用户在10天内请求的时候,都只会访问浏览器中的缓存,而不会去请求nginx。

注:需要注意的是,这种缓存方式只能在用户不对浏览器强制刷新的情况下生效,如果用户通过url来进行访问,是可以访问到缓存的。
1.静态资源配置 
编译安装:/etc/nginx/nginx.conf
yum安装: /etc/nginx/conf.d/default.conf

server {
        listen 80;
        server_name     localhost;

        location ~ .(html|jpg|png|js|css) {
        root /home/www/nginx;
        expires      1d; #为客户端设置静态资源缓存时间
        }
}
# mkdir -p /home/www/nginx
# cd /home/www/nginx 
上传照片并给权限

测试:
[root@nginx-yum2 conf.d]# curl -I http://10.0.105.200/test.jpg
HTTP/1.1 200 OK
Server: nginx/1.16.0
Date: Mon, 07 Sep 2019 11:35:08 GMT
Content-Type: image/jpeg
Content-Length: 27961
Last-Modified: Mon, 07 Sep 2019 11:31:17 GMT
Connection: keep-alive
ETag: "5f561a05-6d39"
Expires: Tue, 08 Sep 2019 11:35:08 GMT  #缓存到期时间
Cache-Control: max-age=86400 #缓存持续时间秒
Accept-Ranges: bytes
2.动态资源配置:
yum 安装php7.1
[root@nginx-server ~]# yum install -y epel-release
[root@nginx-server ~]# rpm -ivh  http://rpms.remirepo.net/enterprise/remi-release-7.rpm
[root@nginx-server ~]# cd /etc/yum.repos.d/
[root@nginx-server yum.repos.d]# ls
remi-php73.repo              remi-php74.repo
remi-php80.repo              nginx.repo
remi-php81.repo              remi-modular.repo
remi-php82.repo              remi-php54.repo
remi-php83.repo              remi-php70.repo
remi.repo                    remi-php71.repo
remi-safe.repo               epel.repo
remi-php72.repo
[root@nginx-server ~]# yum install -y yum-utils
[root@nginx-server ~]# yum-config-manager --enable remi-php71
[root@nginx-server ~]# yum -y install php-xsl php php-ldap php-cli php-common php-devel php-gd php-pdo php-mysql php-mbstring php-bcmath php-mcrypt php-fpm
[root@nginx-server ~]# systemctl start php-fpm
[root@nginx-server ~]# systemctl enable php-fpm
#动态服务器编辑nginx连接php
编辑nginx的配置文件:
编译安装:/etc/nginx/nginx.conf
yum安装: /etc/nginx/conf.d/default.conf

server {
        listen      80;
        server_name     localhost;
        location ~ .php$ {
            root           /home/nginx/html;  #指定网站目录
            fastcgi_pass   127.0.0.1:9000;    #开启fastcgi连接php地址
            fastcgi_index  index.php;		#指定默认文件
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name; #站点根目录,取决于root配置项
            include        fastcgi_params;  #包含fastcgi使用的常量
        		}
        }
创建目录:mkdir -p /home/nginx/html
测试代码:
#vim /home/nginx/html/index.php

<?php
echo "hello world"
?>
3.配置nginx反向代理upstream,并实现客户端缓存时间
配置upstream:

upstream static {
        server 10.0.105.196:80 weight=1 max_fails=1 fail_timeout=60s;
        }
upstream php {
        server 10.0.105.200:80 weight=1 max_fails=1 fail_timeout=60s;
        }

配置反向代理:
        server {
        listen      80;
        server_name     localhost
        #动态资源加载
        location ~ .(php|jsp)$ {
            proxy_pass http://php;
            proxy_set_header Host $host:$server_port;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }
        #静态资源加载
        location ~ .*.(html|jpg|png|css|js)$ {
            proxy_pass http://static;
            proxy_set_header Host $host:$server_port;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }
        }
当访问静态页面的时候location 匹配到 (html|jpg|png|js|css) 通过转发到静态服务器,静态服务通过location的正则匹配来处理请求。

当访问动态页面时location匹配到 .php 结尾的文件转发到后端php服务处理请求。

五、nginx的localtion指令详解

Nginx 的 HTTP 配置主要包括三个区块,结构如下:

http { 						# 这个是协议级别
  include mime.types;
  default_type application/octet-stream;
  keepalive_timeout 65;
  gzip on;
    server {			 # 这个是服务器级别
      listen 80;
      server_name localhost;
        location / {  # 这个是请求级别
          root html;
          index index.html index.htm;
        }
      }
}
1、location 区段
- location 是在 server 块中配置,根据不同的 URI 使用不同的配置,来处理不同的请求。

- location 是有顺序的,会根据不同请求配置的优先级来匹配的location 处理。
基本语法如下:
location [=|^~|~|~*|!~|!~*|/|@] pa4ttern{……}
2、location 前缀含义
常用:
~    表示区分大小写的正则匹配  
~*   表示不区分大小写的正则匹配  
^~   表示uri以某个常规字符串开头,理解为匹配url路径即可
=    表示精确匹配,优先级也是最高的 
!~   表示区分大小写不匹配的正则
!~*  表示不区分大小写不匹配的正则
/    通用匹配,任何请求都会匹配到

查找顺序和优先级

= 大于 ^~  大于 ~|~*|!~|!~* 大于 /
多个location配置的情况下匹配顺序为:首先匹配 =,其次匹配^~, 其次是按正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。
3、location 配置示例

1、没有修饰符 表示:必须以指定模式开始

server {
    listen       80;
    server_name  localhost;

    location  /abc {
        root    /home/www/nginx;
        index   2.html;
        }

那么,如下是对的:
http://192.168.1.9/abc

注意:此时 /home/www/nginx为根目录
在此目录下
创建mkdir /home/www/nginx/abc目录
创建文件 touch /abc/2.html

2、=表示:必须与指定的模式精确匹配

server {
    listen       80;
    server_name  localhost;
    access_log  /var/log/nginx/http_access.log  main;

    location / {
                return https://www.baidu.com;
        }
    
    
    location = / {
                return https://www.jd.com;
        }
}

测试:

3、~ 表示:指定的正则表达式要区分大小写

server {
server_name localhost;
  location ~ /abc {
                root /home/www/nginx;
                index 2.html index.html;
        }
}
测试访问:
http://192.168.1.9/abc
不正确的
http://192.168.1.9/ABC
========================================
如果将配置文件修改为
      location ~ /ABC {
            root /home/www/nginx;
            index 2.html index.html;
        }
在创建目录和文件:
[root@ansible-server html]# cd /home/www/nginx/
[root@ansible-server nginx]# mkdir ABC
[root@ansible-server nginx]# vim ABC/2.html
 访问:
 http://192.168.1.9/ABC/
 
 结论:~ 需要区分大小写。而且目录需要根据大小写定义。

4、^*匹配案例

~*:表示不区分大小写的正则匹配
[root@localhost conf.d]# cat default.conf 
server {
    listen       80;
    server_name  localhost;

    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }

    location ~* /a/b/ {
        return 888;
    }

}

测试:
[root@localhost ~]# curl -I http://192.168.209.200/a/b/
HTTP/1.1 888 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:14:09 GMT
Content-Length: 0
Connection: keep-alive

[root@localhost ~]# curl -I http://192.168.209.200/A/B/
HTTP/1.1 888 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:16:52 GMT
Content-Length: 0
Connection: keep-alive



^~:表示uri以某个常规字符串开头,理解为匹配url路径即可
例如:下面配置文件有两条规则,分别匹配url以字母a开头,但是长度不同,首先将长的规则先注释掉,如下:
[root@localhost conf.d]# cat default.conf 
server {
    listen       80;
    server_name  localhost;

    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }


    location ^~ /a/ {
        return 123;
        }

    #location ^~ /a/b/ {
        #return 12345;
        #}

}

测试:
[root@localhost ~]# curl -I http://192.168.209.200/a/
HTTP/1.1 678 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:28:03 GMT
Content-Length: 0
Connection: keep-alive

[root@localhost ~]# curl -I http://192.168.209.200/a/b/
HTTP/1.1 678 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:28:07 GMT
Content-Length: 0
Connection: keep-alive

[root@localhost ~]# curl -I http://192.168.209.200/a/b/dsdfsdf
HTTP/1.1 678 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:28:10 GMT
Content-Length: 0
Connection: keep-alive

结论:
当前只有一个规则开启,因此当匹配url以/a/开头的任何url时,都会返回状态码678

现在打开注释:
[root@localhost conf.d]# cat default.conf 
server {
    listen       80;
    server_name  localhost;

    #access_log  /var/log/nginx/host.access.log  main;


    location ^~ /a/ {
        return 678;
        }

    location ^~ /a/b/ {
        return 876;
        }
}


测试:
[root@localhost ~]# curl -I http://192.168.209.200/a/
HTTP/1.1 678 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:44:52 GMT
Content-Length: 0
Connection: keep-alive

[root@localhost ~]# curl -I http://192.168.209.200/a/b/
HTTP/1.1 876 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:44:56 GMT
Content-Length: 0
Connection: keep-alive

[root@localhost ~]# curl -I http://192.168.209.200/a/b/sdgsdgdg
HTTP/1.1 876 
Server: nginx/1.24.0
Date: Fri, 24 Nov 2023 08:44:58 GMT
Content-Length: 0
Connection: keep-alive

结论:
两条规则同时被匹配成功,但是第二条规则比较长,因此第二条规则优先被匹配。

六、nginx 地址重写 rewrite

1、什么是Rewrite

Rewrite对称URL Rewrite,即URL重写,就是把传入Web的请求重定向到其他URL的过程

  • 从安全角度上讲,如果在URL中暴露太多的参数,无疑会造成一定量的信息泄漏,可能会被一些黑客利用,对你的系统造成一定的破坏,所以静态化的URL地址可以给我们带来更高的安全性。
  • 实现网站地址跳转,例如用户访问360buy.com,将其跳转到jd.com。例如当用户访问tianyun.com的
    80端口时,将其跳转到443端口。
2、Rewrite 相关指令
  • Nginx Rewrite 相关指令有 if、rewrite、set、return
2.1、if 语句
  • 应用环境

    server,location
    

    语法:

    if (condition) {}
    if 可以支持如下条件判断匹配符号
    ~ 					正则匹配 (区分大小写)
    ~* 				    正则匹配 (不区分大小写)
    !~                  正则不匹配 (区分大小写)
    !~*		            正则不匹配  (不区分大小写)
    -f 和!-f 		    用来判断是否存在文件
    -d 和!-d 		    用来判断是否存在目录
    -e 和!-e 		    用来判断是否存在文件或目录
    -x 和!-x 		    用来判断文件是否可执行
    
    在匹配过程中可以引用一些Nginx的全局变量
    $args				请求中的参数;
    $document_root	    针对当前请求的根路径设置值;
    $host				请求信息中的"Host",如果请求中没有Host行,则等于设置的服务器名;
    $limit_rate			对连接速率的限制;
    $request_method		请求的方法,比如"GET""POST";
    $remote_addr		客户端地址;
    $remote_port		客户端端口号;
    $remote_user		客户端用户名,认证用;
    $request_filename   当前请求的文件路径名(带网站的主目录/usr/local/nginx/html/images/a.jpg)
    $request_uri		当前请求的文件路径名(不带网站的主目录/images/a.jpg)
    $query_string$args相同;
    $scheme				用的协议,比如http或者是https
    $server_protocol	请求的协议版本,"HTTP/1.0""HTTP/1.1";
    $server_addr 		服务器地址,如果没有用listen指明服务器地址,使用这个变量将发起一次系统调用以取得地址(造成资源浪费);
    $server_name		请求到达的服务器名;
    $document_uri$uri一样,URI地址;
    $server_port 		请求到达的服务器端口号;
    
    2.2、Rewrite flag 地址重写的四个标记

    rewrite 指令根据表达式来重定向URI,或者修改字符串。可以应用于server,location, if环境下每行rewrite指令最后跟一个flag标记,支持的flag标记有:

    last 			    表示完成rewrite。默认为last。
    break 				本条规则匹配完成后,终止匹配,不再匹配后面的规则
    redirect 			返回302临时重定向,浏览器地址会显示跳转后的URL地址
    permanent 		    返回301永久重定向,浏览器地址会显示跳转后URL地址
    

    redirect 和 permanent区别则是返回的不同方式的重定向:

    对于客户端来说一般状态下是没有区别的。而对于搜索引擎,相对来说301的重定向更加友好,如果我们把一个地址采用301跳转方式跳转的话,搜索引擎会把老地址的相关信息带到新地址,同时在搜索引擎索引库中彻底废弃掉原先的老地址。

    使用302重定向时,搜索引擎(特别是google)有时会查看跳转前后哪个网址更直观,然后决定显示哪个,如果它觉的跳转前的URL更好的话,也许地址栏不会更改。

1、Rewrite匹配参考示例
本地解析host文件--wind
# http://www.testpm.com/a/1.html ==> http://www.testpm.com/b/2.html
    location /a {
        root    /html;
        index   1.html index.htm;
        rewrite .* /b/2.html permanent;
        }
    location /b {
        root    /html;
        index   2.html index.htm;
        }
例2:
# http://www.testpm.com/2019/a/1.html ==> http://www.testpm.com/2018/a/1.html
     location /2019/a {
        root    /var/www/html;
        index   1.html index.hml;
        rewrite ^/2019/(.*)$ /2018/$1 permanent;
        }
     location /2018/a {
        root    /var/www/html;
        index   1.html index.htl;
        }

例3:
# http://www.qf.com/a/1.html ==> http://jd.com
location /a {
        root    /html;
        if ($host ~* www.qf.com ) {
        rewrite .* http://jd.com permanent;
        }
        }

例4:
# http://www.qf.com/a/1.html ==> http://jd.com/a/1.html
location /a {
        root /html;
        if ( $host ~* qf.com ){
        rewrite .* http://jd.com$request_uri permanent;
        }
        }

例5:
# http://www.tianyun.com/login/tianyun.html ==> http://www.tianyun.com/reg/login.html?user=tianyun
	location /login {
        root   /usr/share/nginx/html;
        rewrite ^/login/(.*).html$ http://$host/reg/login.html?user=$1;
        }
    location /reg {
        root /usr/share/nginx/html;
        index login.html;
        }

例6:
#http://www.tianyun.com/qf/11-22-33/1.html  ==>  http://www.tianyun.com/qf/11/22/33/1.html
location /qf {
            rewrite ^/qf/([0-9]+)-([0-9]+)-([0-9]+)(.*)$ /qf/$1/$2/$3$4 permanent;
        }

        location /qf/11/22/33 {
                root /html;
                index   1.html;
        }
2、set 指令

set 指令是用于定义一个变量,并且赋值

应用环境:

server,location,if

应用示例

例8:
#http://alice.testpm.com ==> http://www.testpm.com/alice
#http://jack.testpm.com ==> http://www.testpm.com/jack

[root@nginx-server conf.d]# cd /usr/share/nginx/html/
[root@nginx-server html]# mkdir jack alice
[root@nginx-server html]# echo "jack.." >> jack/index.html
[root@nginx-server html]# echo "alice.." >> alice/index.html

本地解析域名host文件
10.0.105.202 www.testpm.com
10.0.105.202 alice.testpm.com
10.0.105.202 jack.testpm.com
编辑配置文件:
server {
    listen       80;
    server_name  www.testpm.com;

    location / {
         root   /usr/share/nginx/html;
         index  index.html index.htm;
         if ( $host ~* ^www.testpm.com$) {
                break;
                }
         if ( $host ~* "^(.*).testpm.com$" ) {
                set $user $1;
                rewrite .* http://www.testpm.com/$user permanent;
                }
        }
    location /jack {
         root /usr/share/nginx/html;
         index  index.html index.hml;
        }
    location /alice {
         root /usr/share/nginx/html;
         index index.html index.hml;
        }
}
3、return 指令

return 指令用于返回状态码给客户端

server,location,if

应用示例:

例9:如果访问的.sh结尾的文件则返回403操作拒绝错误
server {
    listen       80;
    server_name  www.testpm.cn;
    #access_log  /var/log/nginx/http_access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
        }

    location ~* .sh$ {
        return 403;
        }
}

例10:80 ======> 443 :80转443端口
server {
    listen       80;
    server_name  www.testpm.cn;
    access_log  /var/log/nginx/http_access.log  main;
    return 301 https://www.testpm.cn$request_uri;
}

server {
    listen 443 ssl;
    server_name www.testpm.cn;
    access_log  /var/log/nginx/https_access.log  main;

    #ssl on;
    ssl_certificate   /etc/nginx/cert/2447549_www.testpm.cn.pem;
    ssl_certificate_key  /etc/nginx/cert/2447549_www.testpm.cn.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
    ssl_prefer_server_ciphers on;

    location / {
        root  /usr/share/nginx/html;
        index index.html index.htm;
    }
}

[root@nginx-server ~]# curl -I http://www.testpm.cn
HTTP/1.1 301 Moved Permanently
Server: nginx/1.16.0
Date: Wed, 03 Jul 2019 13:52:30 GMT
Content-Type: text/html
Content-Length: 169
Connection: keep-alive
Location: https://www.testpm.cn/
4、last,break详解

[root@localhost test]# cat /etc/nginx/conf.d/last_break.conf 
server {
    listen       80;
    server_name  localhost;
    access_log  /var/log/nginx/last.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
    location /break/ {
        root /usr/share/nginx/html;
        rewrite .* /test/break.html break;
    }
    location /last/ {
        root /usr/share/nginx/html;
        rewrite .* /test/last.html last;
    }
    location /test/ {
        root /usr/share/nginx/html;
        rewrite .* /test/test.html break;
    }

}
[root@localhost conf.d]# cd /usr/share/nginx/html/
[root@localhost html]# mkdir test
[root@localhost html]# echo "last" > test/last.html
[root@localhost html]# echo "break" > test/break.html
[root@localhost html]# echo "test" > test/test.html

http://10.0.105.196/break/break.html
http://10.0.105.196/last/last.html

注意:

- last 标记在本条 rewrite 规则执行完后,会对其所在的 server {} 标签重新发起请求;

- break 标记则在本条规则匹配完成后,停止匹配,不再做后续的匹配;

- 使用 proxy_pass 指令时,则必须使用break。

nginx 日志配置

1、nginx 日志介绍

nginx 有一个非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志, 所需日志模块 ngx_http_log_module 的支持,日志格式通过 log_format 命令来定义,日志对于统计和排错是非常有利的,下面总结了 nginx 日志相关的配置 包括 access_loglog_formatrewrite_logerror_log

# 设置访问日志
access_log path;
# 关闭访问日志
access_log off; 
  • path 指定日志的存放位置。

作用域:

可以应用access_log指令的作用域分别有httpserverlocation,也就是说,在这几个作用域外使用该指令,Nginx会报错。

access_log /var/logs/nginx-access.log

该例子指定日志的写入路径为/var/logs/nginx-access.log,日志格式使用默认的combined

2、log_format 指令

Nginx 预定义了名为 combined 日志格式,如果没有明确指定日志格式默认使用该格式:

log_format combined '$remote_addr - $remote_user [$time_local] '
                    '"$request" $status $body_bytes_sent '
                    '"$http_referer" "$http_user_agent"';

如果不想使用Nginx预定义的格式,可以通过log_format指令来自定义。

语法

log_format name [escape=default|json] string ...;
- name 格式名称。在 access_log 指令中引用。
- escape 设置变量中的字符编码方式是`json`还是`default`,默认是`default`。
- string 要定义的日志格式内容。该参数可以有多个。参数中可以使用Nginx变量。

log_format 指令中常用的一些变量:

$remote_addr, $http_x_forwarded_for   #记录客户端IP地址
$remote_user                    #记录客户端用户名称
$request                   #记录请求的URL和HTTP协议
$status                     #记录请求状态
$body_bytes_sent      #发送给客户端的字节数,不包括响应头的大小
$bytes_sent               #发送给客户端的总字节数
$connection               #连接的序列号
$connection_requests  #当前通过一个连接获得的请求数量。
$msec                      #日志写入时间。单位为秒,精度是毫秒。
$http_referer            #记录从哪个页面链接访问过来的,可以根据该参数进行防盗链设置
$http_user_agent      #记录客户端浏览器相关信息
$request_length        #请求的长度(包括请求行,请求头和请求正文)。
$request_time           #请求处理时间,单位为秒,精度毫秒; 从读入客户端的第一个字节开始,直到把最后一个字符发送给客户端后进行日志写入为止。
$time_iso8601           #ISO8601标准格式下的本地时间。
$time_local               #通用日志格式下的本地时间。

自定义日志格式的使用:

access_log /var/logs/nginx-access.log main

log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                  '$status $body_bytes_sent "$http_referer" '
                  '"$http_user_agent" "$http_x_forwarded_for"';
注意:
注:如果Nginx位于负载均衡器,nginx反向代理之后,web服务器无法直接获取到客户端真实的IP地址。
$remote_addr获取的是反向代理的IP地址。反向代理服务器在转发请求的http头信息中,可以增加X-Forwarded-For信息,用来记录客户端IP地址。

使用log_format指令定义了一个main的格式,并在access_log指令中引用了它。客户端发起请求访问:http://192.168.246.154/,看一下请求的日志记录:

10.0.105.207 - - [01/Jul/2019:10:44:36 +0800] "GET / HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36" "-"

我们看到最终的日志记录中$remote_user$http_referer$http_x_forwarded_for都对应了一个-,这是因为这几个变量为空。

面试时:注意日志里面的ip地址一定要在第一列。

3、error_log 指令

错误日志在Nginx中是通过error_log指令实现的。该指令记录服务器和请求处理过程中的错误信息。

语法

配置错误日志文件的路径和日志级别。

error_log file [level];
Default:	
error_log logs/error.log error;

file 参数指定日志的写入位置。

level 参数指定日志的级别。level可以是debug, info, notice, warn, error, crit, alert,emerg中的任意值。可以看到其取值范围是按紧急程度从低到高排列的。只有日志的错误级别等于或高于level指定的值才会写入错误日志中。默认值是error

扩展日志级别:
 debug级别:低级别,包含的信息非常详细
 info级别:稍微的高一点了。用的多一些。
 notice 和warning
 notice:相当于提示
 warning:警告 和warn 一样
 err和error 一样,记录错误日志
 crit:比较严重了
 alert:告警,很严重
 emerg: 恐慌级别, 级别最高的

基本用法

error_log /var/logs/nginx/nginx-error.log

配置段: http, server, location作用域。

例子中指定了错误日志的路径为:/var/logs/nginx/nginx-error.log,日志级别使用默认的 error

4、nginx 日志配置总结

Nginx中通过access_logerror_log指令配置访问日志和错误日志,通过log_format我们可以自定义日志格式。

详细的日志配置信息可以参考Nginx官方文档

单独开启server的访问日志

[root@nginx-client ~]# cd /etc/nginx/conf.d/
[root@nginx-client conf.d]# vim nginx.conf
server {
    listen       80;
    server_name  localhost;

    charset koi8-r;
    access_log  /var/log/nginx/test.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
    location /admin {
        root /usr/share/nginx/html;
        index index.html index.htm;
        }
}
[root@nginx-client conf.d]# nginx -s reload
访问
[root@nginx-client conf.d]# curl -I http://192.168.1.10

当我们访问的这个server的时候日志将会输出到test.access.log.

作业:编写nginx日志切割脚本
[root@nginx-web script]# cat nginx_log.sh
#!/bin/bash
date=`date +%F -d -1day`
log_dir=/var/log/nginx/
log_name=access.log
[ -d $log_dir ] && cd $log_dir || exit 1
[ -f $log_name ] || exit 1
/bin/mv $log_name $log_name.${date}
/usr/sbin/nginx -s reload
tar czf $log_name.${date}.tar.gz $log_name.${date} && rm -rf $log_name_${date}


#delete
cd $log_dir || exit 1
find ./ -mtime +7 -type f -name *.tar.gz | xargs rm -rf

nginx 的平滑升级

1、为什么要对 nginx 平滑升级

随着 nginx 越来越流行,并且 nginx 的优势也越来越明显,nginx 的版本迭代也来时加速模式,1.9.0版本的nginx更新了许多新功能,例如 stream 四层代理功能,伴随着 nginx 的广泛应用,版本升级必然越来越快,线上业务不能停,此时 nginx 的升级就是运维的工作了

nginx 方便地帮助我们实现了平滑升级。其原理简单概括,就是:
(1)在不停掉老进程的情况下,启动新进程。
(2)老进程负责处理仍然没有处理完的请求,但不再接受处理请求。
(3)新进程接受新请求。
(4)老进程处理完所有请求,关闭所有连接后,停止。
这样就很方便地实现了平滑升级。一般有两种情况下需要升级 nginx,一种是确实要升级 nginx 的版本,另一种是要为 nginx 添加新的模块
2、Nginx信号简介
主进程支持的信号
- TERM, INT: 立刻退出
- QUIT: 等待工作进程结束后再退出
- KILL: 强制终止进程
- HUP: 重新加载配置文件,使用新的配置启动工作进程,并逐步关闭旧进程。
- USR1: 重新打开日志文件
- USR2: 启动新的主进程,实现热升级
- WINCH: 逐步关闭工作进程
工作进程支持的信号
- TERM, INT: 立刻退出
- QUIT: 等待请求处理结束后再退出
- USR1: 重新打开日志文件
3、nginx 平滑升级实战

1、查看现有的 nginx 编译参数

[root@nginx-server ~]# /usr/local/nginx/sbin/nginx -V

按照原来的编译参数安装 nginx 的方法进行安装,只需要到 make,千万不要 make install 。如果make install 会将原来的配置文件覆盖

[root@nginx-server ~]# cd /usr/local/nginx-1.16.0/
[root@nginx-server nginx-1.16.0]# ./configure --prefix=/usr/local/nginx --group=nginx --user=nginx --sbin-path=/usr/local/nginx/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/tmp/nginx/client_body --http-proxy-temp-path=/tmp/nginx/proxy --http-fastcgi-temp-path=/tmp/nginx/fastcgi --pid-path=/var/run/nginx.pid --lock-path=/var/lock/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-pcre --with-http_realip_module --with-stream --with-http_image_filter_module
[root@nginx-server nginx-1.16.0]# make
3、备份原 nginx 二进制文件

备份二进制文件和 nginx 的配置文件(期间nginx不会停止服务)

[root@nginx-server nginx-1.16.0]# mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx_$(date +%F)

4、复制新的nginx二进制文件,进入新的nginx源码包

[root@nginx-server nginx-1.16.0]# cp /usr/local/nginx-1.16.0/objs/nginx /usr/local/nginx/sbin/

5、测试新版本的nginx是否正常

[root@nginx-server nginx-1.16.0]# /usr/local/nginx/sbin/nginx -t

6、给nginx发送平滑迁移信号(若不清楚pid路径,请查看nginx配置文件)

[root@nginx-server ~]# kill -USR2 `cat /var/run/nginx.pid`

7、查看nginx pid,会出现一个nginx.pid.oldbin

[root@nginx-server ~]# ll /var/run/nginx.pid*
-rw-r--r-- 1 root root 5 Jul  1 11:29 /var/run/nginx.pid
-rw-r--r-- 1 root root 5 Jul  1 09:54 /var/run/nginx.pid.oldbin

8、从容关闭旧的Nginx进程

[root@nginx-server ~]# kill -WINCH `cat /var/run/nginx.pid.oldbin`

9、结束工作进程,完成此次升级

[root@nginx-server ~]# kill -QUIT `cat /var/run/nginx.pid.oldbin`

10、验证Nginx是否升级成功

[root@nginx-server ~]# /usr/local/nginx/sbin/nginx -V
4、nginx 错误页面配置

nginx错误页面包括404 403 500 502 503 504等页面,只需要在server中增加以下配置即可:

#error_page  404 403 500 502 503 504  /404.html;
                location = /404.html {
                        root   /usr/local/nginx/html;
                }
注意:
/usr/local/nginx/html/ 路径下必须有404.html这个文件!!!

404.html上如果引用其他文件的png或css就会有问题,显示不出来,因为其他文件的访问也要做配置;
 为了简单,可以将css嵌入文件中,图片用base编码嵌入;如下:

base64 图片—转码

[root@localhost html]# vim 404.html


    
        
        
        404
        
    
    
        

哎呀,找不到该页面啦!

请检查您的网络连接是否正常或者输入的网址是否正确

AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD//Z" class=“layout-img”>

哎呀,找不到该页面啦!


请检查您的网络连接是否正常或者输入的网址是否正确






```

本文地址:https://www.vps345.com/10861.html

搜索文章

Tags

docker 容器 运维 java-rabbitmq java 智能驾驶 BEVFusion Ubuntu 服务器带宽 上行带宽 上行速率 什么是上行带宽? PV计算 带宽计算 流量带宽 #docker #centos #容器 macos windows linux 服务器 嵌入式硬件 #windows #自动化 #运维 pytorch tensorflow 网络 远程连接 vscode 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP ubuntu 无人机 机器人 github AI Dify 大模型应用 CC攻击 攻击怎么办 #git #ssh #windows ide ubuntu24.04 todesk #linux #命令 #网络 c# 开发语言 网络协议 网络安全 ssh漏洞 ssh9.9p2 CVE-2025-23419 云原生 安全 python c++ php ai nlp harmonyos 华为 react native #harmonyos #android #ios #ubuntu #linux #java #华为 ssh remote-ssh centos 人工智能 #macos #EasyConnect conda 边缘计算 具身智能 强化学习 #javascript #开发语言 #ecmascript #jenkins #人工智能 #云原生 ROS 自动驾驶 经验分享 部署 ollama llm IPMI 自动化 wireshark 深度学习 远程工作 #区块链 #智能合约 debian wps 安卓 tomcat micropython esp32 单片机 mqtt 物联网 语言模型 AI大模型 DeepSeek agi prometheus grafana 中间件 web安全 可信计算技术 安全架构 网络攻击模型 数据库 mysql adb web3 区块链 区块链项目 n8n CosyVoice LLM 大模型面经 大模型 职场和发展 Deepseek 大模型学习 存储维护 NetApp存储 EMC存储 虚拟机 AIGC comfyui comfyui教程 zabbix 网络药理学 生信 分子对接 autodock mgltools PDB PubChem 开源 dity make 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 快捷键 旋转屏幕 自动操作 r语言 数据挖掘 数据可视化 数据分析 机器学习 kylin ddos 持续部署 jenkins flutter Google pay Apple pay intellij-idea Playwright pythonai PlaywrightMCP 华为云 华为od Agent llama CrewAI 智能合约 压力测试 哈希算法 ssl Linux 维护模式 MVS 海康威视相机 游戏引擎 学习 3d uni-app m3u8 HLS 小程序 移动端H5网页 APP安卓苹果ios 监控画面 直播视频流 golang svn bash 编辑器 pip 算法 智能路由器 YOLO 目标检测 rk3588 npu rknn-toolkit2 #激光雷达 #览沃 #ubuntu22.04 #ros2 #大疆 负载均衡 unix 自然语言处理 DevEco Studio HarmonyOS OpenHarmony 真机调试 html http json css stm32 tcp/ip django fastapi 后端 springsecurity6 oauth2 授权服务器 前后端分离 git 网络工程师 华为认证 YOLOv8 NPU Atlas800 A300I pro rag ragflow 大模型部署 gnu iot bug 运维开发 gpu算力 Java进程管理 DevOps自动化 脚本执行 跨平台开发 远程运维 Apache Exec JSch apache pdf xml 1024程序员节 计算机视觉 群晖 低代码 onlyoffice 在线office unity GameFramework HybridCLR Unity编辑器扩展 自动化工具 性能优化 MCP AI编程 visual studio code 单例模式 课程设计 yolov5 c语言 计算机网络 阿里云 云计算 spring boot spring dash 正则表达式 ESXi Dell HPE 联想 浪潮 飞牛NAS 飞牛OS MacBook Pro 鸿蒙 混合开发 环境安装 JDK opencv arm开发 ruoyi MacMini Mac 迷你主机 mini Apple linux环境变量 ffmpeg 音视频 视频编解码 redis 其他 kvm qemu libvirt qt linuxdeployqt 打包部署程序 appimagetool chatgpt Cline Kylin-Server 国产操作系统 服务器安装 deepseek 鲲鹏 昇腾 nginx #网络 #dify 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 typescript 微信 appium 软件测试 自动化测试 功能测试 程序人生 策略模式 mac mac安装软件 mac卸载软件 mac book nvcc cuda A100 搜索引擎 程序员 prompt word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 fpga开发 动态库 GCC编译器 -fPIC -shared 爬虫 CUDA PyTorch GCC aarch64 编译安装 HPC vite Svelte crosstool-ng 实时音视频 实时互动 AI提示词优化 设计模式 oceanbase 传统数据库升级 银行 rtsp h.265 rpa open webui ansible playbook 自动化运维 okhttp android mamba 技能大赛 大模型压力测试 EvalScope Autoware 辅助驾驶 #embedding 神经网络 uniapp vue postgresql pgpool gpt transformer vmamba 笔记 MobaXterm 文件传输 Qwen3 qwen3 32b vllm 本地部署 milvus 向量数据库 SSH Linux Xterminal android studio 交互 websocket 银河麒麟 信创国产化 达梦数据库 mybatis Docker Docker Compose Kubernetes 嵌入式Linux IPC HTTP 服务器控制 ESP32 DeepSeek kubernetes k8s searxng 交换机 硬件 设备 GPU PCI-Express MS Materials 硬件工程 chrome chrome devtools selenium chromedriver 三维重建 SenseVoice rpc 远程过程调用 Windows环境 图像处理 流程图 mermaid 程序 编程 内存 性能分析 EVE-NG 架构 springboot容器部署 springboot容器化部署 微服务容器化负载均衡配置 微服务容器多节点部署 微服务多节点部署配置负载均衡 dify dify部署 华为机试 C++ Java Python glibc iventoy VmWare OpenEuler DevOps 大数据 软件交付 数据驱动 应用场景 数据安全 LLM Web APP Streamlit rc.local 开机自启 systemd 麒麟 远程桌面 rust 前端 openssl 鸿蒙系统 hdc 鸿蒙NEXT 数据集 智能手机 elasticsearch #人工智能 #深度学习 #机器学习 #考研 #计算机视觉 大模型入门 大模型教程 vue.js javascript 服务器配置 #chrome #mac #拓展程序 #禁用 蓝桥杯 Claude Desktop Claude MCP Windows Cli MCP FunASR ASR AutoDL Qwen2.5-VL LVS HTTP状态码 客户端错误 服务器端错误 API设计 嵌入式 linux驱动开发 截图 录屏 gif 工具 LLMs GenAI LLM 推理优化 LLM serving 进程信号 openjdk 智能体开发 microsoft coze SSE 知识图谱 安全漏洞 信息安全 chatbox oracle 关系型 分布式 WSL2 上安装 Ubuntu 火绒安全 mybase ui 计算机学习路线 编程语言选择 安全威胁分析 安全性测试 wsl dubbo mcu 信息与通信 Windsurf 飞腾处理器 硬件架构 国产化 node.js 多线程服务器 Linux网络编程 王者荣耀 系统架构 视频平台 录像 RTSP 视频转发 性能测试 视频流 存储 UOS 开机自启动 桌面快捷方式 进程间通信 GPU训练 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 金融 docker desktop image 毕设 EasyConnect llama3 Chatglm 开源大模型 语音识别 开发工具 基础指令 指令 计算机外设 langchain deep learning openwrt USB网络共享 seatunnel 政务 分布式系统 监控运维 Prometheus Grafana vue3 nohup 异步执行 操作系统 openEuler 欧拉系统 FTP 服务器 pycharm 三级等保 服务器审计日志备份 大大通 第三代半导体 碳化硅 科技 Windows ai工具 代码调试 ipdb 企业微信 servlet 监控 软件工程 软件构建 webpack YOLOv12 相机 主从复制 rabbitmq cron crontab日志 工作流自动化工具 bushujiaocheng 部署教程 算家云 AI算力 租算力 到算家云 #centos #vscode #ubuntu 环境迁移 云计算面试题 harmonyOS面试题 安卓模拟器 arkUI arkTs #IntelliJ IDEA #Java #Kotlin gitee QQ bot Docker Hub docker pull 镜像源 daemon.json ragflow 源码启动 pygame Kali 渗透 word ACL 流量控制 基本ACL 网络管理 规则配置 MLLMs VLM gpt-4v Apache Flume 数据采集 安装部署 配置优化 高级功能 大数据工具集成 游戏 驱动开发 嵌入式实习 DNS iNode Macos burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 多线程 进程 pthread 系统 zephyr 个人开发 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer eureka spring cloud 小智 MCP server agent C/S 信号处理 tcpdump 麒麟OS CH340 串口驱动 CH341 uart 485 Bug解决 Qt platform OpenCV RTX5090 torch2.7.0 工作流 workflow 知识库 本地化部署 计算生物学 生物信息学 生物信息 基因组 换源 国内源 Debian devops 防火墙 ufw FTP服务器 maven 学习方法 xrdp GIS 遥感 WebGIS 统信 虚拟机安装 游戏服务器 Minecraft elk jvm muduo 网络库 hadoop big data sdkman UEFI Legacy MBR GPT U盘安装操作系统 Claude Vmamba ShapeFile GeoJSON Nginx vim 百度 paddlepaddle arm visualstudio HCIE 数通 opensearch helm 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 程序化交易 量化交易 高频交易 mariadb mcp mcp协议 go-zero mcp服务器 yum apt 前端框架 HarmonyOS Next arcgis gitlab jupyter cursor 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 #算法 #数据清洗 Ollama RAGFlow 本地知识库部署 DeepSeek R1 模型 安装MySQL 镜像 开源软件 stm32项目 系统安全 kind 雨云 NPS 云服务器 flask web3.py 外网访问 内网穿透 端口映射 Deepseek-R1 私有化部署 推理模型 matlab gitee go SecureCRT latex 环境部署 flash-attention 报错 网页服务器 web服务器 微信公众平台 RAG Multi-Agent 集成学习 集成测试 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 https 反向代理 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 tidb GLIBC 微信开放平台 微信公众号配置 windows 服务器安装 Chatbox glm4 element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 计算机系统 网络编程 cmake eclipse 5G list 网络结构图 yaml Ultralytics 可视化 缓存 线程 测试工具 IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 iBMC UltraISO NAS Termux Samba open Euler dde deepin 统信UOS triton 模型分析 UOS1070e webrtc #c++ wsl2 Cursor 电子信息 通信工程 毕业 chromium dpi nvm node ros 树莓派项目 程序员创富 微服务 数据结构 电脑 gcc centos 7 卷积神经网络 fiddler 物理地址 页表 虚拟地址 Alist rclone mount 挂载 网盘 论文笔记 考研 H3C IMM RAID RAID技术 磁盘 统信操作系统 智能硬件 jar 话题通信 服务通信 umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 Spring AI 大模型应用开发 AI 应用商业化 #服务器 软件需求 环境配置 烟雾检测 yolo检测 消防检测 RustDesk自建服务器 rustdesk服务器 docker rustdesk 常用命令 文本命令 目录命令 sql 游戏程序 宝塔面板 grub 版本升级 扩容 服务器扩容没有扩容成功 Pyppeteer 抽象工厂模式 进程控制 trae sequoiaDB embedding 重启 排查 系统重启 日志 原因 nftables vmware Obsidian Dataview rnn cudnn nvidia deepseek-v3 ktransformers RagFlow 线程互斥与同步 升级 CVE-2024-7347 漏洞 自定义客户端 SAS Dell R750XS 源代码管理 vmware tools VMware jdk zookeeper RockyLinux paddle react.js 迁移 openeuler lvgl8.3 lvgl9.2 lvgl lvgl安装 #服务器 #c语言 #git #vim 远程 命令 执行 sshpass 操作 ai小智 语音助手 ai小智配网 ai小智教程 esp32语音助手 diy语音助手 perl 抓包工具 postgres Docker Desktop Dify重启后重新初始化 框架搭建 弹性计算 裸金属服务器 弹性裸金属服务器 虚拟化 HP Anyware ftp服务 文件上传 PyQt PySide6 分布式账本 信任链 共识算法 NVML nvidia-smi 生成对抗网络 gemini gemini国内访问 gemini api gemini中转搭建 Cloudflare NFS maxkb ARG archlinux kde plasma 模块测试 nac 802.1 portal yolov8 人工智能生成内容 PX4 Linux Vim docker compose 终端工具 远程工具 jellyfin nas 记账软件 springboot 容器部署 udp VSCode 密码学 我的世界 我的世界联机 数码 rust腐蚀 MQTT mosquitto 消息队列 树莓派 Navidrome ipython ip 我的世界服务器搭建 minecraft 产品经理 libreoffice word转pdf 安装 代码复审 codereview code-review 腾讯云大模型知识引擎 can 线程池 ecmascript KVM k8s部署 MySQL8.0 高可用集群(1主2从) 健康医疗 代理模式 物联网开发 ISO镜像作为本地源 postman AI-native 7-zip bigdata 微信小程序 notepad++ 矩阵乘法 3D深度学习 虚拟显示器 远程控制 ArkTs ArkUI CPU 使用率 系统监控工具 linux 命令 g++ g++13 burp suite 抓包 rocketmq ollama api ollama外网访问 shell 文档 virtualenv DocFlow 网络建设与运维 网络搭建 神州数码 神州数码云平台 云平台 性能调优 安全代理 etcd cfssl GPUGEEK 豆瓣 追剧助手 迅雷 ESP32 音乐服务器 音流 KylinV10 麒麟操作系统 Vmware html5 less hive ranger MySQL8.0 jmeter rsync OpenGL 图形渲染 Uvicorn 数学建模 python2 ROS2 隐藏文件 sqlserver 实时内核 vsxsrv IP地址 IPv4 IPv6 端口号 计算机基础 easyTier 组网 FS 文件系统 bootfs rootfs linux目录 #字体 #安装 #微软雅黑 #office ShenTong 前端面试题 go gru Crawlee dns是什么 如何设置电脑dns dns应该如何设置 #自动化 odoo 服务器动作 Server action ukui 麒麟kylinos 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 p2p 性能监控 stable diffusion AI作画 iTerm2 打不开xxx软件 无法检查其是否包含恶意软件 miniconda 软件商店 信创 livecd systemtools 开发环境 微软 Kali Linux Logstash 日志采集 拓扑图 虚拟局域网 ip命令 新增网卡 新增IP 启动网卡 Mermaid 可视化图表 自动化生成 kubeless nohup后台启动 创业创新 LSTM rdp 实验 C语言 大模型微调 僵尸世界大战 游戏服务器搭建 adobe thingsboard midjourney AI写作 ECS API 开发效率 Windmill 状态模式 #开发语言 centos-root /dev/mapper yum clean all df -h / du -sh 源码 毕业设计 anaconda 鸿蒙项目 eNSP 企业网络规划 华为eNSP 网络规划 文心一言 软考设计师 中级设计师 SQL 软件设计师 STP 生成树协议 PVST RSTP MSTP 防环路 网络基础 计算机八股 Trae IDE AI 原生集成开发环境 Trae AI 单一职责原则 无桌面 命令行 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap nuxt3 游戏开发 分布式训练 CDN Netty ios aac 若依 内存不足 outofmemory Key exchange 主包过大 xcode cocoapods MacOS 向日葵 notepad 安装教程 GPU环境配置 Ubuntu22 Anaconda安装 gpt-3 渗透测试 vnc miniapp 调试 debug 断点 网络API请求调试方法 kali 共享文件夹 网卡 显卡驱动持久化 GPU持久化 网络爬虫 android-studio perf 面试 仙盟大衍灵机 东方仙盟 仙盟创梦IDE spark HistoryServer Spark YARN jobhistory 云电竞 云电脑 express CORS 跨域 计算虚拟化 弹性裸金属 kafka 云服务 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 媒体 Jellyfin AI员工 CPU架构 服务器cpu struts 物联网嵌入式开发实训室 物联网实训室 嵌入式开发实训室 物联网应用技术专业实训室 C 环境变量 进程地址空间 ArcTS 登录 ArcUI GridItem 命名管道 客户端与服务端通信 protobuf 序列化和反序列化 ubuntu20.04 开机黑屏 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 系统内核 Linux版本 kernel function address 函数 地址 内核 NVIDIA显卡安装 Ubuntu开机黑屏 DBeaver 数据仓库 kerberos minicom 串口调试工具 网络用户购物行为分析可视化平台 大数据毕业设计 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos seleium 宝塔 WSL 云原生开发 接口优化 k8s二次开发 zip unzip edge 远程服务 Masshunter 质谱采集分析软件 使用教程 科研软件 卸载 软件 列表 unionFS OverlayFS OCI docker架构 写时复制 pppoe radius armbian u-boot 技术 css3 大模型推理 服务器繁忙 网工 tailscale derp derper 中转 bonding 链路聚合 黑客 计算机 网站搭建 serv00 博客 .netcore .net core .net NFC 近场通讯 智能门锁 aws Python 视频爬取教程 Python 视频爬取 Python教程 Python 视频教程 localhost fpga 客户端-服务器架构 点对点网络 服务协议 网络虚拟化 网络安全防御 LangGraph CLI JavaScript langgraph.json fstab linux内核 桌面环境 ArkTS js yum换源 TRAE minio AI代码编辑器 车载系统 mcp-proxy mcp-inspector fastapi-mcp sse yum源切换 更换国内yum源 增强现实 沉浸式体验 技术实现 案例分析 AR ros2 moveit 机器人运动 宝塔面板无法访问 计算机科学与技术 大语言模型 lstm LSTM-SVM 时间序列预测 Docker 部署es9 Docker部署es Docker搭建es9 Elasticsearch9 Docker搭建es #redis 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 gaussdb C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 outlook IM即时通讯 剪切板对通 HTML FORMAT saltstack 虚幻 python3.11 pyside6 界面 京东云 鸿蒙开发 移动开发 Echarts图表 折线图 柱状图 异步动态数据 可视化效果 Ubuntu 22.04 MySql 算力租赁 Charles 磁盘挂载 新盘添加 partedUtil HP打印机 3GPP 卫星通信 OpenSSH 监控k8s集群 集群内prometheus 脚本 autoware 冯诺依曼体系 超级终端 多任务操作 提高工作效率 lvs Agentic Web NLWeb 自然语言网络 微软build大会 issue 局域网 v10 dell服务器 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 PVE 文件分享 WebDAV 银河麒麟高级服务器 外接硬盘 Kylin 聊天室 致远OA OA服务器 服务器磁盘扩容 SWAT 配置文件 服务管理 网络共享 剧本 图形化界面 机柜 1U 2U 锁屏不生效 华为昇腾910b3 Featurize Mobilenet 分割 neo4j 数据库开发 database 灵办AI 稳定性 看门狗 系统开发 binder framework 源码环境 initramfs Linux内核 Grub Ardupilot Ubuntu20.04 2.35 mac设置host Android ANDROID_HOME zshrc 更换镜像源 tftp nfs homebrew windows转mac ssh密匙 Mac配brew环境变量 gstreamer 流媒体 深度求索 私域 Open WebUI 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 WSL2 ip协议 opengl tar 切换root Quixel Fab Unity UE5 游戏商城 虚幻引擎 react next.js 部署next.js rustdesk frp 内网服务器 内网代理 内网通信 腾讯云 asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 React Next.js 开源框架 显示器 日志分析 系统取证 ArtTS docker-compose IP 地址 vm SystemV 单元测试 测试用例 PPI String Cytoscape CytoHubba Typore 7z ubuntu安装 linux入门小白 powerpoint ajax 二级页表 数据链路层 AD域 SSL证书 tcp unity3d 数据库系统 Headless Linux 信息收集 Anolis nginx安装 linux插件下载 状态管理的 UDP 服务器 Arduino RTOS llama.cpp LDAP AD 域管理 massa sui aptos sei 商用密码产品体系 finebi janus cn2 带宽 #提示词注入 #防护 #安全 #大模型 iftop 网络流量监控 版本 华为证书 HarmonyOS认证 华为证书考试 resolv.conf brew swift excel 药品管理 团队开发 #pytorch SSH 服务 SSH Server OpenSSH Server 自动化任务管理 x64 SIGSEGV xmm0 监控k8s 监控kubernetes mongodb 私有化 开放端口 访问列表 匿名管道 进程池实现 OS CAN 多总线 Typescript 数字化转型 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 autodl 即时通信 NIO 模拟退火算法 网络穿透 dba 客户端 java-ee 硅基流动 ChatBox 笔灵AI AI工具 概率论 linux cpu负载异常 SRS flink DICOM chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 prometheus数据采集 prometheus数据模型 prometheus特点 Qwen2.5-coder 离线部署 c/c++ 串口 进程优先级 调度队列 进程切换 openvpn server openvpn配置教程 centos安装openvpn 推荐算法 星河版 NVM Node Yarn PM2 firewalld pycharm安装 harmonyosnext charles 鸿蒙面试 面试题 openstack Xen Hyper-V Linux24.04 Xinference Node-Red 编程工具 流编程 rime numpy gromacs 分子动力学模拟 MD 动力学模拟 OpenManus 转换 5090 显卡 AI性能 嵌入式实时数据库 authorized_keys 密钥 去中心化 网络配置 路由配置 汇编 xop RTP RTSPServer 推流 视频 gitea 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP firefox 毕昇JDK 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 gunicorn 大模型训练/推理 推理问题 mindie web linq sqlite Cache Aside Read/Write Write Behind 过期连接 材料工程 全文检索 服务发现 make命令 makefile文件 Metastore Catalog npm orbslam2 ubuntu22.04 更新apt 安装hadoop前的准备工作 热榜 ubuntu24.04.1 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 路径解析 ue4 着色器 ue5 easyui deekseek intellij idea 设置代理 实用教程 top Linux top top命令详解 top命令重点 top常用参数 Apache Beam 批流统一 案例展示 数据分区 容错机制 cnn VGG网络 卷积层 池化层 Xshell 线程同步 线程互斥 条件变量 MAVROS 四旋翼无人机 写时拷贝 Linux的进程调度队列 活动队列 模拟器 pnet pnetlab lsof linux命令 #java #maven #java-ee #spring boot #jvm #kafka #tomcat pillow 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 模型联网 CherryStudio rsyslog 直播推流 iis vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 信创终端 中科方德 浪潮信息 AI服务器 lua SFTP SFTP服务端 flinkcdc mcp client mcp server 模型上下文协议 #游戏 #云计算 edge浏览器 Hive环境搭建 hive3环境 Hive远程模式 VMware安装mocOS macOS系统安装 沙盒 智慧农业 开源鸿蒙 pyicu 动静态库 milvus安装 代码 对比 meld Beyond Compare DiffMerge RAGflow 管道 pipe函数 管道的大小 匿名管道的四种情况 北亚数据恢复 数据恢复 服务器数据恢复 数据库数据恢复 oracle数据恢复 上架 VLAN 企业网络 互联网医院 Python基础 Python技巧 卡死 vr RBAC docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 ros1 Noetic 20.04 apt 安装 RDP 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 企业风控系统 互联网反欺诈 DDoS攻击 SQL注入攻击 恶意软件和病毒攻击 nacos Apache OpenNLP 句子检测 分词 词性标注 核心指代解析 Spring Boot es MySQL csapp 缓冲区 cpu 实时 使用 pyqt 磁盘监控 api X11 Xming 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 db samba es6 qt6.3 g726 logstash 实时传输 AudioLM scrapy Mac内存不够用怎么办 kotlin iphone beautifulsoup CUPS 打印机 Qt5 illustrator 数码相机 全景相机 设备选择 实用技巧 数字空间 podman 美食 空Ability示例项目 讲解 蓝牙 大屏端 LVM 磁盘分区 lvresize 磁盘扩容 pvcreate 考试 软考 隐藏目录 管理器 通配符 client-go NVIDIA 百度云 文件共享 可用性测试 risc-v Linux权限 xshell 权限掩码 粘滞位 pandas matplotlib 进程状态 僵尸进程 #运维 #openssh升级 #银河麒麟V10 SP10 kylin v10 麒麟 v10 audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 项目部署到linux服务器 项目部署过程 云桌面 AD域控 证书服务器 Carla YashanDB 崖山数据库 yashandb 串口服务器 万物互联 工业自动化 工厂改造 teamspeak 接口隔离原则 零售 log4j fd 文件描述符 权限 苹果电脑装windows系统 mac安装windows系统 mac装双系统 macbook安装win10双 mac安装win10双系统 苹果电脑上安装双系统 mac air安装win dnf 进程等待 内存泄漏 linux/cmake 蓝耘科技 元生代平台工作流 ComfyUI 办公自动化 pdf教程 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 Reactor 显示过滤器 ICMP Wireshark安装 DeepSeek r1 System V共享内存 进程通信 Zoertier 内网组网 图搜索算法 深度强化学习 深度Q网络 Q_Learning 经验回收 量子计算 CKA shell编程 弹性 #llama #docker #kimi 流式接口 TrinityCore 魔兽世界 dns VNC 服务器管理 配置教程 网站管理 Web服务器 多线程下载工具 PYTHON solidworks安装 ECS服务器 gitlab服务器 网络接口 时间间隔 所有接口 多网口 MultiServerMCPC load_mcp_tools load_mcp_prompt 显卡驱动 nvidia驱动 Tesla显卡 深度优先 排序算法 滑动验证码 反爬虫 cs144 高考 省份 年份 分数线 数据 uni-popup报错 连接服务器超时 点击屏幕重试 uniapp编译报错 uniapp vue3 imported module TypeError 黑苹果 邮件APP 免费软件 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 Ubuntu共享文件夹 共享目录 Linux共享文件夹 本地部署AI大模型 网络文件系统 可执行程序 csrf OpenCore firewall chrome历史版本下载 chrominum下载 软硬链接 文件 #数据库 #华为 #harmonyos #手机 iperf3 带宽测试 mq 读写锁 Helm k8s集群 compose WireGuard 异地组网 IO rtc 漏洞报告生成 智能体 Jenkins流水线 声明式流水线 双系统 多系统 Nginx报错413 Request Entity Too Large 的客户端请求体限制 驱动器映射 批量映射 win32wnet模块 网络驱动器映射工具 sse_starlette Starlette FastAPI Server-Sent Eve 服务器推送事件 直播 CPU oneapi nextjs reactjs ecm bpm TCP服务器 qt项目 qt项目实战 qt教程 大数据平台 XCC Lenovo 框架 PTrade QMT 量化股票 OSB Oracle中间件 SOA ueditor导入word 客户端/服务器架构 分布式应用 三层架构 Web应用 跨平台兼容性 SQI iOS Server Trust Authentication Challenge 前端项目部署 微前端 HarmonyOS5 sonoma 自动更新 mysql安装报错 windows拒绝安装 termux 环境搭建 STL photoshop devmem cuda驱动 调试方法 Valgrind 内存分析工具 libtorch MAC地址 #apache 离线部署dify 实习 视觉检测 QT 5.12.12 QT开发环境 Ubuntu18.04 DenseNet 自动化编程 2024 2024年上半年 下午真题 答案 Reactor反应堆 web环境 axure 轮播图 学习路线 BCLinux 软件安装 分类 dataworks maxcompute pytorch3d zotero 同步失败 echarts 信息可视化 网页设计 银河麒麟桌面操作系统 Kylin OS token sas 远程看看 远程协助 思科模拟器 思科 Cisco ABAP 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors 服务器ssl异常解决 CNNs 图像分类 漫展 TCP 多进程 TCP回显服务器 VMware安装Ubuntu Ubuntu安装k8s bcompare Linux的基础指令 支付 微信支付 开放平台 HiCar CarLife+ CarPlay QT RK3588 软链接 硬链接 大版本升 升级Ubuntu系统 免密 教程 公钥 私钥 powerbi JAVA uni-app x 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 vr看房 在线看房系统 房产营销 房产经济 三维空间 openssh pyautogui P2P HDLC docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 RAGFLOW qps 高并发 GRE webview visual studio d3d12 python高级编程 Ansible elk stack Linux系统编程 冯诺依曼体系结构 BMS 储能 飞书 mysql 8 mysql 8 忘记密码 Invalid Host allowedHosts DeepSeek-R1 API接口 IIS Hosting Bundle .NET Framework vs2022 BMC 带外管理 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 asm MQTT协议 消息服务器 飞牛 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 RK3568 pxe 工厂方法模式 socket 证书 签名 大学大模型可视化教学 全球气象可视化 大学气象可视化 观察者模式 JavaWeb 回显服务器 Echo deepseek r1 中兴光猫 换光猫 网络桥接 自己换光猫 ci/cd 用户缓冲区 Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 设备树 Linux find grep SPI debezium 数据变更 数据迁移 VUE Mysql sublime text 金仓数据库 2025 征文 数据库平替用金仓 bat qt5 客户端开发 Alexnet GeneCards OMIM TTD Isaac Sim 虚拟仿真 VM虚拟机 LLaMA-Factory NLP 开发 Playwright MCP Makefile Make 客户端和服务器端 机器人操作系统 TraeAgent #apache #flink c EMQX 通信协议 Ubuntu 24.04.1 轻量级服务器 windows日志 kamailio sip VoIP WebRTC IIS服务器 IIS性能 日志监控 联想开天P90Z装win10 netty 半虚拟化 硬件虚拟化 Hypervisor 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 client close 规格说明书 设计规范 Webserver 异步 http状态码 请求协议 ftp 相机标定 HTTP3 全双工通信 多路复用 实时数据传输 mysql离线安装 mysql8.0 键盘 ruby 英语 MAC Mac部署 Ollama模型 Openwebui 配置教程 AI模型 源码软件 编译器 electron docker run 数据卷挂载 交互模式 运维监控 camera Arduino autogen openai 桥接模式 windows虚拟机 虚拟机联网 ocr 蜂窝网络 频率复用 射频单元 无线协议接口RAN 主同步信号PSS 容器化 Serverless 内存管理 4 - 分布式通信、分布式张量 AOD-PONO-Net 图像去雾技术 MinerU #python #信息可视化 做raid 装系统 Flask Waitress Gunicorn uWSGI DeepSeek行业应用 Heroku 网站部署 freebsd 智能音箱 智能家居 音乐库 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? 联机 僵尸毁灭工程 游戏联机 开服 配置原理 pyscenic 生信教程 科勘海洋 数据采集浮标 浮标数据采集模块 blender three.js 数字孪生 jvm调优 LRU策略 内存增长 垃圾回收 医疗APP开发 app开发 移动端开发 Maven 泰山派 根文件系统 Linux的进程控制 Ubuntu22.04 IMX317 MIPI H265 VCU composer 输入法 VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 Linux的进程概念 自动化测试框架 重构 gin #大数据 #python #毕业设计 #Hadoop #SPark #数据挖掘 磁盘满 孤岛惊魂4 黑客技术 ldap 金仓数据库概述 金仓数据库的产品优化提案 匿名FTP 邮件传输代理 SSL支持 chroot监狱技术 电子信息工程 全栈 raid proto actor actor model Actor 模型 英语六级 加密 华为OD机考 机考真题 需要广播的服务器数量 USB转串口 Redis Desktop AList webdav fnOS export env 变量 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia 编译 烧录 根目录 ssh远程登录 lio-sam SLAM 论文阅读 virtualbox 大模型技术 本地部署大模型 输入系统 AzureDataStudio LInux 命令模式 电子器件 二极管 三极管 青少年编程 编程与数学 WebFuture c盘 磁盘清理 #YOLO #目标检测 #YOLOv13 UDP的API使用 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 银河麒麟操作系统 swoole gateway Clion Nova ResharperC++引擎 Centos7 远程开发 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 OD机试真题 华为OD机试真题 服务器能耗统计 阿里云ECS 内网渗透 靶机渗透 EtherCAT转Modbus EtherCAT转485网关 ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口网关 ECT转Modbus串口服务器 mvc 机架式服务器 1U工控机 国产工控机 教育电商 Lenovo System X GNOME Scoket 套接字 笔记本电脑 Ubuntu Server Ubuntu 22.04.5 conda配置 conda镜像源 csrutil mac恢复模式进入方法 恢复模式 grep GKI KMI tar.gz tar.xz linux压缩 direct12 PATH 命令行参数 main的三个参数 react Native 实战项目 入门 精通 单用户模式 #tomcat #架构 #servlet springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 ceph curl wget Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 finalsheel 软路由 Arduino下载开发板 esp32开发板 esp32-s3 开启关闭防火墙 思科实验 高级网络互联 #python3.11 vscode1.86 1.86版本 ssh远程连接 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 live555 源码剖析 rtsp实现步骤 流媒体开发 端口测试 镜像下载 跨域请求 免费 cocos2d 3dcoat 零日漏洞 CVE 决策树 医药 多端开发 智慧分发 应用生态 鸿蒙OS 小游戏 五子棋 检索增强生成 文档解析 大模型垂直应用 Linux PID 开发人员主页 数据库管理 机床 仿真 课件 虚拟现实 教学 课程 iptables linux安装配置 免费域名 域名解析 rancher 本地知识库 打包工具 链表 dnn #adb #数据库开发 #mysql #sql vasp安装 服务器时间 银河麒麟服务器操作系统 系统激活 file server http server web server rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK wsgiref Web 服务器网关接口 W5500 OLED u8g2 LORA 智能电视 java-zookeeper IP配置 netplan win向maOS迁移数据 CTE AGE bpf bpfjit pcap GoogLeNet AnythingLLM AnythingLLM安装 聚类 目标跟踪 OpenVINO 推理应用 Sealos 图片增强 增强数据 K8S k8s管理系统 服务注册与发现 电脑操作 wpf dsp开发 文件权限 muduo库 laravel java-rocketmq 充电桩 欧标 OCPP 券商 股票交易接口api 类型 特点 股票量化接口 股票API接口 Putty 花生壳 DELL R730XD维修 全国服务器故障维修 多媒体 网络带宽 问题排查 服务器租用 物理机 SPP 嵌入式系统开发 一切皆文件 导航栏 PostgreSQL15数据库 热键 octomap_server linux常用命令 uboot 部署方案 IMX6ULL Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 WebVM copilot llamafactory 微调 Qwen DrissionPage 服务 SSM 项目实战 页面放行 迭代器模式 vb filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 C# MQTTS 双向认证 emqx nosql 动态规划 网站 deepseek-r1 大模型本地部署 openvino GPU状态 网络IO 队列 数据库占用空间 shell脚本免交互 expect linux免交互 sublime text3 mac cocoapods macos cocoapods 苹果 I/O 设备管理 #数据结构 #c++ #链表 #笔记 su sudo sudo原理 su切换 post.io 企业邮箱 搭建邮箱 本地环回 bind SoC 原子操作 AXI time时间函数 #n8n #n8n工作流 #n8n教程 #n8n本地部署 #n8n自动化工作流 #n8n使用教程 #n8n工作流实战案例 #大数据 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 Socket VPS DOIT 四博智联 ardunio BLE 温湿度数据上传到服务器 Arduino HTTP Web应用服务器 vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 web开发 建站 粘包问题 信号 GRANT REVOKE 流水线 脚本式流水线 国产数据库 瀚高数据库 下载安装 import save load 迁移镜像 netlink libnl3 xfce PCB fork 进程管理 #bright data 网卡的名称修改 eth0 ens33 个人博客 ping++ junit hibernate googlecloud asp.net大文件上传下载 小智AI服务端 xiaozhi TTS 主板 电源 deepseak 豆包 KIMI 腾讯元宝 文件存储服务器组件 宠物 免费学习 宠物领养 宠物平台 支持向量机 惠普服务器 惠普ML310e Gen8 惠普ML310e Gen8V2 磁盘IO iostat 进度条 序列化反序列化 keepalived 代理服务器 权限命令 特殊权限 用户管理 systemctl Linux的基础开发工具 容器清理 大文件清理 空间清理 进程创建 进程退出 端口 原创作者 vscode-server ubuntu18.04 影刀 #影刀RPA# telnet 远程登录 deployment daemonset statefulset cronjob 问题解决 自学笔记 小米 澎湃OS redhat 电视剧收视率分析与可视化平台 富文本编辑器 scapy 集成 openGauss ssrf 失效的访问控制 EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 VMware创建虚拟机 banner 软件开发 三次握手 快速入门 VR手套 数据手套 动捕手套 动捕数据手套 基础入门 分析解读 cmos Cookie 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 Maxkb RAG技术 Unlocker elementui 若依框架 抗锯齿 linux子系统 忘记密码 能效分析 图论 coze扣子 AI口播视频 飞影数字人 coze实战 TiDB测试集群 #php 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 聊天服务器 Dedicated Host Client 无头主机 hugo 网络原理 caddy asp.net 鼠标 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 基础环境 diskgenius jdk11安装 jdk安装 openjdk11 openjdk11安装 Python学习 Python编程 #mobaxterm #termius #electerm #tabby #termcc CentOS 子网掩码 公网IP 私有IP ubuntu24 vivado24 源代码 nano proxy_pass 2025一带一路金砖国家 金砖国家技能大赛 技能发展与技术创新大赛 首届网络系统虚拟化管理与运维 比赛样题 阻塞队列 生产者消费者模型 服务器崩坏原因 UDP 游戏机 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 备选 调用 示例 服务器主板 AI芯片 IDEA skynet 服务器部署 本地拉取打包 Qualcomm WoS QNN AppBuilder 行情服务器 股票交易 速度慢 切换 腾讯云服务器 轻量应用服务器 linux系统入门 messages dmesg EMUI 回退 降级 wait waitpid exit Bandizip Mac解压 Mac压缩 压缩菜单 分布式总线 杂质 leetcode TCP协议 efficientVIT YOLOv8替换主干网络 TOLOv8 烟花代码 烟花 元旦 飞牛nas fnos 钉钉 NLP模型 Docker快速入门 工具分享 MinIO ROS1/ROS2 dockerfile Wayland 麒麟kos 网络检测 ping mcp-server ipv6 光猫设置 路由器设置 WIFI7 无线射频 高通 射频校准 射频调试 射频匹配 #debian SVN Server tortoise svn 同步 备份 移动云 vSphere vCenter 大文件秒传跨域报错cors DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 创意 社区 西门子PLC 通讯 gradle 代码托管服务 弹性服务器 bootstrap bug定位 缺陷管理 RustDesk 搭建服务器 材质 贴图 高级IO epoll cpolar 体验鸿蒙电脑操作系统 Windows电脑能装鸿蒙吗 #DevEco Studio #HarmonyOS Next Linux环境 软负载 AI Agent 字节智能运维 并查集 IPv6测试 IPv6测速 IPv6检测 IPv6查询 anythingllm open-webui docker国内镜像 高可用 registries 搜狗输入法 中文输入法 回归 huggingface rtsp转rtmp 海康rtsp转rtmp 摄像头rtsp到rtmp rtsp转发 rtsp摄像头转rtmp rtsp2rtmp #stm32 #单片机 #freeRTOS code-server Spring Security MI300x 能力提升 面试宝典 IT信息化 VS Code ueditor导入pdf ueditor导入ppt 环境 非root 大厂程序员 硅基计算 碳基计算 认知计算 生物计算 AGI 系统架构设计 软件哲学 程序员实现财富自由 slave 支付宝小程序 云开发 访问公司内网 #AI #MCP Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 trea idea lvm MDK 嵌入式开发工具 桶装水小程序 在线下单送水小程序源码 桶装水送货上门小程序 送水小程序 订水线上商城 ebpf CUDA Toolkit CAN总线 #VMware #虚拟机 #nacos jina 多路转接 SSH 密钥生成 SSH 公钥 私钥 生成 浏览器开发 AI浏览器 k8s集群资源管理 实战案例 lb 协议 手机 HBase分布式集群 HBase环境搭建 HBase安装 HBase完全分布式环境 network NetworkManager dockercompose安装 compose.yml文件详解 dockercompose使用 pavucontrol 蓝牙耳机 人工智能作画 #计算机网络 #tcp/ip rtp MNN 显示管理器 lightdm gdm Erlang OTP gen_server 热代码交换 事务语义 算力 干货分享 黑客工具 密码爆破 数字证书 签署证书 蓝桥杯C++组 实时云渲染 云渲染 3D推流 站群服务器 MateBook MQTT Broker GMQT alphafold3 #vscode #编辑器 #ide #阿里云 #ai #AI编程 服务网格 istio uv Linux的权限 终端 java毕业设计 微信小程序医院预约挂号 医院预约 医院预约挂号 小程序挂号 C/C++ webgis cesium 程序地址空间 云盘 安全组 pi0 lerobot aloha act #分区 产测工具框架 管理框架 WebUI DeepSeek V3 GRUB引导 Linux技巧 solr BitTorrent 搜索 简单工厂模式 NAT转发 NAT Server 并集查找 换根法 树上倍增 iDRAC R720xd 雨云服务器 加解密 Yakit yaklang ECT转Modbus协议 EtherCAT转485协议 ECT转Modbus网关 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 错误代码2603 无网络连接 2603 华为OD 可以组成网络的服务器 AWS qwen2vl 事件驱动 accept 自定义登录信息展示 motd 美化登录 光电器件 LED js逆向 捆绑 链接 谷歌浏览器 youtube google gmail alias unalias 别名 termius iterm2 Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 AppLinking 应用间跳转 影视app 线程安全 时序数据库 iotdb EulerOS 版本对应 Linux 发行版 企业级操作系统 RHEL 开源社区 #电脑 #经验分享 #ansible #role #galaxy #ansible-galaxy #kali cd 目录切换 容器技术 需求分析 知行EDI 电子数据交换 知行之桥 EDI 通用环境搭建 openresty BiSheng Jenkins 配置凭证 #经验分享 #kubernetes #数据结构 #爬虫 Radius WinRM TrustedHosts XFS xfs文件系统损坏 I_O error AI agent 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 宕机切换 服务器宕机 雾锁王国 算法协商 故障排查 Web测试 pve cordova 跨域开发 #合成孔径雷达 #GAMMA #InSAR #飞算Java炫技赛 #Java开发 小艺 Pura X HarmonyOS NEXT 原生鸿蒙 软件卸载 系统清理 vpn DIFY 多产物 提示词 wifi驱动 文件清理 应急响应 CTF 南向开发 北向开发 ai编程 HDC2025 HarmonyOS 6 #conda IO模型 机械臂 静态IP Trae叒更新了? 红黑树封装map和set fabric nacos容器环境变量 docker启动nacos参数 nacos镜像下载 #安全 #nginx #web安全 #database #macos webstorm opcua opcda KEPServer安装 RTMP 应用层 流量运营 繁忙 解决办法 替代网站 汇总推荐 AI推理 负载测试 矩池云 数据下载 数据传输 OpenManage MCP 服务器 JADX-AI 插件 视频服务器 软件高CPU占用 ProcessExplorer Process Hacker System Informer Windbg 线程的函数调用堆栈 springcloud 微信分享 Image wxopensdk 多层架构 解耦 macOS retry 重试机制 子系统 CodeBuddy首席试玩官 系统完整性 越狱设备 系统升级 16.04 Termius Vultr 远程服务器 NAT ICMPv6 docker安装mysql win下载mysql镜像 mysql基本操作 docker登陆私仓 docker容器 deepseek与mysql #openssh #chrome #电脑上不了网 #IP设置 #网卡驱动 #路由器设置 #wifi设置 #网络防火墙 #无法连接到这个网络 asi_bench 根服务器 多个客户端访问 IO多路复用 TCP相关API 技术共享 WebServer oracle fusion oracle中间件 zerotier c/s 海康 access blocked 破解 anonymous rtmp eventfd 高性能 国产芯片 视频直播物理服务器租用 物理服务器 物理机租用 Bluedroid #默认分类 魔百盒刷机 移动魔百盒 机顶盒ROM MacOS录屏软件 regedit 开机启动 safari 查看显卡进程 fuser 空间 查错 互联网实用编程指南 ps命令 时间轮 Navigation 路由跳转 鸿蒙官方推荐方式 鸿蒙原生开发 路径规划 CKEditor5 分布式锁 MVVM 鸿蒙5.0 备忘录应用 #矫平机 #校平机 #铁 #钢 etl CLion selete hosts hosts文件管理工具 Web3 Telegram AI控制浏览器 Browser user Cilium SEO 社交电子 sqlite3 浏览器自动化 联网 easyconnect 代理 Qt QModbus 独立服务器 Windows 11 重装电脑系统 Java 日志框架 Log4j2 Logback SLF4J 结构化日志 企业级应用 BIO Java socket Java BIO Java NIO Java 网络编程 ESP8266简单API服务器 Arduino JSON 集群 科研绘图 生信服务器 tengine web负载均衡 WAF proteus #其他 元服务 应用上架 Attention CentOS Stream fonts-noto-cjk 跨平台 qtcreator English nmcli #技能认证 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm 解决方案 底层实现 UFW CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 containerd 恒玄BES 触觉传感器 GelSight GelSightMini GelSight触觉传感器 requests python库 机床主轴 热误差补偿 风电齿轮箱 故障诊断 物理-数据融合 预测性维护 线性代数 #udp #网络通信 #网络协议 #Socket #redis #缓存 #网络协议 #ip 网络犯罪 人工智能 win11 无法解析服务器的名称或地址 软件定义数据中心 sddc SSL 域名 直流充电桩 服务器部署ai模型 KingBase IPMITOOL 硬件管理 clickhouse 互信 代码规范 VPN wireguard AimRT vue在线预览excel和编辑 vue2打开解析xls电子表格 浏览器新开页签或弹框内加载预览 文件url地址或接口二进制文档 解决网页打不开白屏报错问题 zipkin funasr asr 语音转文字 webgl Office Github加速 Mac上Github加速 Chrome浏览器插件 自定义shell当中管道的实现 匿名和命名管道 Bluetooth 配对 Linux指令 Windows应急响应 webshell 网络攻击防御 网络攻击 学习笔记 HarmonyOS 5开发环境 对话框showDialog showActionMenu 操作列表ActionSheet CustomDialog 文本滑动选择器弹窗 消息提示框 警告弹窗 FreeLearning 嵌入式软件 RTOS CMake 自动化编译工具 PDF 图片 表格 文档扫描 发票扫描 #rockylinux #rhel #操作系统 #系统安装 linux上传下载 docker命令大全 docker部署Python 李心怡 dock 加速 达梦 DM8 端口聚合 windows11 scikit-learn 网易邮箱大师 mapreduce 定义 核心特点 优缺点 适用场景 数字比特流 模拟信号 将二进制数据映射到模拟波形上 频谱资源 振幅频率相位 载波高频正弦波 物理层 进程操作 理解进程 工作流自动化 AI智能体 线程同步与互斥 #mcp #浏览器自动化 #gpt #chatgpt 架构与原理 工业4.0 域名服务 DHCP 符号链接 配置 shard 流量 aiohttp asyncio AI导航站 cangjie 哥sika webserver #aws #搜索引擎 #elasticsearch #全文检索 玩机技巧 软件分享 软件图标 Ark-TS语言 模拟实现 历史版本 下载 玩游戏 macbook 顽固图标 启动台 ubantu 命令键 tvm安装 深度学习编译器 云解析 云CDN SLS日志服务 云监控 infini-synapse #http #OCCT #Qt #信息可视化 #qml #qt 查看 ss 代理配置 企业级DevOps 影刀证书 分享 改行学it #端口 #web安全 #网络安全 #渗透测试 #计算机 #转行 #职场发展 #干货分享 #部署配置docker #容器化 #飞书 执法记录仪 智能安全帽 smarteye 矩阵 超融合 云耀服务器 #STC8 #STM32 udp回显服务器 labview SpringBoot 开闭原则 KingbaseES #哈希算法 #散列表 ollama下载加速 接口返回 nginx默认共享目录 端口开放 本地不受DeepSeek C++11 lambda 包装类 coffeescript Eigen 黑马 苍穹外卖 vmvare mysql8.4.5 Win10修改MAC Bilibili B站 skywalking #comfyui docker search 5分钟快速学 docker入门 rxjava gerrit 电子学会 usb typec docker 失效 docker pull失效 docker search超时 #kubernetes Wi-Fi 查询数据库服务IP地址 SQL Server jetty undertow 相差8小时 UTC 时间 URL 田俊楠 搭建个人相关服务器 win服务器架设 windows server RNG 状态 可复现性 随机数生成 机器人仿真 模拟仿真 EF Core 客户端与服务器评估 查询优化 数据传输对象 查询对象模式 gpu siteground siteground安装wp 一键安装wordpress 服务器安装wordpress 泛微OA 转流 rtsp取流 rtmp推流 threejs 3D 强制清理 强制删除 mac废纸篓 ubuntu 18.04 bert Ubuntu 24.04 搜狗输入法闪屏 Ubuntu中文输入法 clipboard 剪贴板 剪贴板增强 Windows Hello 摄像头 指纹 生物识别 HarmonyOS SDK Map Kit 地图 恢复 FreeFileSync 定时备份 #Linux #Ubuntu #ubuntu24 #ubuntu2404 #ubuntu安装 #sudo #前端 #macos26 #启动台 #vue.js figma 交叉编译 WLAN sql注入 FCN 扩展错误 myeclipse #神经网络 #自然语言处理 #语言模型 #云原生 #阿里云 HAProxy h.264 Nuxt.js sysctl.conf vm.nr_hugepages ux chfs ubuntu 16.04 服务器正确解析请求体 安防软件 WINCC 充电桩平台 充电桩开源平台 Async注解 风扇散热策略 曙光 海光 宁畅 中科可控 事件分析 边缘服务器 利旧 AI识别 Modbustcp服务器 CSDN开发云 openlayers bmap tile server 协作 EasyTier av1 电视盒子 navicat 合成模型 扩散模型 图像生成 亲测 redisson #机器人 语法 生活 ELF加载 MobileNetV3 VAD 视频异常检测 VAR 视频异常推理 推理数据集 强化微调 GRPO 系统架构设计师 #目标跟踪 内网环境 佛山戴尔服务器维修 佛山三水服务器维修 业界资讯 SysBench 基准测试 迁移指南 授时服务 北斗授时 火山引擎 动态域名 jQuery 云服务器租用 FreeRTOS 报警主机 豪恩 VISTA120 乐可利 霍尼韦尔 枫叶 时刻 参数服务器 分布式计算 数据并行 红黑树 android-ndk RHCE 智能手表 Pura80 WATCH 5 nvm安装 idm 智能问答 Milvus 医院门诊管理系统 共享 设置 分布式数据库 集中式数据库 业务需求 选型误 微信自动化工具 微信消息定时发送 手动分区 最新微服务 Searxng scala #iotdb #时序数据库 cpp-httplib xss Unity插件 rtcp java18 虚拟主机 物理服务器租用 #c# #OPCUA 连接失败 Mosquitto 极限编程 Mac软件 mujoco GDB调试 Ubuntu环境 四层二叉树 断点设置 安全整改 黑屏 #WSL #Dify linux 命令 sed 命令 仓库 实时语音识别 流式语音识别 概率与统计 随机化 位运算 几何计算 数论 敏捷开发 视频会议 #图像处理 #nginx #性能优化 #科技 压测 电商平台 hexo 高效I/O 制造 站群 多IP 静态NAT OpenAI FS100P 小亦平台 运维问题解决方法 gaussdb问题解决 食用文档 whistle broadcom 九天画芯 铁电液晶 显示技术 液晶产业 技术超越 视频号 vsode #sql #学习 #自动化测试 #软件测试 xpath定位元素 proxy模式 uprobe isaacgym pow 指数函数 优化 中文分词 NGINX POD #数据库 sentinel TrueLicense authing 模板 泛型编程 能源 开启黑屏 #RAG 激光雷达 镭眸 汽车 arkts arkui 路由器 ohmyzsh PP-OCRv5 ubuntu20.04 OCR mac完美终端 项目部署 #时序数据库 #iotdb #重构 #excel #PG处理POI分类数据 #Java处理POI分类数据 #ApachePOI数据处理 #高德POI分类数据存储 #POI数据分类存储 vscode 1.86 AISphereButler 物理机服务器 dos 批处理 日期 #面试 #职场和发展 #统信uos NTP服务器 效率 #小程序 #驱动 #嵌入式 集群管理 Modbus TCP N8N OpenTiny vue2 #golang 恒源云 tty2 统信uos 实时日志 logs IT 护眼模式 #后端 #jdk #编程 watchtower homeassistant 集合 List UDS Bootloader #架构 #分布式 #单机架构 #微服务 #vue.js lrzsz 选择排序 地平线5 机架式 IDC pikachu靶场 XSS漏洞 XSS DOM型XSS #系统架构 #数据库架构 #安全架构 #美食 #django #flask #node.js 重置密码 #shell #脚本 cp 进度显示 #华为云 #云服务部署 #搭建AI #Flexus X实例 #截图工具 fast #物联网 Excel转json Excel转换json Excel累加转json python办公 低成本 #iot 风扇控制软件 #Linux的基础IO 基本指令 #算法 #洛谷 #强连通分量 #缩点 服务器托管 云托管 数据中心 idc机房 mobaxterm #计算机网络 #网络攻击模型 #tensorflow #pip #spring boot 责任链模式 几何绘图 三角函数 #嵌入式硬件 #GESP C++ #C++程序竞赛 #信奥赛 #笔记 #intellij-idea #idea #intellij idea #需求分析 #区块链 #数据分析 #端口占用 #系统详情 #jvm 信奥 guava SonarQube #HTML #核心知识点 #web #知识点 #网页开发 #虚拟地址 #虚拟地址空间 #写时拷贝 #https #postgresql #inlong #pycharm #c语言 #程序人生 #unity #着色器 #mc #服务器搭建 #mc服务器搭建 #mc服务器 #腾讯云 #毕设 #租房管理系统 #论文 #echarts #nginx配置 #nginx案例 #nginx详解 #系统架构 A2A #jenkins #测评 #CCE #Dify-LLM #Flexus #图论 #深度优先 WinCC OT与IT SCADA 智能制造 MES 细胞分割 计数自动化 图像分析 #eureka #音视频 #AIGC #开源 #VNC #Agent #智能运维 #AI开发平台 #AI工具链 #AI编程 #低代码 #智能路由器 #NAT #信息与通信 #进程状态 #僵尸进程 #孤儿进程 #挂起 #rocketmq #零拷贝 #RBAC桎梏 #角色爆炸 #静态僵化 #授权对象体系 #组织维度 #业务维度 dfs #进程优先级 #进程切换 #Linux调度算法 #寄存器 #node.js #CMake #Debian #CentOS #Ollama #agent #向量库 #fastAPI #langchain #tcp/ip #MCP协议 #typescript #实战指南 #MCP服务器 #gitlab #github #leetcode #神经网络 #LoTDB #物联网 #进程 #fork #深信服运维安全管理系统 #远程命令执行漏洞 #DeepSeek #蓝耘智算 #深度学习 #概率论 #github #Linux的进程间通信 #开源 #AI写作 #实时流处理 #设备故障预测 #Flink #微信小程序 #配置教程 #入门教程 #安装教程 #图文教程 #Cookie #Session #HTTP #VMware #VMWare Tool #硬盘读取 #硬盘读取失败 #MAC电脑读取硬盘 #struts #android #缓冲区 #Linux #raid #raid阵列 #beego #go1.19 #beautifulsoup #Apache IoTDB #elasticsearch #list #stl #Linux的进程信号 #react.js #javascript #React 编译器 #自动优化 #记忆化技术 #重新渲染优化 #使用教程 #unix #intellij-idea #内网穿透 #矩阵 #ruby #哈希表 #gitee #权限