2022-09-18 16:48:06    9    0    0
## 查询占用空间最多的五个文件 ``` git rev-list --objects --all | grep "$(git verify-pack -v .git/objects/pack/*.idx | sort -k 3 -n | tail -5 | awk '{print$1}')" ``` ## 从git历史中移除 ``` git filter-branch --force --
2022-09-18 16:46:00    11    0    0
如果你之前的项目提交了一些敏感数据,或者要清除以前提交的记录,给出下面解决方案. 1. 检出一个新的分支 ``` git checkout --orphan latest_branch ``` 2. 暂存所有文件 ``` git add -A ``` 3. 提交刚刚暂存的文件 ``` git commit -am
2022-08-10 12:43:59    25    0    0

安装rust-analyzer扩展,编辑 settings.json 文件添加以下代码即可:

  1. "[rust]": {
  2. "editor.defaultFormatter": "rust-lang.rust-analyzer", // Makes the magic
  3. "editor.formatOnSave": true // Optional
  4. },
2022-06-21 10:14:29    32    0    0

安装 iTerm2

前往 iTerm2 官网 下载并安装。

设置 zsh 为默认终端

macOS 下默认已经安装了 zsh。可执行以下命令,更改默认 Shell 为 zsh。

  1. chsh -s /bin/zsh

安装 ohmyzsh

curl 方式:

  1. sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"

wget 方式:

  1. sh -c "$(wget https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh -O -)"

安装主题 Powerlevel10k

  1. git clone --depth=1 https://gitee.com/romkatv/powerlevel10k.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/themes/powerlevel10k

zsh 的配置文件 ~/.zshrc 中设置 ZSH_THEME="powerlevel10k/powerlevel10k"
设置完成后,重启 iTerm2 会提示安装需要的字体,根据提示安装即可。
完成后,重启 iTerm2 进入配置页,根据提示选择自己喜欢的样式即可。

2022-06-10 10:40:04    46    0    0

CURD

  1. Kubernetes 对象:
    https://kubernetes.io/zh/docs/concepts/overview/working-with-objects/kubernetes-objects/
  2. 创建一个服务对象来暴露 Deployment:
    kubectl expose deployment/nginx-deployment --type=NodePor
  3. 展示 Service 信息:
    kubectl describe services nginx-deployment
    注意服务中的 NodePort 值。
  4. 使用节点地址和 node port 来访问:
    curl http://<public-node-ip>:<node-port>
    或者
    curl http://127.0.0.1:<node-port>
  5. 删除服务:
    kubectl delete services nginx-deployment
  6. 删除部署
    kubectl delete deployment nginx-deployment
    https://kubernetes.io/zh/docs/tasks/access-application-cluster/service-access-application-cluster/

常用查询命令

  • 查询node: kubectl get nodes -o wide
  • 查询pod: kubectl get pods -o wide
  • 查询部署状态: kubectl get deploy
  • 查询服务状态: kubectl get service
  • 查询敏感数据状态: kubectl get secret
  • 查询上线状态:kubectl rollout status deployment/my-nginx-release
  • 查询上线历史:kubectl rollout history deployment/my-nginx-release
  • 查询pod详情描述:kubectl describe pod my-nginx-release-659d46fcd4-w5s8h (可以查看镜像部署状态以及报错详细信息)
2022-06-10 10:39:10    39    0    0

在/root/.ssh/目录下:

  1. [root@localhost .ssh]# tree -a
  2. .
  3. ├── authorized_keys
  4. ├── id_dsa
  5. ├── id_dsa.pub
  6. ├── id_rsa
  7. ├── id_rsa_2048_9417.pub
  8. ├── id_rsa.pub
  9. └── known_hosts
  • 若没有则创建 .ssh 文件夹,则创建并设置权限:chmod 700 ~/.ssh
  • .ssh 目录下生成公钥私钥:ssh-keygen -t rsa 其中 id_dsa,id_rsa 是私钥,id_rsa.pub,id_dsa.pub 是公钥
  • authorized_keys 文件存放其他主机的公钥,其他主机即可ssh登录该机,此文件的权限:chmod 644 ~/.ssh/authorized_keys
  • know_hosts 记录主机登陆过的其他主机的公钥信息

示例 A 和 B 免密登录 C

  • 分别在 A 和 B 下生成私钥密钥对,执行命令 ssh-keygen -t rsa,生成 id_rsaid_rsa.pub
  • 分别将生成的 A 的 id_rsa.pub 和 B 的 id_rsa.pub 内容追加到C主机的 authorized_keys 中,A 和 B 可以通过 ssh C 登录,exit 退出。
    ssh
    $ cat authorized_keys
    ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAvqtPwT7kjfKzycR7r0FLe+UgxOSoeOW9EVb6eUb9MsO5IHvlVBKJK6F62dc5BNgemkwR8/UUDQ6tK4DMWipHI+t8naxgyXl9Kdc7oh78c/ADW1svBkrV3qOfxey/z+8ykN+kCgk7q65NytllpQH3FAi7b/0mO3cAEQWGSAC5wSG7XOamMmL4CLjhhLGwLwIAni50nOTBVVBjrXVn10EW4Bwcv+tH7KAIlZ+kZuatOUMIYyuBWleBokJzgQm2joQfe9RiO2Ayja6O4CpJSj0g3Efkb0bdxaOxYrgigp/0
2022-06-10 10:37:54    28    0    0
  1. 查看已经连接的硬盘
  1. fdisk -l
  1. 硬盘分区和格式化
    • 分区
      sh
      fdisk /dev/sdb1

      输入n回车:新建分区
      然后依次输入:p回车、1回车、分区开始位置(默认则直接回车)回车、分区结束位置(默认则直接回车)回车
      输入w回车:保存设置并退出分区操作
    • 格式化
      sh
      mkfs -t ext4 /dev/sdb1
  2. 查看分区和格式化结果
  1. lsblk -f
  1. 挂载硬盘
  1. mount /dev/sdb1 /指定文件的路径 (这种挂载会在虚拟机重启后会取消挂载)
  1. 设置自动挂载
  1. vim /etc/fstab
2022-05-28 12:10:24    70    0    0
问题: ```bash dyld: Library not loaded: /usr/local/opt/icu4c/lib/libicuuc.69.dylib ``` 解决: ``` brew reinstall icu4c ```
MySQL    2021-11-25 12:24:14    117    0    0
## 1. 在MySQL 5.6版本以前,只有MyISAM存储引擎支持全文引擎.在5.6版本中,InnoDB加入了对全文索引的支持,但是不支持中文全文索引.在5.7.6版本,MySQL内置了ngram全文解析器,用来支持亚洲语种的分词. 在学习之前,请确认自己的MySQL版本大于5.7.6.我的版本为8.0.同时文中的所有操作都基于InnoDB存储引擎. 查询mysql版本,设置全文索引
2021-11-19 17:55:19    211    0    0
## 1 背景 > 保护服务节点或者数据节点,防止瞬时流量过大造成服务和数据崩溃,导致服务不可用 ## 2 主流限流算法 ### 2.1 固定/滑动窗口限流算法 #### 2.1.1 固定窗口限流 实现过程: 也叫计数器算法,顾名思义就是固定一个窗口,在这个时间窗口下维护一个累加的计数器,每来一个请求计数器+1,并判断计数是否超过阈值, 超过阈值则拒绝请求直到下一个时间窗口将计数器清零再继
1/8