对软件进行测试, 发现软件系统的问题
正确性: 软件是否有bug 是否会对用户操作、体验、造成影响
安全性: 权限,软件数据是否安全 是否会泄露用户隐私 软件是否会被恶意攻击 导致用户操作、体验、造成影响
软件质量: 用户的体验感觉 设计缺陷
让软件越来越好
软件测试是一种用来促进鉴定软件的正确性、完整性、安全性和质量的过程。它主要是一种实际输出与预期输出之间的审核或比较过程,旨在发现软件中的错误、缺陷或不符合设计要求的地方,并评估软件的整体质量。
软件测试的具体要求包括:
测试理论与实践知识:
测试类型与内容:
功能测试:验证软件的各项功能是否按照预期工作,检查产品是否达到用户要求的功能。
1000w 用户 - > tb 压力测试 响应时间是否达到预期2s
吞吐量: 程序在1s内能够同时处理多少个请求
资源占用:数据资源 100%
性能测试:评估软件在不同负载和压力下的性能表现,如响应时间、吞吐量、资源占用等。
淘宝 -> 电子券系统核销使用接口 系统->外部或子系统的接口
接口测试:主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。
1.安全性能
2.数据保护
3.访问控制
4.漏洞扫描
安全测试:评估软件的安全性能,包括数据保护、访问控制、漏洞扫描等方面。
不同的浏览器 谷歌 腾讯浏览器 360浏览器
手机、电脑
兼容性测试:检查软件在不同的操作系统、浏览器、硬件配置等环境下是否能正常运行。
用户体验: 操作流程是否简单 是否符合用户操作习惯
用户体验测试:评估软件的易用性、界面设计、交互逻辑等方面的优缺点。
编程语言与工具使用:
沟通与协作能力:
测试计划与执行:
持续学习与适应:
总之,软件测试是一项复杂而重要的工作,它要求测试人员具备扎实的测试理论知识、丰富的实践经验、良好的编程能力、熟练使用各种测试工具以及优秀的沟通与协作能力。通过这些努力,可以确保软件在发布前达到最佳的质量水平,满足用户的需求和期望。
什么是软件测试?软件测试具体要求做什么?
软件bug,在计算机科学中,指的是在计算机软件程序、操作系统或游戏等中存在的错误、缺陷、故障或漏洞,这些错误可能导致程序无法按照预期的方式运行,或者导致程序崩溃、数据丢失、功能异常或安全漏洞等问题。简而言之,软件bug是程序中不期望的行为或结果,它违反了程序的规格说明或设计意图。
软件bug可以出现在软件开发的各个阶段,包括需求分析、设计、编码、测试、部署和维护等。它们可以由多种原因引起,包括但不限于:
为了发现和修复软件bug,通常会进行一系列的测试活动,包括单元测试、集成测试、系统测试和验收测试等。这些测试旨在验证软件的正确性、可靠性和性能,并尽可能多地发现潜在的bug。
一旦软件bug被发现,通常会根据bug的严重性和影响范围来评估其优先级,并安排相应的开发人员进行修复。修复bug后,还需要重新进行测试,以确保修复没有引入新的问题,并且原有的bug已经被完全解决。
优先级
1.不影响用户体验 不会对用户数据造成影响 s
2.不影响用户体验 对用户数据造成影响 m
3.影响用户体验 对用户数据造成影响 b
4.影响多用户体验 对多用户数据造成影响 est
黑盒测试是一种测试方法,测试人员在不了解程序内部结构和代码的情况下,从用户的角度出发,通过输入各种可能的输入值来验证软件的功能和性能。常用的黑盒测试方法主要包括:
1)等价类划分:将输入数据划分为不同的等价类,选取代表性的数据进行测试。 2)边界值分析:针对输入或输出范围的边界进行测试,尤其聚焦于边界条件。 3)决策表测试:使用决策表来设计测试用例,确保覆盖所有可能的情况和组合。 4)因果图:用于处理输入条件和输出结果之间的依赖关系,生成测试用例。 5)状态迁移测试:测试不同状态之间的转移情况,适用于带有状态机的系统。
黑盒测试方法太多了,我从一些经典的测试方法展开讲讲。
1)等价类划分
2)边界值分析
3)决策表测试
4)因果图
5)状态迁移测试
当你的系统存在多个状态并且可以在这些状态之间转移时,你会用到这种方法。
比如一个简单的自动售票机:有"待机"、“选择票”、“付款”、"出票"四个状态,通过不同操作如按按钮、投币等行为在状态之间迁移。测试用例需覆盖所有状态以及状态转移。
美团点外卖: 1. 下单(选单、选择地址、选择电子券) 2.支付 (微信、支付宝、云闪付、银行卡) 3.商家接单 (打小票,语音提示,备餐)
4.骑手接单(骑手接单语音) 5. 骑手取货(到店) 6.骑手配送 7.骑手送达 8.用户评价
灰盒测试在实际场景中有着广泛的应用,以下是一些具体实例:
这些场景展示了灰盒测试在软件测试领域中的重要性和实用性。
白盒测试(White-Box Testing)是一种基于软件内部结构和实现方式的测试方法。它关注软件的逻辑流、数据处理和功能实现,主要面向代码级别的验证。那么,具体的方法有哪些呢?
1)语句覆盖:测试每一条语句至少被执行一次。 2)分支覆盖:每个条件分支(如 if-else 语句)至少被执行一次。 3)路径覆盖:测试每一条独立的路径,确保所有可能的逻辑路径都被执行。 4)条件覆盖:确保每个条件表达式的所有可能布尔值都至少被一次覆盖。 5)多条件覆盖:确保每种组合的条件表达式的结果都至少被一次覆盖。 6)路径覆盖与路径测试:通过遍历代码的所有独立路径,确保覆盖所有可能的执行路径。
在实施白盒测试的过程中,可以按照以下步骤来进行:
1)分析要求和设计:了解代码所实现的功能和逻辑。 2)设计测试用例:根据选定的测试方法,设计相应的测试用例,确保覆盖所有需要测试的代码部分。 3)编写和运行测试代码:根据设计的测试用例编写测试代码,并运行来检验功能和逻辑的正确性。 4)结果分析和报告:分析测试结果,找出缺陷并记录测试覆盖率,生成测试报告。 5)回归测试:对于发现的缺陷进行修复后,重新测试以确保问题已解决且没有引入新的问题。
说到白盒测试,不得不提各种常用的工具和框架,它们可以大大提高测试的效率和准确性。比如:
1)JUnit:这是用于Java的一个常用单元测试框架,非常方便编写和运行测试用例。 2)PyTest:这是Python中比较流行的测试框架,支持简单灵活的测试和丰富的扩展功能。 3)CppUnit:用于C++的单元测试框架,类似于JUnit,但针对C++特性做了相应调整。 4)CodeCoverage工具:如Covertura或JaCoCo,可以用来分析你的代码覆盖率,帮助你确定哪些部分仍未被测试。
此外,对于复杂的系统,白盒测试可能不够全面,此时应结合黑盒测试进行混合测试,以全面确保软件质量。黑盒测试关心的是输入输出的正确性,不关注代码内部实现,两者结合才能覆盖更多的测试维度,达到较高的测试质量保证。
定义:静态测试是指在不运行被测程序的情况下,通过分析或检查源程序的语法、结构、过程、接口等来检查程序的正确性。这种方法主要关注程序内部的逻辑和结构,以及代码是否符合编程标准和规范。
特点:
常见方法:
常用工具:
定义:单元测试(Unit Testing)是指对软件中的最小可测试单元进行检查和验证。在面向对象编程中,一个单元通常指的是一个类或一个方法。
目的:确保每个单元在独立于其他单元的情况下都能正常工作。
实施方法:
定义:集成测试(Integration Testing),也叫组装测试或联合测试,是在单元测试的基础上,将多个单元组合在一起进行测试。
目的:检查各个模块之间的接口是否正常工作,以及是否存在数据传递问题。
实施方法:
定义:系统测试(System Testing)是对整个系统的测试,将硬件、软件、操作人员看作一个整体,检验它是否有不符合系统说明书的地方。
目的:验证最终软件系统是否满足用户规定的需求。
实施方法:
定义:验收测试(Acceptance Testing)是部署软件之前的最后一个测试操作,也称为交付测试。
目的:确保软件准备就绪,并且可以让最终用户将其用于执行软件的既定功能和任务。
实施方法:
定义:
手工测试是由测试人员手动执行测试用例,并观察软件的行为和结果,以此来评估软件的质量和性能。它不需要编写额外的自动化脚本,而是依赖于测试人员的技能和经验来发现软件中的缺陷。
特点:
然而,手工测试也存在一些局限性,如测试效率相对较低、结果可能受到测试人员主观因素的影响等。
定义:
自动化测试是通过编写测试脚本或使用自动化测试工具来模拟用户操作,自动执行测试用例并验证测试结果的过程。它旨在提高测试效率、减少人为错误,并确保软件质量的一致性。
特点:
然而,自动化测试也需要一定的先期投入,包括测试脚本的编写、自动化工具的购买和维护等成本。此外,对于需求变化频繁的软件项目,自动化测试脚本的维护成本也可能较高。
手工测试和自动化测试各有优缺点,它们并不是对立的,而是可以相互补充的。在软件测试过程中,应根据项目的实际情况和需求来选择合适的测试方式。例如,在初期阶段可以更多地采用手工测试来快速发现和解决问题;在后期阶段则可以引入自动化测试来提高测试效率和确保软件质量的一致性。同时,随着技术的发展和工具的完善,未来可能会出现更多将手工测试和自动化测试相结合的新方法和新工具。
在软件测试领域,功能测试、接口测试、性能测试、安全测试、安装卸载测试和兼容性测试是六种常见的测试类型,每种测试都有其特定的目标和应用场景。以下是对这六种测试类型的详细解释:
定义:功能测试是对产品的各功能进行验证,确保产品达到用户要求的功能。它主要关注软件是否按照需求规格说明书的规定正常工作。
特点:
定义:接口测试是软件测试中的重要环节,它关注软件系统中不同模块之间的交互接口。
特点:
定义:性能测试是通过模拟生产运行的业务压力量和使用场景组合,来测试系统的性能是否满足软件的性能要求。
类型:
特点:
定义:安全测试是IT软件开发中的重要环节,旨在发现软件中的安全隐患。
特点:
定义:安装卸载测试是确保软件在正常情况下和异常情况的不同条件下,能够正确地进行安装和卸载。
特点:
定义:兼容性测试是在不同软件、硬件、操作系统、网络环境等多个平台上测试产品的兼容性质量,以确保软件在各种环境下的正常运行。
特点:
综上所述,这六种测试类型在软件测试过程中各司其职,共同确保软件的质量和稳定性。
定义:Web应用测试是指对Web网页应用程序进行验证和评估的过程,以确保其功能、性能和安全性符合预期。
特点:
定义:App软件测试是针对移动应用程序(如iOS和Android应用)进行的测试,以确保其在各种设备和网络环境下的稳定性和性能。
特点:
定义:PC应用测试是针对个人电脑(PC)上运行的应用程序进行的测试,以确保其在Windows、macOS等操作系统上的稳定性和性能。
特点:
定义:小程序测试是针对微信小程序、支付宝小程序等轻量级应用进行的测试,以确保其在不同设备和平台上的用户体验和性能。
特点:
综上所述,Web应用测试、App软件测试、PC应用测试和小程序测试在测试目标、测试环境和测试方法上各有侧重,但都是为了确保软件的质量和稳定性,提升用户体验。
定义:冒烟测试是在软件版本包出包之后,正式测试之前进行的一种预测试。它的目的是快速验证软件的基本功能是否正常,以决定是否能进行后续的正式测试工作。
特点:
定义:弱网测试是在网络环境不佳(如网络带宽小、丢包、延时等)的情况下对应用软件或系统进行的测试。
目的:
定义:并发互斥测试主要关注多个用户或进程同时访问系统时,系统能否正确处理数据并发和互斥访问,以保证数据的一致性和完整性。
测试内容:
定义:回归测试是指修改了旧代码或增加了新功能后,重新进行测试以确认修改没有引入新的错误或导致其他代码产生错误。
特点:
定义:随机测试主要是根据测试者的经验对软件进行功能和性能抽查。
特点:
定义:探索性测试是测试人员根据自己对软件的理解,自由地对软件进行测试,并在测试过程中不断调整测试策略和测试方法。
特点:
定义:权限测试主要关注系统对用户权限的控制是否准确有效,确保用户只能访问其被授权的资源。
测试内容:
这些测试类型在软件测试过程中各有侧重,共同构成了软件质量保证的重要手段。
测试计划是软件测试过程中的重要文档,它详细规划了测试活动的各个方面,以确保测试工作的全面、系统、有序进行。一个完整的测试计划通常包含以下内容:
描述通过测试要达到的具体目的,如功能测试、性能测试、安全性测试等,以确保软件或应用程序的各个方面都得到全面评估。
明确测试的具体范围,包括要测试的功能、模块、接口等,以及它们的优先级和测试顺序。
详细描述测试所需的软硬件环境,包括操作系统、数据库、网络环境、硬件设备等配置要求。
提供必要的测试数据,包括初始数据、中间数据和最终数据,以确保测试的全面性和准确性。这些数据应覆盖所有测试场景,以验证软件的稳定性和可靠性。
制定详细的测试进度表,包括每个测试阶段的开始和结束时间,以及关键节点的里程碑事件。这有助于跟踪测试进度,确保按时完成测试任务。
明确测试过程中的文档管理要求,包括测试计划、测试报告、缺陷跟踪等文档的编写、整理和提交。这些文档对于记录测试过程、分析测试结果和跟踪缺陷修复具有重要意义。
制定测试开始、挂起、恢复及结束的标准,以确保测试过程的规范性和一致性。这些标准有助于判断测试是否达到预期的效果和目标。
编写测试计划是一个系统而详细的过程,旨在确保软件测试活动的顺利进行和有效管理。以下是一个编写测试计划的详细步骤和要点:
测试计划文档应包含以下内容:
需求分析在软件开发过程中起着至关重要的作用,主要原因有以下几点:
进行需求分析是一个系统而详细的过程,旨在确保软件开发项目能够准确满足用户和业务的需求。以下是如何进行需求分析的具体步骤和方法:
提高需求分析能力是软件开发和项目管理中的关键技能,以下是一些建议和方法,可以帮助你提升这一能力:
测试用例(Test Case)是软件测试中的基本概念,它是一组为了特定目标而设计的测试输入、执行条件以及预期结果的文档或记录。测试用例用于指导测试执行人员如何对系统进行测试,以验证系统是否满足规定的需求,以及是否存在缺陷。
一个完整的测试用例通常包含以下几个部分:
测试用例的设计是软件测试过程中的关键活动之一,它直接影响测试的质量和效率。良好的测试用例应该具有全面性、代表性、可重复性和可追踪性等特点,以确保测试能够覆盖到系统的所有重要功能和场景,并且能够准确地发现潜在的缺陷。
测试用例的设计方法有很多,如等价类划分、边界值分析、因果图法、正交实验设计、场景法等,测试人员可以根据具体的测试需求和系统特点选择合适的设计方法。
编写测试用例在软件测试过程中起着至关重要的作用。以下是编写测试用例的几个主要作用:
综上所述,编写测试用例是软件测试过程中不可或缺的一环。它有助于确保测试的全面性、明确性、可重复性、可管理性和高效性,并为评估测试质量提供支持。
测试用例的设计方法多种多样,旨在全面、有效地验证软件的功能、性能和稳定性。以下是几种常用的测试用例设计方法:
以上是几种常用的测试用例设计方法,每种方法都有其适用的场景和优缺点。在实际测试过程中,测试人员可以根据项目的具体情况和需求选择合适的测试用例设计方法,以确保测试的全面性和有效性。
保证用例覆盖度是软件测试中至关重要的一环,它直接关系到软件质量的可靠性。以下是一些关键的策略和步骤,以确保测试用例能够全面覆盖软件系统的各个方面:
通过以上措施的实施,可以显著提高测试用例的覆盖度,从而保障软件系统的质量和可靠性。然而,需要注意的是,完全覆盖一个软件系统是不可能的,因此测试人员需要根据项目的实际情况和风险评估结果来设定合理的用例覆盖度目标,并持续努力改进和优化测试工作。
测试用例练手:xmind思维导图、excel测试用例
1.登录的测试用例 2.微信分享测试用例 3.电梯测试用例 4.饮料自动贩卖机的测试用例
BUG本意是臭虫、缺陷、损坏等意思,现在通常指在电脑系统或程序中隐藏着的、未被发现的缺陷或问题。这些缺陷或问题可能导致软件运行不正常、功能失效、死机、数据丢失或非正常中断等现象。在中文中,BUG常被称作“缺陷”,这一术语更能反映事情的本质,即程序本身存在的问题或偏差。
BUG在软件中的具体表现可能包括:
BUG对软件的质量和用户体验产生负面影响,因此需要及时进行修复。根据BUG的严重程度和影响范围,可以将其分为不同的等级,如严重、一般、轻微等。同时,BUG还可以根据其产生的原因和性质进行分类,如代码错误、设计缺陷、配置问题等。
提交BUG的规范以及包含的要素对于确保软件开发团队能够有效地跟踪、理解和修复问题至关重要。以下是根据多个来源整理的提交BUG规范及包含的关键要素:
BUG(缺陷)的管理方法是软件开发过程中的重要环节,它涉及发现、报告、跟踪和解决软件中的缺陷。以下是一套系统的BUG管理方法:
在软件测试过程中,测试人员一旦发现缺陷,需要准确地记录缺陷的详细信息,这些信息通常包括:
测试团队会对每个缺陷进行分类和分级,常见的分类包括:
分级则根据缺陷的严重程度和影响范围进行划分,如致命、严重、一般、轻微等。
一旦缺陷被报告,测试团队需要将其分配给相应的开发人员或团队进行修复。分配时通常会考虑开发人员的专业领域、负责的模块或功能等因素。
跟踪缺陷是确保缺陷得到及时解决的关键步骤。测试团队会使用缺陷跟踪系统或工具来记录缺陷的状态、解决进度和相关讨论等信息。这有助于团队成员之间的沟通和协作,并确保缺陷得到适时处理。常见的缺陷跟踪状态包括:
开发人员接收到分配的缺陷后,会进行相应的修复工作。修复完成后,测试团队会重新测试相关功能或模块,以确认缺陷是否已经得到解决。
一旦缺陷被修复并且经过验证,测试团队会将其标记为已关闭。此时,缺陷报告中的状态将被更新为已解决,并且相关的文档和记录也会进行更新。
测试团队可以根据缺陷报告和缺陷跟踪系统中的数据生成报告,以便评估软件质量、发现潜在的趋势和改进测试过程。这有助于团队在未来的开发过程中避免类似缺陷的出现,提高软件的整体质量。
input(键盘、鼠标等等)
output (屏幕、音响等等)
操作系统是计算机软硬件系统的中枢,常见的操作系统有多种,以下是一些主要的操作系统:
1.网线 2.光纤 3. 单位 4.物理IP、内网IP、子网掩码、网关 5.协议
CPU处理器 : Intel i5-13490F 核心数 10 (6P+4E) 线程数 16 (12P+4E)工艺 Intel 7 AMD 控制器、处理器
i3入门 i5初级 i7高级 i9旗舰 代数 级别 F无核显 K超频 S顶级
内存条: DDR5 5000-8000 hz 依赖于主板支持什么
DDR4 2000-4000 hz 虚拟内存 物理内存
核心数: CPU一共有多少个核心同时处理任务
线程:CPU可以同时处理多少个任务
进程:一个程序线程包含很多个进程->子任务
一、文件和命令
1、cd 命令
(它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径)
cd /home 进入 ‘/ home’ 目录
cd .. 返回上一级目录
cd ../.. 返回上两级目录
cd / 返回跟目录
cd - 返回上次所在的目录
mkdir <目录名> 创建目录
mkdir dir1 dir2 同时创建两个目录
mkdir -p /tmp/dir1/dir2 递归创建目录树
rm -f file1 删除’file1’⽂件
rmdir dir1 删除’dir1’⽬录
rm -rf dir1 删除’dir1’⽬录和其内容
-rm -rf dir1 dir2 同时删除两个⽬录及其内容
2、pwd 命令
pwd 显示工作路径
3、ls 命令
ls 查看目录中的文件
ls -l 显示文件和目录的详细资料
ls -a 列出全部文件,包含隐藏文件
ls -lh 查看⽂件和⽬录的详情列表(增强⽂件⼤⼩易读性)
ls -lSr 查看⽂件和⽬录列表(以⽂件⼤⼩升序查看)
tree 查看⽂件和⽬录的树形结构 (如果没有需要先安装 yum install tree)
ls -R 连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
ls -al /proc/pid/exe 通过pid查询程序正在运行的路径
4、cp 命令
(用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下)
-a 将文件的特性一起复制
-p 连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
-i 若目标文件已经存在时,在覆盖时会先询问操作的进行
-r 递归持续复制,用于目录的复制行为
-u 目标文件与源文件有差异时才会复制
-cp dir/* . 复制某目录下的所有文件至当前目录
cp -a dir1 dir2 复制目录
cp -a /temp/dir1 . 复制一个目录至当前目录
ln -s file1 link1 创建指向⽂件/⽬录的软链接
ln file1 lnk1 创建指向⽂件/⽬录的物理链接
touch -t 0712250000 file1 修改一个文件或目录的时间戳 - (YYMMDDhhmm)
5、mv 命令
-f force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
-i 若目标文件已经存在,就会询问是否覆盖
-u 若目标文件已经存在,且比目标文件新,才会更新
1 old_dir new_dir 重命名/移动⽬录
6、rm 命令
-f :就是force的意思,忽略不存在的文件,不会出现警告消息
-i :互动模式,在删除前会询问用户是否操作
-r :递归删除,最常用于目录删除,它是一个非常危险的参数
二、查看文件内容
7、cat 命令
(用于查看文本文件的内容,后接要查看的文件名,通常可用管道与 more 和 less 一起使用)
cat file1 从第一个字节开始正向查看文件的内容
cat -n file1 标示文件的行数
cat xxx.txt awk ‘NR%2==1’
tac file1 从最后一行开始反向查看一个文件的内容
more file1 查看一个长文件的内容
less file1 类似 more 命令,但允许方向操作
head -n 2 file1 查看一个文件的前两行
tail -f /log/msg 实时查看添加到⽂件中的内容
tail -n 2 file1 查看一个文件的最后两行
tail -n +1000 file1 从1000行开始显示,显示1000行以后的
cat filename | head -n 3000 | tail -n +1000 显示1000行到3000行
cat filename | tail -n +3000 | head -n 1000 从第3000行开始,显示1000(即显示3000~3999行)
grep ss hello.txt 在⽂件hello.txt中查找关键词 ss
grep ^s hello.txt 在⽂件hello.txt中查找以 s 开头的内容
grep [0-9] hello.txt 选择hello.txt⽂件中所有包含数字的⾏
sed 's/ss/mm/g' hello.txt 将hello.txt⽂件中的 ss 替换成 mm
sed '/^$/d' hello.txt 从hello.txt⽂件中删除所有空⽩⾏
sed '/ *#/d; /^$/d' hello.txt 从hello.txt⽂件中删除所有注释和空⽩⾏
sed -e '1d' hello.txt 从⽂件hello.txt 中排除第⼀⾏
sed -n '/s1/p' hello.txt 查看只包含关键词"s1"的⾏
sed -e 's/ *$//' hello.txt 删除每⼀⾏最后的空⽩字符
sed -e 's/s1//g' hello.txt 从⽂档中只删除词汇s1并保留剩余全部
sed -n '1,5p;5q' hello.txt 查看从第⼀⾏到第5⾏内容
sed -n '5p;5q' hello.txt 查看第5⾏
paste file1 file2 合并两个⽂件或两栏的内容
paste -d '+' file1 file2 合并两个⽂件或两栏的内容,中间⽤"+"区分
sort file1 file2 排序两个⽂件的内容
sort file1 file2 uniq
sort file1 file2 uniq -u
sort file1 file2 uniq -d
comm -1 file1 file2 ⽐较两个⽂件的内容(去除’file1’所含内容)
comm -2 file1 file2 ⽐较两个⽂件的内容(去除’file2’所含内容)
comm -3 file1 file2 ⽐较两个⽂件的内容(去除两⽂件共有部分)
三、文件搜索
8、find 命令
find / -name file 从根目录开始搜索文件/目录
find / -user user1 搜索用户 user1 的文件/目录
find /dir -name *.bin 在目录/dir 中搜索带有 .bin 后缀的文件
find / -name file1 从 ‘/’ 开始进入根文件系统搜索文件和目录(完整文件或文件名)
find / -user user1 搜索属于用户 ‘user1’ 的文件和目录
find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件
find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件
find . -regex '.*\(net\|comm\).*' ‘-regex’ 选项匹配整个路径名,出当前目录树中所有文件名中任意位置包含字符串 net 或 comm 的文件
locate *.mp4 寻找 .mp4结尾的文件
whereis <关键词> 显示某⼆进制⽂件/可执⾏⽂件的路径
whereis halt 显示一个二进制文件、源码或man的位置
which <关键词> 查找系统⽬录下某的⼆进制⽂件
which halt 显示一个二进制文件或可执行文件的完整路径
四、文件的权限 - 使用 “+” 设置权限,使用 “-” 用于取消
9、chmod 命令
ls -lh 显示当前目录所有文件的权限
chmod 777 文件名 修改文件权限(最高权限)
chmod ugo+rwx dir 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r,4 )、写(w,2)和执行(x,1)的权限
chmod go-rwx dir1 删除群组(g)与其他人(o)对目录的读写执行权限
chmod u+s /bin/file1 设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限
chmod u-s /bin/file1` 禁用一个二进制文件的 SUID位
chmod g+s /home/public 设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的
chmod g-s /home/public 禁用一个目录的 SGID 位
chmod o+t /home/public 设置一个文件的 STIKY 位 - 只允许合法所有人删除文件
chmod o-t /home/public 禁用一个目录的 STIKY 位
chmod +x 文件路径 为所有者、所属组和其他用户添加执行的权限
chmod -x 文件路径 为所有者、所属组和其他用户删除执行的权限
chmod u+x 文件路径 为所有者添加执行的权限
chmod g+x 文件路径 为所属组添加执行的权限
chmod o+x 文件路径 为其他用户添加执行的权限
chmod ug+x 文件路径 为所有者、所属组添加执行的权限
chmod =wx 文件路径 为所有者、所属组和其他用户添加写、执行的权限,取消读权限
chmod ug=wx 文件路径 为所有者、所属组添加写、执行的权限,取消读权限
10、chown 命令
(改变文件的所有者)
chown user1 file1 改变一个文件的所有人属性
chown -R user1 dir1 改变一个目录的所有人属性并同时改变改目录下所有文件的属性
chown user1:group1 file1 改变一个文件的所有人和群组属性
11、chgrp 命令
(改变文件所属用户组)
chgrp group1 file1 改变文件的群组
五、文本处理
12、grep 命令
(分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等)
grep Aug /var/log/messages 在文件 '/var/log/messages’中查找关键词"Aug"
grep ^Aug /var/log/messages 在文件 '/var/log/messages’中查找以"Aug"开始的词汇
grep [0-9] /var/log/messages 选择 ‘/var/log/messages’ 文件中所有包含数字的行
grep Aug -R /var/log/* 在目录 ‘/var/log’ 及随后的目录中搜索字符串"Aug"
sed 's/stringa1/stringa2/g' example.txt 将example.txt文件中的 “string1” 替换成 “string2”
sed '/^$/d' example.txt 从example.txt文件中删除所有空白行
13、paste 命令
paste file1 file2 合并两个文件或两栏的内容(查看两文件合并后的内容)
paste -d '+' file1 file2 合并两个文件或两栏的内容,中间用"+"区分
14、sort 命令
sort file1 file2 排序两个文件的内容
sort file1 file2 | uniq 取出两个文件的并集(重复的行只保留一份)
sort file1 file2 | uniq -u 删除交集,留下其他的行
sort file1 file2 | uniq -d 取出两个文件的交集(只留下同时存在于两个文件中的文件)
15、comm 命令
comm -1 file1 file2 比较两个文件的内容只删除 ‘file1’ 所包含的内容
comm -2 file1 file2 比较两个文件的内容只删除 ‘file2’ 所包含的内容
comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部
六、打包和压缩文件
16、tar 命令
对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压)推荐
-c :新建打包文件
-t :查看打包文件的内容含有哪些文件名
-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
-j :通过bzip2的支持进行压缩/解压缩
-z :通过gzip的支持进行压缩/解压缩
-v :在压缩/解压缩过程中,将正在处理的文件名显示出来
-f filename :filename为要处理的文件
-C dir :指定压缩/解压缩的目录dir
压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称
查询:tar -jtv -f filename.tar.bz2
解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
bunzip2 file1.bz2 解压一个叫做 'file1.bz2’的文件
bzip2 file1 压缩一个叫做 ‘file1’ 的文件
gunzip file1.gz 解压一个叫做 'file1.gz’的文件
gzip file1 压缩一个叫做 'file1’的文件
gzip -9 file1 最大程度压缩
rar a file1.rar test_file 创建一个叫做 ‘file1.rar’ 的包
rar a file1.rar file1 file2 dir1 同时压缩 ‘file1’, ‘file2’ 以及目录 ‘dir1’
rar x file1.rar 解压rar包
zip file1.zip file1 创建一个zip格式的压缩包
unzip file1.zip 解压一个zip格式压缩包
zip -r file1.zip file1 file2 dir1 将几个文件和目录同时压缩成一个zip格式的压缩包
#查看当前系统的信息
uname -a
#切换管理员账号
su root
#查看当前文件夹下所有文件的信息
ll
#移动文件夹并重命名
mv 文件夹路径 新路径
数据库(Database)是存储和组织数据的一种结构化方式,使得数据的访问、管理和更新变得更加高效和便捷。以下是数据库的一些基本概念:
官网下载页面地址:
https://downloads.mysql.com/archives/community/
Product Version 选择 5.7.39
;
Operating System 选择 Linux Generic
;
OS Version 选择 Linux - Generic (glibc 2.12) (x86, 64-bit)
;
下载 mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz
。
此版本的下载链接:
https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz
为 MySQL 创建单独的属组、用户,把安装目录属主改为mysql。
在MySQL启动的时候,单进程mysqld,该进程的属主就是mysql,这样就保证了mysql服务的独立性。
即使mysql服务被黑掉,得到了mysql用户权限,也不会影响整个系统的安全。
# 创建新数组 mysql
groupadd mysql
# 创建用户 mysql ,指定属组为 mysql,禁止其登录
useradd -r -g mysql mysql -s /sbin/nologin
# 创建安装目录
mkdir /usr/local/mysql
将安装包 mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz
上传到 /root/
目录。
# 进入到root目录
cd root
# 解压
tar -zxvf mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz
# 将解压后的mysql文件挪到创建的安装目录
mv /root/mysql-5.7.39-linux-glibc2.12-x86_64/* /usr/local/mysql/
创建所需目录
# 创建数据存储目录
mkdir /usr/local/mysql/data/
# 创建数据日志目录
mkdir /usr/local/mysql/log/
# 创建临时文件目录
mkdir /usr/local/mysql/tmp/
# 创建运行文件目录
mkdir /usr/local/mysql/run/
# 创建启动错误日志
touch /usr/local/mysql/log/mysqld_safe_error.log
# 创建默认的错误日志目的地
touch /usr/local/mysql/log/alert.log
# 创建慢查询日志文件
touch /usr/local/mysql/log/slow.log
# 创建通用查询日志文件的
touch /usr/local/mysql/log/general.log
编辑配置文件
vi /etc/my.cnf
将以下内容写入配置文件 /etc/my.cnf
# mysqld_safe脚本启动时读取的配置
[mysqld_safe]
# 存放 MySQL 后台程序 pid 的文件位置
pid-file=/usr/local/mysql/run/mysqld.pid
# 启动错误日志
log-error=/usr/local/mysql/log/mysqld_safe_error.log
# 本地 mysql 客户端程序的配置块
[mysql]
# 本地 mysql 客户端连接的端口
port=3306
# 本地 mysql 客户端命令行提示信息
prompt=\\u@\\d \\r:\\m:\\s>
# 本地 mysql 客户端字符集
default-character-set=utf8mb4
# 开启命令补全
no-auto-rehash
# 所有mysql客户端程序读取的配置块
[client]
# 连接端口
port=3306
# mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体文件
socket=/usr/local/mysql/run/mysql.sock
# mysql服务端程序mysqld、mysqld_safe和mysqld_multi的配置文件
[mysqld]
# 进程崩溃时生成core file dump文件,便于程序调试和问题排查
core-file
# 该参数指定了安装 MySQL 的安装路径(mysql安装目录),填写全路径可以解决相对路径所造成的问题。
basedir=/usr/local/mysql
# 该参数指定MySQL的数据文件的存放目录,数据库文件即我们常说的 MySQL data 文件。
datadir=/usr/local/mysql/data
# 临时目录
tmpdir=/usr/local/mysql/tmp
# 用于错误消息的区域设置。默认值是en_US。服务器将参数转换为语言名,并将其与lc_messages_dir的值结合,以生成错误消息文件的位置。
lc_messages=zh_CN
# 错误消息所在的目录。服务器使用该值和lc_messages的值来生成错误消息文件的位置。
lc_messages_dir=/usr/local/mysql/share
# 默认的错误日志目的地。如果目标是控制台,则值为stderr。否则,目标是一个文件,log_error值是文件名。
log-error=/usr/local/mysql/log/alert.log
# 慢查询日志文件名。默认值是host_name-slow.log,但可以通过slow_query_log_file选项更改初始值。
slow_query_log_file=/usr/local/mysql/log/slow.log
# 通用查询日志文件的名称。默认值是host_name.log,但初始值可以通过general_log_file选项更改。
general_log_file=/usr/local/mysql/log/general.log
# mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体文件
socket=/usr/local/mysql/run/mysql.sock
# 服务端字符集
character-set-server=utf8mb4
# 此变量控制写入错误日志的消息中的时间戳的时区,以及写入文件的一般查询日志和慢查询日志消息中的时间戳的时区。
log_timestamps=SYSTEM
# 操作系统中可用于mysqld的文件描述符的数量。
open_files_limit=61535
# 同时允许的最大客户端连接数。
max_connections=1000
# mysql_stmt_send_long_data() C API函数发送的一个包或任何生成/中间字符串的最大大小,或任何参数的最大大小。默认是64MB。
max_allowed_packet=1G
# 如果设置为0,表名将按指定的方式存储,并且比较区分大小写。如果设置为1,表名将以小写形式存储在磁盘上,比较不区分大小写。如果设置为2,则表名按给定值存储,但以小写进行比较。此选项也适用于数据库名称和表别名。
lower_case_table_names=1
# 慢查询日志是否开启。取值为0(或OFF)表示关闭日志,取值为1(或ON)表示打开日志。默认值取决于是否给出——slow_query_log选项。日志输出的目标由log_output系统变量控制;如果该值为NONE,则即使启用了日志,也不会写入任何日志项。
slow_query_log=1
# validate_password插件的加载方法
plugin-load-add=validate_password.so
# validate-password在服务器启动时使用该选项来控制插件的激活
validate-password=FORCE_PLUS_PERMANENT
# 将安装目录的所有权授予用户、属组 mysql:mysql
chown -R mysql:mysql /usr/local/mysql
# 初始化数据库
cd /usr/local/mysql
./bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
# 再次将安装目录的所有权授予用户、属组 mysql:mysql
chown -R mysql:mysql /usr/local/mysql
# 将安装目录的 rwx 授予其所属用户mysql
chmod u+wrx -R /usr/local/mysql
接下来打印的日志中,localhost@root:
后面的内容,就是本机root用户的初始密码,需要记录下来。
初始密码:i5xUY_9KcHqk
。
如需重新初始化,需要清空 /usr/local/mysql/data
目录。
把启动脚本 mysql.server
放到开机初始化目录 /etc/init.d/
,同时改名为 mysqld
。
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
# 启动mysql服务
service mysqld start
其他相关命令
# 停止mysql服务
service mysqld stop
# 重启mysql服务
service mysqld restart
# 查看mysql服务是否启动
service mysqld status
登录MySQL
# 进入MySQL安装目录
cd /usr/local/mysql/
# 登录MySQL
./bin/mysql -u root -p
# 密码是前面记录的初始密码
# 如果前面没有记下,可以使用下面命令查询mysql初始密码
# grep -e 'temporary' /usr/local/mysql/log/alert.log
设置root密码
此处将root的密码设置为 123456
(按个人需求设置),将此处设置的新密码进行妥善记录。
-- 设置密码验证安全级别
set global validate_password_policy=LOW;
-- 设置密码验证最小长度
set global validate_password_length=6;
-- 设置密码为123456(根据自己的想法设置)
alter user root@localhost identified by '123456';
降低密码验证等级
-- 查看密码验证规则
SHOW VARIABLES LIKE 'validate_password%';
设置允许远程访问
-- 选择 mysql 库
use mysql;
-- 将 root 用户的可访问主机改为 %,即任何主机
update user set user.Host='%' where user.User='root';
-- 执行生效指令
flush privileges;
-- 退出登录
exit;
防火墙放行MySQL监听的端口
# 防火墙放行 3306 tcp 端口
firewall-cmd --zone=public --add-port=3306/tcp --permanent
# 防火墙重新加载
firewall-cmd --reload
在安装 MySQL 的机器登录
# 进入MySQL安装目录
cd /usr/local/mysql/
./bin/mysql -u root -p
# 密码是新设置的密码
简单使用
# 查看所有库
show databases;
# 选择一个库
use sys;
# 查看所有表
show tables;
# 查看一张表的所有数据
select * from sys_config;
# 退出登录
exit;
关系型数据库
MySQL
Microsoft SQL Server
Oracle
非关系型数据库
1)需求分析阶段:明确软件要解决的问题,定义具体的功能需求和性能需求。 产品经理
2)设计阶段:架构设计和详细设计。确立软件的整体架构和模块之间的接口,随后进入具体模块和流程设计。 UI/UX工程师 架构师
3)编码阶段:根据设计文档进行实际编码,将设计转换为可执行的软件。 前端/后端开发
4)测试阶段:对编码完成的软件进行功能、性能和安全方面的全面测试,确保软件质量。 测试工程师
5)安装和部署阶段:将测试合格的软件部署到用户环境中,让用户开始使用。 运维工程师
6)维护阶段:对已经部署的软件进行后续支持和维护,修复发现的缺陷或添加新的功能需求。 运维工程师 开发/测试
7)退役阶段:软件已不再使用,进行遗留数据处理和系统关闭。 运维工程师
本地环境(Local Environment):
也称为dev或开发环境,是开发人员在自己的计算机上搭建的用于编写和初步测试代码的环境。这个环境通常包含开发所需的所有工具和库,以便开发人员能够高效地编写和调试代码。
测试环境(Test Environment):
专门用于测试人员执行测试用例的环境。测试环境通常与生产环境相似,但可能不包含生产环境中的全部数据或用户。测试环境用于验证软件的功能、性能、安全性和稳定性,确保软件在发布前能够满足所有需求。
预发布环境(Staging Environment):
也称为预生产环境或QA环境,是软件在正式发布到生产环境之前进行最终测试和验证的环境。预发布环境通常与生产环境非常接近,包括相同的硬件、操作系统、网络配置和数据库等。这个环境用于模拟生产环境,以便在软件正式上线前发现并解决潜在的问题。
生产环境(Production Environment):
也称为线上环境或正式环境,是软件最终运行的环境,面向真实的用户和数据。生产环境需要高度稳定和安全,以确保软件能够持续、可靠地为用户提供服务。
9 月 14 日,阿里云盘被曝出存在一个“灾难级的严重 bug”。有用户偶然发现,在阿里云盘的相册功能中,只要创建一个文件夹,然后在分类选择图片这一操作下,竟然可以看到其他用户云盘里的图片。
a用户竟然看到b用户云盘隐私????
1. 权限的问题 a用户——> b用户 前端a用户访问-> b用户属性到后端 后端没有校验 a->b用户的数据 越权的问题
2. 前端没有去处理权限, 后端也没有处理权限问题