程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> c完成linux下的數據庫備份

c完成linux下的數據庫備份

編輯:關於C++

c完成linux下的數據庫備份。本站提示廣大學習愛好者:(c完成linux下的數據庫備份)文章只能為提供參考,不一定能成為您想要的結果。以下是c完成linux下的數據庫備份正文


Linux下c完成的數據庫備份,只需修正數據庫列表文件的信息便可。

db_list.txt把後綴去失落便可,一個數據庫一行。

1. main.c  

#include<sys/types.h>
#include<sys/wait.h>
#include<ctype.h>
#include<unistd.h>
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
 
//待備份的數據表文件(一個數據庫一行)
#define DB_FILE "./db_list"
//最多可以備份的數據庫數目
#define NUM 20
//一個數據庫名字的最長字符數
#define LEN 128
//保留從DB_FILE中讀取到的數據庫
char *db_list[NUM];
//從DB_FILE文件中讀取到的數據庫數目
int read_num;
//要求內存函數
void malloc_dblist();
//釋放內存函數
void free_dblist();
//讀取數據庫文件
void readDbFile();
 
int main(int argc, char *argv[]) {
  pid_t pid;
  int i;
  char buf[LEN];
 
  //從文件讀取數據庫信息
  readDbFile();
   
  pid = fork();
 
  if (pid < 0) {
    fprintf(stderr, "fork error\n");
    exit(1);
  }
   
  switch (pid) {
    case -1:
      fprintf(stderr, "fork failed\n");
      exit(1);
    case 0:
      //子過程停止數據庫的備份
      for (i = 0; i < read_num; i++) {
        memset(buf, '\0', LEN);
        sprintf(buf, "%s%s%s%s%s", "mysqldump -uroot ", db_list[i], " > ", db_list[i], ".sql");
        system(buf);
        printf("%d,%s\n", i, buf);
      }
      break;
  }
  //期待子過程的停止
  if (pid > 0) {
    int stat_val;
    pid_t child_pid;
     
    child_pid = wait(&stat_val);
     
    if (!WIFEXITED(stat_val)) {
      fprintf(stdout, "Child terminated abnormaly\n");
    }
    exit(1);
     
  }
   
  free_dblist();
   
  exit(0);
   
}
 
void malloc_dblist()
{
  int i = 0;
  //malloc for db_list
  for (i = 0; i < NUM; i++) {
    db_list[i] = malloc(LEN);
    memset(db_list[i], '\0', LEN);
  }
}
void free_dblist()
{
  int i;
  //free db_list's memory
  for (i = 0; i < NUM; i++) {
    free(db_list[i]);
  }
}
 
void readDbFile()
{
  FILE *fp;
   
  fp = fopen(DB_FILE, "r");
  if (!fp) {
    fprintf(stderr, "%s not found\n", DB_FILE);
  }
  else {
    malloc_dblist();
     
    read_num = 0;
    while (fscanf(fp, "%127[^\r\n]\n", db_list[read_num]) == 1) {
      puts(db_list[read_num]);
      read_num++;
    }
     
    fclose(fp); 
  }
   
}

2. db_list.txt

admin
book

3.

#include<sys/types.h>
#include<sys/wait.h>
#include<ctype.h>
#include<unistd.h>
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
 
//待備份的數據表文件(一個數據庫一行)
#define DB_FILE "./db_list"
//最多可以備份的數據庫數目
#define NUM 20
//一個數據庫名字的最長字符數
#define LEN 128
//保留從DB_FILE中讀取到的數據庫
char *db_list[NUM];
//從DB_FILE文件中讀取到的數據庫數目
int read_num;
//要求內存函數
void malloc_dblist();
//釋放內存函數
void free_dblist();
//讀取數據庫文件
void readDbFile();
 
int main(int argc, char *argv[]) {
  pid_t pid;
  int i;
  char buf[LEN];
 
  //從文件讀取數據庫信息
  readDbFile();
   
  pid = fork();
 
  if (pid < 0) {
    fprintf(stderr, "fork error\n");
    exit(1);
  }
   
  switch (pid) {
    case -1:
      fprintf(stderr, "fork failed\n");
      exit(1);
    case 0:
      //子過程停止數據庫的備份
      for (i = 0; i < read_num; i++) {
        memset(buf, '\0', LEN);
        sprintf(buf, "%s%s%s%s%s", "mysqldump -uroot ", db_list[i], " > ", db_list[i], ".sql");
        system(buf);
        printf("%d,%s\n", i, buf);
      }
      break;
  }
  //期待子過程的停止
  if (pid > 0) {
    int stat_val;
    pid_t child_pid;
     
    child_pid = wait(&stat_val);
     
    if (!WIFEXITED(stat_val)) {
      fprintf(stdout, "Child terminated abnormaly\n");
    }
    exit(1);
     
  }
   
  free_dblist();
   
  exit(0);
   
}
 
void malloc_dblist()
{
  int i = 0;
  //malloc for db_list
  for (i = 0; i < NUM; i++) {
    db_list[i] = malloc(LEN);
    memset(db_list[i], '\0', LEN);
  }
}
void free_dblist()
{
  int i;
  //free db_list's memory
  for (i = 0; i < NUM; i++) {
    free(db_list[i]);
  }
}
 
void readDbFile()
{
  FILE *fp;
   
  fp = fopen(DB_FILE, "r");
  if (!fp) {
    fprintf(stderr, "%s not found\n", DB_FILE);
  }
  else {
    malloc_dblist();
     
    read_num = 0;
    while (fscanf(fp, "%127[^\r\n]\n", db_list[read_num]) == 1) {
      puts(db_list[read_num]);
      read_num++;
    }
     
    fclose(fp); 
  }
   
}

以上所述就是本文的全體內容了,願望年夜家可以或許愛好。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved