经验

预防误执行rm -rf /*

  1. rm -rf删除目录是要判断目录

    1
    2
    3
    4
    5
    6
    7
    8
    #!/bin/bash
    work_path=`pwd`

    #如果目录不为空,才执行删除操作

    if [ ${work_path} != "" ];then
    rm -fr ${work_path}/*
    fi

    在执行删除目录操作前,先判断要删除的目录是否为空,不为空才执行删除操作。

  2. Shell脚本指定 set -u

    执行脚本的时候,如果遇到不存在的变量,Bash 默认忽略它。

    1
    2
    3
    #!/bin/bash
    echo $a
    echo hello

    上面代码中,$a 是一个不存在的变量,执行结果如下。

    1
    2
    3
    $ bash test.sh

    hello

    可以发现,echo $a 输出了一个空行,Bash 忽略了不存在的 ​$a,然后继续执行 echo hello。

    最好是遇到变量不存在,脚本应该报错,而不是一声不响地往下执行。

    set -u 就用来改变这种行为,在脚本加上它,遇到不存在的变量就会报错,并停止执行。

    1
    2
    3
    4
    5
    #!/bin/bash
    set -u

    rm -rf $a/*
    echo hello

    运行结果如下:

    1
    2
    3
    $ bash test.sh

    test.sh: line 4: a: unbound variable

    可以看到,因为 a 是未定义变量,脚本报错了,并且不再执行后面的语句。

  3. safe-rm替换rm

    safe-rm 是一个开源软件工具,这名字听起来就很安全嘛,所以它是用来替代不太安全的 rm。

    它可以在 /etc/safe-rm.conf 中配置路径黑名单,定义哪些不能被 safe-rm 删除。

    我们可以将 safe-rm 更名为 rm,假设定义了 /etc/ 无能被删除,那么删除 /etc 时就会报错:

    1
    2
    $ rm -rf /etc/
    safe-rm: skipping /etc/
  4. 建立回收站机制

    Windows 是有回收站的,即使误删了,也可以在回收站恢复。所以,我们也可以在 Linux 实现回收站的机制。

    实现思路:

    删除文件时,它并不真正执行删除操作,而是将文件移动到一个特定目录,可以设置定时清除回收站,或者在回收站里面的文件大小达到一定容量时(或者用时间做判断)执行删除操作以腾出空间。

    可以写个 Shell 脚本替换 rm 命令,或者在需要删除文件的时候使用 mv 命令将文件移动到回收站。 

    1. 创建回收站目录

    mkdir /home/.trash

    1. 编写remove.sh脚本,内容如下
    1
    2
    3
    4
    5
    6
    7
    8
    9
    TRASH_DIR="/home/.trash"

    for i in $*;do
    STAMP=`data +s`
    fileName=`basename $i`

    # 将对应文件 mv 至 .trash 目录
    mv $i ${TRASH_DIR}/${fileName}.${STAMP}
    done
    1. 修改~/.bashrc,用我们自建的 remove.sh 替代rm命令

    alias rm="sh /home/remove.sh"

    1. 设置crontab,定期清空垃圾箱,如每天0点清空垃圾箱

    0 0 * * * /usr/bin/rm -rf /home/.trash/*

    1. 最后执行以下命令,使之生效

    source ~/.bashrc

  5. 根文件挂载成只读

    在 /etc/fstab 文件,把 / 文件系统挂载成只读的方式。

    1
    2
    3
    4
    ~]$ cat /etc/fstab
    # /etc/fstab: static file system informat ion .
    #<file system> <mount pt> <type> <opt ions> <dump> <pass>
    /dev/root / ext4 remount,ro,noatime 0 1

    其中 remount,ro,就表示只读的方式挂载。

    只读的方式挂载后,进行删除操作是无法成功的:

    image-20200522184043090

总结:

涉及到 rm -rf 命令的代码,要留个心眼,要反复检查,要做好预防误执行 rm -fr /*,并在测试机验证完后,再拖到实体机上跑,千万不可大意。

就算的发生了 rm -fr /*,要第一时间停掉它,并且要做到三不要:

  • 不要慌,不要心跳爆炸(稳住稳住);
  • 不要隐瞒删库事件(不丢人);
  • 不要重启服务器或断开 ssh 会话(保留现场)。

只要立马掐断 rm -fr /* ,它是干不死我们的。

利用当下环境剩有的命令,冷静分析,是有机会恢复的。

Go语言中的嵌套结构体

tag使用mapstructure:"xxx"

技术栈

Windows10升级导致Ubuntu进不了grub界面

环境:Windows10+Ubuntu双系统

原因:Windows10大版本升级

解决:

以管理员的身份在cmd中敲入命令:

bcdedit /set "{bootmgr}" path \EFI\ubuntu\grubx64.efi

然后重启就有ubuntu引导了,亲测有效

还有其他修复命令的,自行百度。

打开office提示“应用程序无法正常启动(0xc0000142)“

打开office(Word,Excel等)提示“应用程序无法正常启动(0xc0000142)。请单击确认关闭应用程序”

解决:

  • 以管理员身份打开 Windows PowerShell

  • 输入DISM.exe /Online /Cleanup-image /Restorehealth

  • 输入sfc /scannow

一定要等每一条命令执行结束。之后重启电脑即可。若无效,请自行百度其他办法。

windows10输入法显示仅桌面且无法删除

第一步:打开注册表:window+R 输入:regedit

第二步:到注册表的如下目录下:\HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\CTF\TIP\

\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\CTF\TIP\

可以看到 有许多{xxxxx-xxx-xxx-xxx}的目录

可以搜索0x00000804,其中包含00000804的是中文输入法

找到 自己 不想要的,将连同我最外面得{xxx-xxx}目录一起删除,

最好记下 {}中的数字,然后全局再搜索一下这个数字,可以把出现的地方一起修改或删除。

Linux配置了代理依然无法访问gcr.io

docker pull 请求将首先转到 docker daemon 通过REST端点 /images/createdocker daemon将接管pull工作。

为了要做 docker daemon 要使用代理,我们需要设置 http_proxy & https_proxy 到的地方 dockerd 运行,即 root 用户。
要设定 https_proxy & http_proxy
因为我只想设定 http_proxy & https_proxy 为了 docker daemon(dockerd) 仅针对root用户,我将代理信息设置为 systemd 这样的服务单元(对于我的计算机,配置文件位于以下位置: /lib/systemd/system/docker.service:

1
2
3
4
5
6
7
8
9
10
11
12
[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
Environment="http_proxy=http://127.0.0.1:7777"
Environment="https_proxy=http://127.0.0.1:7777"
ExecStart=/usr/bin/dockerd -D -H fd:// --containerd=/run/containerd/containerd.sock
ExecReload=/bin/kill -s HUP $MAINPID
TimeoutSec=0
RestartSec=2
Restart=always