一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

云服務(wù)器|WEB服務(wù)器|FTP服務(wù)器|郵件服務(wù)器|虛擬主機(jī)|服務(wù)器安全|DNS服務(wù)器|服務(wù)器知識|Nginx|IIS|Tomcat|

服務(wù)器之家 - 服務(wù)器技術(shù) - 服務(wù)器知識 - Docker容器定時備份數(shù)據(jù)庫并發(fā)送到指定郵箱(設(shè)計思路)

Docker容器定時備份數(shù)據(jù)庫并發(fā)送到指定郵箱(設(shè)計思路)

2022-01-25 16:43陳小c 服務(wù)器知識

這篇文章主要介紹了Docker容器定時備份數(shù)據(jù)庫并發(fā)送到指定郵箱,文中寫了一下shell腳本,邏輯也很簡單,當(dāng)前時間與啟動時間相同時,則調(diào)用sendmail函數(shù)發(fā)送郵件,具體腳本跟隨小編一起看看吧

項目地址及使用說明:https://gitee.com/noovertime/mysqlmail

一、背景:

一開始的初衷是,想寫一個腳本來監(jiān)控服務(wù)器的高占用率進(jìn)程并通過郵件發(fā)送給我,然后突發(fā)奇想,可以使用這種方式來備份我的數(shù)據(jù)庫,開始動手!

二、設(shè)計思路:

通過編寫shell腳本,調(diào)用linux的mail工具,mysqldump的方式來保存數(shù)據(jù)庫的sql文件,通過mail工具添加到附件,最后發(fā)送到我的郵箱。

三、編寫啟動腳本

首先我們來編寫一個啟動腳本
為了方便以后的個性化配置,我們將腳本中的變量都提取到一個application.yml文件中,文件如下:

?
1
2
3
4
5
6
RUNTIME: 084900 ##啟動時間,因為容器時區(qū)問題,需要當(dāng)前時間減去8小時
HOST: 172.17.0.3 ##數(shù)據(jù)庫IP地址
USER: root ##數(shù)據(jù)庫用戶
PASSWORD: 123456 ##數(shù)據(jù)庫密碼
DATABASE: solo ##數(shù)據(jù)庫名
TARGETMAIL: [email protected] ##發(fā)送的郵箱地址

接下來我們來寫一下shell腳本,邏輯也很簡單,當(dāng)前時間與啟動時間相同時,則調(diào)用sendmail函數(shù)發(fā)送郵件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#!/bin/bash
#author: chenteng
 
RUNTIME=$(cat ./application.yml | grep RUNTIME| awk '{print $2}')
HOST=$(cat ./application.yml | grep HOST| awk '{print $2}')
USER=$(cat ./application.yml | grep USER| awk '{print $2}')
PASSWORD=$(cat ./application.yml | grep PASSWORD| awk '{print $2}')
DATABASE=$(cat ./application.yml | grep DATABASE| awk '{print $2}')
TARGETMAIL=$(cat ./application.yml | grep TARGETMAIL| awk '{print $2}')
 
function  sendmail(){
  mysqldump -h$HOST  -u$USER -p$PASSWORD  --complete-insert --skip-add-drop-table  --hex-blob $DATABASE  > $DATABASE.sql
  echo -e "mysqlbak_$CURRENT_TIME" |mail -s "mysqlbak_$CURRENT_TIME" -a $DATABASE.sql $TARGETMAIL
  sleep 1
}
while true
do
  CURRENT_TIME=$(date +%H%M%S)
  if [ $CURRENT_TIME = $RUNTIME ];then
    echo "starting bak mysql database"
    sendmail
    continue
  else
    echo $CURRENT_TIME
    sleep 1
  fi
done

四、構(gòu)建鏡像

因為我們最后要放到k8s平臺上的,所以我們要構(gòu)建一個鏡像,在構(gòu)建鏡像之前,請先把a(bǔ)pplication.yml demo.sh Dockerfile放在同一目錄下
Dockerfile如下:
PS:添加了mysql的客戶端,郵件mail客戶端

?
1
2
3
4
5
6
FROM centos
RUN mkdir /app && yum install -y mysql.x86_64 sendmail  mailx libreport-plugin-mailx
WORKDIR /app
COPY demo.sh .
COPY application.yml .
CMD ["/bin/sh","demo.sh"]

使用docker build命令構(gòu)建鏡像,要記得加一下最后的點

?
1
docker build -t mysqlmail-bak:1.0.1 .

五、添加邊車容器

邊車容器(sidecar):邊車容器就是與主容器一起在一個pod中運(yùn)行的容器,為業(yè)務(wù)容器賦能,共享一個網(wǎng)絡(luò)空間,所以可以用127.0.0.1:3306連接主容器的數(shù)據(jù)庫。

5.1 創(chuàng)建配置文件

為了方便調(diào)試,我把里面的shell腳本也掛載出來。
創(chuàng)建兩個configmap,分別對應(yīng)容器內(nèi)的配置文件與shell腳本,后面如果不需要調(diào)試可以取消mysqlshell的掛載。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
apiVersion: v1
kind: ConfigMap
metadata:
  name: mysqlmail-conf
  namespace: solo
data:
  application.yml: |
    RUNTIME: 105800
    HOST: 127.0.0.1
    USER: root
    PASSWORD: 123456
    DATABASE: solo
    TARGETMAIL: [email protected]
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: mysqlmail-shell
  namespace: solo
data:
  demo.sh: |
    #!/bin/bash
    #author: chenteng
    RUNTIME=$(cat ./application.yml | grep RUNTIME| awk '{print $2}')
    HOST=$(cat ./application.yml | grep HOST| awk '{print $2}')
    USER=$(cat ./application.yml | grep USER| awk '{print $2}')
    PASSWORD=$(cat ./application.yml | grep PASSWORD| awk '{print $2}')
    DATABASE=$(cat ./application.yml | grep DATABASE| awk '{print $2}')
    TARGETMAIL=$(cat ./application.yml | grep TARGETMAIL| awk '{print $2}')
    function  sendmail(){
      mysqldump -h$HOST  -u$USER -p$PASSWORD  --complete-insert --skip-add-drop-table  --column-statistics=0 --hex-blob $DATABASE  > $DATABASE.sql
      echo -e "mysqlbak_$CURRENT_TIME" |mail -s "mysqlbak_$CURRENT_TIME" -a $DATABASE.sql $TARGETMAIL
      sleep 1
    }
    while true
    do
      CURRENT_TIME=$(date +%H%M%S)
      if [ $CURRENT_TIME = $RUNTIME ];then
        echo "starting bak mysql database"
        sendmail
        continue
      else
        echo $CURRENT_TIME
        sleep 1
      fi
    done

5.2 創(chuàng)建有狀態(tài)服務(wù)部署文件

我們的deploy文件使用的是上篇文章中創(chuàng)建的mysql有狀態(tài)服務(wù)的yaml,有興趣的可以看下我上篇遷移的文章

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: mysql
  namespace: solo
spec:
  serviceName: mysql-service
  selector:
    matchLabels:
      app: mysql
  replicas: 1
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - name: mysqlmail-bak
        imagePullPolicy: IfNotPresent
        image: mysqlmail-bak:1.0.1
        volumeMounts:
        - name: mysqlmail-conf
          mountPath: /app/application.yml
          subPath: application.yml
        - name: mysqlmail-shell
          mountPath: /app/demo.sh
          subPath: demo.sh
      - name: mysql-pod
        imagePullPolicy: IfNotPresent
        image: mysql:5.7
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: "123456"
        ports:
        - containerPort: 3306
          name: msyql-listin
        volumeMounts:
        - name: mysql-data
          mountPath: /var/lib/mysql
          subPath: mysql-data
        - name: mysql-conf
          mountPath: /etc/mysql/conf.d/my.cnf
          subPath: my.cnf
      volumes:
      - name: mysql-data
        hostPath:
          path: /data/mysql
      - name: mysql-conf
        configMap:
          name: mysql-conf
      - name: mysqlmail-conf
        configMap:
          name: mysqlmail-conf
      - name: mysqlmail-shell
        configMap:
          name: mysqlmail-shell
---
 
apiVersion: v1
kind: Service
metadata:
  name: mysql-service
  namespace: solo
  labels:
    app: mysql
spec:
  ports:
  - targetPort: 3306
    port: 3306
  clusterIP: None
  selector:
     app: mysql

六、測試

我們上面給他定的時間是RUNTIME: 105800,上海時區(qū)也就是18點58分,我們來看一下效果
查看日志,
注意: 當(dāng)一個pod包含多個容器時,要使用 -c 參數(shù)指定查看哪個容器

?
1
2
3
4
5
6
7
8
9
10
[root@VM-24-15-centos solo]# kubectl logs -n solo mysql-0  -c mysqlmail-bak | grep mysql -C 5
105755
105756
105757
105758
105759
starting bak mysql database
mysqldump: [Warning] Using a password on the command line interface can be insecure.
105801
105802

從日志可以看到,郵件已經(jīng)發(fā)送成功了!我們來去郵箱看一下,發(fā)現(xiàn)也已經(jīng)成功了,至此我們的實驗完美完成!

Docker容器定時備份數(shù)據(jù)庫并發(fā)送到指定郵箱(設(shè)計思路)

到此這篇關(guān)于Docker容器定時備份數(shù)據(jù)庫并發(fā)送到指定郵箱的文章就介紹到這了,更多相關(guān)Docker定時備份數(shù)據(jù)庫內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://blog.csdn.net/weixin_43143310/article/details/122260774

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产日产欧产精品精品软件 | 国产高清在线播放免费观看 | 亚洲第一永久色 | 18韩国美女vip视频7 | 国产在线观看99 | 亚洲福利在线观看 | 久久免费资源福利资源站 | 69福利区 | 深夜在线观看网站 | 草莓视频网站18勿进 | 免费国产之a视频 | 91社区在线观看精品 | 日本高清在线精品一区二区三区 | 都市风流贵妇激情 | 日产乱码卡一卡2卡三卡四福利 | 好男人在线观看hd中字 | 99久久精品99999久久 | free性videoxxⅹ印度 | 日剧整部剧护妻狂魔免费观看全集 | 亚洲大尺码 | 亚洲成年网站在线777 | 亚洲天堂色视频 | 四虎影视紧急入口地址大全 | 国产成人精品在线观看 | 牧教师在线观看 | 亚洲精品综合一二三区在线 | 娇小XXXXX第一次出血 | 四虎影视在线影院在线观看 | 欧美 亚洲 综合 卡通 另类 区 | 欧美特黄aaaaaa | 青青草99热这里都是精品 | 冰雪奇缘1完整版免费观看 变形金刚第一部 | 美女扒开屁股让我桶免费 | 草草草视频 | 免费看1级伦理 | 天美传媒果冻传媒星空传媒 | 亚洲精品无码不卡 | 国产精品国色综合久久 | 国产成人亚洲精品91专区高清 | 免费十几分视频 | 欧美同性video |