iCloud 链接到标题
iCloud 是 Mac 的默认云盘,Apple 为 Mac 提供了一定程度上的 iCloud 集成,在 Apple ID -> iCloud -> iCloud 云盘
中,可以选择让“桌面与文稿文件夹”也使用 iCloud 云盘,此时,你原先的 /Users/Documents
和 /Users/Desktop
会被替换为 iCloud/Documents
中的 文稿 - zwy - mbp14
以及 icloud/Desktop
中的 桌面 - zwy - mpb14
目录,同时 iCloud 中的 文稿
目录与 桌面
目录会被分别作为 Mac 的 /Users/Documents
与 /Users/Desktop
目录,推测是通过符号链接来实现的?
此后所有的对 /Users/Docuements
与 /Users/Desktop
的修改都会反映到 iCloud 中。
要注意一点,推荐关闭 iCloud 的 优化 Mac 储存空间
功能,否则当你的 Mac 存储空间不足的时候,/Users/Documents
与 /Users/Desktop
目录中的内容会变成仅保存在 iCloud 云端,而本地没有保存内容,这会导致在这两个目录中执行 git
与 cd
等命令非常卡顿。
OneDrive 链接到标题
Windows 也提供了对 OneDrive 的集成,但是开启之后,不像 iCloud 那么彻底,原先的 C:\Users\zwyyy\Documents
与 C:\Users\zwyyy\Desktop
目录依旧存在,只是文件管理器左侧显示的 桌面
与 文档
会指向 C:\Users\zwyyy\OneDrive\Desktop
和 C:\Users\zwyyy\OneDrive\Documents
两个目录,同时 Windows 的桌面显示的内容也被替换成了 C:\Users\zwyyy\OneDrive\Desktop
中的内容。
最佳实践 链接到标题
通过 git 进行版本管理 的代码文件不适合存放在云盘会自动同步的目录中,哪怕是使用 mega 这种自定义排除同步功能十分丰富的云盘,也不推荐,这是因为云盘对文件的同步容易被 git 视为修改,从而在 git pull 时发生 conflict,哪怕这个文件的内容你实际上没有修改。
推荐将 code 目录直接存放在 /Users/zwyyy/
目录下(Mac)或者 C:\Users\zwyyy
目录下(Windows)。
代码文件统一存放在 code 目录下,blog 也存放在 code 目录下。
源代码编译时会产生大量的临时文件,这也是不推荐将代码源文件通过云同步工具进行同步的一个重要原因。
代码文件的自动同步 链接到标题
代码文件一般通过 git 进行版本管理,因此不适合存放在云盘中进行同步,然而总有代码写了一部分,忘记 push 到 github,而回家之后,要接着修改代码的情况,那应该如何实现代码的自动同步呢?
对 Mac 或者 Linux,解决方案为通过 crontab 自动执行 git push
命令,具体一点,即定时执行以下命令:
git add -A
git commit -m "mac, auto sync"
git push ali main:mac # Linux 替换为 linux 分支,Windows 替换为 win 分支
Windows 应该差不多,即要求定时执行 powershell 脚本。
git add -A
git commit -m "win, auto push"
git push ali main:win
之后,假设回到家,发现之前忘记手动 push 了,那么只需要执行以下命令:
git checkout mac # 切换到 mac 分支
git pull gitlab mac
git checkout main
git merge mac # 将本地的 mac 分支的更改合并到 main 分支中
git push origin main
对于 windows,则是:
git checkout win
git pull ali win
git checkout main
git merge win
根据当前作息,我将设置 mac 在 18:10 与 20:40 定时执行 push。
mac 设置 crontab 链接到标题
mac 可以通过 crontab 工具实现定时执行 push 操作。为了保证 crontab 可以正常执行,我们需要做一点额外配置。
首先执行 crontab -e
,修改为如下内容并退出保存:
6 18 * * * zsh /Users/zwyyy/.config/mac-push.sh
7 18 * * * zsh /Users/zwyyy/code/bean/mac-push.sh
8 18 * * * zsh /Users/zwyyy/code/leetcode/mac-push.sh
9 18 * * * zsh /Users/zwyyy/code/blog/zwyb_blog/mac-push.sh
36 20 * * * zsh /Users/zwyyy/.config/mac-push.sh
37 20 * * * zsh /Users/zwyyy/code/bean/mac-push.sh
38 20 * * * zsh /Users/zwyyy/code/leetcode/mac-push.sh
39 20 * * * zsh /Users/zwyyy/code/blog/zwyb_blog/mac-push.sh
然后执行 sudo launchctl list | grep cron
查看任务是否存在,我的输出如下:
zwyyy@zwy-mbp14 ~/c/bean (main)> sudo launchctl list | grep cron (base)
458 0 com.vix.cron
有输出说明任务存在。然后执行 locate com.vix.cron
查看启动项配置,如果有 WARNING
,就执行系统提供的命令 sudo launchctl load -W /System/Library/LaunchDaemons/com.apple.locate.plist
。
然后查看 /etc/crontab
是否存在,我这里是不存在的,需要执行 sudo touch /etc/crontab
来创建。
之后,可能需要给 crontab 完全磁盘访问权限,crontab 安装于 /usr/bin
,我们打开 系统偏好设置 -> 隐私与安全性 -> 完全磁盘访问权限
,将访达中的 crontab 图标拖进去,即可为 crontab 启用完全磁盘访问权限。
但是我的 crontab 执行的命令似乎并不需要完全磁盘访问权限,一般来说,应用需要访问 User 的 Documents、Desktop、Downloads、OneDrive 这几个目录会需要单独授予磁盘访问权限,对 crontab,我们无法单独授予对某个文件夹的访问权限,因此只能授予完全磁盘访问权限。
关于 crontab 是否需要完全磁盘访问权限,这一点还有待测试。 当前测试表明不需要完全磁盘访问权限。
Windows 设置定时任务 链接到标题
以 Win11 操作系统为例,打开 任务计划程序
,点击 任务计划程序库
,然后点击右侧的 创建任务
,在 触发器
标签处选择每日重复,在 操作
标签下,程序
选择 pwsh.exe
,参数
设置为 -ExecutionPolicy Bypass -File "C:\path\to\your\script.ps1"
。
其中 -ExecutionPolicy Bypass
表示 PowerShell 脚本的执行策略为 Bypass
,即允许所有 PowerShell 脚本运行而不受任何限制,-File
之后则是要执行的脚本的具体路径。