Nginx运维常用技术点总结

news2025/1/4 19:16:04

文章目录

    • 一、简介:
      • 1、Nginx简介
      • 2、常用四大发行版
    • 二、Nginx编译安装:
      • 1、Nginx编译安装
      • 2、Nginx目录结构
      • 3、Nginx 相关命令
    • 三、Nginx配置文件解析
      • 1、最小配置
      • 2、虚拟主机
      • 3、匹配正则表达式
    • 四、Nginx反向代理
      • 1、理论
      • 2、实践:Nginx反代代理Tomcat
    • 五、Nginx负载均衡
      • 1、实践:Nginx负载均衡Tomcat
      • 2、负载均衡策略
    • 六、Nginx + Keepalived 高可用
      • 1、环境说明
      • 2、实践
    • 七、Nginx证书认证
      • 1、SSL证书配置
      • 2、rewrite地址重写
    • 八、Nginx平滑升级
      • 1、Nginx平滑升级原理
      • 2、实践:1.16版本 升级到 1.18版本
      • 3、升级失败 回滚操作
      • 4、遇到问题
    • 九、Nginx 优化方案
    • 十、扩展
      • 1、网站返回码
      • 2、URL和URI的区别
      • 3、F12网络返回参数
      • 4、curl 常用测试参数

一、简介:

1、Nginx简介

Nginx是一款免费且开源的Web服务器项目,常用来做、Web服务器、反向代理服务器、负载均衡服务器。特点如下:

  • 免费且开源:免费试用,开放源代码。
  • 轻量级且模块化:消耗内存少、保留核心模块、不需要全部安装、支持第三方模块。
  • 高性能:Nginx支持很高的并发 。
  • 热部署:在不重启Web服务器时升级、或者添加新模块等。

2、常用四大发行版

Nginx开源版官网:

Nginx plus 商业版官网:

Openresty官网:

Tengine官网:

Openresty:是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。

Tengine:是由淘宝网发起的Web服务器项目。它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性。

二、Nginx编译安装:

1、Nginx编译安装

1、依赖环境安装

yum -y install pcre-devel pcre gcc gcc-c++ zlib zlib-devel openssl openssl-devel

# gcc: C语言编辑器 nginx是C语言编写的 所以需要C环境
# pcre: 支持正则表达式
# openssl: 支持HTTPS加密协议
# zlib: 支持数据包头压缩

2、编译安装

wget http://nginx.org/download/nginx-1.18.0.tar.gz

tar xf nginx-1.18.0.tar.gz -C /usr/src/
cd /usr/src/nginx-1.18.0/

./configure --prefix=/usr/local/nginx --with-http_ssl_module 
make && make install

3、启动

cd /usr/local/nginx/sbin/
./nginx

netstat -anput | grep 80

4、防火墙设置

firewall-cmd --add-port=80/tcp --permanent
firewall-cmd --add-service=http --add-service=https --permanent 
firewall-cmd --reload 

5、验证

浏览器访问 自己的IP地址即可!

2、Nginx目录结构

/usr/local/nginx                 # 服务安装目录
/usr/local/nginx/sbin            # 服务主程序目录
/usr/local/nginx/sbin/nginx      # 服务程序文件
/usr/local/nginx/conf            # 服务主配置文件目录
/usr/local/nginx/logs/           # 服务日志文件目录
/usr/local/nginx/logs/nginx.pid  # 服务pid文件
/usr/local/nginx/logs/error.log  # 服务错误日志文件
/usr/local/nginx/logs/access.log # 服务访问日志文件

3、Nginx 相关命令

/usr/local/nginx/sbin/nginx             # 启动nginx
/usr/local/nginx/sbin/nginx -v          # 小写v查看nginx版本信息
/usr/local/nginx/sbin/nginx -V          # 大写V除版本信息外还显示配置参数信息
/usr/local/nginx/sbin/nginx -t          # 检查nginx配置文件是否正确
/usr/local/nginx/sbin/nginx -s reload   # 重新加载nginx
/usr/local/nginx/sbin/nginx -s quit     # 正常关闭nginx
/usr/local/nginx/sbin/nginx -s stop     # 快速关闭nginx

quit 和 stop 的区别:

  • quit:当nginx服务已经启动,想要停止服务可以使用quit信号正常停止服务,quit信号并不会立即停止 服务,而是先不接收新的请求,但是会先处理完已经接收的连接后在停止服务,这种停止的方式被称为 ”优雅 的停止“
  • stop:当nginx服务已经启动,想要停止服务可以使用stop信号快速停止服务,stop信号会立即停止服 务,这种停止服务的方式被称为 ”暴力停止“

三、Nginx配置文件解析

1、最小配置

去除Nginx配置文件中的注释等内容 -r 支持正则 -i.bak备份

sed  -r -i.bak '/(^$|^#|#)/d' nginx.conf
worker_processes  1;           # worker工作进程数

events {
    worker_connections  1024;  # 每个worker进程可以创建的连接数
}

http {
    include       mime.types;   # 解析类型定义 
    default_type  application/octet-stream;  # 默认解析类型
    
    sendfile        on;         # 减少Copy的过程
    keepalive_timeout  65;      # 保持连接超时时间
    
    server {                    # 虚拟主机 vhost
        listen       80;        # 监听端口号 
        server_name  localhost; # 主机名、域名
        
        location / {            # 根据规则匹配URL  
            root   html;        # 网页主目录 nginx根目录中的html
            index  index.html index.htm;  # 默认页
        }
        
        error_page   500 502 503 504  /50x.html;   # 错误网页指定
        location = /50x.html {                  
            root   html;
        }
    }
}

2、虚拟主机

原本一台服务器只能对应一个站点、通过虚拟主机技术可以虚拟化多个站点对外提供服务。

每一段 server 中就是一个虚拟主机 如下:

server {
	.. ..
    }

实验:通过不同端口 设置多实例虚拟主机

创建不同的 index.html文件

mkdir /www
cd /www/
mkdir www video

echo "This is the www site." > /www/www/index.html
echo "This is the video site." > /www/video/index.html
http {
	..  .. 
	
server {
        listen       80;
        server_name  localhost;

        location / {
            root   /www/www;          # 设置80端口网页主目录
            index  index.html index.htm;
        }
}

server {
        listen       88;
        server_name  localhost;

        location / {
            root   /www/video;         # 设置88端口网页主目录
            index  index.html index.htm;
        }
    }
  }
/usr/local/nginx/sbin/nginx -s reload

测试:

curl 127.0.0.1
This is the www site.

curl 127.0.0.1:88
This is the video site.

3、匹配正则表达式

=         # 开头表示精确匹配
~         # 区分大小写匹配
~*        # 不区分大小写匹配
!~和!~*   # 分别为区分大小写不匹配及不区分大小写不匹配的正则
^ 		  # 以什么字符开头
$         # 以什么字符结尾
^~        # 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可
*         # 任意字符   
/         # 通用匹配,任何请求都会匹配到

举例:

通用匹配 任何请求都会匹配到

location / {
}

严格区分大小写,匹配.php结尾

location ~ \.php$ {
	fastcgi_pass http://127.0.0.1:9000;
}

严格区分大小写,匹配.jsp结尾

location ~ \.jsp$ {
	proxy_pass http://127.0.0.1:8080;
}

不区分大小写匹配

location ~* "\.(sql|bak|tgz|tar.gz|.git)$ {
	default_type text/html;
	return 403 "启用访问控制";
}

四、Nginx反向代理

1、理论

反向代理 记住 proxy_pass 一个词即可

反向代理的工作原理是,代理服务器来接受客户端的网络访问连接请求,然后服务器将请求有策略的转发给网络中实际工作的业务服务器,并将从业务服务器处理的结果,返回给网络上发起连接请求的客户端。

2、实践:Nginx反代代理Tomcat

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KcfBNDV7-1687140794614)(D:\MD归档文档\IMG\image-20220405194618578.png)]

1、部署安装Tomcat (两台同步操作)

安装JDK环境 并验证

yum install -y java-1.8.0-openjdk-devel.x86_64
java -version

下载Tomcat 并解压启动

wget https://dlcdn.apache.org/tomcat/tomcat-9/v9.0.62/bin/apache-tomcat-9.0.62.tar.gz --no-check-certificate

tar xf apache-tomcat-9.0.62.tar.gz -C /usr/local/
cd /usr/local/apache-tomcat-9.0.62/bin/

./startup.sh  
ps -aux |grep java

防火墙配置

# 开启8080端口
firewall-cmd --add-port=8080/tcp --permanent 
firewall-cmd --reload 

# 开启8081端口
firewall-cmd --add-port=8081/tcp --permanent 
firewall-cmd --reload 

2、更改其中一台的端口号为 8081

cd /usr/local/apache-tomcat-9.0.62/conf/
vim server.xml 
	.. ..
<Connector port="8081" protocol="HTTP/1.1"

重启 Tomcat

./shutdown.sh
./startup.sh

netstat -anput |grep 8081

3、插入不同的页面

# 101 操作
mv /usr/local/apache-tomcat-9.0.62/webapps/ROOT/index.jsp{,.bak}

cd /usr/local/apache-tomcat-9.0.62/webapps/ROOT
echo "This is 101" > index.jsp

# 105 操作
mv /usr/local/apache-tomcat-9.0.62/webapps/ROOT/index.jsp{,.bak}

cd /usr/local/apache-tomcat-9.0.62/webapps/ROOT
echo "This is 105" > index.jsp

测试

curl 10.10.14.101:8081
This is 101

curl 10.10.14.105:8080
This is 105

4、Nginx 反代配置

http {
	.. .. 
	
    server {
            listen 8888;
            server_name 10.10.14.100;

            location = /8080/ {
                    proxy_pass http://10.10.14.105:8080/;
            }

            location = /8081/ {
                    proxy_pass http://10.10.14.101:8081/;
            }

        }
}

验证

curl 10.10.14.100:8888/8080/
This is 105

curl 10.10.14.100:8888/8081/
This is 101

五、Nginx负载均衡

负载均衡是基于 反向代理之上的 需要配合proxy_pass一起来使用,可以通过配置负载均衡策略 将请求转发到 后端集群中。

所谓的集群定义 是多台服务器提供相同服务,在客户端开来好像就只有一台服务器。

1、实践:Nginx负载均衡Tomcat

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9rahWOdU-1687140794615)(D:\MD归档文档\IMG\image-20220405203919554.png)]

1、配置Tomcat 参考 四、Nginx反向代理 最终效果如下:

curl 10.10.14.101:8080
This is 101

curl 10.10.14.105:8080
This is 105

2、Nginx 配置

upstream 负载均衡配置 需要在http 字段下定义

http {
	..	..
	
    upstream tomcat {
    server 10.10.14.101:8080 weight=8;
	server 10.10.14.105:8080 weight=2;
	# server 10.10.14.101:8080 weight=8 down;
	# server 10.10.14.105:8080 weight=2 backup;
	}
	
	..  ..
 }

weight 权重值 此值越高 被分配的优先级也就越高

down 不使用此服务器

backup 备份服务器 当没有一台可以提供服务时自动启动

虚拟主机配置:

http {
   ..	..
   
server {
       listen       8888;
       server_name  localhost;

       location / {
        	proxy_pass http://tomcat;
        	# 当使用proxy_pass 就需要注释掉下面内容
           # root   /www/www;
           # index  index.html index.htm;
       }
     }
   }

3、防火墙配置

在外网不能访问后端Tomcat 只能通过Nginx访问 如下图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WyZKaS90-1687140794615)(D:\MD归档文档\IMG\image-20220409133146085.png)]

Tomcat服务器上配置防火墙:

systemctl start firewalld.service

firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="10.10.14.100" port protocol="tcp" port="8080" accept"
firewall-cmd --reload

移除规则:

firewall-cmd --permanent --remove-rich-rule="rule family="ipv4" source address="10.10.14.100" port protocol="tcp" port="8080" accept"
firewall-cmd --reload

4、重启Nginx并验证

curl 10.10.14.100:8888
This is 101

curl 10.10.14.100:8888
This is 105

2、负载均衡策略

目前为止 内置策略有3中 分别是:轮询策略、加权策略和ip_hash策略,默认使用轮询策略。

1、轮询策略

默认使用 轮询策略 逐一转发 适用于无状态请求。

2、加权策略(weight)

设置优先级 weight的大小和访问率成正比。

3、ip_hash策略

根据客户端ip地址转发同一台服务器,可以保持回话。

4、least_conn

最少连接访问。

5、url_hash

根据用户访问url定向转发请求。

六、Nginx + Keepalived 高可用

1、环境说明

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sbsZN6MW-1687140794615)(D:\MD归档文档\IMG\image-20220409165640177.png)]

环境:

IP地址说明备注
10.10.14.100Nginx_Master节点Master和Backup配置文件保持一致
10.10.14.102Nginx_Backup节点Master和Backup配置文件保持一致
10.10.14.105Tomcat 节点1
10.10.14.101Tomcat 节点2

2、实践

1、Nginx_Master节点 和 Nginx_Salve节点 配置保持一致 nginx配置文件如下

http {
   .. ..
    upstream tomcat {
	server 10.10.14.101:8080;
	server 10.10.14.105:8080;
	}

    server {
        listen       80;
        server_name  localhost;

        location / {
	    proxy_pass http://tomcat;
        }
    }
    .. .. 

 }

2、keepalived 安装配置(两台Nginx 都需要操作)

yum -y install openssl-devel libnl libnl-devel libnfnetlink-devel
wget https://www.keepalived.org/software/keepalived-2.0.20.tar.gz --no-check-certificate

tar zxf keepalived-2.0.20.tar.gz 
cd keepalived-2.0.20/
./configure --sysconf=/etc
make && make install 

# --sysconf 指定配置文件路径

3、Master keepalived配置:

[root@nginx1 ~]# cat /etc/keepalived/keepalived.conf 
! Configuration File for keepalived

global_defs {
   router_id 111
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 50
    priority 100
    advert_int 1

    authentication {
        auth_type PASS
        auth_pass 1111
    }

    virtual_ipaddress {
        10.10.14.200
    }
}

4、Slave keepalived配置:

cat /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {
   router_id 102
}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 50
    priority 50
    advert_int 1

    authentication {
        auth_type PASS
        auth_pass 1111
    }

    virtual_ipaddress {
        10.10.14.200
    }
}

5、启动验证

systemctl restart keepalived.service 
ip a 
# 配置正确应该 Master上可以看到200IP地址 Backup则不能
# 在Master上停止keepalived 看VIP是否可以票到Backup主机上

6、防止脑裂配置

firewall-cmd --direct --permanent --add-rule ipv4 filter INPUT 0  --destination 224.0.0.18 --protocol vrrp -j ACCEPT
firewall-cmd --reload

7、 监控脚本

监控本地Nginx是否正常 如果不正常 则停止keepalived

cat keep_nginx.sh 
#!/bin/bash
if ! (which killall);then
	(yum install psmisc -y) &>/dev/null
fi

killall  -0  nginx
if  [ $? -ne 0 ];then
  systemctl stop keepalived
fi

# killall -0 nginx: 判断Nginx进程是否存在 存在则返回0

添加脚本追踪模块到keepalived配置文件

cat /etc/keepalived/keepalived.conf 

! Configuration File for keepalived

global_defs {
   router_id 111
}

vrrp_script keep_nginx.sh {
        script "/root/keep_nginx.sh"
        interval 2
        weight 5
        }

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 50
    priority 100
    advert_int 1

    authentication {
        auth_type PASS
        auth_pass 1111
    }

    virtual_ipaddress {
        10.10.14.200
    }
track_script {
        keep_nginx.sh
    }
}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AEVrJtud-1687140794616)(D:\MD归档文档\IMG\image-20220409174046153.png)]

七、Nginx证书认证

1、SSL证书配置

# CA:证书颁发机构
# RA:证书注册机构

证书配置:

mkdir /usr/local/nginx/ssl_key
cd /usr/local/nginx/ssl_key

创建私钥:

[root@loaclhost ssl_key]# openssl genrsa -idea -out server.key 2048 
Generating RSA private key, 2048 bit long modulus
......................................+++
.....+++
e is 65537 (0x10001)
Enter pass phrase for server.key:    # 密码
Verifying - Enter pass phrase for server.key: # 密码

生成证书 去除私钥密码:

openssl req -days 3650 -x509 -sha256 -nodes -newkey rsa:2048 -keyout server.key -out server.crt

ls /usr/local/nginx/ssl_key
server.crt  server.key

Nginx配置:

server {
        listen       443 ssl;
        server_name  localhost;

        ssl_certificate      /usr/local/nginx/ssl_key/server.crt;   # 指定证书位置
        ssl_certificate_key  /usr/local/nginx/ssl_key/server.key;   # 指定私钥位置
        ssl_session_timeout  5m;
    }

防火墙配置:

firewall-cmd --add-service=https --permanent 
firewall-cmd --add-service=http  --permanent 
firewall-cmd --reload 

启动测试:

echo "Test Service SSL" > html/index.html
nginx -t
nginx 

浏览器访问:https://NginxIP

若涉及到本地域名等信息需要修改hosts文件:C:\Windows\System32\drivers\etc\hosts

  • 格式:域名 IP地址

2、rewrite地址重写

server {
        listen 80;
        server_name https.benet.com;
#       rewrite .* https://https.benet.com;  #重定向任选其一
#       rewrite .* https://$host$request_uri redirect;
#       rewrite .* https://$server_name$request_uri redirect;
        rewrite .* https://$server_name$1 redirect;
}

八、Nginx平滑升级

1、Nginx平滑升级原理

一般有两种情况下需要升级 nginx,一种是确实要升级 nginx 的版本,另一种是要为 nginx 添加新的模块。

Nginx平滑升级其原理简单概括:

  • (1)在不停掉老进程的情况下,启动新进程。
  • (2)老进程负责处理仍然没有处理完的请求,但不再接受处理请求。
  • (3)新进程接受新请求。
  • (4)老进程处理完所有请求,关闭所有连接后,停止。

信号说明:

信号nginx内置shell说明
HUPnginx -s reload重载配置文件
USR1nginx -s reopen重新打开日志文件,配置mv,用做日志切割
USR2-热升级nginx程序
WINCH-优雅的关闭相关的worker进程
QUITnginx -s squit优雅的停止nginx
TERM,INTnginx -s stop立即停止nginx

2、实践:1.16版本 升级到 1.18版本

nginx -v
nginx version: nginx/1.16.1

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

wget http://nginx.org/download/nginx-1.18.0.tar.gz
tar zxvf nginx-1.18.0.tar.gz -C /usr/local/src
cd /usr/local/src/nginx-1.18.0

./configure --prefix=/usr/local/nginx --user=nginx --with-http_ssl_module
make 

备份替换nginx命令:

mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx_$(date +%F)
cp /usr/local/src/nginx-1.18.0/objs/nginx /usr/local/nginx/sbin/

测试新版本:

/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -v

查找nginx.pid文件位置

find / -name nginx.pid
/usr/local/nginx/logs/nginx.pid

发送平滑迁移信号 USR2: 启动新的主进程,实现热升级

kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`

发送WINCH信号给旧版主进程,旧版主进程就开始从容关闭

kill -WINCH `cat /usr/local/nginx/logs/nginx.pid.oldbin`

3、升级失败 回滚操作

1、替换原来的 nginx命令

cd /usr/local/nginx/sbin/
mv nginx_2022-03-21 nginx

2、kill -HUP 旧版本的Master进程号

//不重载 配置文件下 启动旧的worker进程

kill -HUP `cat /usr/local/nginx/logs/nginx.pid.oldbin`

3、kill -USR2 新版本的主进程号

kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`

4、kill -WINCH 新版本的主进程号

kill -WINCH `cat /usr/local/nginx/logs/nginx.pid`

4、遇到问题

**问题:**执行完成 “发送平滑迁移信号 USR2” 没有出现新的Master进程信息

查看日志 报错内容为: 大致意思是 找不到 nginx 目录

execve() failed while executing new binary process "nginx" (2: No such file or directory)

原因: Nginx平滑升级是根据环境变量来进行的 ,找不到 nginx目录 是因为上次启动nginx不是 使用完全路径启动的 而环境变量中并没有 nginx这个目录 所以导致 这个问题!

**解决:**使用正确的启动方法

/usr/local/nginx/sbin/nginx 

九、Nginx 优化方案

参考文档1:

参考文档2:

十、扩展

1、网站返回码

200				# 请求成功
201				# 上传文件成功
301				# 永久重定向(redirect)
302,307		    # 临时重定向(redirect)
304				# 浏览器缓存
403				# 请求不到首页,没有权限
404				# 请求的资源在前端查明不存在
405				# 请求方法不支持
500				# 服务器的内部错误,程序错误
502				# 请求的资源前端有记录指向后端数据库,却找不到后端资源
503				# 服务暂时不可用
504				# 请求超时

2、URL和URI的区别

URL:统一资源定位符
	格式:https://www.baidu.com/?tn=98010089_dg&ch=12
	
URL和URI的区别:
    URI:可以理解成一个网站的首页
	URL:可以理解成资源的具体路径

3、F12网络返回参数

General(大致信息):

Request URL: http://10.10.14.100/index.html    # 请求的URL地址
Request Method: GET                            # 请求的方法
Status Code: 304 OK                            # 状态码
Remote Address: 10.10.14.100:80                # 请求地址(ipv4/ipv6)
Referrer Policy: no-referrer-when-downgrade	   # 降级(从https降级到http)

Request Headers(请求头部信息):

Accept: text/html			           # 请求的类型
Accept-Encoding: gzip, deflate, br	   # 是否进行压缩
Accept-Language: zh-CN,zh;q=0.9		   # 请求的语言
Connection: keep-alive			       # TCP长连接
cache-control:max-age=0			       # 缓存时间
Cookie: 					           # 客户端缓存,用户密码等网站信息
Host:www.baidu.com/			           # 请求的域名
Upgrade-Insecure-Requests: 1		   # 启用升级https访问
User-Agent: Mozilla/5.0 			   # 客户端浏览器(可以理解xxx浏览器是基于什么内核开发出开的)

Response Headers(服务器响应头部信息):

Cache-Control: private			# 缓存类型非公开(公开:pubLic)
Connection: keep-alive			# 长连接
Content-Encoding: gzip			# 压缩格式gzip
Content-Type: text/html;charset=utf-8   # 文档类型
Date: Sat, 14 Mar 2020 08:48:02 GMT	    # 响应时间
Expires: Sat, 14 Apr 2022 08:47:42 GMT  	# 失效时间
Server: BWS/1.1			                    # 网站服务器软件	
status:200				                   # 状态码

4、curl 常用测试参数

-I 参数: 只显示响应内容

curl -I 127.0.0.1:8080

HTTP/1.1 200 
Set-Cookie: JSESSIONID=CA2EC2BDA2C9E6A0BE3EB87FDEEFA8FA; Path=/; HttpOnly
Content-Type: text/html;charset=ISO-8859-1
Transfer-Encoding: chunked
Date: Sat, 09 Apr 2022 06:27:19 GMT

-i 参数:显示响应内容 + 整体内容

curl -i 127.0.0.1:8080

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

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

相关文章

兼容性测试如何提高网站的安全性?

兼容性测试如何提高网站的安全性? 在今天的互联网时代&#xff0c;随着各种网络攻击和黑客活动的频繁发生&#xff0c;网站的安全性问题越来越引起人们的关注。而在提高网站安全性方面&#xff0c;兼容性测试是一个非常重要的环节。本文将从什么是兼容性测试、为什么兼容性测试…

【MySQL】数据库基础 ①

✍什么MYSQL是数据库&#xff1f; MySQL 是一个关系型数据库管理系统&#xff0c;它是基于关系模型的数据存储方式&#xff0c;以表格形式组织数据&#xff0c;并使用结构化查询语言 (SQL) 进行数据操作。MySQL 是一个流行的数据库管理系统&#xff0c;被广泛用于互联网应用和网…

Python基础(6)——Python输出

Python基础&#xff08;6&#xff09;——Python输出 文章目录 Python基础&#xff08;6&#xff09;——Python输出目标输出格式化输出1.1 格式化符号1.2 体验1.3 转义字符1.4 结束符 总结 目标 格式化输出 格式化符号f-字符串 print的结束符 输出 作用&#xff1a;程序输出…

【正点原子STM32连载】 第三十四章 PWM DAC实验摘自【正点原子】STM32F103 战舰开发指南V1.2

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html# 第三…

NSS刷web(1)

一点点做,简单的也不跳了,就当回忆知识了 [SWPUCTF 2021 新生赛]gift_F12 ctrlu [SWPUCTF 2021 新生赛]jicao [SWPUCTF 2021 新生赛]easy_md5 [SWPUCTF 2021 新生赛]easy_sql [SWPUCTF 2021 新生赛]include [SWPUCTF 2021 新生赛]easyrce [SWPUCTF 2021 新生赛]caidao [SWP…

PMP证书考下来要多少费用?

PMP考试形式分为&#xff1a;笔试、机考。PMP考试这里只着重介绍笔试&#xff08;大陆地区目前都是笔试&#xff09;&#xff1a; PMP认证考试在大陆内的考试一般一年举行四次&#xff0c;分别在3、6、9、12月份。2023年考试时间是3、5、8、11月份。 考试方式是笔试。考试改版…

【云原生】初识Kubernetes的理论基础

1.k8s的由来及其技术运用 1.1 k8s的简介 Kubernetes&#xff0c;词根源于希腊语的 舵手、飞行员。在国内又称k8s&#xff08;因为k和s之间有8个字母&#xff0c;所以得名。“国内程序员的幽默”&#xff09;。用于自动部署、扩展和管理“容器化&#xff08;containerized&…

面向锂电池行业实验室测试排配智能优化解决方案

获取更多资讯&#xff0c;赶快关注公众号&#xff08;《智能制造与智能调度》和》《商简智能》&#xff09;吧&#xff01; 文章目录 1 何为排配问题2 排配特点3 排配现状和痛点4 智能排配解决方案4.1 整体架构4.2 总体思路4.3 智能排配约束4.4 智能算法助力智能排配4.5 智能交…

RFID课程要点总结_3 Wireless Communication Principle of RFID

3. Wireless Communication Principle of RFID Different work principles of different carrier frequency 不同频率载波也适用不同的工作原则。 前面已经有所涉及&#xff0c;比如LF HF适用于近距离&#xff0c;UHF SHF适合远距离。 前者适用 Inductively Coupled RF Mod…

使用华为云AstroZero,不用一行代码,制作端午节加班申请模板

前言 6月22号就要端午了&#xff0c;很多公司会想统计下端午节加班的人数。传统的做法是用社交软件&#xff0c;谁要加班谁反馈&#xff0c;然后逐级汇总上传。大一点的企业&#xff0c;可能用自己的内部办公系统来申请。 但对于小企业来说&#xff0c;没有定制化的办公系统&a…

文件夹提示《文件或目录损坏》怎么解决

在经常使用电脑的过程中&#xff0c;大家平常会遇见一些困难&#xff0c;其中最常见的就是文件夹了&#xff0c;许多人就反映说自己遇见过文件夹《文件或目录损坏》打不开&#xff0c;那么遇见这个困难该怎么办呢&#xff1f;不知道的朋友赶紧瞧瞧小编整理的文件夹《文件或目录…

【参考设计】2KW AC/DC数字电源方案

什么是数字电源&#xff1f; 数字电源即通过一颗通用的数字信号控制器&#xff0c;完成传统模拟电源控制IC所具备的PWM、保护、环路补偿等功能&#xff0c;同时具备通信监控功能。 数字电源的数字信号控制器取代了模拟电源的控制芯片、环路补偿的运放及相关器件。软件处理的灵…

软考A计划-系统集成项目管理工程师-信息化知识(一)

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff…

leetcode 225. 用队列实现栈

2023.6.19 这题使用队列来实现栈的功能&#xff0c;和栈实现队列稍有不同。pop操作的实现 需要将队列1的除队尾元素之外的所有元素移到队列2中&#xff0c;然后返回并移除队列1剩下的元素。 下面上代码&#xff1a; class MyStack {queue<int> que1;queue<int> qu…

How to Write and Publish a Scientific Paper-Approaching a Writing Project

contents Approaching a Writing ProjectESTABLISHING THE MINDSETPREPARING TO WRITEDOING THE WRITINGREVISING YOUR WORK Approaching a Writing Project ESTABLISHING THE MINDSET 也许最基本的是&#xff0c;请记住你的写作目的是为了传达信息&#xff0c;而不是为了给人…

Flutter悬浮UI的设计Overlay组件

文章目录 APP开发经常要遇到的开发场景Overlay 的介绍Overlay的使用规则举例说明源码例子报错报错No Overlay widget found报错原因解决方法 修改后的源码 例子效果 APP开发经常要遇到的开发场景 有时候我们在开发APP的时候会遇到下面这些需求&#xff1a; 在现有页面上添加浮…

选择题UI

选择题UI QuestionInfoSetting.cs using System; using System.Collections.Generic; using System.Threading.Tasks; using TMPro; using UnityEngine; using UnityEngine.UI;public class QuestionInfoSetting : MonoBehaviour {[Header("选项")]public GameObj…

LabVIEW错误-1073807360发生于 VISA Configure Serial Port (Instr).vi

调试上位机发生错误&#xff0c;错误信息为&#xff1a;“错误-1073807360发生于 VISA Configure Serial Port (Instr).vi->300W.vi中的属性节点&#xff08;arg 1&#xff09;” 查阅资料后得出的出错原因大致分为两种&#xff1a; 1.在运行程序时&#xff0c;没有选择端…

华为OD机试之MELON的难题(Java源码)

MELON的难题 题目描述 MELON有一堆精美的雨花石(数量为n&#xff0c;重量各异)&#xff0c;准备送给S和W。MELON希望送给俩人的雨花石重量一致&#xff0c;请你设计一个程序&#xff0c;帮MELON确认是否能将雨花石平均分配。 输入描述 第1行输入为雨花石个数: n&#xff0c;0&…

SN74LVC2T45使用说明

DIR高电平&#xff0c;允许从A传输到B&#xff0c;而低电平则允许从B传输到A。 针脚A和DIR以VCCA为基准&#xff0c;针脚B以VCCB为基准