深度——进程管理和计划任务

目录

一、查看进程信息相关命令

1、ps-查看静态的进程统计信息

1.1 查看静态的进程统计信息

1.2 例子

1.2.1查看进程的特定属性

1.2.2 按CPU利用率倒序排序

1.2.3 排序,查找占用最多内存和CPU的进程

1.2.4 思考:找到未知进程的执行程序文件路径

1.2.5 查看进程信息 prtstat

2、top-查看动态的进程排名信息

3、pgrep-根据特定条件查询进程PID信息

4、pstree-以树形结构列出进程信息

5、lsof-列出打开的文件

6、vmstat-监控系统资源

二、查看系统性能

1、内存

2、cpu使用率

3、磁盘容量

4、磁盘读写

5、网卡流量

三、进程管理

1、手动启动

2、进程的前后台调度

2.1 "命令 &",把命令放入后台执行

2.2  jobs命令

2.3 fg命令

3、结束进程

3.1 kill

3.2  killall

3.3  pkill命令

四、计划任务管理

1、at-设置一次性计划任务

2、crontab-设置周期性计划任务

进程的管理主要是指进程的关闭与重启。我们一般关闭或重启软件,都是关闭或重启它的程序,而不是直接操作进程的。比如,要重启 apache 服务,一般使用命令"service httpd restart"重启 apache的程序。

那么,可以通过直接管理进程来关闭或重启 apache 吗?答案是肯定的,这时就要依赖进程的信号(Signal)了。我们需要给予该进程 信号,告诉进程我们想要让它做什么。

系统中可以识别的信号较多,我们可以使用命令"kill -l"或"man 7 signal"来查询

代号信号名称说 明
1SIGHUP该信号让进程立即关闭.然后重新读取配置文件之后重启
2SIGINT程序中止信号,用于中止前台进程。相当于输出 Ctrl+C 快捷键
3SIGQUIT退出
8SIGFPE在发生致命的算术运算错误时发出。不仅包括浮点运算错误,还包括溢出及除数为 0 等其他所有的算术运算错误
9SIGKILL用来立即结束程序的运行。本信号不能被阻塞、处理和忽略。般用于强制中止进程
14SIGALRM时钟定时信号,计算的是实际的时间或时钟时间。alarm 函数使用该信号
15SIGTERM正常结束进程的信号,kill 命令的默认信号。如果进程已经发生了问题,那么这 个信号是无法正常中止进程的,这时我们才会尝试 SIGKILL 信号,也就是信号 9
18SIGCONT该信号可以让暂停的进程恢复执行。本信号不能被阻断
19SIGSTOP该信号可以暂停前台进程,相当于输入 Ctrl+Z 快捷键。本信号不能被阻断

一、查看进程信息相关命令

1、ps-查看静态的进程统计信息

--查看静态的进程状态

ps 即 process state,可以查看进程当前状态的快照,默认显示当前终端中的进程,Linux系统各进程的相关信息均保存在/proc/数字 目录/status 下的文件中。

支持三种选项:

  • UNIX选项 如: -A -e

  • GNU选项 如: --help

  • BSD选项 如: a

查看静态的进程统计信息

  • "ps aux"  可以查看系统中所有的进程;

  • "ps -le"    可以查看系统中所有的进程,而且还能看到进程的父进程的 PID 和进程优先级;

  • "ps -l"      只能看到当前 Shell 产生的进程;

常用选项

a显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将示系统中所有的进程信息。
u使用以用户为主的格式输出进程信息。
x显示当前用户在所有终端下的进程信息
-e显示系统内的所有进程信息。
-l使用长(Long)格式显示进程信息。
-f使用完整的(Full)格式显示进程信。
k|--sort 属性对属性排序,属性前加 - 表示倒序 ps aux k -%cpu
o 属性…选项显示定制的信息 pid、cmd、%cpu、%mem

1.1 查看静态的进程统计信息

ps aux
表头含义
USER该进程是由哪个用户产生的。
PID进程的 ID。
%CPU该进程占用 CPU 资源的百分比,占用的百分比越高,进程越耗费资源。
%MEM该进程占用物理内存的百分比,占用的百分比越高,进程越耗费资源。
VSZ该进程占用虚拟内存的大小,单位为 KB。
RSS该进程占用实际物理内存的大小,单位为 KB。
TTY

该进程是在哪个终端运行的。其中,tty1 ~ tty7 代表本地控制台终端(可以通过 Alt+F1 ~ F7 快捷键切换不同的终端),tty1~tty6 是本地的字符界面终端,tty7 是图形终端。pts/0 ~ 255 代表虚拟终端,一般是远程连接的终端,第一个远程连接占用 pts/0,第二个远程连接占用 pts/1,依次増长。?代表和终端无关,系统进程

STAT

进程状态。常见的状态有以下几种:

-D:不可被唤醒的睡眠状态,通常用于 I/O 情况。

-R:该进程正在运行。

-S:该进程处于睡眠状态,可被唤醒。

-T:停止状态,可能是在后台暂停或进程处于除错状态。

-W:内存交互状态(从 2.6 内核开始无效)。

-X:死掉的进程(应该不会出现)。

-Z:僵尸进程。进程已经中止,但是还是占用硬件资源,但是不多。

-<:高优先级(以下状态在 BSD 格式中出现)。

-N:低优先级。

-L:被锁入内存。

-s:包含子进程。

-l:多线程(小写 L)。

-+:位于后台。

START该进程的启动时间。
TIME该进程占用 CPU 的运算时间,注意不是系统时间。
COMMAND产生此进程的命令名。
ps-ef 命令输出信息
表头含义
F进程标志,说明进程的权限,常见的标志有两个: 1:进程可以被复制,但是不能被执行;4:进程使用超级用户权限;
S进程状态。具体的状态和"psaux"命令中的 STAT 状态一致;
UID运行此进程的用户的 ID;
PID进程的 ID;
PPID父进程的 ID;
C该进程的 CPU 使用率,单位是百分比;
PRI进程的优先级,数值越小,该进程的优先级越高,越早被 CPU 执行;系统定义不可以人为修改
NI进程的优先级,数值越小,该进程越早被执行;可以人为修改
ADDR该进程在内存的哪个位置;
SZ该进程占用多大内存;
WCHAN该进程是否运行。"-"代表正在运行;
TTY该进程由哪个终端产生;
TIME该进程占用 CPU 的运算时间,注意不是系统时间;
CMD产生此进程的命令名;

1.2 例子

#查看进程的特定属性
ps axo pid,cmd,%mem,%cpu

#按CPU利用率倒序排序
ps aux k -%cpu
dd if=/dev/zero of=/dev/null
#模拟cpu忙

#排序,查找占用最多内存和CPU的进程
ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%mem | head
ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%cpu | head
#按内存倒序排序
ps axo pid,cmd,%cpu,%mem --sort %mem

查看进程信息 prtstat
#prtstat 18395
1.2.1查看进程的特定属性

1.2.2 按CPU利用率倒序排序

 --模拟cpu忙

1.2.3 排序,查找占用最多内存和CPU的进程

1.2.4 思考:找到未知进程的执行程序文件路径

[root@localhost ~]#ps aux k -%cpu |head

#运行的程序会占cpu,按cpu利用率降序排列

[root@localhost ~]#ll /proc/26314/exe
#在/proc这个文件夹下面查看这个可执行文件

1.2.5 查看进程信息 prtstat
prtstat PID号

2、top-查看动态的进程排名信息

  • 相当于windows中的任务管理器
  • top 命令的输出内容是动态的,默认每隔 3 秒刷新一次。
选项功能
-d 秒数指定 top 命令每隔几秒更新。默认是 3 秒;
-b使用批处理模式输出。一般和"-n"选项合用,用于把 top 命令重定向到文件中;
-n 次数指定 top 命令执行的次数。一般和"-"选项合用;
-p 进程PID仅查看指定 ID 的进程;
-s使 top 命令在安全模式中运行,避免在交互模式中出现错误;
-u 用户名只监听某个用户的进程;

top 命令的输出内容是动态的,默认每隔 3 秒刷新一次。命令的输出主要分为两部分:

  1. 第一部分是前五行,显示的是整个系统的资源使用状况,我们就是通过这些输出来判断服务器的资源使用状态的;
  2. 第二部分从第六行开始,显示的是系统中进程的信息;

第一行:任务队列信息

15:58:16 系统时间
up 1:49系统已运行时长,本机己经运行 1 小时49 分钟
2 users当前登录用户数,本机两个
load average:0.00,0.01,0.05系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟、5分钟、15分钟前到现在的平均值

第二行:进程信息

Tasks总进程数
running正在运行的进程数
sleeping休眠的进程数
stopped中止的进程数
zombie僵死的进程数
第三行:CPU信息

Cpu(s):

0.0 %us

用户模式占用的 CPU 百分比
0.0%sy系统模式占用的 CPU 百分比
0.0%ni改变过优先级的用户进程占用的 CPU 百分比
100.0%id空闲 CPU 占用的 CPU 百分比
0.0%wa等待输入/输出的进程占用的 CPU 百分比
0.0%hi硬中断请求服务占用的 CPU 百分比
0.0%si软中断请求服务占用的 CPU 百分比
0.0%stst(steal time)意为虚拟时间百分比,就是当有虚拟机时,虚拟 CPU 等待实际 CPU 的时间百分比
第四行:内存信息

Mem:

3865308 total

物理内存的总量,单位为KB

3018352 free

空闲的物理内存数量。
357804 used己经使用的物理内存数量
489152 buff/cache作为缓冲的内存数量

第五行:行为交换空间的信息

Swap:

4194300 total

交换分区(虚拟内存)的总大小

0 used已经使用的交换分区的大小
4194300 free空闲交换分区的大小
3206440  cached作为缓存的交换分区的大小
第六行:进程信息解释

PID进程的IDS进程状态
USER该进程所属的用户%CPU占用CPU的百分比
PR NI优先级,数值越小,优先级越高%MEM占用内存的百分比
VIRT虚拟内存大小KBTIME+占用的CPU时间
RES物理内存大小KBCOMMAND进程的命令名
SHR共享内存大小KB

在 top 命令的显示窗口中,还可以使用如下按键,进行一下交互操作

按键交互作用
? 或 h显示交互模式的帮助;
c按照 CPU 的使用率排序,默认就是此选项;
M按照内存的使用率排序;
N按照 PID 排序;
T按照 CPU 的累积运算时间排序,也就是按照 TIME+ 项排序;
k按照 PID 给予某个进程一个信号。一般用于中止某个进程,信号 9 是强制中止的信号;
r按照 PID 给某个进程重设优先级(Nice)值;
q退出 top 命令;

3、pgrep-根据特定条件查询进程PID信息

查看指定的进程

  • -U 指定用户

  • -l: 显示进程名

  • -a: 显示完整格式的进程名

  • -P pid: 显示指定进程的子进程

pidof 已知程序名,查找pid号

4、pstree-以树形结构列出进程信息

pstree   [OPTION] [ PID | USER ]                                                                                                                                             
常用选项
-a               显示启动每个进程对应的完整指令,包括启动进程的路径、参数等
-p               显示PID
-T               不显示线程thread,默认显示线程
-u               显示用户切换
-H  pid号    高亮显示指定进程及其前辈进程                                                                                                                                                                                                                                     

5、lsof-列出打开的文件

  • 通过 lsof 命令,我们就可以根据文件找到对应的进程信息,也可以根据进程信息找到进程打开的文件。

lsof [选项]

选项功能
-c 字符串只列出以字符串开头的进程打开的文件。
+d 目录名列出某个目录中所有被进程调用的文件。
-u 用户名只列出某个用户的进程打开的文件。
-p pid列出某个 PID 进程打开的文件。

6、vmstat-监控系统资源

  • 可用来监控 CPU 使用、进程状态、内存使用、虚拟内存使用、硬盘输入/输出状态等信息。

二、查看系统性能

1、内存

free

top

2、cpu使用率

top 动态

ps aux 静态

ps -elf

vmstat

3、磁盘容量

查看剩余:df

分区:lsblk

详细查看:fdisk -l 设备名

4、磁盘读写

iotop 动态

vmstat

iostat

dd

5、网卡流量

iftop

三、进程管理

进程的启动方式分为:手动启动和调度启动

1、手动启动

  • 前台启动:通过终端启动,且启动后一直占据终端
  • 后台启动:可通过终端启动,但启动后即转入后台运行(释放终端)

2、进程的前后台调度

2.1 "命令 &",把命令放入后台执行

让作业运行于后台

  • 运行中的作业: Ctrl+z 放到后台 但是会停止作业

  • 尚未启动的作业: COMMAND &

第一种把命令放入后台的方法是在命令后面加入 空格 &。使用这种方法放入后台的命令,在后台处于执行状态。

注意,放入后台执行的命令不能与前台有交互,否则这个命令是不能在后台执行的

2.2  jobs命令

  • [ -l ]:显示PID号
  • 查看处于后台的任务列表

2.3 fg命令

  • 将后台进程恢复到前台运行,可指定任务序号

3、结束进程

3.1 kill

kill 从字面来看,就是用来杀死进程的命令,但事实上,这个或多或少带有一定的误导性。从本质上讲,kill 命令只是用来向进程发送一个信号,至于这个信号是什么,是用户指定的。

也就是说,kill 命令的执行原理是这样的,kill 命令会向操作系统内核发送一个信号(多是终止信号)和目标进程的 PID,然后系统内核根据收到的信号类型,对指定进程进行相应的操作。

信号编号信号名含义
0EXIT程序退出时收到该信息。
1HUP挂掉电话线或终端连接的挂起信号,这个信号也会造成某些进程在没有终止的情况下重新初始化。
2INT表示结束进程,但并不是强制性的,常用的 "Ctrl+C" 组合键发出就是一个 kill -2 的信号。
3QUIT退出。
9KILL杀死进程,即强制结束进程。
11SEGV段错误。
15TERM正常结束进程,是 kill 命令的默认信号。

3.2  killall

       killall 也是用于关闭进程的一个命令,但和 kill 不同的是,killall 命令不再依靠 PID 来杀死单个进程,而是通过程序的进程名来杀死一类进程,也正是由于这一点,该命令常与 ps、pstree 等命令配合使用

killall [选项] [信号] 进程名

  • -i:交互式,询问是否要杀死某个进程;

  • -I:忽略进程名的大小写;

3.3  pkill命令

根据特定条件终止相应的进程(不建议使用)

  • -U:根据进程所属的用户名终止相应进程;
  • -t:根据进程所在的终端终止相应进程。

四、计划任务管理

1、at-设置一次性计划任务

at 工具

  1. 由包 at 提供

  2. 依赖与atd服务,需要启动才能实现at任务

  3. at队列存放在/var/spool/at目录中,ubuntu存放在/var/spool/cron/atjobs目录下

  4. 执行任务时PATH变量的值和当前定义任务的用户身份一致

at 命令的访问控制是依靠 /etc/at.allow(白名单)和 /etc/at.deny(黑名单)这两个文件来实现的,具体规则如下:

  • 如果系统中有 /etc/at.allow 文件,那么只有写入 /etc/at.allow 文件(白名单)中的用户可以使用 at 命令,其他用户不能使用 at 命令(注意,/etc/at.allow 文件的优先级更高,也就是说,如果同一个用户既写入 /etc/at.allow 文件,又写入 /etc/at.deny 文件,那么这个用户是可以使用 at 命令的)。

  • 如果系统中没有 /etc/at.allow 文件,只有 /etc/at.deny 文件,那么写入 /etc/at.deny 文件(黑名单)中的用户不能使用 at 命令,其他用户可以使用 at 命令。不过这个文件对 root 用户不生效。

  • 如果系统中这两个文件都不存在,那么只有 root 用户可以使用 at 命令。

系统中默认只有 /etc/at.deny 文件,而且这个文件是空的,因此,系统中所有的用户都可以使用 at 命令。不过,如果我们打算控制用户的 at 命令权限,那么只需把用户写入 /etc/at.deny 文件即可

at [option] TIME
at [选项] [时间]
[HH:MM]  [yyyy-mm-dd]

格式用法
HH:MM比如 04:00 AM。如果时间已过,则它会在第二天的同一时间执行。
Midnight(midnight)代表 12:00 AM(也就是 00:00)。
Noon(noon)代表 12:00 PM(相当于 12:00)。
Teatime(teatime)下午茶代表 4:00 PM(相当于 16:00)。
英文月名 日期 年份比如 January 15 2018 表示 2018 年 1 月 15 号,年份可有可无。
MMDDYY、MM/DD/YY、MM.DD.YY比如 011518 表示 2018 年 1 月 15 号。
now+时间以 minutes、hours、days 或 weeks 为单位,例如 now+5 days 表示命令在 5 天之后的此时此刻执行

2、crontab-设置周期性计划任务

crontab [选项] [file]

选项功能
-u user用来设定某个用户的 crontab 服务,例如 "-u demo" 表示设备 demo 用户的 crontab 服务,此选项一般有 root 用户来运行。
-e编辑某个用户的 crontab 文件内容。如果不指定用户,则表示编辑当前用户的 crontab 文件。
-l显示某用户的 crontab 文件内容,如果不指定用户,则表示显示当前用户的 crontab 文件内容。
-r从 /var/spool/cron 删除某用户的 crontab 文件,如果不指定用户,则默认删除当前用户的 crontab 文件。
-i在删除用户的 crontab 文件时,给确认提示。

crontab -e
#进入 crontab 编辑界面。会打开Vim编辑你的任务
* * * * * 执行的任务

项目含义范围
第一个"*"一小时当中的第几分钟(minute)0~59
第二个"*"一天当中的第几小时(hour)0~23
第三个"*"一个月当中的第几天(day)1~31
第四个"*"一年当中的第几个月(month)1~12
第五个"*"一周当中的星期几(week)0~7(0和7都代表星期日)

在时间表示中,还有一些特殊符号需要学习

特殊符号含义
*(星号)代表任何时间。比如第一个"*"就代表一小时种每分钟都执行一次的意思。
,(逗号)代表不连续的时间。比如"0 8,12,16***命令"就代表在每天的 8 点 0 分、12 点 0 分、16 点 0 分都执行一次命令。
-(中杠)代表连续的时间范围。比如"0 5 ** 1-6命令",代表在周一到周六的凌晨 5 点 0 分执行命令。
/(正斜线)代表每隔多久执行一次。比如"*/10命令",代表每隔 10 分钟就执行一次命令。

在书写 crontab 定时任务时,需要注意以下几个事项:

  • 6 个选项都不能为空,必须填写。如果不确定,则使用“*”代表任意时间。

  • crontab 定时任务的最小有效时间是分钟,最大有效时间是月。像 2018 年某时执行、3 点 30 分 30 秒这样的时间都不能被识别。

  • 在定义时间时,日期和星期最好不要在一条定时任务中出现,因为它们都以天为单位,非常容易让管理员混淆。

  • 在定时任务中,不管是直接写命令,还是在脚本中写命令,最好都使用绝对路径。有时使用相对路径的命令会报错。

  • 27
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
⼤数据期末知识点总结 ⼤数据特点: ⼤数据特点: 五个主要技术特点:5V Volume(⼤体量):即可从数百TB到数⼗数百PB、甚⾄EB规模。 Variety(多样性):即⼤数据包括各种格式和形态的数据。 Velocity(时效性):即很多⼤数据需要在⼀定的时间限度下得到及时处理。 Veracity(准确性):即处理的结果要保证⼀定的准确性。 Value(⼤价值):即⼤数据包含很多深度的价值,⼤数据分析挖掘和利⽤带来巨⼤的商业价值。 ⼤数据概念: ⼤数据概念: ⼤数据是指数据规模⼤,尤其指因为数据形式多样、⾮结构化特征明显,导致数据存储、处理和挖掘异常困难的那类数据集。 ⼤数据性质: ⼤数据性质: ⾮结构性,不完备性,时效性,安全性,可靠性 ⼤数据技术概述: ⼤数据技术概述: ⼤数据及时是指从数据采集、清洗、集成、分析与解释,进⽽从各种各样的巨量数据中快速获得有价值信息的全部技术。 ⼤数据趋势: ⼤数据趋势: ⼤数据细分市场、⼤数据推动企业发展、⼤数据分析的新⽅法出现、⼤数据与云计算⾼度融合、⼤数据⼀体化设备陆续出现、⼤数据安全⽇ 益受到重视。 ⼤数据应⽤实例: ⼤数据应⽤实例: ⽹络⼤数据、⾦融⼤数据、企业⼤数据、政府管理⼤数据、安全⼤数据。 在医疗⾏业中医疗保健内容的预测分析、早产婴⼉的预测分析、精确确诊的预测分析 在能源⾏业中:智能电⽹、风⼒系统依靠⼤数据技术对⽓象数据进⾏分析 在通信⾏业中:通过分析客户的资料分析客户需求 交通⾏业中:车辆的运输管理,解决道路拥堵 零售业中:收集社交信息,分析消费者⽔平 科学研究四个范式: 科学研究四个范式: 第⼀范式: 第⼀范式: 概念:科学实验主要描述⾃然现象,以观察和实验为依据的研究,也可称为经验范式。 内容:实验是⼈们为实验预定⽬的,在⼈⼯控制条件下,通过⼲预和控制科研对象⽽观察和探索科研对象的规律和机制的⼀种研究⽅法, 特征:纯化观察对象条件、强化观察对象、可重复性 第⼆范式: 第⼆范式: 概念:以建模和归纳为基础的理论学科和分析范式,⼜称为理论范式。 内容:是对某种经验现象或事实的科学解说和系统解释,他是由⼀系列特定的概念、原理、命题以及对他们的严密论证组成的知识体系。 特征:抽象性、逻辑性、系统性 第三范式: 第三范式: 概念:是以模拟复杂现象为基础的计算科学范式⼜称模拟范式 内容:模拟有三种⽅法 数学模型⽅法 模拟程序⽅法 物理模型⽅法 特征:⾼度抽象 ⾼度精确 具有普遍意义 第四范式: 第四范式: 概念:以考察为基础,联合理论、实验、和模拟⼀体的数据密集计算的范式 内容:数据被捕获或者由模拟器⽣成,利⽤软件处理,信息和知识存储在计算机中国,科学家使⽤数据管理统计学⽅法分析数据 特征:处理对象是数据,是围绕数据展开的计算;计算的含义是从数据获取到管理再到分析、理解的整个过程;其⽬的是推动技术前沿发 展,⽬标是依赖传统的单⼀数据源和准静态数据库⽆法实现的应⽤。 可伸缩性: 可伸缩性: ⼜称可扩展性,是指通过扩展系统规模来提⾼性能并处理更⼤数量的⽤户和通过扩展系统规模提⾼系统的容错能⼒等 横⾏扩展: 横⾏扩展: 向逻辑单元之外的扩展,增加更多逻辑单元的资源,并使他们像⼀个单元⼀样⼯作。 CAP定理: 定理: ⼀个分布式系统不可能同时满⾜⼀致性、可⽤性和分区容错性三个系统需求,最多只能同时满⾜俩个系统需求。在考虑满⾜系统需求时,要 根据实际需要来选择关注点,进⽽采⽤相应的策略。 函数式编程优点: 函数式编程优点: 逻辑可证、模块化、组件化、易于调试、易于测试、更⾼的⽣产率 函数式编程的特征: 函数式编程的特征: 没有副作⽤、⽆状态编程、只有输⼊值与输出值 Mapreduce是⾕歌针对⼤规模群组中的海量数据处理⽽提出的分布式编程模型 Hadoop 是⼀个⽤于收集、共享和分析来⾃⽹络的⼤量结构化、半结构化和⾮结构化数据的平台。 Hadoop优点:⽅便、健壮、横向可扩展、简单。 Hadoop与sql数据库⽐较:横向扩展代替纵向扩展、键值对代替关系表、函数式编程代替声明式查询、离线批量处理代替在线处理 流式数据的特征:实时性,易失性,突发性,⽆序性,⽆限性,可靠性 流式计算性能指标:计算⽅式,常驻空间,时效性,有序性,数据量,数据速率,是否可重现,移动对象,数据精确度 Storm:任务拓扑=有向⽆环图(Spout、Bolt)Spout读取数据(元组)——》Blot。节点:Nimbus Supervisor。特征:编程模型简单 (Spout,Blot),多语⾔⽀持,作业级容错,⽔平可拓展,快速消息计算。Zookeeper:存储信息,1任务拓扑,任务分配,任务执⾏状 态,2从节点状态,⼯作进程状态,⼼跳信息,3集群状态配置信息 Nimbus master资源分配,任务调度,状态监控,故障

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值