【Nginx22】Nginx学习:FastCGI模块(四)错误处理及其它

Nginx学习:FastCGI模块(四)错误处理及其它

FastCGI 最后一篇,我们将学习完剩下的所有配置指令。在这里,错误处理还是单独拿出来成为一个小节了,而剩下的内容都放到其它中进行学习。不要感觉是其它的就没用了,有些配置指令还是非常重要的哦,或许正好你现在的项目就能用上呢。

今天学习的内容都是可以设置在 http、server、location 中的,有特殊情况的我会单独说。

错误处理

FastCGI 模块的错误处理可不是 error_page 那种指定跳转页面什么的,当然,也有一个和它相关的配置,之前我们就学过了。其它大部分的配置,其实是假设万一连接的后端服务器出现问题了该怎么办的,这里也会牵涉到一点 upstream 相关的内容,这一块我们后面还会细说,主线还是先看看 FastCGI 模块是怎么处理这些问题的吧。

fastcgi_next_upstream

指定在哪些情况下应将请求传递给下一个服务器。

fastcgi_next_upstream error | timeout | invalid_header | http_500 | http_503 | http_403 | http_404 | http_429 | non_idempotent | off ...;

默认值是 error timeout; 每个参数的意思其实也比较明显,就是遇到这些指定的情况时,要不要将请求转发给下一个 upstream 中配置的 server 。

  • error 与服务器建立连接、向其传递请求或读取响应标头时发生错误

  • invalid_header 服务器返回空响应或无效响应

  • http_xxx 返回指定的状态码,比如 http_500 就是 PHP 那边返回了 500 状态码时

  • non_idempotent 通常如果请求已发送到上游服务器(1.9.13),则使用非幂等方法(POST、LOCK、PATCH)的请求不会传递到下一个服务器,显式启用此选项允许重试此类请求

  • 禁止将请求传递到下一个服务器

这个测试比较麻烦,我们需要再启动一个 PHP-FPM ,然后在 Nginx 的 http 模块下配置一下 upstream ,也就是服务器组,这个具体内容我们会在后面服务器组模块的学习中学到,这个模块的内容就是 Nginx 负载均衡的配置。

# 再启动一个PHP,需要修改php-fpm.conf及php-fpm.d/www.conf里面的内容,比如 listen 部分和 pid 部分
# 然后执行一下 php-fpm 就可以了# http 模块下
upstream fcgicache {server unix:/var/sock/php-fpm/www.sock;server unix:/var/sock/php-fpm/www2.sock;
}

启动多个 PHP-FPM 这里不多解释了,不会的小伙伴可以查下资料或者到时候看视频哈。然后再修改 Nginx 配置中 fastcgi_pass 指向这个新的服务器组。

fastcgi_pass fcgicache;

默认配置中的 error 这个选项,其实就已经帮我们处理掉 502 这种连接问题了,比如说这时候我们 kill 掉一个 PHP-FPM 进程,但是程序依然可以正常响应,也就是说,一般的 502 这种连接错误是 error 处理的。那么要如何检测其它的错误情况下 fastcgi_next_upstream 的效果呢?我们可以在 php 文件中进行修改。

// 3.php
echo posix_getpid();
if (posix_getpid() < 1648){throw new Exception("错了");
}

posix_getpid() 是 PHP 的 Posix 扩展中的函数,如果没有话可以自己装一下。它可以获取到我们当前执行的进程 ID ,查看进程情况,

[root@localhost phpfpm2]# ps -ef | grep php
root      1640     1  0 09:47 ?        00:00:00 php-fpm: master process (/root/phpfpm2/php-fpm.conf)
www       1641  1640  0 09:47 ?        00:00:00 php-fpm: pool www
www       1642  1640  0 09:47 ?        00:00:00 php-fpm: pool www
www       1643  1640  0 09:47 ?        00:00:00 php-fpm: pool www
www       1644  1640  0 09:47 ?        00:00:00 php-fpm: pool www
www       1645  1640  0 09:47 ?        00:00:00 php-fpm: pool www
root      1648     1  0 09:47 ?        00:00:00 php-fpm: master process (/etc/php-fpm.conf)
www       1649  1648  0 09:47 ?        00:00:00 php-fpm: pool www
www       1650  1648  0 09:47 ?        00:00:00 php-fpm: pool www
www       1651  1648  0 09:47 ?        00:00:00 php-fpm: pool www
www       1652  1648  0 09:47 ?        00:00:00 php-fpm: pool www
www       1653  1648  0 09:47 ?        00:00:00 php-fpm: pool www

可以看到两个 php-fpm 进程的情况,上面 PHP 代码的意思就是小于 php-fpm: master process (/etc/php-fpm.conf) 这个进程 ID 的进程,也就是另外一个 PHP-FPM 的进程处理时,都抛出一个异常。直接抛出异常就是 500 错误,500 错误是需要单独的 http_500 来配置的。

在没有配置 fastcgi_next_upstream http_500 的情况下,刷新页面,会一下 500 ,一下正常,这是因为 upstream 默认情况下是轮询的,这个以后我们也会细说。现在,配置上 fastcgi_next_upstream 。

fastcgi_next_upstream error http_500;

再次不停地刷新,页面始终会返回 200 ,而错误日志中,会有 FastCGI 的错误信息。

2022/08/25 10:07:31 [error] 1720#0: *110 FastCGI sent in stderr: "PHP message: PHP Fatal error:  Uncaught Exception: 错了
……………………

注意,这个配置项不是追加的,比如上面如果我们只设置了 http_500 ,那么之前说的 kill 掉某个 PHP-FPM 转发跳转的效果就没有了。大家可以自己试试哦。

应该记住,只有在尚未向客户端发送任何内容的情况下,才有可能将请求传递给下一个服务器。也就是说,如果在传输响应的过程中发生错误或超时,则无法解决此问题。该指令还定义了与服务器通信的不成功尝试。错误、超时和 invalid_header 的情况总是被认为是不成功的尝试,即使它们没有在指令中指定。 http_500、http_503 和 http_429 的情况仅在指令中指定时才被视为不成功的尝试。 http_403 和 http_404 的情况永远不会被认为是不成功的尝试。将请求传递到下一个服务器可能会受到尝试次数和时间的限制。

最后,有啥用?其实通过这个,就可以实现 PHP-FPM 的负载均衡,只要有一个 PHP-FPM 存在,服务就可以一直提供,PHP-FPM 使用 TCP 端口形式也是可以分布到不同的主机或者 Docker 中的,并且可以实现不同的版本或者版本的平滑升级。

fastcgi_next_upstream_timeout

限制可以将请求传递到下一个服务器的时间。

fastcgi_next_upstream_timeout time;

默认 0 表示关闭此限制。

fastcgi_next_upstream_tries

限制将请求传递到下一个服务器的可能尝试次数。

fastcgi_next_upstream_tries number;

默认是 0 ,表示不限制。

fastcgi_catch_stderr

设置要在从 FastCGI 服务器接收到的响应的错误流中搜索的字符串。

fastcgi_catch_stderr string;

如果找到指定的字符串,则认为 FastCGI 服务器返回了无效响应。这允许在 nginx 中处理应用程序错误,例如:

location /php/ {fastcgi_pass backend:9000;...fastcgi_catch_stderr "PHP Fatal error";fastcgi_next_upstream error timeout invalid_header;
}

其实呀,就是我们上面学习过的 fastcgi_next_upstream ,只不过不是根据状态码,如果在响应字符串中有相应的内容被捕获到了,就直接走 fastcgi_next_upstream 的处理了。由于我们都是在一台机器上的 PHP-FPM ,一个输出错误了别的也是输出错误,也就测不出什么效果,有兴趣的小伙伴可以使用跨服务器的 IP Socket 方式连接 PHP 进行测试。

fastcgi_intercept_errors

确定代码大于或等于 300 的 FastCGI 服务器响应是否应传递给客户端或被拦截并重定向到 nginx 以使用 error_page 指令进行处理。

fastcgi_intercept_errors on | off;

默认值是 off 。之前在学习 error_page 时用过,也介绍过啦。注意,fastcgi_next_upstream 如果同时存在,并且 fastcgi_next_upstream 里面有正常响应的,那么会走正常响应的,如果所有的 upsteam 都返回错误,就会按这边的配置。

其它配置

剩下的就是一些不太好划分大类的配置指令了。说实话,很多闻所未闻,根本就没见过,而且平常配置的时候可能真的不太用得上。但是,说实话,很涨知识哦,特别是 PATH INFO 部分,我也是边查资料边学习的,以前还以为这只是 TP 特有的东西,原来是 TP 遵循的 PATH INFO 规范。怎么样,感兴趣了吧?别急,咱们一个一个来看。

fastcgi_connect_timeout

定义与 FastCGI 服务器建立连接的超时时间。

fastcgi_connect_timeout time;

默认是 60s ,通常不超过 75 秒。注意,它是 Nginx 和 PHP-FPM 建立通讯的时间,不是说我们们在 PHP 中 sleep() 一下就可以测出来的。是 TCP 建立连接的超时时间。

fastcgi_force_ranges

启用对来自 FastCGI 服务器的缓存和未缓存响应的字节范围支持,无论这些响应中的“Accept-Ranges”字段如何。

fastcgi_force_ranges on | off;

默认值是 off ,具体作用不清楚,有了解的小伙伴可以评论留言哦。

fastcgi_bind

与 FastCGI 服务器的传出连接源自具有可选端口 (1.11.2) 的指定本地 IP 地址。

fastcgi_bind address [transparent] | off;

看不懂上面的解释吧?我也看不懂,于是查了一下,它是指定 Nginx 与 FastCGI 通信的 IP 地址,一般不做设置。指令在调用 connect() 函数之前将解析每个上游 socket 到一个本地地址,可以使用在主机拥有多个网卡接口或别名的情况下,但是你只允许到外部的连接来自指定的网卡或者地址的情况下。 与回环 IP 地址通信,需要设置路由表。

好嘛,一般不做设置,而且还是看不懂,更重要的是,我不知道咋测。就这样吧,具体的解释官方文档上还有不少,不过纯英文的。查到的解释大部分也就是上面那一句话,那么我也重复我之前经常说过的话,不懂就别瞎设置,期待有大佬用过或者明白啥意思的能够用更通俗的话在评论里解释一下,让大家一起学习下哈。

fastcgi_ignore_client_abort

确定当客户端关闭连接而不等待响应时是否应关闭与 FastCGI 服务器的连接。

fastcgi_ignore_client_abort on | off;

默认是关闭的。

fastcgi_keep_conn

默认情况下,FastCGI 服务器将在发送响应后立即关闭连接。

fastcgi_keep_conn on | off;

当这个指令设置为 on 时,nginx 将指示 FastCGI 服务器保持连接打开。这对于到 FastCGI 服务器的 keepalive 连接来说是必要的。我们之前学习过 Nginx 在处理和客户端的连接时的长连接问题,对于和 FastCGI 的通信,也是可以通过长连接进行连接的。

fastcgi_limit_rate

限制从 FastCGI 服务器读取响应的速度。

fastcgi_limit_rate rate;

默认 0 表示不限制 ,速率以每秒字节数指定。该限制是针对每个请求设置的,因此如果 nginx 同时打开两个到 FastCGI 服务器的连接,则总体速率将是指定限制的两倍。仅当启用了来自 FastCGI 服务器的响应缓冲时,该限制才有效。和 Nginx 普通的 limit_rate 参数是一样的,只不过这是针对后端服务器的。

fastcgi_pass_request_body

指示是否将原始请求正文传递给 FastCGI 服务器。

fastcgi_pass_request_body on | off;

默认值是 on ,关了之后在 PHP 这边就拿不到 $_POST 里的东西啦!

fastcgi_pass_request_headers

指示是否将原始请求的标头字段传递给 FastCGI 服务器。

fastcgi_pass_request_headers on | off;

默认值是 on ,和上面的一样,关了 PHP 中就拿不到 header 里面的内容了。这个可以直接打印 $_SERVER查看。

fastcgi_request_buffering

启用或禁用客户端请求正文的缓冲。

fastcgi_request_buffering on | off;

默认值是 on ,表示在将请求发送到 FastCGI 服务器之前,会从客户端读取整个请求正文。

当缓冲被禁用时,请求正文在收到后立即发送到 FastCGI 服务器。在这种情况下,如果 nginx 已经开始发送请求正文,则无法将请求传递给下一个服务器。

貌似和 fastcgi_next_upstream 有关系,但是不知道怎么测试,有了解的小伙伴评论留言哈。

fastcgi_send_lowat

如果该指令设置为非零值,nginx 将尝试使用 kqueue 方法的 NOTE_LOWAT 标志或 SO_SNDLOWAT 套接字选项,使用指定的大小来最小化到 FastCGI 服务器的传出连接上的发送操作数。

fastcgi_send_lowat size;

好巧不巧,它的默认值就是 0 ,意思也就是不开启的,具体功能和如何测试我也不太清楚,反正不懂就不要设置了,有了解这个配置的小伙伴评论留言哦。

fastcgi_send_timeout

设置将请求传输到 FastCGI 服务器的超时时间。

fastcgi_send_timeout time;

默认值是 60s ,超时仅在两个连续的写操作之间设置,而不是为整个请求的传输设置。如果 FastCGI 服务器在这段时间内没有收到任何内容,则关闭连接。

fastcgi_socket_keepalive

为到 FastCGI 服务器的传出连接配置“TCP keepalive”行为。

fastcgi_socket_keepalive on | off;

它的默认值是 off ,在默认情况下,操作系统的设置对套接字有效。如果该指令设置为值“on”,则为套接字打开 SO_KEEPALIVE 套接字选项。好吧,又是网络基础知识中的,不知道咋测,但很明显,它是是否在和 FastCGI 绑定的后端之间进行通信的 TCP 是否启用长连接的一个设置。这个长连接和 HTTP 的长连接的概念是相同的,无非就是减少建立连接时的消耗从而提升性能。但是不懂就别乱动,保持默认就好,同时还是更希望有接触过的小伙伴可以来释疑一下哈。

网上能够搜到同时开启 fastcgi_socket_keepalive 和 fastcgi_keep_conn 之后会产生一些问题,可能的解决方案是要将 PHP-FPM 的 pm.max_requests 设置成和 keepalive_requests 相同的值。不过我没遇到过,也不知道真假哈,先记录一下,万一将来遇到了就可以试试,可能的报错信息是这样的:

readv() failed (104: Connection reset by peer) while reading upstream and recv() failed (104: Connection reset by peer) while reading response header from upstream

fastcgi_split_path_info

定义一个捕获 $fastcgi_path_info 变量值的正则表达式。

fastcgi_split_path_info regex;

正则表达式应该有两个捕获:第一个成为 $fastcgi_script_name 变量的值,第二个成为 $fastcgi_path_info 变量的值。

之前我们学过了 $fastcgi_script_name 是干嘛的,有点像静态页面中的 $uri 变量,返回的都是访问的路径。不过针对 FastCGI ,还提供了一个变量 $fastcgi_path_info,可以用于实现 PATH INFO 能力。这个东西其实是 PHP 用得比较多的,通过 PATH INFO 实现伪静态。最常见的就是 TP 框架的 http://xxxx.com/index.php/xxx/xx 这种路径。不过一般我们会通过 Nginx 的 rewrite 重写去掉中间的 index.php 。最后的请求 URL 就是 http://xxxx.com/xxx/xx 这样的。

我们可以这样配置一个。

fastcgi_split_path_info  ^(.+\.php)(.*)$;return 200 $uri+++$fastcgi_script_name+++$fastcgi_path_info;

然后请求配置了这个参数的路径,比如这里是 http://192.168.56.88/fastcgi4/5.php/ppp/hhh 就会看到返回的结果中 $fastcgi_path_info 变量的值是 /ppp/hhh 。默认情况下它是没有值的,如果想把这个值传给 PHP 的话,就可以加一个 fastcgi_param 。

fastcgi_param PATH_INFO $fastcgi_path_info;

这样在 PHP 中,就可以在 $_SERVER 中看到 PATH_INFO 这个属性了。

在 TP6 中,如果使用 fastcgi_split_path_info ,那么就可以不用再配置官网那个 rewrite 的方式来实现 PATH INFO 路径了。

location / { // …..省略部分代码if (!-e $request_filename) {rewrite  ^(.*)$  /index.php?s=/$1  last;}
}

官网这个配置其实是对于不支持 PATH INFO 的服务器,比如老版本的 Nginx 而采用的一种跳转回兼容模式的方式来实现的 PATH INFO 效果。同时还可以去除 index.php 。我们不使用它,直接使用下面这个配置。

location ~ \.php {fastcgi_pass   127.0.0.1:9000;fastcgi_index  index.php;fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;include        fastcgi_params;fastcgi_split_path_info  ^(.+\.php)(.*)$;fastcgi_param PATH_INFO $fastcgi_path_info;
}

注意,要把 location 默认正则中的最后一个 $ 去掉哦,或者换成 \.php(.*)$ 之前默认的是 location ~ \.php$ 这个样子的。然后就可以直接通过完全的 PATH INFO 来使用 TP 了,不需要再配官方文档那个 rewrite 的指令。不过,需要注意的是 PATH INFO 是有 index.php 的,要想去除 index.php ,还是得 rewrite ,所以,说实话,还是老实用之前那种形式吧。但如果启用了 PATH INFO ,则 rewrite 可以换个写法 rewrite ^(.*)$ /index.php$1 last; ,因为我们不需要使用 TP 的兼容模式了,也就不需要那个名为 s 的 GET 参数了。

而对于 Laravel 框架来说,则走的不是 PATH INFO 模式,它是根据 $request_uri 通过 fastcgi_param 传递到 PHP 的 $_SERVER 中的 REQUEST_URI 来进行路由解析分析的,所以它在 Nginx 的配置中,rewrite 只需要指向 /index.php 就可以了,不需要像 TP 那样还要带个 s 参数。Laravel 是这样的:

location / {if (!-e $request_filename) {rewrite  ^(.*)$  /index.php  last;}
}

也就是说,使用 Laravel 时不用考虑 PATH INFO 的问题。

fastcgi_store

允许将文件保存到磁盘。

fastcgi_store on | off | string;

默认值是 off ,on 参数保存具有与指令别名或根目录相对应的路径的文件。 off 参数禁用保存文件。此外,可以使用带有变量的字符串显式设置文件名。

根据收到的“Last-Modified”响应头域设置文件的修改时间。响应首先被写入一个临时文件,然后文件被重命名。从版本 0.8.9 开始,临时文件和持久存储可以放在不同的文件系统上。但是,请注意,在这种情况下,文件是跨两个文件系统复制的,而不是廉价的重命名操作。因此建议对于任何给定的位置,保存的文件和保存临时文件的目录(由 fastcgi_temp_path 指令设置)放在同一个文件系统上。

该指令可用于创建静态不可更改文件的本地副本。

简单按照官网的例子试了下,好像没啥明显的效果,去百度、Google也没找到有啥资料,只有一篇文章说不要开,会影响性能。好吧,还是希望有相关经验的小伙伴评论留言一起学习哦!

fastcgi_store_access

为新创建的文件和目录设置访问权限。

fastcgi_store_access users:permissions ...;

默认值是 user:rw ,如果指定了任何组或所有访问权限,则可以省略用户权限。

总结

错误处理中我们见到了 FastCGI 也是可以做负载均衡的,说实话,带 pass 这个词的,在 Nginx 中其实都可以做负载均衡,因为它们其实都是一个意思,通过(代理)到某个地方。最后在其它部分,PATH INFO 这一块的知识对我来说确实是收获非常大,别看干了这么久,而且也用过 TP ,但直到今天才真的明白 TP 文档中关于 URL 路径这里讲的是啥意思,惭愧啊。

好了,到此为止,整个 FastCGI 相关的模块就学习完了。怎么样,之前说过的学习 Nginx 就是在挑战我们的基础知识水平,这话一点都没错吧。很多东西我也不知道,但是学习文档,特别是写文章的时候,为了要表述清楚,就需要查询更多的相关资料,自然而然地顺带学习到了更多的知识。而且,这样学习的效果更好。之前在小视频和一些文章中也提过,这就是费曼学习法,坚持下去就是最大的收获,大家也可以尝试一下哦。

最后再强调一遍,uwsgi 和 FastCGI 的很多内容很像,后面也不会单独再写 uwsgi 部分的内容了,有 Python 同学或者其它语言的同学使用 uwsgi 的可以自己参考一下官方文档进行学习。

参考文档:

http://nginx.org/en/docs/http/ngx_http_fastcgi_module.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/63179.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android system_server WatchDog简介

简介 android系统中SystemServer WatchDog的主要作用是监控SystemServer进程的运行状态,防止其卡住或者死锁。 具体来说,watchDog线程会定期去检查SystemServer线程的运行情况。如果发现SystemServer线程超过一定时间未有响应,watchDog会认为SystemServer进程发生了问题,这时…

手写Openfeign实现原理——极简版

文章目录 前言Openfeign实现思路前期准备基本依赖项 开始实现自定义注解自定义代理类定义创建代理对象的工厂InstantiationAwareBeanPostProcessor实现bean的注入OpenInstantiationAwareBeanPostProcessor 自定义 feign接口启动类小结 踩坑记录ImportComponent和Configuration区…

HTTP与SOCKS5的区别对比

在互联网世界中&#xff0c;服务器是一种重要的工具&#xff0c;可以帮助我们提高网络安全性等。今天&#xff0c;我们将重点关注两种常见的技术&#xff1a;HTTP和SOCKS5。让我们深入了解它们的工作原理、用途和优缺点&#xff0c;并通过Python代码示例学习如何使用它们。 HT…

一文了解tcp/ip协议的运行原理

接触代理ip的人都了解https/sock5等ip协议&#xff0c;那么TCP/IP 协议又是什么&#xff1f; 一、什么是TCP/IP 协议&#xff1f; TCP/IP 协议实际上是一系列网络通信协议的一个统称&#xff0c;他负责具体的数据传输工作&#xff0c;核心的两个协议包括TCP以及IP&#xff0c…

Unity3D 如何在ECS架构下,用Unity引擎进行游戏开发详解

前言 Unity3D是一款强大的游戏引擎&#xff0c;它提供了丰富的功能和工具&#xff0c;可以帮助开发者快速构建高质量的游戏。而Entity Component System&#xff08;ECS&#xff09;是Unity3D中一种新的架构模式&#xff0c;它可以提高游戏的性能和可扩展性。本文将详细介绍在…

Flink 如何定位反压节点?

分析&回答 Flink Web UI 自带的反压监控 —— 直接方式 Flink Web UI 的反压监控提供了 Subtask 级别的反压监控。监控的原理是通过Thread.getStackTrace() 采集在 TaskManager 上正在运行的所有线程&#xff0c;收集在缓冲区请求中阻塞的线程数&#xff08;意味着下游阻…

Redis数据结构总结

Redis 是一款开源的&#xff0c;内存中的数据结构存储系统&#xff0c;它可以用作数据库、缓存和消息代理。Redis 支持多种类型的数据结构&#xff0c;如字符串&#xff08;String&#xff09;、哈希&#xff08;Hashes&#xff09;、列表&#xff08;Lists&#xff09;、集合&…

vue3的面试题

ref里面放对象发生的事情 ref只会对对象的属性进行响应式转换&#xff0c;而不会对对象的原型链上的属性进行转换。如果需要对对象的原型链上的属性进行响应式转换&#xff0c;可以使用reactive函数。 toRefs的适用场景&#xff1f; toRefs是Vue 3中的一个响应式API&#xf…

使用环境中的视觉地标和扩展卡尔曼滤波器定位移动机器人研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

SQL高阶语句

目录 1、概念 1.1、概述 1.2、常见的MySQL高阶语句的概念&#xff1a; 1.3、 SQL高阶语句的作用 2、常用查询 2.1、按关键字排序 2.1.1、概述和作用 2.1.2、 &#xff08;1&#xff09;语法 2.1.3、模板表&#xff1a;ky30 ​编辑2.1.4、分数按降序排列 2.1.5、ORDER…

Kafka环境搭建与相关启动命令

一、Kafka环境搭建 点击下载kafka_2.11-2.3.1.tgz文件链接 1、上传kafka_2.11-2.3.1.tgz&#xff0c;解压kafka_2.11-2.3.1.tgz&#xff0c;得到kafka_2.11-2.3.1文件夹 1&#xff09;上传 #使用mobaxterm将 kafka_2.11-2.3.1.tgz 传入tools文件夹 #用下面代码进入tools文件…

Python -【Socket select】基本使用介绍

一. 前言 在Python中&#xff0c;select 是一个用于异步I/O多路复用的模块。它提供了一种简单的方法&#xff0c;用于监视多个文件描述符&#xff08;file descriptor&#xff09;&#xff0c;以确定其中哪些文件描述符已经就绪可读、可写或者发生了异常。使用 select 模块可以…

SPSS统计作图教程:频率多边形

SPSS统计作图教程&#xff1a;频率多边形 1、问题与数据 某研究者想了解某数据集中最大携氧能力&#xff08;VO2max&#xff09;是否服从正态分布&#xff0c;部分数据如图1。研究者应如何绘图查看呢&#xff1f; 图1 部分数据 2、对问题的分析 研究者想绘图展示最大携氧能…

深入理解 JVM 之——Java 内存区域与溢出异常

更好的阅读体验 \huge{\color{red}{更好的阅读体验}} 更好的阅读体验 本篇为深入理解 Java 虚拟机第二章内容&#xff0c;推荐在学习前先掌握基础的 Linux 操作、编译原理、计算机组成原理等计算机基础以及扎实的 C/C 功底。 该系列的 GitHub 仓库&#xff1a;https://github…

go学习part20(1)反射

283_尚硅谷_反射基本介绍和示意图_哔哩哔哩_bilibili 1.介绍 1&#xff09;基本数据类型的类型和类别一致&#xff0c;但是结构体等不一样。 2)反射的例子&#xff08;桥连接&#xff0c;序列化&#xff09; 序列化指定tag&#xff0c;会反射生成tag字符串 3&#xff09;refl…

Vue在表格中拿到该行信息的方式(作用域插槽-#default-scope-解决按钮与行点击的顺序问题)

遇到的问题 在做表格的时候&#xff0c;表格是封装好了的&#xff0c;用于展示数据。如果想给单行增加按钮&#xff0c;可以单独写一列存放按钮&#xff0c;最基本的需求是&#xff0c;点击按钮后要拿到数据然后发起请求。 且Vue的element-plus&#xff0c;当我们点击按钮之后…

Linux挖矿程序清除

1. 找到挖矿进程 2.找到病毒的文件地址 ls -l /proc/进程ID/exe3.删除文件命令 rm -rf 文件地址4.杀死挖矿进程 kill -9 进程ID

11 mysql float/double/decimal 的数据存储

前言 这里主要是 由于之前的一个 datetime 存储的时间 导致的问题的衍生出来的探究 探究的主要内容为 int 类类型的存储, 浮点类类型的存储, char 类类型的存储, blob 类类型的存储, enum/json/set/bit 类类型的存储 本文主要 的相关内容是 float, decimal 类类型的相关数据…

15. 卡牌游戏

目录 题目 思路 C整体代码&#xff08;含详细注释&#xff09; 题目 Description 小张在玩一种卡牌游戏&#xff0c;牌组由张牌组成&#xff0c;其中张上写有数字各一张&#xff0c;其余张上全部是数字。 现在牌组经过随机打乱后&#xff0c;小张拿走其中张牌作为手牌&#…

【方案】基于视频与AI智能分析技术的城市轨道交通视频监控建设方案

一、背景分析 地铁作为重要的公共场所交通枢纽&#xff0c;流动性非常高、人员大量聚集&#xff0c;轨道交通需要利用视频监控系统来实现全程、全方位的安全防范&#xff0c;这也是保证地铁行车组织和安全的重要手段。调度员和车站值班员通过系统监管列车运行、客流情况、变电…