案例一:锁定并查看用户密码状态
1.1 锁定用户密码
# passwd -l zhumingyu
1.2 查看用户密码的锁定状态
# passwd -S zhumingyu
案例二:解锁并和查看用户密码状态
2.1 解锁用户密码
# passwd -u zhumingyu
2.2 查看用户密码的锁定状态
# passwd -S zhumingyu
# passwd -l zhumingyu
# passwd -S zhumingyu
# passwd -u zhumingyu
# passwd -S zhumingyu
# ssh-keygen -b 4096 -t rsa -C "<content>" -f "<public private key name>"
(注意:在生成复杂 SSH 密钥的时候最好也设置它的使用密码)
# mv <public private key name>* ~/.ssh/
# chmod -R 600 ~/.ssh/<public private key name>*
# ssh-copy-id -i ~/.ssh/<public private key name>.pub <destination IP address>
# ssh -i ~/.ssh/<public private key name> <destination IP address>
# vim /etc/ssh/sshd_conf
将其中的:
......
# PasswordAuthentication yes
......
# ChallengeResponseAuthentication yes
......
修改为:
......
PasswordAuthentication no
......
ChallengeResponseAuthentication no
......
# ssh-keygen -p -f ~/.ssh/<public private key name>
(补充:无密码的 SSH 密钥也能通过此方法设置密码)
# ssh-keygen -l -f ~/.ssh/<public private key name>
文中的 python 系统名、mysite 项目只是站主在本次操作中随意取的名称,读者可以根据自己的喜好换成任意别的名称
(1)服务器的系统需要是 CentOS 8 版本
(2)服务器要关闭防火墙
(3)服务器要关闭 SELinux
(4)服务器系统要配置好可用的软件源
(5)服务器要能够连接外网
[root@django ~]# yum -y groupinstall 'Server with GUI'
[root@django ~]# systemctl set-default graphical.target
[root@django ~]# reboot
(注意:如果要到远程服务器上使用 PyCharm,则在 ssh 的时候需要添加 -X 参数:# ssh -X <用户>@)
[root@django ~]# pip3 install --upgrade pip
[root@django ~]# pip3 install django
[root@django ~]# python3 -m venv django_env
[root@django ~]# source django_env/bin/activate
(django_env) [root@django ~]# django-admin startproject mysite
# cd mysite/
(django_env) [root@django mysite]# tree
.
|-- manage.py
`-- mysite
|-- __init__.py
|-- asgi.py
|-- settings.py
|-- urls.py
`-- wsgi.py
1 directory, 6 files
# tar -xvf pycharm-community-2020.1.tar.gz
# vim pycharm-community-2020.1/bin/pycharm64.vmoptions
将以下内容:
-Xms128m
-Xmx750m
......
修改为:
-Xms2048m
-Xmx4096m
......
# vim pycharm-community-2020.1/bin/pycharm.vmoptions
将以下内容:
-Xms128m
-Xmx750m
......
修改为:
-Xms2048m
-Xmx4096m
......
# ./pycharm-community-2020.1/bin/pycharm.sh







(1)选择左上角的 “File” 点击 “Settings”
(2)选择 “Editor” 下的 “Code Completion”
(3)建议将 “Code Completion” 设置成如下图所示

(4)点击 OK
选择左上角的 "File" 点击 “Invalidate and Restart”
# django-admin startproject <project>
# django-admin startapp <subproject>
# python3 manage.py runserver <local IP address>:<port>
使用方法:
1. 将此脚本和 patch.cs 文件放在同一目录下
2. patch.cs 里每一个 IP 地址和每一个 RPM 包名称占用一行
3. 给此脚本添加执行权限
4. 执行此脚本
5. 此脚本执行完成后,会将运行结果写入当前目录下的 checkout.csv
注意:此脚本执行前必须要先保证执行本脚本的用户能无密码 ssh 远程这些远程服务器
补充:patch.cs 示例如下:
192.168.100.101,kernel-4.18.0-80.el8.x86_64,other0
192.168.100.102,kernel-4.18.0-80.el8.x86_64,other1
192.168.100.103,kernel-4.11.0-80.el8.x86_64,other2
192.168.100.104,kernel-4.18.0-80.el8.x86_64,other3
192.168.100.105,kernel-4.18.0-80.el8.x86_64,other4
#!/bin/bash
for i in `seq 1 $(cat patch.csv | wc -l)`
do
servername=`sed -n "$[i]p" patch.csv | cut -d ',' -f 1`
software=`sed -n "$[i]p" patch.csv | cut -d ',' -f 2`
ssh $servername "rpm -qa | grep $software" &> /dev/null
if [ $? -eq 0 ];then
echo "$servername,$software,have not patched"
else
echo "$servername,$software,have patched"
fi
done
开启 core dump 之后,如果出现了 C 语言程序的 crash,则会将 crash 的结果记录到一个文件里
# ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 31722
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 31722
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
# ulimit -c unlimited
# ulimit -a
core file size (blocks, -c) unlimited
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 31722
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 31722
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
# sysctl -w kernel.core_pattern=/tmp/corefile/core-%e-%p