From 1860ca6c4263c45901a65327796164171a9a26b9 Mon Sep 17 00:00:00 2001 From: Awin Huang Date: Fri, 12 Jan 2024 10:17:37 +0800 Subject: [PATCH] vault backup: 2024-01-12 10:17:37 --- .obsidian/workspace.json | 13 ++++++------- 00. Inbox/systemd.md | 4 ++++ 00. Inbox/樹莓派.canvas | 2 +- 3 files changed, 11 insertions(+), 8 deletions(-) create mode 100644 00. Inbox/systemd.md diff --git a/.obsidian/workspace.json b/.obsidian/workspace.json index 61f6d2c..1de37fd 100644 --- a/.obsidian/workspace.json +++ b/.obsidian/workspace.json @@ -43,9 +43,9 @@ "state": { "file": "00. Inbox/樹莓派.canvas", "viewState": { - "x": -980.811858027452, - "y": 1437.5282478124002, - "zoom": -0.3890515971812937 + "x": -1228.1540864748197, + "y": 1633.2719797648233, + "zoom": -0.09942106314468102 } } } @@ -217,9 +217,11 @@ }, "active": "069e76e47c814366", "lastOpenFiles": [ + "00. Inbox/systemd.md", + "00. Inbox/01. TODO.md", + "00. Inbox/樹莓派.canvas", "attachments/Pasted image 20240111231507.png", "00. Inbox/SSIM.md", - "00. Inbox/樹莓派.canvas", "05. 資料收集/Tool Setup/Software/vim.md", "00. Inbox/自我成長.canvas", "00. Inbox/[APP] 設定CPU Power mode.md", @@ -243,13 +245,11 @@ "05. 資料收集/Linux/Programming.md", "03. 個人:Travel/20230214 - 日本福岡旅遊.md", "00. Inbox/00. Inbox.md", - "00. Inbox/01. TODO.md", "README.md", "00. Inbox/Project Zomboid.md", "02. 個人:Daily/2024-01-01(週一).md", "02. 個人:Daily/2023/2023年度目標.md", "02. 個人:Daily/2024", - "02. 個人:Daily/2023/12/2023-12-01(週五).md", "02. 個人:Daily/2023/12", "attachments/Pasted image 20231225164717.png", "attachments/Pasted image 20231225164413.png", @@ -257,7 +257,6 @@ "attachments/Pasted image 20231220095827.png", "attachments/Pasted image 20231212181946.png", "attachments/Pasted image 20231212181543.png", - "attachments/Pasted image 20231212180917.png", "未命名 1.canvas", "未命名.canvas", "02. 個人:Daily/2023/11", diff --git a/00. Inbox/systemd.md b/00. Inbox/systemd.md new file mode 100644 index 0000000..1f59a0a --- /dev/null +++ b/00. Inbox/systemd.md @@ -0,0 +1,4 @@ +## 列出系統中的 systemd service +```bash +systemctl list-units --type=service +``` \ No newline at end of file diff --git a/00. Inbox/樹莓派.canvas b/00. Inbox/樹莓派.canvas index 30f9760..ee50e45 100644 --- a/00. Inbox/樹莓派.canvas +++ b/00. Inbox/樹莓派.canvas @@ -6,7 +6,7 @@ {"id":"6184baf71c6585ff","type":"text","text":"## crontab\n### 加入\n使用`crontab -e`,然後加入這一行:\n`*/1 * * * * /home/awin/script/ddns.sh`\n\n### 說明\n![[Pasted image 20240111231507.png]]\n依序是 **分鐘,   小時,   日期,   月份,    星期,   command**\n參數為 0-59,   0-23,   1-31,  1-21,   0-6,   需要執行的command\n**※ 星期參數為 0 代表星期日**\n\n- 【*】:星號,代表任何時刻都接受的意思\n- 【,】:逗號,代表分隔時段。例如:30 9,17 * * * command,代表早上 9 點半和下午五點半都執行 command。\n- 【-】:減號,代表一段時間範圍。例如:15 9-12 * * * command,代表從 9 點到 12 點的每個 15 分都執行 command。\n- 【/n】:斜線,n 代表數字,表示每個 n 單位間隔。例如:*/5 * * * * command,代表每隔 5 分鐘執行一次 command。\n\n■ 還有一些人性化的參數,一次取代全部五個數字參數\n- 【@reboot】 :僅在開機的時候執行一次。\n- 【@yearly】 :一年執行一次,和0 0 1 1 * command效果一樣。\n- 【@annually】:(和@yearly一樣)\n- 【@monthly】:一個月執行一次,和0 0 1 * * command效果一樣。\n- 【@weekly】:一個星期執行一次,和0 0 * * 0 command效果一樣。\n- 【@daily】:每天執行,和0 0 * * * command效果一樣。\n- 【@midnight】:(和@daily一樣)\n- 【@hourly】 :每小時執行,和0 * * * * command效果一樣。\n\n### 範例\n- 每 5 分鐘執行一次:\n - `*/5 * * * *  root    /usr/libexec/atrun`\n- 每 5 小時執行一次\n - `​* */5 * * * root    /usr/libexec/atrun`\n- 每天 AM 5:00 執行指令(星號與星號之間要有空隔)\n - `​00 05   * * *  username /bin/bash /路徑/command`\n- 1 至 20 號每天執行一次\n - ​`0 1 1-20  * * root    /usr/libexec/atrun`\n- 當分針移到第 5 分時,執行此 cron\n - `​5 * * * * root    /usr/libexec/atrun`\n- 當時針移到 1 點 1 分時,執行此 cron\n - ​`1 1 * * * root    /usr/libexec/atrun`\n- 每週一的 1 點 1 分,執行\n - `​1 1 * * 1 root    /usr/libexec/atrun`\n- 2 月 29 日時針到 1 點 1 分,執行\n - ​`1 1 29 2 * root    /usr/libexec/atrun`\n- 8 點到 16 點每 5 分鐘執行一次 cron\n - `​/5 8-16 * * *   root    /usr/libexec/atrun`\n\n### crontab 命令\n#### 啟動\n`sudo service cron start`\n\n#### 重新啟動\n`/etc/init.d/cron restart`\n\n#### 查詢service狀態\n`sudo /etc/init.d/cron status`\n\n#### 編輯 crontab\n`crontab -e`\n\n\n","x":-731,"y":620,"width":631,"height":430}, {"id":"6ad2c15172b3b925","type":"text","text":"## 設定 DDNS of Cloudflare\n1. 準備`/home/awin/script/ddns.sh`\n2. 把script加入craontab\n\n","x":-60,"y":624,"width":371,"height":136}, {"id":"89db003eaa4162c9","type":"text","text":"## `/home/awin/script/ddns.sh`\n```bash\n#!/bin/bash\nCF_ACCESS_TOKEN=033xQP4_ZpTq3sSkeftz5J6BWw_R9eoDNTba7zfH\nCF_ZONE_ID=1d6a623d1780c31544fc86f718dac16e\nURLS=('awin.one'\n 'blog.awin.one'\n 'ftp.awin.one'\n 'git.awin.one',\n 'storj.awin.one')\nCF_RECORD_IDS=('d67b2a1b3d7cd520b8e8dad2cb522460'\n '69dcc0bd619b1a3d4a71458faff2aa50'\n 'bd397d9779d42c0b92c9c9c47b765769'\n '4eccb48e85f2daa8fefeb92c8cb4b4ee'\n '216d631bc860c6a11b62e3a1003f3e3e')\n\nINTERNET_IP=`curl -s http://ipv4.icanhazip.com`\nINTERFACE_IP=`ip address show ppp0 | grep ppp0 | grep global | awk '{print$2}'`\nDNS_RECORD_IP=`dig +short \"${URLS[0]}\" | grep -Eo '([0-9]{1,3}\\.){3}[0-9]{1,3}' | awk 'NR==1{print}'`\nNOW_TIME=`date`\n\nif [ \"$INTERNET_IP\" != \"$DNS_RECORD_IP\" ]\nthen\n echo \"Renew IP: ${DNS_RECORD_IP} to ${INTERNET_IP}\"\n echo \"${NOW_TIME}: Renew IP: ${DNS_RECORD_IP} to ${INTERNET_IP}\" > /home/awin/log/ddns.log\n for ((i = 0; i < ${#URLS[@]}; i++)); do\n curl -X PUT \"https://api.cloudflare.com/client/v4/zones/${CF_ZONE_ID}/dns_records/${CF_RECORD_IDS[$i]}\" \\\n -H \"Authorization: Bearer ${CF_ACCESS_TOKEN}\" \\\n -H \"Content-Type: application/json\" \\\n --data '{\"type\":\"A\",\"name\":\"'${URLS[$i]}'\",\"content\":\"'${INTERNET_IP}'\",\"ttl\":120,\"proxied\":false}'\n done\nelse\n echo \"No change: ${INTERNET_IP}\"\n echo \"${NOW_TIME}: No change: ${INTERNET_IP}\" > /home/awin/log/ddns.log\nfi\n```\n\n### 參考\n- [5 分鐘整合 Cloudflare API 實做 Cloudflare DDNS 動態 IP 對應網址](https://blog.toright.com/posts/7333/cloudflare-ddns)\n- [自架 DDNS 教學:用 Cloudflare API 達成多域名同步更新! | by Rex | Medium](https://blog.rexyuan.com/%E7%94%A8-cloudflare-dns-api-%E4%BE%86%E9%81%94%E6%88%90-ddns-adaee3c5a84d)","x":-1660,"y":350,"width":886,"height":700}, - {"id":"84c3e0d9a25b9cfd","x":-1448,"y":1160,"width":928,"height":640,"type":"text","text":"## 看log\nRaspberry Pi 4沒有`/var/log/syslog`,要使用`journalctl`。\n```bash\njournalctl\n```\nOr \n```bash\njournalctl | grep SOMETHING\n```\n\n### 看系統訊息\n```bash\njournalctl -p 0\n```\n\n#### Error code意思\n```\n0: 紧急情况\n1: 警报\n2: 危急\n3: 错误\n4: 警告\n5: 通知\n6: 信息\n7:调试\n```\n\n### 看開機log\n```bash\njournalctl --list-boots\n```\n\n- 第一個數字顯示的是journald 的唯一的啟動追蹤號碼,你可以在下一個命令中使用它來分析該特定的啟動。\n- 第二個數字是啟動ID,你也可以在指令中指定。\n- 接下來的兩個日期、時間組合是儲存在對應文件中的日誌的時間。如果你想找出某個特定日期、時間的日誌或錯誤,這就非常方便了。\n\n例如:\n```bash\njournalctl -b -45\n```\nOr\n```bash\njournalctl -b 8bab42c7e82440f886a3f041a7c95b98\n```\n\n也可以使用 `-x` 選項,在顯示器上加入systemd 錯誤訊息的解釋。在某些情況下,這是個救命稻草。例:\n```bash\njournalctl -xb -p 3\n```"} + {"id":"84c3e0d9a25b9cfd","type":"text","text":"## 看log\nRaspberry Pi 4沒有`/var/log/syslog`,要使用`journalctl`。\n```bash\njournalctl\n```\nOr \n```bash\njournalctl | grep SOMETHING\n```\n\n### 看系統訊息\n```bash\njournalctl -p 0\n```\n\n#### Error code意思\n```\n0: 紧急情况\n1: 警报\n2: 危急\n3: 错误\n4: 警告\n5: 通知\n6: 信息\n7:调试\n```\n\n### 看開機log\n```bash\njournalctl --list-boots\n```\n\n- 第一個數字顯示的是journald 的唯一的啟動追蹤號碼,你可以在下一個命令中使用它來分析該特定的啟動。\n- 第二個數字是啟動ID,你也可以在指令中指定。\n- 接下來的兩個日期、時間組合是儲存在對應文件中的日誌的時間。如果你想找出某個特定日期、時間的日誌或錯誤,這就非常方便了。\n\n例如:\n```bash\njournalctl -b -45\n```\nOr\n```bash\njournalctl -b 8bab42c7e82440f886a3f041a7c95b98\n```\n\n也可以使用 `-x` 選項,在顯示器上加入systemd 錯誤訊息的解釋。在某些情況下,這是個救命稻草。例:\n```bash\njournalctl -xb -p 3\n```\n\n### 看某一特定時間、日期的日誌記錄\n使用 `--since` 選項與 `yesterday`、`today`、`tomorrow` 或 `now` 組合。\n\n以下是一些不同指令的範例。你可以根據你的需求修改它們。它們是不言自明的。以下命令中的日期、時間格式為 `\"YYYY-MM-DD HH:MM:SS\"`\n```bash\njournalctl --since \"2020-12-04 06:00:00\"\njournalctl --since \"2020-12-03\" --until \"2020-12-05 03:00:00\"\njournalctl --since yesterday\njournalctl --since 09:00 --until \"1 hour ago\"\n```\n\n### 看內核特定的記錄\n```bash\njournalctl -k\n```\n\n### 過濾出某個systemd 服務單元的特定日誌\n例如,如果要查看 NetworkManager 服務的日誌\n```bash\njournalctl -u NetworkManager.service\n```\n\n如果不知道service name,看[[systemd#列出系統中的 systemd service]]\n\n### 查看使用者、群組的日誌\n```bash\nid -u debugpoint # 先找出使用者的uid\njournalctl _UID=1000 --since today\n```\n\n### 查看可執行檔的日誌\n```bash\njournalctl /usr/bin/gnome-shell --since today\n```\n\n### 看log佔用的磁碟空間\n```bash\njournalctl --disk-usage\n```\n\n### 清除日誌\n#### 手動清除\n```bash\nsudo journalctl --flush --rotate # 將所有日誌歸檔\nsudo journalctl --vacuum-time=7d # 只保留最近7天的日誌\nsudo journalctl --vacuum-time=1s # 只保留最近1秒的日誌\n```\n或者設定日誌的大小\n```bash\nsudo journalctl --vacuum-size=400M # 保留最後400M\n```\n\n#### 自動清除\n修改`/etc/systemd/journald.conf`,裡面有下面幾個設定項:\n- `SystemMaxUse`: 指定日志在持久性存储中可使用的最大磁盘空间。例:`SystemMaxUse=500M`\n- `SystemKeepFree`: 指定在将日志条目添加到持久性存储时,日志应留出的空间量。例:`SystemKeepFree=100M`\n- `SystemMaxFileSize`: 控制单个日志文件在被轮换之前在持久性存储中可以增长到多大。例:`SystemMaxFileSize=100M`\n- `RuntimeMaxUse`: 指定在易失性存储中可以使用的最大磁盘空间(在 /run 文件系统内)。例:`RuntimeMaxUse=100M`\n- `RuntimeKeepFree`: 指定将数据写入易失性存储(在 /run 文件系统内)时为其他用途预留的空间数量。例:`RuntimeMaxUse=100M`\n- `RuntimeMaxFileSize`: 指定单个日志文件在被轮换之前在易失性存储(在 /run 文件系统内)所能占用的空间量。例:`RuntimeMaxFileSize=200M`\n\n修改後記得重啟`journalctl`:\n```bash\nsudo systemctl restart systemd-journald\n```\n\n也請記得[[確認日誌的完整性]]\n\n### 確認日誌的完整性\n```bash\njournalctl --verify\n```\n\n### 參考\n- [系統運作|如何使用journalctl 檢視和分析systemd 日誌(附實例)](https://linux.cn/article-15544-1.html)","x":-1659,"y":1180,"width":928,"height":640} ], "edges":[ {"id":"f01be3b2d50be1dd","fromNode":"2379c5036a2ef1af","fromSide":"bottom","toNode":"3a39140e3c8408cf","toSide":"top"},