發表文章

目前顯示的是 11月, 2024的文章

解決 Docker 官方的 MySQL 8 執行 INSERT 超級慢的問題

原本 insert 20 筆資料會耗時 1秒,改完後,insert 500 筆不到 0.1 秒! 注意事項 雖然以下不會執行sql語法,但動到資料庫參數,要確認隨時可以回復到可用狀態。 如果已有 my.cnf 檔,就建立另一個檔 環境 官方的 MySQL 8.4 Docker image ( FROM mysql:8 ) 解法 加入一個自定義 my.cnf 檔在 /etc/mysql/conf.d/ ,內容: [mysqld] # 通常設定為系統 RAM 的 60-80%。這裡數值約16G innodb_buffer_pool_size = 17089934592 # 增大此緩衝區可以提高寫入性能,特別是在處理大量寫入時,會減少磁碟寫入的頻率。 # 這裡數值約256MB innodb_log_buffer_size = 268217728 # 是否在每個事務提交後同步二進制日誌(Binary Log)。 # 設置為 1 會增加每個事務的成本,設為 0 或 100 可以提高寫入性能。 sync_binlog = 0 # 事務提交時,何時將日誌寫入磁碟的選項。設為 0 可以減少事務提交的 I/O 負擔, # 但會犧牲持久性,可能遺失最近 1 秒內的事務記錄。 innodb_flush_log_at_trx_commit = 0 # 停用二進制日誌(Binary Log) skip-log-bin = 0   References ChatGPT 解决连接Docker mysql容器慢的问题 MySQL 8.0 执行 insert 插入数据非常缓慢的问题及解决方法   以下僅為測試數據 用以下參數,insert 500 筆的時間: 0 分 10.40642 秒 [mysqld] innodb_buffer_pool_size = 17089934592 innodb_log_buffer_size = 268217728 # sync_binlog = 0 innodb_flush_log_at_trx_commit = 0 skip-log-bin = 0 用以下參數,insert 500 筆的時間:...

取得小米藍牙裝置 bindkey 加密金鑰 綁定碼

   注意事項 要取得小米藍牙裝置的 bindkey 加密金鑰 綁定碼 台灣用戶的 Server 是 sg 環境 作業系統: MacOS 12.7 取得小米裝置資訊 curl -L -O https://github.com/PiotrMachowski/Xiaomi-cloud-tokens-extractor/releases/latest/download/token_extractor.zip # 解壓縮 unzip token_extractor.zip # 進入已解壓縮的資料夾 cd token_extractor # 安裝該程式所需套件 pip3 install -r requirements.txt # 執行該程式 python3 token_extractor.py # 輸入小米帳號 # 再來輸入小米密碼 # Server 打 sg # 就會列出該帳號有的所有裝置 # 欄位 BLE KEY 就是 bindkey 加密金鑰 來源:https://github.com/PiotrMachowski/Xiaomi-cloud-tokens-extractor#manual-run-in-python

免 sudo、免密碼終端機執行 docker 跟 docker-compose 指令

解決執行 docker 跟 docker-compose 要打 sudo 並且輸入密碼才可以執行的麻煩 注意事項 安全性會降低 此文的 Docker 是透過 snap 安裝 環境 作業系統:Ubuntu 24 確認 Docker 服務是否正在執行 snap services docker # inactive 的話,就啟動它 sudo snap start docker 或是 sudo systemctl status snap.docker.dockerd.service # inactive 的話,就啟動它 sudo systemctl start snap.docker.dockerd.service 檢查 docker 群組是否存在 cat /etc/group | grep docker # 有的話會看起來類似這樣 # docker:x:1001:{your_account} 輸出是空的話,建立該群組。對,就是建一個 docker 群組 sudo groupadd docker 檢查你是否在 docker 群組中 groups $USER # 看起來類似這樣 # {your_account} : group1 adm cdrom sudo dip plugdev users lpadmin docker 此指令也可以看 id $USER 如果沒有 docker 字樣出現的話,把你加入 sudo usermod -aG docker $USER 立即生效 newgrp docker 確認是否不需 sudo 可正常執行 docker ps

如何產生客戶端用的 ovpn 檔

注意事項 已有 OpenVPN server、ca.key 用戶端在使用此憑證時無需輸入密碼 固定 IP ,已經定好的檔名,後續不可修改   先在 server 生成憑證、密鑰和配置 $ ssh {your_server} $ sudo docker run \ -v /volume1/docker/tun/etc:/etc/openvpn \ --rm -it kylemanna/openvpn \ easyrsa build-client-full {your_file_name} nopass # 原 /etc/openvpn/ 的檔已存在 /volume1/docker/tun/etc 裡了,所以這裡要輸入ca.key的密碼 Enter pass phrase for /etc/openvpn/pki/private/ca.key:   成功應該要出現這些訊息: Enter pass phrase for /etc/openvpn/pki/private/ca.key: Check that the request matches the signature Signature ok The Subject's Distinguished Name is as follows commonName :ASN.1 12:'{your_file_name}' Certificate is to be certified until Mar 9 01:15:10 2026 GMT (825 days) Write out database with 1 new entries Data Base Updated _________________ 以上會生成三個檔, pki/issued/{your_file_name}.crt、pki/private/{your_file_name}.key、pki/reqs/{your_file_name}.req    設該 ovpn 設定檔的固定 IP $ sudo docker exec -it {your_container_name} /bin/bash $ cd /e...