• 深入解析 Tengine:高性能 Web 服务器与反向代理的企业级应用

深入解析 Tengine:高性能 Web 服务器与反向代理的企业级应用

2025-04-27 13:57:44 0 阅读

Tengine 的目的

Tengine 是由淘宝技术团队(现阿里巴巴)基于 Nginx 开发的一款高性能 Web 服务器和反向代理服务器。它的主要目的是在 Nginx 的基础上增强性能、扩展功能、提升稳定性,并为大规模、高并发的互联网应用提供更高效的解决方案。

以下是 Tengine 的主要目的及其相关实现:


1. 提升高并发场景下的性能

目的:

在处理高并发连接和大流量请求时,提供比 Nginx 更高的性能,能够更好地满足企业级应用(如电商、社交媒体、搜索引擎等)的需求。

实现方式:
  • 优化内存管理:提升内存分配和缓存机制的效率,减少资源消耗。
  • 增强事件驱动模型:进一步优化事件分发和 I/O 处理,充分利用多核 CPU 的并发能力。
  • 支持大连接数:通过优化连接管理机制,支持更高的连接数,适合高并发流量场景。

2. 提供企业级功能扩展

目的:

扩展 Nginx 的功能,满足企业级应用的复杂需求,例如动态负载均衡、健康检查、缓存、流量控制等。

实现方式:
  • 动态负载均衡

    • 支持动态调整后端服务器的权重,无需重启服务即可生效。
    • 支持多种负载均衡策略(轮询、权重、IP 哈希、一致性哈希等)。
  • 健康检查

    • 内置健康检查模块,实时检测后端服务器的健康状态,并根据结果调整请求分发,确保高可用性。
  • 缓存功能

    • 提供高效的静态文件缓存和代理缓存功能,加快资源响应速度。
  • 流量控制

    • 支持限流和连接数限制,防止恶意流量攻击和资源耗尽。
  • 增强日志与监控

    • 提供丰富的日志记录功能,支持实时流量统计和性能监控,便于运维和故障排查。

3. 支持动态模块加载

目的:

降低开发和维护成本,允许在无需重新编译的情况下动态加载新功能模块。

实现方式:
  • 动态模块机制
    • 支持通过 load_module 指令加载动态模块,无需重启服务。
    • 允许企业根据需求定制化功能扩展,适应快速变化的业务需求。

4. 提升稳定性和可靠性

目的:

针对大流量、高并发场景下的异常情况,提供更高的容错能力和系统稳定性。

实现方式:
  • 异常保护

    • 提供多种保护机制,防止因单个请求或模块异常导致服务中断。
  • 优雅重启

    • 支持平滑升级和优雅重启,保障服务在更新过程中不中断。
  • 健康检查与故障剔除

    • 自动识别不可用的后端服务器并剔除,确保流量始终分发到健康的节点。

5. 满足互联网场景的特殊需求

目的:

根据中国互联网企业的业务特点和需求,在 Nginx 的基础上增加针对性的优化和扩展。

实现方式:
  • 多语言支持

    • 支持多种编程语言和框架(如动态脚本 Lua 模块),便于企业灵活开发。
  • CDN优化

    • 增强静态资源分发的能力,优化内容分发网络(CDN)的性能。
  • 安全增强

    • 提供 Web 应用防火墙(WAF)功能,防御常见的 Web 攻击(如 SQL 注入、XSS 跨站脚本攻击、DDoS 攻击等)。

6. 保持与 Nginx 的兼容性

目的:

在增强功能的同时,保证与原生 Nginx 的配置、模块、生态的兼容性,便于用户从 Nginx 平滑迁移到 Tengine。

实现方式:
  • 完全兼容 Nginx 配置文件语法

    • 用户可以直接使用现有的 Nginx 配置文件,无需额外调整。
  • 支持大多数 Nginx 模块

    • 继承了 Nginx 的核心模块,同时增强了其扩展能力。

8. 提升开发与运维效率

目的:

通过功能优化和工具支持,降低开发和运维的复杂度,缩短上线周期。

实现方式:
  • 可视化监控

    • 支持实时流量监控和性能分析,帮助运维人员快速定位问题。
  • 灵活的日志系统

    • 支持自定义日志格式和日志切割,便于调试和数据分析。
  • 易于部署和扩展

    • 提供简单易用的编译和部署工具,支持快速扩展和更新。

Tengine 项目使用指南

Tengine 是一个基于 Nginx 的高性能 Web 服务器和反向代理服务器,适用于高并发、高流量的场景。它继承了 Nginx 的功能,并增加了许多扩展功能,如动态负载均衡、健康检查、WAF(Web 应用防火墙)等。本指南将介绍 Tengine 的安装、配置和常见功能的使用。


一、Tengine 的安装

Tengine 支持源码编译安装和预编译包安装,以下是两种方式的具体步骤。

1.1 源码编译安装

步骤:
  1. 下载源码

    git clone https://github.com/alibaba/tengine.git
    cd tengine
    
  2. 配置编译选项

    ./configure --prefix=/usr/local/tengine 
                --with-http_ssl_module 
                --with-http_v2_module 
                --with-http_gzip_static_module 
                --with-http_realip_module
    
    • --prefix:指定安装目录。
    • --with-*:启用特定模块功能。
  3. 编译并安装

    make && make install
    
  4. 验证安装
    查看是否安装成功:

    /usr/local/tengine/sbin/nginx -v
    

    输出类似以下内容:

    Tengine version: Tengine/2.x.x
    
  5. 启动 Tengine
    启动 Tengine 服务:

    /usr/local/tengine/sbin/nginx
    

1.2 使用预编译包安装

步骤:
  1. 下载预编译包
    从 Tengine 官方下载页面 获取最新的预编译包。

  2. 解压并安装

    tar -xvf tengine-2.x.x.tar.gz
    cd tengine-2.x.x
    ./configure
    make && make install
    
  3. 启动 Tengine

    /usr/local/tengine/sbin/nginx
    

二、Tengine 的基本配置

Tengine 的配置文件默认路径为 /usr/local/tengine/conf/nginx.conf,其语法与 Nginx 基本一致,同时增加了一些 Tengine 独有的配置选项。

以下是一个简单的 Tengine 配置文件示例:

# 全局配置
worker_processes  4;            # 启动的工作进程数
worker_rlimit_nofile 65535;     # 每个进程的最大文件句柄数

events {
    worker_connections  1024;   # 每个进程的最大连接数
}

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile      on;
    keepalive_timeout  65;

    # Gzip 压缩
    gzip  on;
    gzip_min_length 1k;
    gzip_comp_level 6;
    gzip_types text/plain application/json text/css;

    # 日志格式
    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;

    # 负载均衡配置
    upstream backend {
        server 192.168.1.101:8080 weight=5;  # 后端服务器1
        server 192.168.1.102:8080 weight=3;  # 后端服务器2
        server 192.168.1.103:8080 backup;    # 备用服务器
    }

    # 服务器配置
    server {
        listen       80;
        server_name  example.com;

        location / {
            proxy_pass http://backend;         # 转发请求到 upstream 定义的后端
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }

        # 错误页面
        error_page 404 /404.html;
        location = /404.html {
            root /usr/local/tengine/html;
        }
    }
}

三、Tengine 的常见功能使用

3.1 负载均衡

Tengine 提供了强大的负载均衡功能,支持多种策略,包括轮询(默认)、权重、IP 哈希等。

配置示例:
# 定义后端服务组
upstream backend {
    server 192.168.1.101:8080 weight=5;  # 权重为5
    server 192.168.1.102:8080 weight=3;  # 权重为3
    server 192.168.1.103:8080 backup;    # 备用服务器
}

# 使用负载均衡
server {
    listen 80;
    location / {
        proxy_pass http://backend;
    }
}
负载均衡策略:
  • 默认轮询:请求被依次分配给每个服务器。
  • 权重(weight):根据权重分配流量。
  • IP 哈希(ip_hash):根据客户端 IP 地址分配流量,使同一 IP 的用户访问同一台服务器。

IP 哈希示例:

upstream backend {
    ip_hash;                          # 启用 IP 哈希
    server 192.168.1.101:8080;
    server 192.168.1.102:8080;
}

3.2 健康检查

Tengine 增强了 Nginx 的健康检查功能,可以定期检测后端服务器状态,并剔除故障服务器。

健康检查配置:
http {
    upstream backend {
        server 192.168.1.101:8080;
        server 192.168.1.102:8080;

        # 开启健康检查
        check interval=3000 rise=2 fall=5 timeout=1000 type=http;
        check_http_send "HEAD / HTTP/1.0

";
        check_http_expect_alive http_2xx http_3xx;
    }

    server {
        listen 80;
        location / {
            proxy_pass http://backend;
        }
    }
}

参数说明:

  • interval=3000:检查间隔(单位毫秒)。
  • rise=2:连续检查 2 次成功视为健康。
  • fall=5:连续检查 5 次失败视为故障。
  • timeout=1000:检查超时时间(单位毫秒)。
  • type=http:健康检查类型(支持 TCP 或 HTTP)。
  • check_http_send:发送的 HTTP 请求内容。
  • check_http_expect_alive:期望的响应状态码。

3.3 动态模块

Tengine 支持动态加载模块,无需重新编译即可加载新功能模块。

加载动态模块:

在配置文件中使用 load_module 指令加载模块:

load_module modules/ngx_http_lua_module.so;
生成动态模块:

通过添加 --add-dynamic-module 参数编译模块:

./configure --add-dynamic-module=/path/to/module
make modules

生成的动态模块文件通常位于 objs/ 目录下。


3.4 启用 HTTP/2

Tengine 支持 HTTP/2,可以通过以下配置启用:

server {
    listen 443 ssl http2;      # 启用 HTTP/2
    server_name example.com;

    ssl_certificate /path/to/cert.pem;
    ssl_certificate_key /path/to/key.pem;

    location / {
        root /usr/share/nginx/html;
    }
}

3.5 WAF(Web 应用防火墙)

Tengine 提供了 Web 应用防火墙模块,可以防御常见的安全威胁,如 SQL 注入、XSS 攻击等。

启用 WAF 模块:

安装并加载 WAF 模块(如 ngx_http_lua 模块),然后在配置文件中启用:

location / {
    access_by_lua_block {
        -- Lua 脚本实现 WAF 规则
        local args = ngx.req.get_uri_args()
        if args["id"] and tonumber(args["id"]) < 0 then
            ngx.exit(403)
        end
    }
}

四、Tengine 的管理命令

Tengine 提供了一些管理命令,用于控制服务器的运行状态。

启动 Tengine
/usr/local/tengine/sbin/nginx
重新加载配置
/usr/local/tengine/sbin/nginx -s reload
停止 Tengine
/usr/local/tengine/sbin/nginx -s stop
平滑升级
/usr/local/tengine/sbin/nginx -s quit
**检查配置
检查配置文件合法性

在修改配置文件后,可以使用以下命令检查其合法性:

/usr/local/tengine/sbin/nginx -t

输出结果:

  • 如果配置正确:
    nginx: the configuration file /usr/local/tengine/conf/nginx.conf syntax is ok
    nginx: configuration file /usr/local/tengine/conf/nginx.conf test is successful
    
  • 如果配置有误,会提示错误信息及出错的具体位置。

五、Tengine 的高级功能使用

5.1 动态负载均衡

Tengine 支持动态调整后端服务器的负载均衡权重,无需重启服务即可生效。

动态负载均衡配置:
http {
    upstream backend {
        server 192.168.1.101:8080;
        server 192.168.1.102:8080;
        server 192.168.1.103:8080;
    }

    server {
        listen 80;

        location / {
            proxy_pass http://backend;
        }
    }
}
动态调整权重:

通过 tengine_upstream.conf 文件,动态调整后端服务器的权重。例如:

echo "192.168.1.101:8080 weight=10" > /usr/local/tengine/conf/tengine_upstream.conf

然后通过以下指令重新加载配置:

nginx -s reload

动态负载均衡可以结合健康检查模块使用,以保证流量分发到健康的服务器节点。


5.2 流量限速

Tengine 提供了流量限制功能,可以限制每个 IP 的并发请求数或每秒请求数,防止恶意请求或流量突增。

限速配置:
http {
    # 定义限速区域
    limit_req_zone $binary_remote_addr zone=req_zone:10m rate=10r/s;

    server {
        listen 80;

        location / {
            limit_req zone=req_zone burst=5;  # 每秒限制 10 个请求,允许 5 个突发请求
            proxy_pass http://backend;
        }
    }
}

参数说明:

  • limit_req_zone:定义限速规则,$binary_remote_addr 表示根据客户端 IP 地址限速。
  • zone=req_zone:10m:定义限速区域大小为 10MB。
  • rate=10r/s:每秒允许的请求数为 10。
  • burst=5:允许 5 个突发请求。

5.3 缓存加速

Tengine 支持内容缓存功能,可以将后端服务器的响应存储到本地磁盘或内存中,从而加速用户的访问。

缓存配置:
http {
    proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m max_size=1g inactive=60m use_temp_path=off;

    server {
        listen 80;

        location / {
            proxy_cache my_cache;                   # 启用缓存
            proxy_cache_valid 200 302 10m;          # 状态码 200 和 302 的内容缓存 10 分钟
            proxy_cache_valid 404 1m;               # 状态码 404 的内容缓存 1 分钟
            proxy_pass http://backend;
        }
    }
}

参数说明:

  • proxy_cache_path:定义缓存路径及参数。
    • levels=1:2:缓存文件的目录层级结构。
    • keys_zone=my_cache:10m:定义名为 my_cache 的缓存区域,大小为 10MB。
    • max_size=1g:缓存目录最大占用空间为 1GB。
    • inactive=60m:60 分钟内未访问的缓存内容将被删除。
  • proxy_cache_valid:设置缓存的有效时间。

5.4 日志切割与管理

Tengine 提供了强大的日志功能,可以记录访问日志、错误日志,并支持日志的自动切割。

日志配置:
http {
    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;

    server {
        listen 80;

        location / {
            proxy_pass http://backend;
        }
    }
}
日志切割:

可以使用外部工具(如 logrotate)实现日志切割,以下是一个 logrotate 配置示例:

/etc/logrotate.d/nginx 配置:

/var/log/nginx/*.log {
    daily
    missingok
    rotate 14
    compress
    delaycompress
    notifempty
    create 0640 www-data www-data
    sharedscripts
    postrotate
        /usr/local/tengine/sbin/nginx -s reopen
    endscript
}

此配置会每天切割日志,保留 14 天的历史日志,并在切割后自动通知 Tengine 重新打开日志文件。


5.5 防盗链配置

Tengine 支持防盗链功能,可以限制某些外部链接直接访问服务器上的资源。

防盗链配置:
http {
    server {
        listen 80;
        server_name example.com;

        location /images/ {
            valid_referers none blocked *.example.com;
            if ($invalid_referer) {
                return 403;
            }
            root /var/www/html;
        }
    }
}

参数说明:

  • valid_referers:定义允许访问的 Referer

    • none:允许没有 Referer 的请求。
    • blocked:允许 Referer 被代理隐藏的请求。
    • *.example.com:允许来自 example.com 的请求。
  • $invalid_referer:检查请求是否为无效来源。


六、Tengine 的常见问题与解决

6.1 配置文件错误

执行 nginx -t 检查时提示配置文件错误:

nginx: [emerg] "server" directive is not allowed here

原因:

  • server 指令必须写在 http 块中。

解决方法:
检查配置文件的层级结构,确保 server 块在 http 块中定义。


6.2 服务启动失败

启动 Tengine 时提示端口占用:

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

原因:

  • 端口 80 已被其他服务占用。

解决方法:

  1. 检查端口占用:
    netstat -tuln | grep 80
    
  2. 停止占用端口的服务,或修改 Tengine 的监听端口。

6.3 高并发下性能下降

原因:

  • 可能是文件描述符不足或工作进程配置过少。

解决方法:

  1. 增大文件描述符限制:
    ulimit -n 65535
    
  2. 修改 worker_processesworker_connections 配置:
    worker_processes auto;
    worker_rlimit_nofile 65535;
    events {
        worker_connections 65535;
    }
    

这句话是关于 Tengine 在微服务场景下的适用性描述,主要是指出 Tengine 并没有像 Spring Cloud Gateway 那样为微服务架构提供原生支持(比如直接与 Eureka、Consul 等服务发现组件集成),但 Tengine 仍然可以通过 反向代理的方式 与微服务架构组合使用,尤其是在 Kubernetes 环境中,通过 Ingress 的方式实现负载均衡和路由功能。

以下将详细解释这句话的含义,以及 Tengine 在微服务架构中的应用方式。


1. 什么是“无原生微服务支持”?

Tengine 是一个高性能的 Web 服务器和反向代理服务器,基于 Nginx 开发,定位是传统的 Web 和 API 网关解决方案,主要提供:

  • 静态资源分发
  • 反向代理
  • 负载均衡
  • 健康检查
  • Web 应用防火墙(WAF)

然而,现代 微服务架构 中,常常需要 API 网关具有以下功能:

  1. 动态服务发现
    • 微服务通常会动态注册到服务注册中心(如 EurekaConsul),网关需要能够实时感知服务的变化。
  2. 动态路由
    • 微服务的路由规则可能会随服务的上线、下线动态调整。
  3. 与微服务生态集成
    • 微服务体系通常包含一整套组件(如服务注册、配置中心、分布式追踪、熔断等),网关需要能够无缝集成这些组件。

Tengine 的局限性

  • 静态配置为主:Tengine 的路由规则和负载均衡配置通常是静态的(通过配置文件 nginx.conf 写死),无法像 Spring Cloud Gateway 那样动态感知微服务的变化。
  • 缺乏原生服务发现支持:Tengine 无法直接与服务注册中心(如 Eureka、Consul)交互。
  • 微服务扩展功能不足:比如限流、熔断、动态认证等需要额外开发或依赖第三方模块。

2. 如何通过反向代理与微服务结合?

虽然 Tengine 缺乏原生的微服务支持,但它可以通过反向代理的方式与微服务结合,尤其是在 Kubernetes 环境中,通过 Ingress 配置实现简单的微服务流量管理。

反向代理的核心思想

  1. Tengine 作为流量的入口,负责接收客户端请求。
  2. 根据 URL 路径或主机名,将请求路由转发到不同的微服务。
  3. 微服务的实例地址可以手动配置,也可以通过动态脚本更新。

3. 在 Kubernetes 中作为 Ingress Controller

在 Kubernetes 中,Ingress 是一种 API 对象,用于定义 HTTP(S) 路由规则,将外部请求转发到集群内部的服务(Service)。
Tengine 可以作为 Ingress Controller 的实现,接管 Kubernetes 的流量入口。

Tengine + Kubernetes Ingress 的架构

客户端(外部请求)
        ↓
Tengine(Ingress Controller)
        ↓
Kubernetes Service(微服务的负载均衡)
        ↓
微服务实例(Pod)

如何通过反向代理支持微服务?

3.1 静态配置示例

在 Tengine 中,配置静态反向代理,将不同的路径转发到对应的微服务。

示例 nginx.conf

http {
    upstream service_a {
        server 10.0.0.1:8080;  # 微服务 A 的实例 1
        server 10.0.0.2:8080;  # 微服务 A 的实例 2
    }

    upstream service_b {
        server 10.0.0.3:9090;  # 微服务 B 的实例 1
    }

    server {
        listen 80;

        # 路由规则
        location /service-a/ {
            proxy_pass http://service_a;
        }

        location /service-b/ {
            proxy_pass http://service_b;
        }
    }
}
  • 优点
    • 简单直接,适合服务实例较少且变动不频繁的场景。
  • 缺点
    • 服务实例的地址需要手动维护,无法动态感知服务变化。

3.2 在 Kubernetes 中使用 Tengine Ingress

Tengine 可以作为 Kubernetes 的 Ingress Controller,通过 Ingress 资源动态配置路由规则。

部署步骤:

  1. 安装 Tengine Ingress Controller

    • 使用 Tengine 社区提供的 Kubernetes Ingress Controller 镜像或自己编译。
    • 在 Kubernetes 集群中部署 Tengine,并将其作为 Ingress 的实现。
  2. 定义 Ingress 资源

    • 通过 Kubernetes 的 Ingress 资源定义路由规则,例如将不同的路径转发到不同的服务。

示例 Ingress 配置:

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: example-ingress
  annotations:
    nginx.org/force-ssl-redirect: "true"
spec:
  rules:
  - host: example.com
    http:
      paths:
      - path: /service-a/
        pathType: Prefix
        backend:
          service:
            name: service-a
            port:
              number: 8080
      - path: /service-b/
        pathType: Prefix
        backend:
          service:
            name: service-b
            port:
              number: 9090
  1. 动态更新路由规则
    • Kubernetes 会动态将流量转发到对应的服务(通过 Service 和 Pod 的 DNS 映射),Tengine 无需手动更新配置。

4. 动态代理服务实例的解决方案

4.1 使用第三方工具更新 Tengine 配置

对于服务实例动态变化的场景,可以使用第三方工具(如 Consul Template 或 Lua 脚本)自动更新 Tengine 的配置文件并重新加载。

示例:使用 Consul Template
  • 将服务实例注册到 Consul。
  • 使用 Consul Template 自动生成 Tengine 的配置文件,并在服务变动时重新加载。

配置模板:

upstream service_a {
    {{ range service "service-a" }}
    server {{ .Address }}:{{ .Port }};
    {{ end }}
}

server {
    listen 80;

    location /service-a/ {
        proxy_pass http://service_a;
    }
}

4.2 使用动态反向代理(OpenResty/Lua)

通过引入 Lua 模块(如 OpenResty),实现动态服务发现和负载均衡。

示例:动态服务发现

location /service-a/ {
    content_by_lua_block {
        local service_a = {
            "10.0.0.1:8080",
            "10.0.0.2:8080"
        }
        local backend = service_a[math.random(#service_a)]
        ngx.var.target = backend
    }
    proxy_pass http://$target;
}

5. 总结

Tengine 的微服务支持特点

  1. 静态配置为主:依赖手动配置路由和服务实例,适合服务实例较固定的场景。
  2. 动态代理方案
    • 借助 Kubernetes Ingress 管理动态路由和服务发现。
    • 使用工具(如 Consul Template 或 Lua 脚本)动态更新配置。
  3. 适用场景
    • 高性能场景:需要处理高并发请求,或对静态资源分发有要求。
    • 简单微服务架构:服务数量较少且路由规则简单。

对于复杂的微服务架构(如动态服务发现、大量路由规则、认证和限流),可以结合 Spring Cloud Gateway 或其他微服务网关组件使用。

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

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 进程 操作系统 进程控制 Ubuntu ssh deepseek Ollama 模型联网 API CherryStudio python MCP 数据库 centos oracle 关系型 安全 分布式 llama 算法 opencv 自然语言处理 神经网络 语言模型 javascript 前端 chrome edge macos adb react.js 前端面试题 node.js 持续部署 Dell R750XS 科技 ai java 人工智能 个人开发 harmonyos 华为 开发语言 typescript 计算机网络 ubuntu numpy 阿里云 网络 网络安全 网络协议 笔记 C 环境变量 进程地址空间 RTSP xop RTP RTSPServer 推流 视频 kvm 无桌面 命令行 ecm bpm zotero WebDAV 同步失败 代理模式 IIS .net core Hosting Bundle .NET Framework vs2022 经验分享 android c++ c语言 ollama llm php 串口服务器 http ESP32 nuxt3 vue3 YOLO 深度学习 pytorch sql KingBase 自动化 蓝耘科技 元生代平台工作流 ComfyUI fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse 银河麒麟 kylin v10 麒麟 v10 spring boot websocket docker 实时音视频 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 pycharm conda pillow kubernetes 容器 学习方法 程序人生 gitlab tcp/ip rust DeepSeek-R1 API接口 nginx 监控 自动化运维 spring json html5 firefox django flask web3.py github 创意 社区 prometheus kylin 银河麒麟操作系统 国产化 rpc 远程过程调用 Windows环境 直播推流 腾讯云 电脑 智能路由器 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn 媒体 微信公众平台 C语言 windows ide 物联网 嵌入式硬件 硬件工程 单片机 svn flutter Hyper-V WinRM TrustedHosts virtualenv arm debian 后端 联想开天P90Z装win10 qt Reactor 设计模式 性能优化 C++ matlab gitee jmeter 软件测试 开源 YOLOv8 NPU Atlas800 A300I pro asi_bench microsoft 报错 Deepseek 统信UOS 麒麟 bonding 链路聚合 vscode JAVA Java spring cloud mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 游戏服务器 Minecraft ddos web安全 安全架构 vim cursor MCP server C/S LLM unity c# agi AIGC 计算机视觉 ansible playbook gpu算力 H3C AI编程 重启 排查 系统重启 日志 原因 uni-app redis 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 golang eureka 华为云 云原生 springsecurity6 oauth2 授权服务器 前后端分离 udp 面试 jdk intellij-idea 架构 html FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 go file server http server web server android studio 交互 集成学习 集成测试 监控k8s集群 集群内prometheus 代码调试 ipdb 远程连接 rdp 实验 远程工作 ssl tomcat Linux PID 消息队列 mongodb 机器人 医疗APP开发 app开发 UOS 统信操作系统 yum 编辑器 oceanbase rc.local 开机自启 systemd 深度优先 图论 并集查找 换根法 树上倍增 AI MNN DeepSeek Qwen 机器学习 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 chatgpt 大模型 llama3 Chatglm 开源大模型 大数据 xss pppoe radius arm开发 AI agent vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 jenkins java-ee react next.js 部署 部署next.js IDEA fpga开发 googlecloud bash 小程序 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP idm 向日葵 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 宝塔面板 同步 备份 建站 安全威胁分析 vscode 1.86 豆瓣 追剧助手 迅雷 nas 微信 内存 unity3d 目标检测 jvm aws 服务器繁忙 备选 网站 api 调用 示例 银河麒麟桌面操作系统 Kylin OS Agent postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 LDAP https 运维开发 IIS服务器 IIS性能 日志监控 maven intellij idea MQTT mosquitto 外网访问 内网穿透 端口映射 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 excel sqlite dubbo 多线程服务器 TCP服务器 qt项目 qt项目实战 qt教程 openssl 密码学 根服务器 kafka hibernate 爬虫 数据集 shell sqlserver 微服务 统信 国产操作系统 虚拟机安装 游戏程序 AI大模型 大模型入门 大模型教程 Dify ffmpeg 音视频 git 3d 数学建模 网络结构图 学习 apache 孤岛惊魂4 恒源云 tcp 权限 博客 mysql oneapi open webui Cursor Headless Linux pdf asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 华为认证 网络工程师 交换机 远程登录 telnet Linux网络编程 visualstudio zookeeper live555 rtsp rtp pygame 小游戏 五子棋 ios 驱动开发 嵌入式实习 WSL win11 无法解析服务器的名称或地址 armbian u-boot Cline Docker Compose docker compose docker-compose ecmascript nextjs reactjs URL ftp HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 MI300x openwrt TRAE Docker Hub docker pull 镜像源 daemon.json Linux ux 多线程 僵尸进程 搜索引擎 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 开发环境 SSL证书 Python 网络编程 聊天服务器 套接字 TCP 客户端 Socket stm32 源码剖析 rtsp实现步骤 流媒体开发 ci/cd GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 flash-attention 能力提升 面试宝典 技术 IT信息化 命令 远程控制 远程看看 远程协助 数据分析 MySql 前端框架 sentinel 中间件 visual studio code 边缘计算 mac 系统安全 CPU composer Xinference RAGFlow cpu 实时 使用 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 epoll 毕设 jupyter GCC Linux环境 相差8小时 UTC 时间 Linux的基础指令 鸿蒙 frp gitea 魔百盒刷机 移动魔百盒 机顶盒ROM 华为od OD机试真题 华为OD机试真题 服务器能耗统计 USB转串口 CH340 腾讯云大模型知识引擎 飞牛NAS 飞牛OS MacBook Pro 信号处理 信息与通信 ipython 邮件APP 免费软件 dns WSL2 三级等保 服务器审计日志备份 低代码 FTP服务器 课程设计 jina Ubuntu Server Ubuntu 22.04.5 VMware安装Ubuntu Ubuntu安装k8s k8s DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 企业微信 Linux24.04 deepin 多个客户端访问 IO多路复用 回显服务器 TCP相关API 程序 编程 性能分析 智能音箱 智能家居 bootstrap web 自动驾驶 软考 黑客 计算机 缓存 dify css unix XCC Lenovo 繁忙 解决办法 替代网站 汇总推荐 AI推理 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 CDN 烟花代码 烟花 元旦 实时互动 dba 压力测试 鲲鹏 昇腾 npu tailscale derp derper 中转 矩阵 线性代数 电商平台 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors deepseek r1 express 可信计算技术 网络攻击模型 王者荣耀 DOIT 四博智联 防火墙 NAT转发 NAT Server 1024程序员节 Unity Dedicated Server Host Client 无头主机 stm32项目 ip wsl n8n 工作流 workflow 硬件架构 make命令 makefile文件 webrtc 负载均衡 embedding selenium 测试工具 windows日志 devops iphone dity make 系统架构 okhttp 数据挖掘 list 数据结构 常用命令 文本命令 目录命令 鸿蒙系统 thingsboard postgresql VMware安装mocOS VMware macOS系统安装 安卓 HarmonyOS Next 端口测试 wireshark 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 iDRAC R720xd LORA 大语言模型 NLP 镜像 命名管道 客户端与服务端通信 ardunio BLE SSH 密钥生成 SSH 公钥 私钥 生成 freebsd r语言 glibc npm iventoy VmWare OpenEuler css3 图形化界面 ShenTong XFS xfs文件系统损坏 I_O error es 游戏引擎 抗锯齿 磁盘监控 iot navicat gcc iperf3 带宽测试 无人机 ROS dell服务器 zabbix mamba Vmamba elasticsearch 程序员 jar less 服务器主板 AI芯片 计算机外设 线程 MacOS录屏软件 openEuler 我的世界服务器搭建 asm Wi-Fi 超融合 minio Spring Security 我的世界 我的世界联机 数码 IMX317 MIPI H265 VCU ruoyi hadoop tidb GLIBC ISO镜像作为本地源 云电竞 云电脑 todesk c proxy模式 BMC IPMI 带外管理 视觉检测 职场和发展 AI-native Docker Desktop 微信小程序 yolov8 虚拟局域网 db jetty undertow bcompare Beyond Compare 模拟器 教程 智能手机 NAS Termux Samba 显卡驱动 rabbitmq ruby Erlang OTP gen_server 热代码交换 事务语义 tcpdump ui 远程桌面 gaussdb g++ g++13 DeepSeek行业应用 Heroku 网站部署 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 pip 策略模式 单例模式 实战案例 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 hugo GPU 思科模拟器 思科 Cisco HarmonyOS IM即时通讯 QQ 剪切板对通 HTML FORMAT 虚幻 apt 中兴光猫 换光猫 网络桥接 自己换光猫 ollama下载加速 kind AI写作 AI作画 ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS 聊天室 ocr 银河麒麟服务器操作系统 系统激活 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 单元测试 功能测试 KylinV10 麒麟操作系统 虚拟机 Vmware 算力 Radius onlyoffice P2P HDLC Windows muduo QT 5.12.12 QT开发环境 Ubuntu18.04 个人博客 X11 Xming prompt 双系统 GRUB引导 Linux技巧 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 其他 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 iBMC UltraISO 图像处理 cd 目录切换 EMQX 通信协议 换源 国内源 Debian HAProxy 技能大赛 rclone AList webdav fnOS aarch64 编译安装 HPC tensorflow junit SEO crosstool-ng 漏洞 显示管理器 lightdm gdm fd 文件描述符 远程 执行 sshpass 操作 阻塞队列 生产者消费者模型 服务器崩坏原因 树莓派 VNC laravel Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 vue matplotlib wps wsl2 grafana 直流充电桩 充电桩 历史版本 下载 安装 rnn SSH xpath定位元素 selete 高级IO p2p 多层架构 解耦 netty 网络穿透 云服务器 linux安装配置 safari Mac 系统 Nuxt.js Xterminal HTTP 服务器控制 ESP32 DeepSeek nvidia seatunnel 群晖 AD域 微信分享 Image wxopensdk 反向代理 致远OA OA服务器 服务器磁盘扩容 CORS 跨域 游戏机 etcd 数据安全 RBAC 嵌入式 linux驱动开发 Netty 即时通信 NIO 技术共享 实习 ue4 着色器 ue5 vasp安装 查询数据库服务IP地址 SQL Server 语音识别 AutoDL 加解密 Yakit yaklang 开机自启动 HCIE 数通 rag ragflow ragflow 源码启动 信号 code-server 模拟实现 SVN Server tortoise svn 数据可视化 小艺 Pura X gateway Clion Nova ResharperC++引擎 Centos7 远程开发 业界资讯 cuda cudnn anaconda 模拟退火算法 eclipse 大数据平台 Qwen2.5-coder 离线部署 银河麒麟高级服务器 外接硬盘 Kylin cocoapods xcode gradle threejs 3D lio-sam SLAM SenseVoice AISphereButler 金仓数据库 2025 征文 数据库平替用金仓 kamailio sip VoIP 5G 3GPP 卫星通信 ukui 麒麟kylinos openeuler ESXi Dell HPE 联想 浪潮 rust腐蚀 VR手套 数据手套 动捕手套 动捕数据手套 框架搭建 .net UDP的API使用 HiCar CarLife+ CarPlay QT RK3588 vSphere vCenter Node-Red 编程工具 流编程 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 av1 电视盒子 .net mvc断点续传 需求分析 规格说明书 温湿度数据上传到服务器 Arduino HTTP cnn GoogLeNet 7z springboot 升级 CVE-2024-7347 VPS 输入法 服务器管理 配置教程 服务器安装 网站管理 web3 linux 命令 sed 命令 autodl 软件定义数据中心 sddc big data Python基础 Python教程 Python技巧 雨云 NPS 飞书 IMM 工业4.0 echarts 传统数据库升级 银行 环境配置 LLMs rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK 单一职责原则 Claude IPMITOOL 硬件管理 opcua opcda KEPServer安装 AnythingLLM AnythingLLM安装 大模型微调 小智AI服务端 xiaozhi TTS k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm 合成模型 扩散模型 图像生成 iis 移动云 云服务 token sas hexo FTP 服务器 DevEco Studio OpenHarmony 真机调试 nfs can 线程池 SSL 域名 Kali rsyslog Anolis nginx安装 环境安装 linux插件下载 僵尸世界大战 游戏服务器搭建 ssh远程登录 毕昇JDK webstorm Trae IDE AI 原生集成开发环境 Trae AI redhat mcu linux上传下载 健康医疗 互联网医院 sdkman SWAT 配置文件 服务管理 网络共享 主板 电源 网卡 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 v10 软件 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 EasyConnect 半虚拟化 硬件虚拟化 Hypervisor prometheus数据采集 prometheus数据模型 prometheus特点 Kali Linux 渗透测试 信息收集 浏览器开发 AI浏览器 相机 黑客技术 micropython esp32 mqtt 软件工程 项目部署到linux服务器 项目部署过程 本地部署 ssrf 失效的访问控制 mysql离线安装 ubuntu22.04 mysql8.0 源码 毕业设计 Typore pgpool vscode1.86 1.86版本 ssh远程连接 SSE open Euler dde etl LLM Web APP Streamlit 田俊楠 网工 .netcore opensearch helm yaml Ultralytics 可视化 软链接 硬链接 outlook hive Hive环境搭建 hive3环境 Hive远程模式 WebUI DeepSeek V3 TrinityCore 魔兽世界 webgl sysctl.conf vm.nr_hugepages adobe elk 考研 在线office bug 文件系统 路径解析 视频编解码 流水线 脚本式流水线 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 efficientVIT YOLOv8替换主干网络 TOLOv8 Ubuntu 24.04.1 轻量级服务器 python3.11 dash 正则表达式 文件分享 log4j odoo 服务器动作 Server action 交叉编译 W5500 OLED u8g2 chfs ubuntu 16.04 环境迁移 rustdesk rocketmq 知识图谱 TCP协议 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR NFS 产测工具框架 IMX6ULL 管理框架 深度求索 私域 知识库 openstack Xen Logstash 日志采集 虚幻引擎 risc-v DocFlow 开发 gpt 串口驱动 CH341 uart 485 harmonyOS面试题 milvus ubuntu24 vivado24 软件需求 swoole 匿名管道 Invalid Host allowedHosts visual studio 自动化编程 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 干货分享 黑客工具 密码爆破 西门子PLC 通讯 k8s集群资源管理 云原生开发 RAGFLOW ros2 moveit 机器人运动 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 宕机切换 服务器宕机 hosts ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 链表 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 triton 模型分析 ubuntu24.04.1 压测 ECS Ark-TS语言 skynet iftop 网络流量监控 fast YOLOv12 大模型应用 OpenSSH 粘包问题 cmos 硬件 wsgiref Web 服务器网关接口 transformer uv 阿里云ECS IO模型 searxng IPv4 子网掩码 公网IP 私有IP 网络药理学 生物信息学 生信 PPI String Cytoscape CytoHubba ros 测试用例 PVE rime ceph camera Arduino 电子信息 服务器配置 Unity插件 Ubuntu共享文件夹 共享目录 Linux共享文件夹 firewall neo4j 程序员创富 nlp Jellyfin Google pay Apple pay Attention TrueLicense RAG 检索增强生成 文档解析 大模型垂直应用 DNS RAID RAID技术 磁盘 存储 LInux UDP 具身智能 强化学习 游戏开发 dock 加速 政务 分布式系统 监控运维 Prometheus Grafana 设备 PCI-Express VMware创建虚拟机 热榜 服务器时间 办公自动化 自动化生成 pdf教程 sqlite3 CentOS 大模型推理 大模型学习 信创 信创终端 中科方德 gpt-3 文心一言 语法 音乐服务器 Navidrome 音流 CentOS Stream ping++ 搭建个人相关服务器 EMUI 回退 降级 金融 gnu 网络用户购物行为分析可视化平台 大数据毕业设计 dns是什么 如何设置电脑dns dns应该如何设置 产品经理 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 蓝桥杯 MDK 嵌入式开发工具 论文笔记 sublime text kali 共享文件夹 arcgis 序列化反序列化 嵌入式Linux IPC 人工智能生成内容 pyautogui 拓扑图 架构与原理 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 运维监控 leetcode 推荐算法 离线部署dify springcloud 代理 灵办AI Redis Desktop bot Docker 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 edge浏览器 Deepseek-R1 私有化部署 推理模型 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 欧标 OCPP 物联网开发 clickhouse lua 社交电子 SSH 服务 SSH Server OpenSSH Server vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 元服务 应用上架 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 eNSP 企业网络规划 华为eNSP 网络规划 项目部署 trae 域名服务 DHCP 符号链接 配置 音乐库 飞牛 实用教程 软负载 多进程 langchain midjourney 裸金属服务器 弹性裸金属服务器 deekseek Open WebUI 分析解读 Cookie RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 状态管理的 UDP 服务器 Arduino RTOS deep learning Windsurf seleium chromedriver 自动化测试 ip命令 新增网卡 新增IP 启动网卡 风扇控制软件 mariadb MacMini 迷你主机 mini Apple 宠物 免费学习 宠物领养 宠物平台 执法记录仪 智能安全帽 smarteye minicom 串口调试工具 PX4 车载系统 SysBench 基准测试 影刀 #影刀RPA# 流量运营 MS Materials mybatis EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 系统开发 binder framework 源码环境 flink 信息可视化 网页设计 华为机试 数据库系统 C# MQTTS 双向认证 emqx figma docker命令大全 x64 SIGSEGV xmm0 CLion 做raid 装系统 llama.cpp remote-ssh 内网服务器 内网代理 内网通信 AI Agent 字节智能运维 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 curl wget bat 端口 查看 ss 火绒安全 firewalld docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 uniapp keepalived 剧本 sonoma 自动更新 xshell termius iterm2 RTMP 应用层 数据仓库 数据库开发 database uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 trea idea 状态模式 rpa docker run 数据卷挂载 交互模式 ArcTS 登录 ArcUI GridItem arkUI 服务网格 istio js 大模型面经 自动化任务管理 chrome devtools VS Code easyui 基础环境 spark HistoryServer Spark YARN jobhistory Linux find grep 键盘 AD 域管理 ubuntu20.04 开机黑屏 网站搭建 serv00 飞牛nas fnos grub 版本升级 扩容 wpf 微信开放平台 微信公众号配置 VSCode 本地知识库部署 DeepSeek R1 模型 yum源切换 更换国内yum源 沙盒 word VLAN 企业网络 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 服务器部署ai模型 多路转接 linux环境变量 vr 鸿蒙开发 移动开发 嵌入式系统开发 代理服务器 raid5数据恢复 磁盘阵列数据恢复 自定义客户端 SAS 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 图形渲染 黑苹果 GIS 遥感 WebGIS minecraft sequoiaDB 大大通 第三代半导体 碳化硅 捆绑 链接 谷歌浏览器 youtube google gmail ai工具 USB网络共享 java-rocketmq ldap Playwright vmware 卡死 Kylin-Server 分布式训练 Linux的权限 内网环境 h.264 ssh漏洞 ssh9.9p2 CVE-2025-23419 远程服务 RustDesk自建服务器 rustdesk服务器 docker rustdesk 流式接口 conda配置 conda镜像源 李心怡 pyqt alias unalias 别名 WebRTC DBeaver win服务器架设 windows server 混合开发 JDK AI代码编辑器 regedit 开机启动 迁移指南 大模型部署 docker部署Python 网卡的名称修改 eth0 ens33 nac 802.1 portal cpp-httplib xrdp SRS 流媒体 直播 本地化部署 centos-root /dev/mapper yum clean all df -h / du -sh ABAP 京东云 基础入门 崖山数据库 YashanDB kerberos 私有化 DenseNet 存储维护 NetApp存储 EMC存储 玩机技巧 软件分享 软件图标 性能测试 CrewAI Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 雨云服务器 perf