空间站做网站有什么/百度seo工具
pytest测试框架
单元测试框架定义:针对软件开发最小的单元(函数,方法)进行正确性位置测试
单元测试框架:java(junit,testing)python(unittest,pytest)
单元测试框架的作用
- 测试发现:从多个文件中找到测试用例
- 测试执行:按照一定的顺序和规则去执行并且生成结果
- 测试判断:通过断言判断预期结果和实际结果的差异
- 测试报告:统计测试的结果,耗时,通过率等生成美观的测试报告
自动化框架的内容:单元测试框架,pom设计模式,数据驱动,关键字驱动,全局配置文件的封装,日志监控,selenium和request二次封装,断言,报告邮件,更多…
pytest简介和安装
- pytest比unittest更灵活,容易上手
- pytest可以和selenium,reques,appnium结合实现web自动化,接口自动化,app自动化
- pytest可以实现测试用例的跳过和reruns失败用例重试
- pytest可以和allure生成测试报告
- pytest可以和jenkins持续集成
- pytest提供强大的插件
如下:建立requirements.txt 内容如下
pytest 本身
pytest-html 生成html格式化报告
pytest-xdist 测试用例分布式进行,多CPU分发
pytest-ordering 用于改变测试用例的执行顺序
pytest-returnfailures 用例失败后重跑
allure-pytest 用于生成美观的测试报告
终端上输入安装:
pip install -r requirements.txt
检验:
pytest --version
模块命名
- 以test_开头或者 _test结尾
- 测试类必须以Test开头并且不再有ini方法
- 测试方法必须以test开头
测试用例的运行方式
1.主函数运行方式
(1)运行所有:pytest.main()
class TestLogin:def test_01_login(self):print("测试登录")if __name__ == '__main__':pytest.main()
(2)运行指定模块:
pytest.main(['-vs','test_login.py'])
(3)指定目录:
pytest.main(['-vs','./test_other.py'])
(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,函数名组成
pytest.main([’-vs‘,’./interface_testcase/test_interface.py::test_04_func‘])
2.命令行模式
(1)运行所有:
pytest
(2)指定模块:
pytest -vs test_login.py
(3)指定目录:
pytest -vs ./test_other.py
(4)指定目录:
pytest -vs ./interface_testcase/test_interface.py::test_04_func
3.参数详解
-v 输出更详细的信息
-s 输出调试信息
-vs:这两个参数一起用
-n:支持多线程或者分布式运行测试用例
如:pytest -vs ./test_login.py -n 2
–returns NUM:失败用例重跑
-x:表示只要要一个用例报错,那么测试就停止
–maxfall=2 出现两个用例失败就停止
-k:根据测试用例的部分字符串指定测试用例
如:pytest -vs/testcase -k"ao"
class TestLogin:def test_01_login(self):print("测试登录")if __name__ == '__main__':pytest.main(['-s'])
案例:创建一个all.py文件运行指定的test用例和控制输出的信息
import pytestif __name__ == '__main__':pytest.main(['-vs','test_login.py'])
相当于终端输入
pytest -vs test_login.py
3.结合pytest.ini全局配置文件执行
pytest为整个pytest的核心配置文件
-
位置:一般放在项目的根目录
-
编码:必须是ANSI编码格式,可以使用notepad++修改编码格式
-
作用:改变pytest默认行为
-
运行规则:不管是主函数的模式运行,命令行模式运行,都会去读取ini文件
1 [pytest] 2 #命令行参数 3 #常见:--html=./reports/report.html --reruns 2 4 addopts = -vs -m "user_manager or smoke" 5 #配置执行的用例位置 6 testpaths = ./testcases 7 #配置修改默认的模块规则 8 python_files = test_*.py 9 #配置修改默认的类规则 10 python_classes = Test* 11 #配置修改默认的用例规则 12 python_functions = test_* 13 #配置基础路径 14 base_url = http://www.baidu.com 15 #标记 16 markers = 17 smoke:冒烟测试用例 18 product_manage:商品管理 19 user_manager:用户管理
pytest 测试用例的顺序
区分
unittest:ascII的大小来绝对的执行顺序
pytest:默认从上到下
改变默认的执行顺序,使用mark标记
添加注释,其中1是执行的顺序
@pytest.mark.run(order=1)
如何分组执行(冒烟、分模块执行、分接口和web执行)
smoke:冒烟用例,分布在各个模块内
添加冒烟标记在.py文件
@pytest.mark.smoke
注意要在pytest.ini文件打一下标记
#标记markers =
smoke:冒烟测试用例
product_manage:商品管理
user_manager:用户管理
在终端输入
pytest -vs -m "smoke"
想执行其他模块
pytest -vs -m "smoke and 其他模块的名称"
跳过执行的用例
-
无条件跳过
@pytest.mark,skipif(reason=’跳过原因‘)
-
有条件跳过
@pytest.mark,skipif(条件,reason=’跳过原因‘)
例如
@pytest.mark.skipif(age>=18,reason='已成年')
pytest框架的一些前后置(固件,夹具)处理,常用的三种
前后置:setup_class、setup、teardown、teardown_class
class TestPosition:def setUp_class(self):print('\n 在每个类执行前的准备工作,例如:创建日志对象、数据库链接、接口请求对象')def setup(self):print('\n 执行用例之前的开始动作,比如打开浏览器')def test_01(self):print('\n 测试用例')def teardown(self):print('\n 执行用例之前的扫尾动作,比如关闭浏览器')def teardown_class(self):print('\n 在每个类执行前的准备工作,例如:销毁日志对象、数据库链接、接口请求对象')
使用@pytest.fixture()装饰器实现部分用例的前后置
装饰器:
@pytest.fixtrue(scope=“作用范围”,autouse=“自动执行”,params=“参数化”,ids=“参数别
名”,name=“固件别名”)
案例:
@pytest.fixture(scope="",params="", autouse="",ids="",name="")
def my_fixture():print('这是前置的方法,可以实现部分以及全部用例的前置')yieldprint('这是后置方法,可以实现部分以及全部用例的后置')
def test_02(self,my_fixture):print('\n 执行fixture')
用法:
- scope表示的是被@pytest.fixture标记的方法的作用域。function(默认),class,moudle,package/session
- params:参数化(支持,列表[],元组(),字典列表[{},{},{}],字典元组({},{},{})
import pytest@pytest.fixture(scope='function',params=['参数1','参数2','参数3'])
def my_fixture(request):print('前置')yield request.param # 注意yield和return都表示返回的以上,但是return后面不能跟代码,yield可以print('后置')
def test_02(self,my_fixture):print('\n 执行fixture')
注意:params和yield不能一起用但是可以和前置一起用。
-
autouse=True:自动化使用,默认False
-
ids:当使用params参数化时,给每一个值设置一个变量名,意义不大
-
name:给表示的是被@pytest.fixture标记的方法取一个别名
当取了别名之后,那么原来的名就用不了了
通过conftest.py和@pytest.fixture()结合使用实现全局的前置应用(如:项目的全局登录,模块的全局处理)
-
conftest.py文件是单独存放的一个夹具的配置文件,名称不能更改
-
用处可以在不同的py文件中使用同一个fixture函数
-
原则上conftest.py需要和运行的用例放在统一层,并且不需要做任何的import导入的操作
案例
全局拥有全局前置,各个子模块下面有一个前置,对于用例编写为
def test_01_testconftest(self,all_fixtuture,user_fixture)print("test用例")print(user_fixture)print(all_fixture)
这样全局前置包含了子模块的前置
setup/teardown,setup_class/teardown_class 它是作用于所有用例或者所有的类
@pytest.fixture() 它的作用是局部的也是全局的
conftest.py和@pytest_fixture()结合使用,作用于全局的前后置
断言
assert
pytest结合allure+pytest插件生成allure测试报告
以前是使用的是pytest_html生成,现在可以使用allure+pytest结合生成美观的报告
1.下载、解压、配置path路径
https://github.com/allure-framework/allure2/releases
配置环境变量如:
D:\allure-2.30.0\bin
验证
allure --version
2.加入命令到pytest.ini文件,生成json格式的临时报告
addopts = -vs --alluredir ./temp
3.生成allure报告
allure generate 命令,固定的
./temp 临时的json格式的报告
-o 输出output
./report 生成allure报告路径
.clear 清空./report路径原来的报告
if __name__ == '__main__':time.sleep(3)# pytest.main(['-vs','test_login.py'])pytest.main()# allure generate 命令,固定的;./temp 临时的json格式的报告 -o 输出output ./report 生成allure报告路径 .clear 清空./report路径原来的报告os.system('allure generate ./temp -o ./report --clear')
yaml接口自动化实战
1,断言的封装
2,allure报告的定制
3,关键字驱动和数据驱动结合实现接口自动化测试
4,python的反射
正常:先初始化对象,再调方法
反射:通过对象得到类对象,然后通过类对象调用方法
5,jenkins的持续集成和allure报告的集成,并且根据项目的自动化的报告错误率发送电子邮件
pytest接口自动化
接口测试
发展背景:
目前市面上主流的接口测试工具:(适用于中小型项目)
- postman+newman+git+jenkins
- jmeter+ant+git+jenkins
目前主流的接口自动化测试技术:(适用于大小型的项目)
requests库
安装
requests用来发送http请求以及接受http响应的python第三方库,主要用于接口自动化测试
pip install requests
requests库常用的方法
requests.get() url是接口的地址,param用于传参
requests.post() url是接口地址,data用于传参,json也适用传参
data和json传参的区别:主要是通过请求头Content-Type来区分
Content-Type:作用是服务器要求传入的报文的内容类型
请求:请求方式,请求路径,请求头,请求正文
requests.pull()
requests.delete()
requests.request() 可以发送所有类型的请求:get,post,put,delete
拓展:postman的四种传参的方式对应的Content-Type的值如下:
from-data:Content-Type:multipart/form-data、boundary=
x-www-from-urlencoded:Content-Type:applic.ation/x-www-form-urlencoded
raw:
text:Content-Type:text/plain
javascript:Content-Type:application/javascript
json:Content-Type:application/json
html:Content-Type:application/xml
binary:Content-Type:application/binary
data和json传参以及Content-Type的关系如下:
1.data传参:
data传参:报文时dict类型,那么默认Content-Type application/x-www-form-urlencoded
data传参:报文是str类型,那么默认Content-Type text/plain
2.json传参:
报文可以是dict类型,那么默认Content-Type application/json
注意:
-
json是字典类型的字符串显示。
-
json.loads() 把json字符串转化为dict格式;json.dumps() 把dict格式转换为json字符串
-
不管是get,post,put,delete,都是调用的requests.request方法。而requests.reques方法调用的是session.reques方法
method 请求方式
url 请求路径
params=None get方式传参
data=None post方式传参
json=None post方式传参
headers=None 请求头
cookie=None 请求cookie
files=None 文件上传
requests模块返回的response对象详解
- res.json() 获取返回的字典格式的数据
- res.text 获得返回的字符串格式的数据
- res.content 获得返回的bytes字节类型的数据
- res_status_code 返回状态码
- res.reason 返回状态信息
- res.cookies 返回cookie信息
- res.headers 返回响应头
- res.request.xxx 返回需求的数据,如:需求头,请求参数
请求必须带有请求头的接口,以及需要cookie鉴权和session鉴权的接口
<input type="hidden" name="csrf_token" value="e7202bf558a7eb34"/>
90%以上的基于web的接口都有cookie鉴权
两种解决方式:
-
使用cookie关联
案例注释:接口关联变量,在第一个接口取值,在第二个接口传值,第三个接口文件上传,访问首页的接口,解决鉴权
import requestsclass TestRequest:#全局变量,类变量,通过类名调用access_token=""csrf_token=""php_cookie=""def test_get_token(self):url:"https://api.weixin.qq.com/cgi-bin/token"data:{"grant_type":"client_credential","appid":"wx74a8627810cfa300","secret":"e40a02f9cf9d79df497e6aaf93ab80"}res=requests.request(method="get",url=url,params=data)print(res.json())TestRequest access_token = res.json()['access_token']# post请求:编辑标签接口def test_edit_flag(self):url:"https://api.weixin.qq.com/cgi-bin/tags/updat?access token="+TestRequest.access_tokendata=["tag":{"id":134,"name":"广东人"}]str_data=json.dumps(data)res=requests.request(method="post",url=url,data=data)print(res.json())# 文件上传 def test_file_upload(self):url:"https://api.weixin.qq.com/cgi-bin/media/uploadimg?access_token="+TestRequest.access_token"+TestRequest.access_tokendata={"media":open(r"E:\shu.png","rb")}res=requests.request(method="post",url=url,files=data)print(res.json())# 访问首页的接口 def test_start(self):url:"https://47.107.116.139/phpwind"res=requests.request(method="get",url=url)print(res.text) # 正则提取token obj=re.search('name="csrf_token" value="(.*?)"',res.text) # print(obj.group(1)) TestRequest.csrf_token=obj.group(1) # 解决鉴权的方式一:提取cookie TestRequest.php_cookie=res.cookies# 登录接口 def test_login(self):url:"https://47.107.116.139/phpwind/index.php?m=u&c=login&a=dorun"data={"username":"msxy","password":"msxy","csrf_token":TestRequest.csrf_token,"backurl":"http://47.107.116.139/phpwind/","invite":""}# 请求头headers={"Accept":"application/json, text/javascript, /; q=0.01","X-Requested-with":"XMLHttpRequest"}res=requests.request(method="post",url=url,data=data,headers=headers,cookies=TestRequest.php_cookie)print(res.json()) # 解决鉴权的方式一:提取cookie TestRequest.php_cookie=res.cookiesif __name__ == '__main__':TestRequest().test_get_token()TestRequest().test_edit_flag()TestRequest().test_file_upload()TestRequest().test_start()TestRequest().test_login()
-
使用session关联
import requestsclass TestRequest:#全局变量,类变量,通过类名调用access_token=""csrf_token=""# php_cookie=""sess=requests.session()def test_get_token(self):url:"https://api.weixin.qq.com/cgi-bin/token"data:{"grant_type":"client_credential","appid":"wx74a8627810cfa300","secret":"e40a02f9cf9d79df497e6aaf93ab80"}res=requests.request(method="get",url=url,params=data)print(res.json())TestRequest access_token = res.json()['access_token']# post请求:编辑标签接口def test_edit_flag(self):url:"https://api.weixin.qq.com/cgi-bin/tags/updat?access token="+TestRequest.access_tokendata=["tag":{"id":134,"name":"广东人"}]str_data=json.dumps(data)res=requests.request(method="post",url=url,data=data)print(res.json())# 文件上传 def test_file_upload(self):url:"https://api.weixin.qq.com/cgi-bin/media/uploadimg?access_token="+TestRequest.access_token"+TestRequest.access_tokendata={"media":open(r"E:\shu.png","rb")}res=requests.request(method="post",url=url,files=data)print(res.json())# 访问首页的接口 def test_start(self):url:"https://47.107.116.139/phpwind"res=TestRequest.sess.request(method="get",url=url)# print(res.text) # 正则提取token obj=re.search('name="csrf_token" value="(.*?)"',res.text) # print(obj.group(1)) TestRequest.csrf_token=obj.group(1)# 登录接口 def test_login(self):url:"https://47.107.116.139/phpwind/index.php?m=u&c=login&a=dorun"data={"username":"msxy","password":"msxy","csrf_token":TestRequest.csrf_token,"backurl":"http://47.107.116.139/phpwind/","invite":""}# 请求头headers={"Accept":"application/json, text/javascript, /; q=0.01","X-Requested-with":"XMLHttpRequest"}res=TestRequest.sess.request(method="post",url=url,data=data,headers=headers)print(res.json())if __name__ == '__main__':TestRequest().test_get_token()TestRequest().test_edit_flag()TestRequest().test_file_upload()TestRequest().test_start()TestRequest().test_login()
相关文章:

pytest框架
pytest测试框架 单元测试框架定义:针对软件开发最小的单元(函数,方法)进行正确性位置测试 单元测试框架:java(junit,testing)python(unittest,pytest&#…...

基于大数据的亚健康人群数据分析及可视化系统
作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码 精品专栏:Java精选实战项目…...

黄金短线交易策略:波动中的高效盈利之法
今日,亚市盘初,现货黄金就高位震荡。在昨日金价再度冲高,一度刷新历史高点至2685.49美元,收报2672.25美元。其中主要原因是美国公布了最新的核心PCE(个人消费支出)物价指数和初请失业金人数等经济数据&…...

西陆家政系统V1.0.1
微信小程序开发的西陆家政服务管理系统小程序 V1.0.1bug修复优化 1.修复首页轮播不能自动轮播问题;2.修复订单详情价格显示问题;3.修复在开放城市模式下,其他城市可以下单问题;4.修复个人二维码跳转小程序路径异常问题;5.修复小程序编辑我的地址选择定位后不刷新问题…...

时间安全精细化管理平台/iapp/mobile/facereg/facereg.html接口存在未授权访问漏洞
漏洞描述 登录--时间&安全精细化管理平台/iapp/mobile/facereg/facereg.html接口存在未授权访问漏洞,黑客可以未授权等级员工信息对平台造成影响 FOFA: body"登录--时间&安全精细化管理平台" 漏洞复现 IP/iapp/mobile/facereg…...

自动化测试实例:Web登录功能性测试(无验证码)
🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 一、什么是自动化测试 把人为驱动的测试行为转化为机器执行的一种过程称为自动化测试。(来自百度百科)本质上来说,自动化测试对比起手工测试除了需要…...

【算法篇】二叉树类(3)(笔记)
目录 一、Leetcode 题目 1. 二叉树的最近公共祖先 2. 二叉搜索树的最近公共祖先 (1)递归法 (2)迭代法 3. 二叉搜索树中的插入操作 (1)递归法 (2)迭代法 4. 删除二叉搜索树中…...

基于php的律所管理系统
作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码 精品专栏:Java精选实战项目…...

MySQL 之索引详解
想象一下,你正在图书馆寻找一本关于 MySQL 索引的书。图书馆里有成千上万本书,但没有目录。你只能一排一排、一本一本地找,直到找到你想要的书。这将会花费大量的时间!数据库索引就像图书馆的目录一样,可以帮助数据库系…...

C#测试调用FreeSpire.PDFViewer浏览PDF文件
Free Spire.PDFViewer是商业版Spire.PDFViewer的社区版本,支持以控件形式打开并查看PDf文件,但由于是免费版本,存在使用限制,打开的PDF文档只显示前10页内容。如果日常操作的pdf文件都不超过10页,可以考虑使用Free Spi…...

又一挣钱副业:AI生成影视解说,半个月涨粉变现3.5W+!
这两年大家都在感叹生活不易,然而我想说的是,机会还是有的,但问题不在于有没有,而在于你是否能够认准机会,然后抓住它。 接触过很多咨询项目的人,发现很多人依旧停留在传统思维中,认为副业就是…...

R语言 基础 笔记 3
起因, 目的: 思考一个问题: AI 这么强,AI 什么都知道,为什么还要学习这些基础的东西, 为什么还要写这些笔记? 我觉得,大体过一遍,还是有好处的。 有个大致印象,下次查的时候,也方便一些。 几个函数 cbind() 按照列,拼接数据, 会改变某些列的数据类型。data() 查看…...

【MySQL】常见的SQL优化方式(一)
目录 1、插入数据 (1)批量插入 (2)手动提交事务 (3)主键顺序插入 2、主键优化 (1)页分裂 (2)页合并 3、order by 优化 (1)排…...

【重点】使用axios.request.put上传文件,报错分析
使用axios的put方法上传文件时,如果遇到错误,可能的原因有以下几点: 跨域问题:如果请求的URL与当前页面的域名不同,可能会触发跨域问题。解决方法是在服务器端设置允许跨域请求,如设置CORS(跨域…...

最新最全的阿里大模型面试真题!看到就是赚到
前言 随着人工智能技术的飞速发展,计算机视觉(CV)、自然语言处理(NLP)、搜索、推荐、广告推送和风险控制等领域的岗位越来越受到追捧,掌握大型模型技术已成为这些岗位的必备技能。然而,目前公开…...

使用Docker快速本地部署RSSHub结合内网穿透访问RSS订阅源
文章目录 前言1. Docker 安装2. Docker 部署Rsshub3. 本地访问Rsshub4. Linux安装Cpolar5. 配置公网地址6. 远程访问Rsshub7. 固定Cpolar公网地址8. 固定地址访问 前言 今天和大家分享的是如何在本地快速简单部署Rsshub工具,并结合cpolar内网穿透工具使用公网地址远…...

win10系统K8S安装教程
准备工作 电脑硬件:支持虚拟化的CPU,内存最好在32G以上,16G也可以操作系统:window10 专业版 1 开启虚拟化 1.1 BIOS 由于主板和CPU的品牌不太一样,这里的操作仅供参考,以Intel的平台为例: …...

C#和Python共享内存技术
我这里做一个简单的示例 1.C#写入内存的方法,FileName是内存共享的名字 t是内存size public static void SaveGluePLYToMemory(string FileName, string msg){try{ long t 100;// SetMemorySize(msg);// 100;//# 创建内存块,test1,其他语言利用这个内存…...

Java每日面试题(JVM)(day15)
目录 Java对象内存布局markWord 数据结构JDK1.8 JVM 内存结构JDK1.8堆内存结构GC垃圾回收如何发现垃圾如何回收垃圾 JVM调优参数 Java对象内存布局 markWord 数据结构 JDK1.8 JVM 内存结构 程序计数器: 线程私有,记录代码执行的位置. Java虚拟机栈: 线程私有&#…...

在 CentOS 8 上安装和部署 OpenSearch 2.17 的实战指南20240924
在 CentOS 8 上安装和部署 OpenSearch 2.17 的实战指南 引言 随着数据的快速增长,企业对高效搜索和分析工具的需求也在不断增加。OpenSearch 是由社区主导的搜索和分析引擎,它为大规模数据索引、日志分析、全文检索等场景提供了强大的支持。在这篇博客…...

青动CRM-E售后V2.0.4
CRM售后管理系统,旨在助力企业销售售后全流程精细化、数字化管理,主要功能:客户、合同、工单、任务、报价、产品、库存、出纳、收费,适用于:服装鞋帽、化妆品、机械机电、家具装潢、建材行业、快销品、母婴用品、办公用…...

免杀对抗—C++混淆算法shellcode上线回调编译执行
前言 上次讲了python混淆免杀,今天讲一下C混淆免杀。其实都大差不差的,也都是通过各种算法对shellcod进行混淆免杀,只不过是语言从python换成c了而已。 实验环境 测试环境依旧是360、火绒、WD还有VT。 shellcode上线 下面是最基本几个sh…...

考研数据结构——C语言实现插入排序
插入排序是一种简单直观的比较排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place(原地排序)&#…...

苍穹外卖学习笔记(十三)
三. 导入商品浏览功能代码 由于user的Controller与admin的相同,记得修改RestController注释 1. 查询分类 CategoryController package com.sky.controller.user;import com.sky.entity.Category; import com.sky.result.Result; import com.sky.service.Categor…...

如果没有pos信息,只有一些近景的照片,可以用编辑重建大师进行建模吗?
可以。软件在新建工程时,提供有无人机和近景的选择,选择为近景即可。 重建大师,这是一款专为超大规模实景三维数据生产设计的集群并行处理软件,支持卫星影像、航空影像、倾斜影像和激光点云多源数据输入建模,可完成超…...

智能感知,主动防御:移动云态势感知为政企安全护航
数字化时代,网络安全已成为企业持续运营和发展的重要基石。随着业务扩展,企业资产的数量急剧增加,且分布日益分散,如何全面、准确地掌握和管理资产成为众多政企单位的难题。同时,传统安全手段又难以有效应对新型、隐蔽…...

论文笔记(四十六)RobotGPT: Robot Manipulation Learning From ChatGPT
xx RobotGPT: Robot Manipulation Learning From ChatGPT 文章概括摘要I. 介绍II. 相关工作III. 方法论A. ChatGPT 提示机器人操作B. 机器人学习 IV. 实验A. 衡量标准B. 实验设置C. 模拟实验D. 真实机器人实验E. AB测试 V. 结论 文章概括 引用: article{jin2024r…...

docker - 镜像操作(拉取、查看、删除)
文章目录 1、docker search --help(用于显示 Docker 搜索命令的帮助信息)2、docker pull(拉取镜像)3、docker images (查看镜像)3.1、docker images --help(用于显示 Docker 镜像管理相关命令的帮助信息)3.…...

如何选择数据库架构
选择合适的数据库架构是一个复杂的过程,它取决于多种因素,包括应用程序的需求、数据量的大小、并发访问量、数据一致性要求、预算以及技术团队的熟悉程度等。以下是一些关键的步骤和考虑因素,帮助你选择合适的数据库架构: 1. 分析…...

Mysql高级篇(中)——锁机制
锁机制 一、概述二、分类1、读锁2、写锁⭐、FOR SHARE / FOR UPDATE(1)NOWAIT(2)SKIP LOCKED(3)NOWAIT 和 SKIP LOCKED 的比较 ⭐、 脏写3、表级锁之 S锁 / X锁(1)总结(2…...