Skip to content

Zeroplex 生活隨筆

軟體開發、伺服器和生活瑣事

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

年份: 2022 年

MySQL 的 session variable vs local variable

Posted on 2022 年 12 月 16 日2022 年 12 月 16 日 By 日落 在〈MySQL 的 session variable vs local variable〉中尚無留言

使用變數的方式主要有二種,一是使用在變數名稱地一個字元加上 @ ,二是使用 DECLARE 宣告再 SET。

要注意的是 @ 開頭的變數 scope 為整個 session,也就是在不同 function / store procedure 都可以讀取數值、設定數值。如以下範例:

DELIMITER ;;
CREATE FUNCTION hello() RETURNS text
BEGIN
    SET @str = 'hello';
    RETURN @str;
END ;;
DELIMITER ;

DELIMITER ;;
CREATE FUNCTION world() RETURNS text
BEGIN
    SET @str = 'world';
    SET @str = CONCAT(hello(), ' ', @str);
    RETURN @str;
END ;;
DELIMITER ;

SELECT world() as result;

因為會讀、寫到同一個變數,所以輸出會是 hello hello。


若使用 DECLARE 宣告變數,則開變數的 scope 僅在 loop、function、store procedure 中才有效。相同的範例,改使用 DECLARE :

DELIMITER ;;
CREATE FUNCTION hello() RETURNS TEXT
BEGIN
    DECLARE str TEXT;
    SET str = 'hello';
    RETURN str;
END ;;
DELIMITER ;

DELIMITER ;;
CREATE FUNCTION world() RETURNS TEXT
BEGIN
    DECLARE str text;
    SET str = 'world';
    SET str = CONCAT(hello(), ' ', str);
    RETURN str;
END ;;
DELIMITER ;

SELECT world() AS result;

輸出結果為 hello world。

Tags:MySQL

透過 restic 做差異性備份

Posted on 2022 年 12 月 13 日2022 年 12 月 13 日 By 日落 在〈透過 restic 做差異性備份〉中尚無留言

參考 restic 官方文件,先建立 backup repository:

restic -r sftp:backup@host:/storage.server/backup-folder init

restic 會自動記錄檔案內容,在同一個 backup repository 的資料都會做差異性備份,檔案內容沒有更動的話,就不會再複製檔案內容,加快備份速度。

用 restic 備份伺服器的資料:

restic -r sftp:backup@host:/storage.server/backup-folder backup \
    /etc /root /home /var/spool/mail/ \
    --exclude-caches=true \
    --cleanup-cache=true \
    --exclude-if-present='.cache'

restic 也可以針對單一檔案做備份。以下是將 mysqldump 的資料直接 pipe 給 restic 做備份:

mysqldump --all-databases | restic -r sftp:backup@host:/storage.server/backup-folder backup --stdin
Tags:Linux

機車輪胎

Posted on 2022 年 12 月 11 日2023 年 1 月 18 日 By 日落 在〈機車輪胎〉中尚無留言

MAXXIS 這顆輪胎偏硬 (號稱漏氣還可以勉強騎到維修站),比較耐磨,側邊有防滑紋路:

MAXXIS MA-3D

米其林 S1 是軟胎,抓地力比較好,不過磨耗較快:

MICHELIN S1 輪胎

市區短程其實第二個款式就很夠用了。長程、山路我可能還是會選擇第一顆輪胎吧。

Tags:機車

PHP 各版本的重大改變

Posted on 2022 年 12 月 4 日2022 年 12 月 16 日 By 日落 在〈PHP 各版本的重大改變〉中有 2 則留言

這份整理拖太久了,到 PHP 8.2 都上線了還沒寫完,所以就整理到 7.x 結束吧。

PHP 從約 5.2 版就開始慢慢的加上一些重大的改變,像是 PHP v5.3 開始支援 `namespace` 之後,開始有了 composer 各種套件系統的發展。這些改變讓 PHP 的開發和維護更方便、更簡單。以下記錄各版本重要的功能,以便在更新程式時可以更快的了解有什麼需要留意的事項。

備註:我沒用過 PHP 4.x,如果你還在用的話,請多保重 ….

More “PHP 各版本的重大改變” »

Tags:PHP

在 Docker 安裝、運行 Mastodon

Posted on 2022 年 11 月 20 日2023 年 1 月 19 日 By 日落 在〈在 Docker 安裝、運行 Mastodon〉中尚無留言

以下是 Mastdodon v4.0.2 在 Linux 上的安裝步驟。不同版本可能會有一些差異,請自行調整。

若沒有特別需求,Mastodon 也可以透過代理商安裝、運行,不必自行架設伺服器。

硬體需求

我自己是在 Raspberry Pi 4 上測試的,Pi 4 跑得起來只是比較慢了一些,若你的硬體配備比 Pi 4 好的話,其實沒什麼需要擔心的。

  • 雙核心處理器,建議時脈在 2 GHz 以上
  • 記憶體至少 2 GB 4 GB (隨著資料量增加,使用的記憶體也會增加)
Mastodon 運行時的 docker stats
Mastodon 運行時的 docker stats

More “在 Docker 安裝、運行 Mastodon” »

Tags:Linux, Mastodon, 網路架站

文章分頁

上一頁 1 2 3 ... 22 下一頁

其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD GCP Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.