背景 将本地目录做一个存储仓库,将归档的文件放入其中。自动同步到远程仓库。

仓库配置 省略

配置密钥 用户可以 git pull \ git push \ git commit

自动 拉取、更新 脚本

文件名:autosave.sh


#!/bin/zsh# 设置变量
LOCAL_DIR=$1# 进入工作目录
cd "$LOCAL_DIR" || { echo "无法进入目录 $LOCAL_DIR"; exit 1; }# 拉取代码
pvsh() { git rev-parse --abbrev-ref HEAD | xargs -I {} git push origin '{}'; };
# 推送代码
pvll() { git rev-parse --abbrev-ref HEAD | xargs -I {} git pull origin '{}'; };
# 强制拉取代码
pxsh() { git rev-parse --abbrev-ref HEAD | xargs -I {} git push origin --force '{}'; };
# 强制推送代码
pxll() { git rev-parse --abbrev-ref HEAD | xargs -I {} git pull origin --force '{}'; };commit() { git log -1 --pretty=format:'%B' | git commit -a -F -;  };if [ "$(git status --short | awk '{print $2}' | wc -l)" -gt 0 ]; then## 当前目录下有新的文件 或者 有文件更新git add .commit;pvll;if [ $? -ne 0 ] ; then## mac OS 系统中调用一个弹窗 弹出脚本异常,用户需要主动修改osascript -e 'tell application "System Events" to display dialog "脚本异常!" buttons {"确定"} default button 1'fipvsh;if [ $? -ne 0 ] ; then## mac OS 系统中调用一个弹窗 弹出脚本异常,用户需要主动修改osascript -e 'tell application "System Events" to display dialog "脚本异常!" buttons {"确定"} default button 1'fi
else## 当前目录没有更新则直接拉取pvll;
fi

定时任务

文件名:com.rc.autosave.plist

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict><key>Label</key><string>com.rc.autosave</string><key>ProgramArguments</key><array><string>/bin/zsh</string><string>/Users/rc/Code/markdown/autosave.sh</string><string>/Users/rc/Code/markdown/</string></array><key>StartInterval</key><integer>300</integer> <!-- 五分钟执行一次 --><key>RunAtLoad</key><true/> <!-- 开机启动 --><key>StandardOutPath</key><string>/tmp/autosave.log</string><key>StandardErrorPath</key><string>/tmp/autosave_error.log</string>
</dict>
</plist>

Mac os 配置任务

launchctl load ./com.rc.autosave.plist # 载入配置文件

launchctl list | grep autosave # 查看自动化配置

Linux 配置任务

  • crontab -e
  • */5 * * * * /Users/rc/Code/markdown/autosave.sh

原文档地址: Issues/51

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/87101.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/87101.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/87101.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu中控制用户存储空间配置步骤

目的&#xff0c;限制用户磁盘空间占用&#xff0c;例如给用户限制100-150G容量 1.安装磁盘配额工具 sudo apt-get install -y quota 2.备份并修改/etc/fstab文件&#xff0c;使能支持quota sudo cp /etc/fstab /etc/fstab.bak vim /etc/fstab #写入如下,usrjquotaaquota.u…

【网络】Linux 内核优化实战 - net.ipv4.tcp_rmem 和 net.core.rmem_default 关系

net.ipv4.tcp_rmem 和 net.core.rmem_default 都是 Linux 内核中控制网络接收缓冲区的参数,但它们的作用范围、优先级和使用场景存在明显区别。以下是详细对比: 核心区别 参数net.ipv4.tcp_rmemnet.core.rmem_default作用协议仅针对 TCP 协议针对 所有网络协议(TCP、UDP 等…

设计模式精讲 Day 14:命令模式(Command Pattern)

【设计模式精讲 Day 14】命令模式&#xff08;Command Pattern&#xff09; 文章内容 在“设计模式精讲”系列的第14天&#xff0c;我们来学习命令模式&#xff08;Command Pattern&#xff09;。命令模式是一种行为型设计模式&#xff0c;它将请求封装为对象&#xff0c;从而…

手机射频功放测试学习(二)——手机线性功放的静态电流和小信号(S-Parameter)测试

目录 一、概要 二、LPA的电流测试 1、LPA的泄漏电流测试 手动测试步骤如下: 自动化测试: 2、LPA的静态电流测试 手动测试步骤如下: 自动化测试: 三、LPA的S-Parameter测试 1、矢量网络分析仪校准 2、LPA的S参数手动测试步骤: 3、LPA的S参数自动测试步骤: 四…

基础算法合集-图论

本文将介绍数据结构图论部分中常见的算法 单源最短路径问题(用来计算一个点到其他所有顶点的最短路径) Dijkstra(n*n) 1. 初始化: 先找出从源点V0到各终点Vk的直达路径(V0,Vk), 即通过一条弧到达的路径 2. 选择: 从这些路径中找出一条长度最短的路径(V0,u) 3. 更新: 然后对其余…

vue-i18n 插件打包解析失效问题记录

vue-i18n 插件打包解析失效问题记录 开发环境中没有问题的&#xff0c;但打包发布之后就不行了&#xff0c;显示的就是模板字符串 // An highlighted block const messages {en: {step: {stepDesc1: Scan,stepDesc2: Analyze,stepDesc3: Result}},zh: {step: {stepDesc1: 扫描…

数据可视化 - 单子图

一、认识单子图 import matplotlib.pyplot as plt import numpy as np import pandas as pdplt.figure(num单子图, figsize(12, 8), facecolorw) # 中文字体 plt.rcParams[font.sans-serif] KaiTi # 负号显示 plt.rcParams[axes.unicode_minus] False# 2行&#xff0c;1列&a…

服务器上设置了代理之后,服务器可以访问外网,但是不能访问服务器本地。如何解决

你在服务器上设置了代理后&#xff0c;发现&#xff1a; 可以访问外网不能访问服务器本地地址&#xff08;如 localhost、127.0.0.1、内网IP&#xff09; 这是代理设置中常见的问题&#xff0c;尤其是当你设置了全局 HTTP/HTTPS 代理时。本地访问也会被强制走代理&#xff0c…

mysql启动报错:Can‘t connect to local MySQL server through socket

文章目录 一、报错内容二、解决方法 一、报错内容 在linux上启动mysql时报错 [rootlocalhost bin]# ./mysql -u root -p Enter password: ERROR 2002 (HY000): Cant connect to local MySQL server through socket /tmp/mysql.sock (2)执行以上命令后报错&#xff0c;并且也…

C# Avalonia 绑定模式 Mode 的区别,它们的应用场景

C# Avalonia 绑定模式 Mode 的区别&#xff0c;它们的应用场景 文章目录 1. **Default&#xff08;默认模式&#xff09;**2. **OneTime&#xff08;一次性绑定&#xff09;**3. **OneWay&#xff08;单向绑定&#xff09;**4. **TwoWay&#xff08;双向绑定&#xff09;**5. *…

【OpenGL学习】(七)纹理单元

【OpenGL学习】&#xff08;七&#xff09;纹理单元 OpenGL的纹理单元&#xff08;Texture Unit&#xff09;是GPU中用于管理和组织纹理资源的逻辑单元&#xff0c;它允许开发者在渲染过程中同时使用多个纹理&#xff0c;并通过采样器&#xff08;Sampler&#xff09;在着色器…

Ubuntu 下降 Linux Kernel 的版本备忘

此处以 ubuntu 22.04 为示例系统&#xff0c;来降低其 Linux kernel 的版本。 1. 降低 Linux kernel 版本 在 Ubuntu 22.04 上降低 Linux 内核版本的步骤如下所示。 步骤 1&#xff1a;检查当前内核版本 uname -r 确认当前运行的内核版本。 步骤 2&#xff1a;查看已安装的…

Python 数据分析与机器学习入门 (八):用 Scikit-Learn 跑通第一个机器学习模型

引言&#xff1a;初识 Scikit-Learn Scikit-learn 是 Python 机器学习领域的黄金标准库。它构建在 NumPy, SciPy 和 Matplotlib 之上&#xff0c;提供了大量用于分类、回归、聚类和降维等任务的算法。Scikit-learn 广受欢迎的原因在于其三大核心优势&#xff1a; 一致的 API 设…

FPGA芯片的配置方法

FPGA芯片的配置方法 文章目录 FPGA芯片的配置方法1. FPGA配置概述2. 主动配置模式3. 被动配置模式4. JTAG配置模式5. 总结 1. FPGA配置概述 当我们在PC机上的FPGA软件集成开发环境中完成我们的设计后&#xff0c;必须通过某种形式将其映射到FPGA芯片硬件中&#xff0c;这样FPG…

通过python+openCV实现对图片中箭头方向的判断

在项目中遇到一个需求,需要对图片中的箭头方向进行判断,本来是使用YOLOv8算法来实现的,但是发现YOLO的效果对箭头的识别效果很差,不管是分类算法还是检测算法,效果都不理想,因此试一试通过openCV对箭头方向进行判断,发现效果还可以。 下面附上完整的代码和原理。 文章目…

React 第六十六节Router中 StaticRouter使用详解及注意事项

前言 StaticRouter 是 React Router 为服务器端渲染&#xff08;SSR&#xff09;提供的专用路由组件。它允许在服务器环境中处理路由逻辑&#xff0c;确保服务器和客户端渲染结果一致。下面我将详细解释其用途、原理并提供完整的代码示例。 一、StaticRouter 的核心用途 服务…

嵌入模型与大语言模型的区别:从结构到应用的深度解析

嵌入模型与大语言模型的区别&#xff1a;从结构到应用的深度解析 在当今自然语言处理&#xff08;NLP&#xff09;技术蓬勃发展的背景下&#xff0c;嵌入模型&#xff08;Embedding Model&#xff09; 和 大语言模型&#xff08;Large Language Model, LLM&#xff09; 成为了…

el-date-picker赋值不成功

vue使用element 的时间组件el-date-picker赋值不成功&#xff0c;点击后才回显数据 解决: 组件未渲染完成之前赋值了&#xff0c;在onMounted函数内赋值&#xff0c;或者在确保组件已经渲染后赋值

深入浅出JavaScript中的私有变量与特权方法

深入浅出JavaScript中的私有变量与特权方法&#xff1a;封装的艺术 在JavaScript的开发实践中&#xff0c;私有变量和特权方法是实现数据封装和代码安全性的核心工具。它们不仅帮助我们隐藏敏感数据&#xff0c;还能通过闭包和作用域机制构建更健壮的代码结构。本文将从基础概…

ReactNative【实战系列教程】我的小红书 2 -- 快捷登录、手机号密码登录

最终效果 技术要点 用户协议 – 打开本地浏览器 点击后&#xff0c;直接打开本地浏览器浏览网页 // 最终需修改为 《用户协议》 的网址Linking.openURL("https://www.baidu.com");手机号输入框的 344 展示 onChangeText{(text: string) > {setPhone(formatPhone(…