自動壓縮備份並rsync至遠端

備份的shell,記得chmod +x 備份.sh

#刪除超過五天的主機備份檔
rm -f /opt/backup/www$(date --date=' 5 days ago' '+%Y-%m-%d').tar.gz;
#docker 匯出mysql備份資料
docker exec CONTAINER /usr/bin/mysqldump -u root --password=123456 --all-databases > /opt/backup/mysql/backup.sql;
#非用docker可以用
#mysqldump -u root --password=123456 --all-databases > /opt/backup/mysql/backup.sql;
#docker cp /etc/httpd/conf/httpd.conf /home/user/backup/httpd/;
#cp /etc/httpd/conf.d/* /home/user/backup/httpd/;
#打包及壓縮www日期.tar.gx
tar zcvf /opt/backup/www$(date +%Y-%m-%d).tar.gz /var/www/html /opt/backup/mysql  ;
//rsync至遠端主機
usr/bin/rsync -rvlHpogDtS --password-file=/etc/rsyncd.secrets /opt/backup webbackup@remoteip::NetBackup

設排程,定時執行內容,定時早上四點執行

crontab -e 
* * 4 * * backup.sh > backup.txt #backup wb file 

docker安裝apache、mariadb、php

在docker安裝Apache php及Mariadb服務,可以快速部署安裝於多種OS,不管是在開發或是正式上線環境都可以一樣。

images使用是官方的apache php 7.2版本;mariadb:latest,其中apache-php部份還需要另外安裝mysqli擴展套件。

《Docker —— 從入門到實踐-》正體中文版

指令如下

資料庫部份

sudo docker search mariadb
sudo docker pull mariadb
sudo docker run -d --name mariadb -e MYSQL_ROOT_PASSWORD=youpass --restart unless-stopped mariadb

參數–restart unless-stopped可以讓os在重開機時自動啟動docker container,不過自已下指令停止時不會自動再啟動

Read More

使用crontab取代wordpress的wp-cron

在檢查apache的log檔時,發現wp-cron常常執行時間很長也常Timeout。當流量不大或是系統資源夠大時,其實並不會發現有什麼問題,可是如果在資源有限及流量增加時,就會因為執行時間太長增加wordpress回傳的反應時間,如果有系統的控制權,建議可以使用排程crontab來取代。

1.首先Disable wp-cron

修改wordpress目錄下的wp-config.php

define('DISABLE_WP_CRON', true);

Read More