RHCE8 资料整理(五)

news2024/11/24 12:22:11

RHCE8 资料整理

  • 第五篇 系统管理
    • 第18章 进程管理
      • 18.1 进程介绍
      • 18.2 查看进程
      • 18.3 向进程发送信号
      • 18.4 进程优先级
    • 第19章 日志
      • 19.1 rsyslog的配置
      • 19.2 查看日志
    • 第20章 网络时间服务器
      • 20.1 时间同步必要性
      • 20.2 配置时间服务器
      • 20.3 配置客户端
    • 第21章 计划任务
      • 21.1 at
      • 21.2 crontab
      • 21.3 anacron

在这里插入图片描述

第五篇 系统管理

第18章 进程管理

18.1 进程介绍

参考 https://blog.csdn.net/u010230019/article/details/132311926

18.2 查看进程

通过ps能够查看进程信息,不加选项的ps显示当前终端的进程

[root@server ~]# ps
    PID TTY          TIME CMD
  42301 pts/0    00:00:00 bash
  42351 pts/0    00:00:00 ps

关于ps详细内容查看 https://blog.csdn.net/u010230019/article/details/132301168

通过pgrep [-f] xxx能够查看某个进程的PID

[root@server ~]# pgrep sshd
899
42289
42291
42293
42312

也可以通过pidof xxx查看PID

[root@server ~]# pidof sshd
42312 42293 42291 42289 899

pgrep会把进程CMD中含有sshd的进程的PID全部找出来,而pidof找的是CMDsshd

ps查看的是执行命令的一瞬间的情况,而想要动态查看进程信息的,可以使用top命令,默认3秒刷新一次,可以通过-d来指定刷新时间
详细参考https://blog.csdn.net/u010230019/article/details/132301168

top - 16:47:00 up 14 days, 22:56,  1 user,  load average: 0.00, 0.00, 0.00
Tasks: 299 total,   1 running, 298 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.1 us,  0.2 sy,  0.0 ni, 99.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
MiB Mem :   1748.7 total,    178.4 free,    897.0 used,    673.3 buff/cache
MiB Swap:   4096.0 total,   4096.0 free,      0.0 used.    656.1 avail Mem

    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
    772 root      20   0  456396  11304   7496 S   0.2   0.6  24:42.64 vmtoolsd
   1344 gdm       20   0 3449740 177048 101844 S   0.2   9.9   8:28.06 gnome-shell
  42252 root      20   0       0      0      0 I   0.2   0.0   0:00.03 kworker/u256:0-events_unbound
  42373 root      20   0       0      0      0 I   0.2   0.0   0:00.24 kworker/1:0-mpt_poll_0
  42395 root      20   0  226152   4488   3508 R   0.2   0.3   0:00.03 top
      1 root      20   0  170640  14660   9460 S   0.0   0.8   0:15.04 systemd
      2 root      20   0       0      0      0 S   0.0   0.0   0:01.84 kthreadd

18.3 向进程发送信号

通过kill -l查看所有信号

[root@server ~]# kill -l
 1) SIGHUP       2) SIGINT       3) SIGQUIT      4) SIGILL       5) SIGTRAP
 6) SIGABRT      7) SIGBUS       8) SIGFPE       9) SIGKILL     10) SIGUSR1
11) SIGSEGV     12) SIGUSR2     13) SIGPIPE     14) SIGALRM     15) SIGTERM
16) SIGSTKFLT   17) SIGCHLD     18) SIGCONT     19) SIGSTOP     20) SIGTSTP
21) SIGTTIN     22) SIGTTOU     23) SIGURG      24) SIGXCPU     25) SIGXFSZ
26) SIGVTALRM   27) SIGPROF     28) SIGWINCH    29) SIGIO       30) SIGPWR
31) SIGSYS      34) SIGRTMIN    35) SIGRTMIN+1  36) SIGRTMIN+2  37) SIGRTMIN+3
38) SIGRTMIN+4  39) SIGRTMIN+5  40) SIGRTMIN+6  41) SIGRTMIN+7  42) SIGRTMIN+8
43) SIGRTMIN+9  44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12
53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9  56) SIGRTMAX-8  57) SIGRTMAX-7
58) SIGRTMAX-6  59) SIGRTMAX-5  60) SIGRTMAX-4  61) SIGRTMAX-3  62) SIGRTMAX-2
63) SIGRTMAX-1  64) SIGRTMAX

常用信号有:

  • 15:以正常的结束进程来终止该进程。由于是正常的终止, 所以后续的动作会将他完成。不过,如果该进程已经发生问题,就是无法使用正常的方法终止时, 输入这个 signal 也是没有用的。
  • 9:代表强制中断一个进程的进行,如果该进程进行到一半, 那么尚未完成的部分可能会有『半产品』产生,类似 vim 会有 .filename.swp 保留下来。
  • 2:相当于用键盘输入 [ctrl]-c 来中断一个进程的进行
  • 1:启动被终止的进程,可让该 PID 重新读取自己的配置文件,类似重新启动

通过kill -n PID可以向进程发送信号,通过killall -n processname可以向所有processname发送信号

18.4 进程优先级

系统中所有的进程都要消耗CPU资源,CPU会为每个进程分配一个时间片,轮到某个进程时CPU会处理这个进程的请求,时间片到期,则会把进程暂停放回队列等待下一轮时间片。在同一颗CPU上如果运行太多的程序就会导致CPU资源不足,可以调整进程的优先级,让指定进程获取更多的资源,更优先的去执行。

进程的优先级由两个值决定:优先顺序(priority)和优先级(niceness)。其中优先顺序由内核对它进行动态更改,我们不需要做太多干预。对用户而言,只需要修改nice值,nice值范围为-20~19,nice值越小,进程就越先执行。

多个进程如果运行在不同的CPU上是互不干扰的,不会发生资源抢占情况。只有运行在同一颗CPU上才会发生资源抢占情况。

查看CPU情况,命令:

[root@server ~]# lscpu
Architecture:            x86_64
  CPU op-mode(s):        32-bit, 64-bit
  Address sizes:         43 bits physical, 48 bits virtual
  Byte Order:            Little Endian
CPU(s):                  2
  On-line CPU(s) list:   0,1
...

调整优先级示例
可以看到有两颗CPU(一颗CPU有两个核,则被认为是两颗CPU),编号分别是0和1。现在关闭1号CPU,命令如下:

[root@server ~]# cat /sys/devices/system/cpu/cpu1/online
1
[root@server ~]# echo 0 > /sys/devices/system/cpu/cpu1/online
[root@server ~]# cat /sys/devices/system/cpu/cpu1/online
0
[root@server ~]# lscpu
Architecture:            x86_64
  CPU op-mode(s):        32-bit, 64-bit
  Address sizes:         43 bits physical, 48 bits virtual
  Byte Order:            Little Endian
CPU(s):                  2
  On-line CPU(s) list:   0
  Off-line CPU(s) list:  1

可以看到1号CPU已经离线,/sys/devices/system/cpu/cpu1/online中的值如果是0则表示CPU离线,1则表示在线

[root@server ~]# cat /dev/zero > /dev/null &
[1] 42453
[root@server ~]# cat /dev/zero > /dev/null &
[2] 42454
[root@server ~]# top -d 5
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
  42453 root      20   0  221096   1048    964 R  49.6   0.1   0:16.22 cat
  42454 root      20   0  221096   1024    940 R  49.4   0.1   0:14.75 cat

可以看到两个cat进程消耗的CPU是差不多的,因为他们的nice值相同,可以平等的消耗CPU资源,下面使用renice修改进程的nice值,改为-10,如下:

[root@server ~]# renice -n -10 42453
42453 (process ID) old priority 0, new priority -10
[root@server ~]# top -d 5
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
  42453 root      10 -10  221096   1048    964 R  89.5   0.1   1:39.67 cat
  42454 root      20   0  221096   1024    940 R   9.7   0.1   1:29.11 cat
[root@server ~]# killall -9 cat

可以看到42453比42454占用了更多的CPU资源,nice值越小可以获得更多的CPU资源

前面是对运行中的进程调整优先级,也可以直接以某个特定的nice值启动进程

nice -n 10 cat /dev/zero > /dev/null &

开启1号CPU

第19章 日志

详细参考
https://blog.csdn.net/u010230019/article/details/127772295
https://blog.csdn.net/u010230019/article/details/132359825

在REHL8/CentOS8中,日志由rsyslogd服务管理的,不同类别的日志由/etc/rsyslog.conf决定保存在具体的文件中
/etc/rsyslog.conf定义规则格式:

日志类别.日志基本标准线	文件

日志类别:

相对序号服务类别说明
0kern(kernel)就是核心(kernel)产生的讯息,大部分都是硬件侦测以及核心功能的启用
1user在用户层级所产生的信息,例如后续会介绍到的用户使用
2mail只要与邮件收发有关的讯息记录都属于这个;
3daemon主要是系统的服务所产生的信息,例如systemd就是这个有关的讯息!
4auth主要与认证/授权有关的机制,例如login,ssh,su等需要账号/密码的咚咚;
5syslog就是由syslog相关协议产生的信息,其实就是rsyslogd这支程序本身产生的信息啊!
6lpr亦即是打印相关的讯息啊!
7news与新闻组服务器有关的东西;
8uucp全名为Unix to Unix Copy Protocol,早期用于unix系统间的程序数据交换;
9cron就是例行性工作排程cron/at等产生讯息记录的地方;
10authpriv与auth类似,但记录较多账号私人的信息,包括pam模块的运作等!
11ftp与FTP通讯协议有关的讯息输出!
16~23local0~local7保留给本机用户使用的一些登录文件讯息,较常与终端机互动。

日志级别:

等级数值等级名称说明
none不需登录等级,忽略掉某些服务的信息
7debug用来 debug (除错) 时产生的讯息数据;
6info仅是一些基本的讯息说明而已;
5notice虽然是正常信息,但比 info 还需要被注意到的一些信息内容;
4warning
(warn)
警示的讯息,可能有问题,但是还不至于影响到某个 daemon 运作的信息;基本上,info, notice, warn 这三个讯息都是在告知一些基本信息而已,应该还不至于造成一些系统运作困扰;
3err
(error)
一些重大的错误讯息,例如配置文件的某些设定值造成该服务服法启动的信息说明, 通常藉由 err 的错误告知,应该可以了解到该服务无法启动的问题呢!
2crit比 error 还要严重的错误信息,这个 crit 是临界点 (critical) 的缩写,这个错误已经很严重了喔!
1alert警告警告,已经很有问题的等级,比 crit 还要严重!
0emerg
(panic)
疼痛等级,意指系统已经几乎要当机的状态! 很严重的错误信息了。通常大概只有硬件出问题,导致整个核心无法顺利运作,就会出现这样的等级的讯息吧!

19.1 rsyslog的配置

*.info;mail.none;authpriv.none;cron.none                /var/log/messages

# The authpriv file has restricted access.
authpriv.*                                              /var/log/secure

# Log all the mail messages in one place.
mail.*                                                  -/var/log/maillog

# Log cron stuff
cron.*                                                  /var/log/cron

# Everybody gets emergency messages
*.emerg                                                 :omusrmsg:*

# Save news errors of level crit and higher in a special file.
uucp,news.crit                                          /var/log/spooler

# Save boot messages also to boot.log
local7.*                                                /var/log/boot.log

*.info;mail.none;authpriv.none;cron.none /var/log/messages除了mail,authpriv和cron的所有info及以上的讯息都记录在/var/log/messages

模拟产生一个mail日志,级别为debug

[root@server ~]# logger -p mail.debug "1111"
[root@server ~]# tail -1  /var/log/maillog
Nov  9 17:42:38 server root[42476]: 1111

19.2 查看日志

不同的日志记录在不同的日志文件中,参考 https://blog.csdn.net/u010230019/article/details/127772295 查看不同的日志信息

  • 查看系统的引导日志,可以查看/var/log.boot.log
  • 查看通过ssh,ftp等登录系统或尝试登录系统的用户,可以查看/var/log/secure
  • 邮件相关日志,可以查看/var/log/maillog
  • 查看安装或卸载了哪些包,可以查看/var/log/dnf.log(REHL)

还可以通过journalctl查看系统的所有日志,格式

journalctl [OPTIONS...] [MATCHES...]
-f : 持续输出
-p 级别:查看指定级别日志
[root@server ~]# journalctl -p crit
Oct 25 17:50:22 server.rhce.cc kernel: Warning: Unmaintained hardware is detected:  e1000:100F:8086 @ 0000:02:00.0
Oct 25 17:50:23 server.rhce.cc kernel: Warning: Unmaintained hardware is detected:  e1000:100F:8086 @ 0000:02:03.0

第20章 网络时间服务器

20.1 时间同步必要性

大部分集群服务器都要求时间必须保持一致,否则会提示警告信息。

20.2 配置时间服务器

这里主要使用chrony进行配置时间服务器

主机ip类型
node-140192.168.17.140时间服务器
node-138192.168.17.138客户端
  1. 启动服务
systemctl start chronyd
systemctl status chronyd
systemctl enable chronyd
  1. 指定时间服务器使用的上层时间服务器,编辑/etc/chrony.conf
[root@server ~]# grep pool  /etc/chrony.conf
# Use public servers from the pool.ntp.org project.
# Please consider joining the pool (https://www.pool.ntp.org/join.html).
pool 127.127.1.0 iburst

pool后面指定上层时间服务器,由于我们这里把node-140作为时间服务器,修改pool 2.rhel.pool.ntp.org iburstpool 127.127.1.0 iburst,即上层时间服务器设置为本地时钟的IP:127.127.1.0

  1. 允许指定的客户端访问
[root@server ~]# grep allow  /etc/chrony.conf
allow 192.168.17.0/24

如果允许所有客户段都能访问,则可以设置allow 0/0allow all

  1. 修改local statum
[root@server ~]# grep local  /etc/chrony.conf
# Allow NTP client access from local network.
local stratum 10

表示即使服务器本身没有和时间服务器保持时间同步,也可以对外提供时间服务

  1. 重启chronyd服务
systemctl restart chronyd

chrony使用的是UDP的123和323端口,所以查看端口

[root@server ~]# ss -nltpu|grep chronyd
udp   UNCONN 0      0            0.0.0.0:123        0.0.0.0:*    users:(("chronyd",pid=42637,fd=7))
udp   UNCONN 0      0          127.0.0.1:323        0.0.0.0:*    users:(("chronyd",pid=42637,fd=5))
udp   UNCONN 0      0              [::1]:323           [::]:*    users:(("chronyd",pid=42637,fd=6))
  1. 如果开启了防火墙,则需要把这两个端口开放,如下
[root@server ~]# firewall-cmd --add-port=123/udp --permanent
success
[root@server ~]# firewall-cmd --add-port=323/udp --permanent
success
[root@server ~]# firewall-cmd --reload
success

20.3 配置客户端

  1. node-138设置为时间服务器客户端,编辑/etc/chrony.conf,修改如下:
[root@node-138 ~]# egrep -v '^$|^#' /etc/chrony.conf
server 192.168.17.140 iburst
driftfile /var/lib/chrony/drift
makestep 200 3
rtcsync
logdir /var/log/chrony
  1. 同步时间
[root@node-138 ~]# date;ssh node-140 date
Thu Nov  9 11:16:23 CST 2023
Thu Nov  9 06:19:33 PM CST 2023
[root@node-138 ~]# systemctl restart chronyd
[root@node-138 ~]# date;ssh node-140 date
Thu Nov  9 11:16:42 CST 2023
Thu Nov  9 06:19:52 PM CST 2023
[root@node-138 ~]# date;ssh node-140 date
Thu Nov  9 18:19:54 CST 2023
Thu Nov  9 06:19:54 PM CST 2023

可以看到时间并不是一下同步的,而是逐渐同步的,为什么呢?
这还需要从/etc/chrony.confmakestep选项说起,makestp那行,格式如下:

makestep 阈值 limit

客户端向时间服务器同步时间有两种方式:stepslew

  • step:跳跃着更新时间,如时间从1点直接跳到7点
  • slew:平滑着移动时间,晶体芯片跳动的会快一些,好比秒针的转速“快进”了一样

如果客户端和服务器时间相差较多,则通过step的方式更新时间;如果相差不多,则通过slew更新时间。那么时间相差多与不多的标准又是什么呢?
这就要看时间差是否超过makestep后面的阈值了。以makestep 10 3为例,如果相差10秒以上,就认为时间相差较多,则前3次通过step方式更新时间(有些程序会因为时间跳动带来问题)。如果是10秒以内,则会通过slew缓慢平滑更新时间。

可以通过chronyc -n sources -v查看现在的同步状况

[root@node-138 ~]# chronyc -n sources -v
210 Number of sources = 1

  .-- Source mode  '^' = server, '=' = peer, '#' = local clock.
 / .- Source state '*' = current synced, '+' = combined , '-' = not combined,
| /   '?' = unreachable, 'x' = time may be in error, '~' = time too variable.
||                                                 .- xxxx [ yyyy ] +/- zzzz
||      Reachability register (octal) -.           |  xxxx = adjusted offset,
||      Log2(Polling interval) --.      |          |  yyyy = measured offset,
||                                \     |          |  zzzz = estimated error.
||                                 |    |           \
MS Name/IP address         Stratum Poll Reach LastRx Last sample
===============================================================================
^* 192.168.17.140               10   6   377    64    +33us[  +70us] +/-  396us

可以看到node-138是向node-140进行时间同步的

第21章 计划任务

详细参考 https://blog.csdn.net/u010230019/article/details/132290764

21.1 at

使用at执行一次性计划任务,格式

at 时间点 <【按Enter】>
> 输入要执行的命令
Ctrl + D 提交

atq job	#查询
at -c job #详细查询具体内容,一般配合 tail -3 使用
atrm job #删除
[root@node-138 ~]# at now+1minutes
at> echo 123
at> <EOT>
job 12 at Thu Nov  9 18:46:00 2023
[root@node-138 ~]# atq
9       Wed Feb 14 01:00:00 2024 a root
10      Wed Feb 14 01:00:00 2024 a root
12      Thu Nov  9 18:46:00 2023 a root

21.2 crontab

如果周期性执行计划任务,则需要使用crontab

crontab -e [-u xxx] #[为其他用户]创建计划任务
crontab -l [-u xxx] #[为其他用户]查询计划任务
crontab -r #删除

详细查询 https://blog.csdn.net/u010230019/article/details/132290764

[root@study ~]# cat /etc/crontab
SHELL=/bin/bash <==使用哪种 shell 接口
PATH=/sbin:/bin:/usr/sbin:/usr/bin <==执行文件搜寻路径
MAILTO=root <==若有额外 STDOUT,以 email 将数据送给谁
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
  • /etc/cron.allow:
    将可以使用 crontab 的账号写入其中,若不在这个文件内的使用者则不可使用 crontab;
  • /etc/cron.deny:
    将不可以使用 crontab 的账号写入其中,若未记录到这个文件当中的使用者,就可以使用 crontab

同时存在时,allow生效

可以直接将指令放到 /etc/cron.hourly/ 让系统每小时定时执行之外,在 /etc/ 底下其实还有 /etc/cron.daily/, /etc/cron.weekly/, /etc/cron.monthly/,那三个目录是代表每日、每周、每月各执行一次的意思

21.3 anacron

anacron 并不是用来取代 crontab 的,anacron 存在的目的就在于我们上头提到的,在处理非 24 小时一直启动的 Linux 系统的 crontab 的执行! 以及因为某些原因导致的超过时间而没有被执行的排程工作。

其实 anacron 也是每个小时被 crond 执行一次,然后 anacron 再去检测相关的排程任务有没有被执行,如果有超过期限的工作在, 就执行该排程任务,执行完毕或无须执行任何排程时,anacron 就停止了。

关于详细内容查看上面连接

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

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

相关文章

java测试private

java测试private变量、方法 📕反射的基本作用、关键? 反射是在运行时获取类的字节码文件对象,然后可以解析类中的全部成分反射的核心思想和关键就是:得到编译以后的class文件对象可以破坏封装性(很突出)也可以破坏泛型的约束性(很突出)更重要的用途是适合:做java高级…

【tgcalls】Instance接口的实例类的创建

tg 里有多个版本,因此设计了版本管理的map,每次可以选择一个版本进行实例创建这样,每个客户端就可以定制开发了。tg使用了c++20创建是要传递一个描述者,里面是上下文信息 G:\CDN\P2P-DEV\tdesktop-offical\Telegram\ThirdParty\tgcalls\tgcalls\Instance.cpp可以看到竟然是…

谷歌桌面布局修改

前言 近期接到一个关于谷歌EDLA认证的需求&#xff0c;我负责的是谷歌原生桌面布局的修改&#xff0c;通过研究源码&#xff0c;将涉及到了一些修改思路发出来&#xff0c;大家可以参考一下有没有对你有用的信息。主要修改内容有&#xff1a; 1、搜索栏、底部导航栏未居中 2、…

VBA技术资料MF81:查找特定填充颜色的最后单元格

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。我的教程一共九套&#xff0c;分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的入门&#xff0c;到…

简单漂亮的登录页面

效果图 说明 开发环境&#xff1a;vue3&#xff0c;sass 代码 <template><div class"container"><div class"card-container"><div class"card-left"><span><h1>Dashboard</h1><p>Lorem ip…

基础课26——业务流程分析方法论

基础课25中我们提到业务流程分析方法包括以下几种&#xff1a; 价值链分析法&#xff1a;主要是找出或设计出哪些业务能够使得客户满意&#xff0c;实现客户价值最大化的业务流程。要进行价值链分析的时候可以从企业具体的活动进行细分&#xff0c;细分的具体方面可以从生产指…

Stable Diffusion WebUI扩展sd-webui-controlnet之Canny

什么是Canny? 简单来说,Canny是计算机视觉领域的一种边缘检测算法。 关于Canny算法大家可以去看我下面这篇博客,里面详细介绍了Canny算法的原理以及代码演示。 OpenCV竟然可以这样学!成神之路终将不远(十五)_maxminval opencv-CSDN博客文章浏览阅读111次。14 图像梯度…

统计学习笔记 第 5 部分:破碎系数

照片由 Unsplash上的 资源数据库提供 1&#xff1a;背景与动机 正如本系列之前的文章所述&#xff0c;统计学习理论为理解机器学习推理问题提供了一个概率框架。用数学术语来说&#xff0c;统计学习理论的基本目标可以表述为&#xff1a; 图片由作者提供 本文是统计学习理论系…

要查看Android应用的签名信息,可以采取以下几种方式

直接查看APK的签名信息。这可以通过在命令行中输入以下命令完成&#xff1a;keytool -list -printcert -jarfile [APK文件路径]。例如&#xff0c;如果你的APK文件名为wechat.apk&#xff0c;你可以在命令行中输入&#xff1a;keytool -list -printcert -jarfile wechat.apk。执…

【OpenCV实现图像:用OpenCV图像处理技巧之白平衡算法】

文章目录 概要加载样例图像统计数据分析White Patch Algorithm小结 概要 白平衡技术在摄影和图像处理中扮演着至关重要的角色。在不同的光照条件下&#xff0c;相机可能无法准确地捕捉到物体的真实颜色&#xff0c;导致图像呈现出暗淡、色调不自然或者褪色的效果。为了解决这个…

C++11常用特性

目录 1、{}初始化 2、auto 3、decltype 4、nullptr 5、范围for 6、STL容器 7、右值引用 ①左值引用和右值引用 ②移动构造 ③移动赋值 ④万能引用与完美转发 8、新的类功能 9、可变模版参数 10、lambda表达式 捕捉列表的使用 [val]&#xff1a;传值捕捉 [&…

ChatGPT生产力|中科院学术ChatGPT优化配置

资源链接&#xff1a;GitHub - binary-husky/gpt_academic b站配置讲解链接&#xff1a;chatgpt-academic 新手运行官方精简指南&#xff08;科研chatgpt拓展&#xff09; 某知配置图文讲解&#xff1a;图文详解&#xff1a;在windows中部署ChatGPT学术版 - 知乎 (zhihu.com) 一…

经典OJ题:随机链表的复制

目录 题目&#xff1a; 本题的解图关键在于画图与看图&#xff01; 思路分析&#xff1a; 方法一&#xff1a;暴力求解法。 方法二&#xff1a;插入法 方法解析&#xff1a; 步骤一、插入 步骤二、 处理每一个copy的randdom指针⭐————重点 步骤三、拆卸节点 代码…

轻松与任何 SQL 数据库集成:Directus 助你无代码开发 | 开源日报 No.69

Ebazhanov/linkedin-skill-assessments-quizzes Stars: 26.5k License: AGPL-3.0 这个项目是一个 LinkedIn 技能评估答案的存储库。它提供了各种领域和主题的问题和答案&#xff0c;以帮助用户更好地学习新概念并准备相关考试。该项目具有以下核心优势&#xff1a; 提供多语…

HarmonyOS开发:UI开展前的阶段总结

前言 关于HarmonyOS&#xff0c;陆陆续续总结了有14篇的文章&#xff0c;大家可以发现&#xff0c;没有一篇是关于UI相关的&#xff0c;不是自己没有分享的打算&#xff0c;而是对于这些UI而言&#xff0c;官方都有着一系列的文档输出&#xff0c;如果我再一一的分享&#xff0…

SPSS线性回归

前言&#xff1a; 本专栏参考教材为《SPSS22.0从入门到精通》&#xff0c;由于软件版本原因&#xff0c;部分内容有所改变&#xff0c;为适应软件版本的变化&#xff0c;特此创作此专栏便于大家学习。本专栏使用软件为&#xff1a;SPSS25.0 本专栏所有的数据文件请点击此链接下…

高级运维学习(十五)Zabbix监控(二)

一 Zabbix 报警机制 1 基本概念 自定义的监控项默认不会自动报警首页也不会提示错误需要配置触发器与报警动作才可以自动报警 2 概念介绍 &#xff08;1&#xff09;触发器 (trigger) 表达式&#xff0c;如内存不足300M&#xff0c;用户超过30个等 当触发条件发生后&a…

【自然语言处理】基于python的问答系统实现

一&#xff0c;文件准备 该问答系统是基于已知的问题和其一一对应的答案进行实现的。首先需要准备两个文本文件&#xff0c;分别命名为“question.txt”和“answer.txt”&#xff0c;分别是问题文件和答案文件&#xff0c;每一行是一个问题以及对应的答案。 问题文件: 中国的首…

Pytorch模型使用与修改、保存与加载

模型的使用及修改、保存与加载 以图像处理中torchvision为例&#xff0c;PyTorch通过torchvision.models模块提供了更多的预训练模型. 在图像分类当中&#xff0c;包括许多模型 import torchvision import warnings import torch warnings.filterwarnings("ignore&quo…

3D Gaussian Splatting:用于实时的辐射场渲染

Kerbl B, Kopanas G, Leimkhler T, et al. 3d gaussian splatting for real-time radiance field rendering[J]. ACM Transactions on Graphics (ToG), 2023, 42(4): 1-14. 3D Gaussian Splatting 是 Siggraph 2023 的 Best Paper&#xff0c;法国团队在会议上展示了其实现的最…