2024
Journal-2024
record my journey in CS, gain from history, sometimes scandal.
12.30
docker容器迁移
# host 1
docker commit mycontainer myimage:latest
docker save myimage:latest -o myimage.tar
# host 2
docker load -i myimage.tar
12.23
docker限制日志文件大小
/etc/docker/daemon.json
:
{
"log-opts": {
"max-size": "50m", // 单个日志文件大小
"max-file": "3" // 保留轮换的日志文件个数
}
}
禁用IDM自动更新
修改注册表\HKEY_CURRENT_USER\SOFTWARE\DownloadManager
中LstCheck
项为0
12.21
bash脚本sleep时trap不生效
通过trap命令设置信号处理函数后,如果调用sleep命令,则需要等待sleep返回才能够对信号进行处理,从而造成不便。
解决方案:将sleep调整为后台执行,然后主进程对sleep进程进行等待,等待过程中可以正常进行信号处理。
trap "signal_handler" SIGINT
sleep 600 &
wait $! # wait for both subprocess and signal
tmux精细调整panel大小
ctrl+b
+ :
进入命令模式,执行set mouse on
,然后使用鼠标拖动panel边界
12.20
git远程代理push
有时临时在某不常用主机上开发项目,又不想为该主机配置用于连接托管平台的SSH密钥。此时可以将开发主机上的项目仓库挂载到常用主机上,由常用主机使用其密钥进行代理操作(push/pull等)
# 常用主机shell
sshfs dev_host:/path/to/dev/repo /path/to/mountpoint # 挂载,其他协议同理,但sshfs最方便
cd /path/to/mountpoint
git push # or git pull, ...
umount /path/to/mountpoint
Windows无法scp
报错:
scp: Received message too long 1347625027
scp: Ensure the remote shell produces no output for non-interactive sessions.
原因是PowerShell没有正确处理scp发起的非交互式会话,输出了额外的字符,导致scp异常
解决方案:
新建一个用户专用于scp,并编辑C:/ProgramData/ssh/sshd_config
,禁用其TTY:
Match User <user_for_scp>
PermitTTY no
重启sshd服务:
net stop ssh
net start ssh
安卓熄屏不锁屏
有时需要保持安卓手机长期唤醒状态,但又不希望屏幕开着费电或者发生烧屏,可以关闭屏幕显示(需要ROOT):
adb shell "su -c 'echo 0 > /sys/class/leds/lcd-backlight/brightness'" # 关闭屏幕
adb shell "su -c 'echo 1 > /sys/class/leds/lcd-backlight/brightness'" # 开启屏幕(设置亮度为1)
更新内核后不重启导致的问题
挂载smb文件系统时出现mount error: cifs filesystem not supported by the system
,是由于更新内核后,内核模块的路径改变了,使得新安装的模块无法被当前运行的旧内核找到。
12.18
Typora强制分页
在需要分页的地方插入如下内容:
<div style="page-break-after: always;"></div>
(导出为PDF时生效)
12.17
tmux导出窗口内容
ctrl+b + :
可进入命令模式,先使用capture-pane -S -
命令将窗口内容捕获到缓冲区,再使用save-buffer /path/to/savefile.txt
将缓冲区内容保存到文件。
12.16
btm按接口过滤网络流量
~/.config/bottom/bottom.toml
:
[net_filter]
is_list_ignored = false # false为正向选择list中的接口,true为反向过滤掉list中的接口
#list = ["virbr0.*"]
list = ["eno1"]
regex = true
case_sensitive = false
whole_word = false
12.12
分析Firefox进程资源
地址栏输入about:processes
12.11
rime禁用shift切换中英
.config/fcitx/rime/default.custom.yaml
:
ascii_composer:
switch_key:
Shift_L: noop
Shift_R: noop
12.9
Clash Verge 链式代理
为需要被链式代理的节点添加dialer-proxy
即可,其值可以是代理/代理组的name ref
proxies:
- name: "ss1"
dialer-proxy: dialer
...
- name: "ss2"
...
proxy-groups:
- name: dialer
type: select
proxies:
- ss2
使用Clash Verge拓展脚本批量添加dialer:
function main(config, profileName) {
config.proxies = config.proxies.map(proxy => {
if (proxy.name && proxy.name !== 'dialer_name') {
proxy['dialer-proxy'] = 'dialer_name';
}
return proxy;
});
return config;
}
12.8
docker更新容器restart策略
docker update --restart=always <name>
12.3
调试Firefox自身UI
Firefox隐藏标签栏
使用树形标签页后,传统标签页没有必要一直显示,通过自定义css隐藏:
11.22
docker清理垃圾
docker system df -v # view detailed space info
docker container prune # remove stopped containers
docker image prune # remove all dangling images
docker image prune -a # remove all images without at least one container associated to them
11.20
使文件只允许追加
sudo chattr +a <file> # append only
WireGuard配置端口转发
在外网服务器上配置:
[Interface]
# ... Other Configurations ...
PostUp = iptables -t nat -A PREROUTING -p tcp -m tcp --dport <outer_port> -j DNAT --to-destination <inner_ip>:<inner_port>
PostDown = iptables -t nat -D PREROUTING -p tcp -m tcp --dport <outer_port> -j DNAT --to-destination <inner_ip>:<inner_port>
docker访问宿主机服务
如果是host
模式,直接使用127.0.0.1
如果是bridge
模式,使用172.17.0.1
11.16
检测客户端连通性
nmap:
nmap -6 -p <端口号> <IPv6地址>
nmap -p <端口号> <IPv4地址>
nc:
# TCP
nc -l <port> # server
nc <addr> <port> # client
# UDP
nc -u -l <port> # server
nc -u <addr> <port> # client
11.14
纯ipv6服务器访问ipv4
配置NAT64,设置公共DNS64服务器
11.10
Windows最速激活
irm https://get.activated.win | iex
(能直连,但是比较慢,最好开代理)
验证/etc/fstab
修改/etc/fstab
后,使用sudo mount -a
验证是否编写正确
11.3
bilibili批量取消关注
10.31
Linux禁用休眠
/etc/systemd/sleep.conf.d/disable-sleep.conf
:
[Sleep]
AllowSuspend=no
AllowHibernation=no
AllowHybridSleep=no
AllowSuspendThenHibernate=no
10.27
挂载nfs
server
在/etc/exports
中配置:
/exported/directory 192.168.1.0/24(rw,sync)
使用exportfs
启用:
sudo exportfs
client
挂载:
sudo mount -t nfs 192.168.1.1:/exported/directory /mount/point
挂载smb协议共享目录
sudo apt install cifs-utils psmisc
sudo mount -t cifs -o username=$(whoami),uid=$(id -u),gid=$(id -g) //[server-ip]/[share-path] /[mount-point]
重置终端光标
有些程序会隐藏光标,而在退出时不恢复,可以手动重置:
tput cnorm # reset cursor
echo -e "\e[?12l\e[?12h" # (optional) make cursor blink
10.26
油猴脚本获取资源被CSP策略阻断
这个策略是由被注入的网站设置的,可以通过将原本XMLHttpRequest
的调用替换为油猴的GM.xmlHttpRequest
来绕过。
油猴脚本获取资源被CORS策略阻断
有时希望在油猴脚本中访问自己服务器上的资源,被浏览器拦下,提示strict-origin-when-cross-origin
。需要在自己的服务中配置CORS中间件或者在Nginx中配置:
add_header 'Access-Control-Allow-Origin' '*'; # 根据需要设置为具体域名
add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'Origin, Content-Type, Accept, Authorization';
if ($request_method = 'OPTIONS') {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'Origin, Content-Type, Accept, Authorization';
add_header 'Access-Control-Max-Age' 1728000;
add_header 'Content-Length' 0;
add_header 'Content-Type' 'text/plain charset=UTF-8';
return 204;
}
git强制启用pager
某些时候如git diff --exit-code
时不会调用pager,使得diff-so-fancy
没有被调用。
solution:
git --paginate diff --exit-code # force to paginate
docker进入容器命令行
docker exec -it <container> bash
docker绑定挂载最佳实践
10.25
FastAPI 422 Unprocessable Entity
import logging
from fastapi import FastAPI, Request, status
from fastapi.exceptions import RequestValidationError
from fastapi.responses import JSONResponse
app = FastAPI()
@app.exception_handler(RequestValidationError)
async def validation_exception_handler(request: Request, exc: RequestValidationError):
exc_str = f'{exc}'.replace('\n', ' ').replace(' ', ' ')
logging.error(f"{request}: {exc_str}")
content = {'status_code': 10422, 'message': exc_str, 'data': None}
return JSONResponse(content=content, status_code=status.HTTP_422_UNPROCESSABLE_ENTITY)
Windows安装程序不认SSD
在BIOS中关闭VMD技术(Volume Management Device)
Windows下WireGuard SSH不通
经排查是MTU问题导致丢包 ref
netsh interface ipv4 show subinterfaces # check MTU configuration
netsh interface ipv4 set subinterface "wg0" mtu=1280 store=persistent # set MTU=1280
Windows下WireGuard被防火墙限制
将wg网络设置为专用网络:
sudo Set-NetConnectionProfile -Name wg0 -NetworkCategory Private
10.24
docker指定容器中hostname
docker run -h <hostname> ...
10.20
Word / WPS实用功能
- Continuous Format Painter:选中内容,右键,Format Painter右侧小图标
- 仅文本粘贴:Ctrl+Alt+T
- 公式格式与自动编号:solution
- 参考文献自动按照出现先后编号:solution
- 查找替换通配符列表:ref
优化git diff
使用diff-so-fancy来生成更加人类可读的差异。
sudo pacman -S diff-so-fancy
git config core.pager "diff-so-fancy | less --tabs=4 -RF" # optional: --global
git config interactive.diffFilter "diff-so-fancy --patch" # optional: --global
10.19
WPS缺字体
yay -S ttf-ms-win10-auto-zh_cn
sudo fc-cache -fv
这个包可以解决SimSun
等字体,但如果还存在缺失,则需要另外安装其他包含的包。
10.18
WireGuard用户空间实现
如果内核中没有wireguard模块,又不便编译安装时,可以使用BoringTun
# make configurations in ~/wg as is kernelspace version
yay -S boringtun # or boringtun-git
sudo pacman -S wireguard-tools
sudo ln -s ~/wg/wg0.conf /etc/wireguard
sudo WG_QUICK_USERSPACE_IMPLEMENTATION=boringtun WG_SUDO=1 wg-quick up wg0
10.16
Kanata改键修正Pad键盘
Pad的键盘Escape处是XF86HomePage,而且没有Fn锁,使用Kanata将其配置为正常键盘键位 ref
(deflocalkeys-linux
🔍 217
)
(defsrc
hmpg 🔅 🔆 🔍 ◀◀ ▶⏸ ▶▶ 🔇 🔉 🔊 powr
F1 F2 F3 F4 F5 F6 F7 F8 F9 F10 F11 F12
` 1 2 3 4 5 6 7 8 9 0
lsft
lctl lalt lmet spc
)
(deflayer default
esc F1 F2 F5 F6 F7 F8 F9 F10 F11 F12
🔅 🔆 F3 F4 F5 ◀◀ ▶⏸ ▶▶ 🔇 🔉 🔊 F12
` 1 2 3 4 5 6 7 8 9 0
lsft
lctl lmet lalt spc
)
(defoverrides
(AltLeft ShiftLeft 3) (F3)
(ControlLeft Space) (F4)
)
10.12
pacman查询某个文件所属的包
pacman -Qo <path>
处理pacsave和pacnew
- pacsave:卸载软件包时检测到配置文件曾被修改,pacman会将其备份为.pacsave文件
- pacnew:更新软件包时检测到配置文件曾被修改,pacman会将更新的配置文件保存为.pacnew文件,并给出警告
- pacdiff:可用于检索pacsave/pacnew文件并进行交互式处理
vim分屏操作
Ctrl+w + v / :vs <file> # 垂直分屏(左右分)
Ctrl+w + s / :sp <file> # 水平分屏(上下分)
Ctrl+w + k/j/h/l # 向上/下/左/右切换
Ctrl+w + +/-/>/< # 增大高度/减小高度/增大宽度/减小宽度
10.11
WiFi信号相关命令
iw reg get # 查询无线监管域相关信息
sudo iw reg set CN # 设置无线监管域为CN
nmcli device wifi # 查询频道和带宽等信息
CPU Benchmark
sudo pacman -S sysbench
sysbench cpu run --threads=1 --time=20
sysbench cpu run --threads=8 --time=20
yay -S geekbench # for x86_64
geekbench
wget https://cdn.geekbench.com/Geekbench-6.3.0-LinuxARMPreview.tar.gz # for ARM64
10.6
Firefox AI Chatbot 自定义
Firefox引入了AI侧边栏的实验性功能,通过修改高级配置可以进行自定义:
进入about:config
,找到browser.ml.chat.provider
,修改为自定义的服务即可,如https://chatgpt.com/?temporary-chat=true&model=gpt-4o-mini
10.5
rofi-bluetooth正确处理颜色转义字符
rofi-bluetooth很久没有更新,没有正确处理bluetoothctl输出中的终端颜色控制字符,而bluetoothctl没有提供关闭彩色输出的选项。
solution: 修改rofi-bluetooth代码,对转义字符进行过滤
devices=$(bluetoothctl devices | grep Device | cut -d ' ' -f 3- | sed 's/\x1b\[[0-9;]*m//g') # 新增sed命令部分
10.4
flatpak应用设置环境变量
flatpak override --env=ENV1=VALUE1 com.name.package
10.1
OpenWrt公钥登录
其使用的ssh server为Dropbear,因此需要将公钥放置在/etc/dropbear/authorized_keys
9.30
du忽略其他文件系统
du -x ...
9.29
SSH over HTTPS
stream {
# dispatch according to server_name
map $ssl_preread_server_name $backend {
ssh.example.com 127.0.0.1:22;
default 127.0.0.1:443;
}
server {
listen 443 ssl;
ssl_preread on;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;
proxy_pass $backend;
include /etc/nginx/ssl_common.conf;
}
}
9.28
NextTract
curl nxtrace.org/nt | bash
Nginx反向代理WebSocket服务
主要是需要自动升级HTTP/1.1
以支持websocket
http {
server {
listen 8020;
server_name your_domain.com;
location / {
proxy_pass http://your_websocket_backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# for websocket
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
}
docker配置代理
/etc/docker/daemon.json
:
{
"proxies": {
"http-proxy": "http://127.0.0.1:7890",
"https-proxy": "http://127.0.0.1:7890",
"no-proxy": "localhost,127.0.0.0/8"
}
}
7z常用命令
7z a <options> <target> <source...> # 压缩
<options>:
-mx=9 # 压缩级别
-tzip # 指定zip格式(默认7z)
-mmt=4 # 指定线程数(默认32)
7z x <target> # 解压,支持7z zip rar等
7z l <target> # 列出归档内容
7z t <target> # 测试完整性
9.27
Tampermonkey加载jQuery
// @require https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js
9.25
使用i3lock-fancy时xautolock不工作
经过排查是因为xautolock
在调用locker
时会关闭其标准输出导致locker
进程异常退出。
xautolock
man page:
By default xautolock closes stdout and stderr. This prevents the locker from writing error messages to these files in case you manually lock your display. The -nocloseout, -nocloseerr and -noclose options cause xautolock to not close stdout and/or stderr. On some platforms users of xnlock will need to use -nocloseout, in order to make xnlock's witty sayings show up. These options can also be used for debugging cases in which locker invocation is not successful.
solution:
xautolock -time 10 -locker i3lock-fancy -nocloseout
9.22
watch带有管道的命令
watch 'cmd1 | cmd2 | cmd3'
9.15
shell获取绝对路径
realpath <target>
9.12
ping指定包长
ping <host> -s <size>
9.8
SSH无法连通时快速失败
设置ConnectTimeout选项
ssh <host> -o ConnectTimeout=1 # 1秒
便捷管理远端clash-core
# 在本机启动yacd
docker run -p <port>:80 -d --name yacd --rm ghcr.io/haishanh/yacd:master
# 将远程主机上clash-core的external-controller端口转发到本地
ssh -L <ctrl_port>:127.0.0.1:<ctrl_port> dasc_llm -vNT
随后在浏览器中访问localhost:<port>
进入yacd,并填写API Base URL为http://localhost:<ctrl_port>
。
9.6
wget断点续传
wget ... -c
9.5
查找字体规范名称
fc-list
# eg. /usr/share/fonts/noto/NotoSansMono-Regular.ttf: Noto Sans Mono:style=Regular
# ==> Noto Sans Mono:style=Regular
9.3
设置窗口透明度
xprop -id <window_id> -f _NET_WM_WINDOW_OPACITY 32c -set _NET_WM_WINDOW_OPACITY <opacity>
其中window_id
可以通过wmctrl -l
获得,opacity
为整数,0
表示不透明,0xffffffff
表示完全透明。
8.30
GPG签名git commit
gpg --list-secret-keys # 列出密钥
gpg --full-generate-key # 生成密钥(交互式)
gpg --armor --export <Fingerprint> # 生成公钥
# 在托管平台添加公钥
git config --global user.signingkey <Fingerprint> # 配置签名公钥
git commit -S -m ... # 提交时签名
git config --global commit.gpgsign true # 提交时默认签名
ssh给AUR投票
ssh aur@aur.archlinux.org vote package_name
8.28
LiteLoaderQQNT在QQ更新后失效
是因为启动代码被覆盖,重新安装即可
yay -S liteloader-qqnt-bin
# :: Running post-transaction hooks...
# (1/1) Patch QQ for LiteLoaderQQNT
跨平台久坐提醒工具
8.26
配置油猴脚本自动更新
在脚本头部新增@updateURL
和@downloadURL
字段,前者提供元信息用于获取版本号,使得油猴插件可以判断脚本是否更新,后者提供脚本完整代码。
(注意链接最后的脚本名是可以随便写的,不影响返回内容 source)
// @downloadURL https://update.greasyfork.org/scripts/<script_id>/<script_name>.user.js
// @updateURL https://update.greasyfork.org/scripts/<script_id>/<script_name>.user.js
8.22
ImageMagick压缩图片
magick -quality 75 <from.png> <to.jpg> # 75 out of 100
8.20
yay禁用check
yay -S <pkg> --mflags "--nocheck"
8.8
oh-my-zsh Cheet Sheet
oh-my-zsh快捷cd
d # display the dir stack
1~9 # cd to the corresponding dir
8.7
fcitx环境变量最佳配置
/etc/environment
:
GTK_IM_MODULE=fcitx
QT_IM_MODULE=fcitx
XMODIFIERS=@im=fcitx
SDL_IM_MODULE=fcitx
GLFW_IM_MODULE=ibus
8.2
禁用某些cpu核
cpupower-gui offline [LIST OF CPUS] # eg. 0,1,2,11,13
8.1
安卓虚拟位置
有没有ROOT都可以,有ROOT支持基站模拟
scp限速
scp -l <limit> ... # 参数单位为Kb/s,所以注意乘以8
7.29
ext4分区在线扩容
7.28
检索手册
apropos <key-word>
web server防止.git文件夹暴露
location ~ /\.git { # 需要放在其他location块之前
deny all;
}
7.26
测试ssh连接质量
yay -S sshping
sshping <host>
7.22
ssh连接复用
有时服务器只允许密码登录,但重复输入密码比较麻烦,可以配置连接复用实现短时间内只用重新输入一次密码。
~/.ssh/config
:
Host <host>
<...>
ControlMaster auto
ControlPath ~/.ssh/sockets/%r@%h-%p
ControlPersist 600 # keep 600s
7.20
md5批量校验
md5sum * > checklist.chk
md5sum -c checklist.chk
7.19
快速传文件到服务器
如果本机到服务器的连接带宽受限,但本机和服务器都有较高的公网带宽,可以借助中转站快速传文件。例如SwissTransfer CowTransfer
下载链接无法直接wget(403 forbidden),可以先在本机浏览器找到任意一个常规请求,拷贝对应的CURL命令,然后将下载链接替换进去。
curl --output a.zip <raw-download-link> -H ... -H ...
7.15
无root权限使用PyEnv
由于pyenv有一些构建依赖,无root时pyenv install
会遭遇Build Fail
。
解决方案:使用conda进行local install,创建虚拟环境给pyenv用。
conda create -n py310 python=3.10
conda activate py310
cd .pyenv/versions
python -m venv py310
pyenv virtualenv py310 new_env
pyenv shell new_env
# new_env is like a normal pyenv virtual environment
# but py310 can not be used directly
无root权限安装zsh
export PREFIX=$HOME/.local
# OPTIONAL: zsh will not install without ncurses. IF your machine doesn't have ncurses, you need to install it first.
export CXXFLAGS=" -fPIC" CFLAGS=" -fPIC" CPPFLAGS="-I${PREFIX}/include" LDFLAGS="-L${PREFIX}/lib"
wget https://ftp.gnu.org/pub/gnu/ncurses/ncurses-6.2.tar.gz
tar -xzvf ncurses-6.2.tar.gz
cd ncurses-6.2
./configure --prefix=$PREFIX --enable-shared
make
make install
cd .. # && rm ncurses-6.2.tar.gz && rm -r ncurses-6.2
# install zsh itself
wget -O zsh.tar.xz https://sourceforge.net/projects/zsh/files/latest/download
mkdir zsh && unxz zsh.tar.xz && tar -xvf zsh.tar -C zsh --strip-components 1
cd zsh
./configure --prefix=$PREFIX
make
make install
cd .. # && rm zsh.tar && rm -r zsh
echo -e "export SHELL=\$HOME/.local/bin/zsh\nexec \$SHELL -l" >> ~/.bash_profile # or chsh
# OPTIONAL: install oh-my-zsh
sh -c "$(wget https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh -O -)"
6.18
更新PyEnv
pyenv update
6.12
sudo常用选项
sudo -u user # 指定用户
sudo -E # 保留环境变量
6.10
端口扫描
nmap -sT <target> # TCP connect扫描
sudo nmap -sS <target> # SYN扫描
6.8
打断pacman安装导致系统损坏的恢复方法
pacman -Syu
过程中卡死,只好强制重启,重启后出现Kernel Panic。经排查,发现是安装更新时首先会删除被更新的文件全部内容(变为空文件),然后再统一写入新文件内容,此时打断导致大量关键文件缺失(如libc.so)。
在这种情况下广为流传的 chroot
+重新安装 方案不能解决问题,执行chroot
时会出现chroot: failed to run command '/bin/bash': Input/output error
。但是可以通过外部pacman
直接向挂载的guest根目录中安装。
solution:
# Boot into an installation media
sudo mount /dev/nvme0n1p8 /mnt
sudo pacman -Syy
sudo pacman --root=/mnt --cachedir=/mnt/var/cache/pacman/pkg -S $(pacman --root=/mnt -Qnq) # re-install all installed packages
期间可能会遇到GPG签名验证不通过的情况,可以通过安装manjaro-keyring
或手动导入密钥解决。
由于不是在当前系统中执行安装,很多post-hook
之类的会执行失败,但是没有关系,不影响修复文件。安装完毕后重启发现可以进入系统,但是一些系统组件没有正常工作(例如由dkms
管理的显卡驱动)。此时需要重新再安装一次,以便正确执行post-hook
。
sudo pacman -Syy
sudo pacman -S $(pacman -Qnq)
6.7
Windows OpenSSH 更改登录SHELL为PowerShell
编辑C:\ProgramData\ssh\sshd_config
,在末尾添加:
Match User <your_username>
ForceCommand powershell.exe -NoLogo -NoProfile
重启sshd服务:
Restart-Service sshd
5.23
gdb打印ip地址
(gdb) p (char*)inet_ntoa(*(uint32_t*)ip_hdr->dst_ip)
ssh port forwarding转发HTTPS服务
ssh -vNT -L 4433:example.com:443 <host>
修改/etc/hosts
:
127.0.0.1 example.com
于是浏览器可以访问https://example.com:4433
pyenv使用系统包管理器安装的包
起因:graph-tool
只能使用conda或包管理器系统级安装,pip无法安装
pyenv virtualenv system venv # use system-wide python version
vim ~/.pyenv/versions/cc_system/cc_system/pyvenv.cfg # EDIT: include-system-site-packages = true
5.19
Linux和Windows之间远程同步文件方案
- 在Windows端配置
Openssh Server
- 使用
sshfs
将Windows端的目标文件夹挂载到Linux端 - 使用基于
rsync
的常规文件同步工作流,忽略文件系统导致的问题rsync --no-owner --no-perms --no-group ...
winget常用命令
winget source remove winget
winget source add winget https://mirrors.ustc.edu.cn/winget-source
winget search 7zip
winget show --id 7zip.7zip
winget install --id 7zip.7zip
winget upgrade --id 7zip.7zip
winget uninstall --id 7zip.7zip
Windows配置ssh server
先启用Openssh Server
应用组件及服务
如果是管理员用户,公钥不能放在%HOME%
:solution
5.16
快速清理旧文件
# only work in zsh
mv path/to/*(.m+30) target/path # move all files with mtime before 30 days
mv path/to/*(/m+30) target/path # for folders
5.11
convert常见用法
convert path/to/input_image.jpg path/to/output_image.png
convert path/to/input_image.png -resize 640x480 path/to/output_image.png
convert path/to/image1.png path/to/image2.png ... -delay 10 path/to/animation.gif # delay 100ms
5.10
配置多网卡后无法上网
ip route # 查看默认网关
ip route del default via 192.168.1.100 # 删除不正确的网关
5.7
解除Firefox侧边栏宽度限制
5.6
网站自定义快捷键
使用油猴插入脚本
window.addEventListener("keydown", function(e){
if(e.altKey && e.key == "z"){
document.getElementsByClassName("icon-shape-rect")[0].click();
}
});
4.30
调试Makefile
打印跟踪信息:make --trace
打印全部调试信息:make --debug=a
4.2
多线程加速apt
多核加速pip build wheel
MAKEFLAGS="-j`nproc`" pip install ...
3.27
普通用户自定义安装CUDA Toolkit
当需要的CUDA版本和全局安装的不一致,又不想影响全局环境
wget https://developer.download.nvidia.com/compute/cuda/12.4.0/local_installers/cuda_12.4.0_550.54.14_linux.run # 从 https://developer.nvidia.com/cuda-downloads 选择合适版本的runfile
export TARGET_PATH=<custom installation path>
bash cuda_12.4.0_550.54.14_linux.run --toolkit --toolkitpath=$TARGET_PATH
# 编辑 .zshrc
alias cuda12_enable="export LD_LIBRARY_PATH=$TARGET_PATH/lib64:$LD_LIBRARY_PATH; export PATH=$TARGET_PATH/bin:$PATH"
pip install自定义临时缓存
当/tmp
空间不足时,pip无法进行安装,自定义缓存路径即可
TMPDIR=/path/to/tmp pip install --cache-dir=$TMPDIR ...
3.26
允许用户设置低nice
/etc/security/limits.conf
username - nice -20
需要重新登录用户,ulimit -a
检查是否设置成功
3.1
docker清理无用容器
docker rm -v $(docker ps --filter status=exited -q)
2.24
ipynb导出到py文件
pip install nbconvert
jupyter nbconvert --to script <xxx.ipynb>
2.20
ipynb跳过单元格
%%script true
<code to skip>
2.18
Python类型注解允许隐式Optional
pyrightconfig.json
:
{
"strictParameterNoneValue": false
}
2.17
VMWare和Linux Memory Compaction的冲突问题
Linux使用Transparent HugePage技术来提高内存效率,需要内核线程kcompactd
在后台进行内存整理。但这一过程会导致虚拟机周期性卡顿,关闭此技术即可。
解决方法(root下执行,重启后失效):
echo never > /sys/kernel/mm/transparent_hugepage/enabled
echo never > /sys/kernel/mm/transparent_hugepage/defrag
2.5
节省yay压缩软件包时间
修改~/.makepkg.conf
中的PKGEXT=.pkg.tar.xz
为PKGEXT=.pkg.tar
因为使用yay打包后一般是立即安装,而不是发布,此设置可以节省xz压缩、解压的过程
1.30
docker容器访问宿主机上的服务
使用host.docker.internal
docker ... --add-host=host.docker.internal:host-gateway
# docker-compose.yml
services:
xxx:
...
extra_hosts:
- "host.docker.internal:host-gateway"
直接使用宿主机网络
(可能不安全)
docker ... --net=host
# docker-compose.yml
services:
xxx:
...
network_mode: host
1.26
简单方便的段错误追踪手段libSegFault.so
libSegFault.so由glibc提供
LD_PRELOAD=/path/to/libSegFault.so ./the_program
1.23
rm避免歧义
当文件/文件夹以-
开头时
rm -rf -- -foo
非scp远程拷贝
ssh dd if=xxx | dd of=xxx
1.6
批量查找
find ... | xargs cat | grep xxx
1.3
rsync同步文件夹
rsync -av --progress sourcefolder /destinationfolder --exclude thefoldertoexclude
-n
: dry run
--exclude
: 相对于sourcefolder, 可重复多次
命令行启动热点
最新一次滚包之后wihotspot-gui
不能使用了,看起来像是gtk更新导致不兼容。但是create_ap
是能正常使用的
sudo create_ap wlo1 wlo1 '<ssid>' '<passphrase>' --freq-band 2.4
1.1
\(\text{A Fresh Start !}\)