首页 > 编程 > C++ > 正文

c实现linux下的数据库备份

2020-05-23 14:18:04
字体:
来源:转载
供稿:网友

本文给大家简单介绍下c实现linux下的数据库备份的方法和具体的源码,十分的实用,有需要的小伙伴可以参考下。

Linux下c实现的数据库备份,只要修改数据库列表文件的信息即可。

db_list.txt把后缀去掉即可,一个数据库一行。

1. main.c

 

 
  1. #include<sys/types.h> 
  2. #include<sys/wait.h> 
  3. #include<ctype.h> 
  4. #include<unistd.h> 
  5. #include<string.h> 
  6. #include<stdlib.h> 
  7. #include<stdio.h> 
  8.  
  9. //待备份的数据表文件(一个数据库一行) 
  10. #define DB_FILE "./db_list" 
  11. //最多可以备份的数据库数量 
  12. #define NUM 20 
  13. //一个数据库名字的最长字符数 
  14. #define LEN 128 
  15. //保存从DB_FILE中读取到的数据库 
  16. char *db_list[NUM]; 
  17. //从DB_FILE文件中读取到的数据库数量 
  18. int read_num; 
  19. //请求内存函数 
  20. void malloc_dblist(); 
  21. //释放内存函数 
  22. void free_dblist(); 
  23. //读取数据库文件 
  24. void readDbFile(); 
  25.  
  26. int main(int argc, char *argv[]) { 
  27. pid_t pid; 
  28. int i; 
  29. char buf[LEN]; 
  30.  
  31. //从文件读取数据库信息 
  32. readDbFile(); 
  33.  
  34. pid = fork(); 
  35.  
  36. if (pid < 0) { 
  37. fprintf(stderr, "fork error/n"); 
  38. exit(1); 
  39.  
  40. switch (pid) { 
  41. case -1: 
  42. fprintf(stderr, "fork failed/n"); 
  43. exit(1); 
  44. case 0: 
  45. //子进程进行数据库的备份 
  46. for (i = 0; i < read_num; i++) { 
  47. memset(buf, '/0', LEN); 
  48. sprintf(buf, "%s%s%s%s%s""mysqldump -uroot ", db_list[i], " > ", db_list[i], ".sql"); 
  49. system(buf); 
  50. printf("%d,%s/n", i, buf); 
  51. break
  52. //等待子进程的结束 
  53. if (pid > 0) { 
  54. int stat_val; 
  55. pid_t child_pid; 
  56.  
  57. child_pid = wait(&stat_val); 
  58.  
  59. if (!WIFEXITED(stat_val)) { 
  60. fprintf(stdout, "Child terminated abnormaly/n"); 
  61. exit(1); 
  62.  
  63.  
  64. free_dblist(); 
  65.  
  66. exit(0); 
  67.  
  68.  
  69. void malloc_dblist() 
  70. int i = 0; 
  71. //malloc for db_list 
  72. for (i = 0; i < NUM; i++) { 
  73. db_list[i] = malloc(LEN); 
  74. memset(db_list[i], '/0', LEN); 
  75. void free_dblist() 
  76. int i; 
  77. //free db_list's memory 
  78. for (i = 0; i < NUM; i++) { 
  79. free(db_list[i]); 
  80.  
  81. void readDbFile() 
  82. FILE *fp; 
  83.  
  84. fp = fopen(DB_FILE, "r"); 
  85. if (!fp) { 
  86. fprintf(stderr, "%s not found/n", DB_FILE); 
  87. else { 
  88. malloc_dblist(); 
  89.  
  90. read_num = 0; 
  91. while (fscanf(fp, "%127[^/r/n]/n", db_list[read_num]) == 1) { 
  92. puts(db_list[read_num]); 
  93. read_num++; 
  94.  
  95. fclose(fp);  
  96.  

2. db_list.txt

 

 
  1. admin 
  2. book 

3.

 

 
  1. #include<sys/types.h> 
  2. #include<sys/wait.h> 
  3. #include<ctype.h> 
  4. #include<unistd.h> 
  5. #include<string.h> 
  6. #include<stdlib.h> 
  7. #include<stdio.h> 
  8.  
  9. //待备份的数据表文件(一个数据库一行) 
  10. #define DB_FILE "./db_list" 
  11. //最多可以备份的数据库数量 
  12. #define NUM 20 
  13. //一个数据库名字的最长字符数 
  14. #define LEN 128 
  15. //保存从DB_FILE中读取到的数据库 
  16. char *db_list[NUM]; 
  17. //从DB_FILE文件中读取到的数据库数量 
  18. int read_num; 
  19. //请求内存函数 
  20. void malloc_dblist(); 
  21. //释放内存函数 
  22. void free_dblist(); 
  23. //读取数据库文件 
  24. void readDbFile(); 
  25.  
  26. int main(int argc, char *argv[]) { 
  27. pid_t pid; 
  28. int i; 
  29. char buf[LEN]; 
  30.  
  31. //从文件读取数据库信息 
  32. readDbFile(); 
  33.  
  34. pid = fork(); 
  35.  
  36. if (pid < 0) { 
  37. fprintf(stderr, "fork error/n"); 
  38. exit(1); 
  39.  
  40. switch (pid) { 
  41. case -1: 
  42. fprintf(stderr, "fork failed/n"); 
  43. exit(1); 
  44. case 0: 
  45. //子进程进行数据库的备份 
  46. for (i = 0; i < read_num; i++) { 
  47. memset(buf, '/0', LEN); 
  48. sprintf(buf, "%s%s%s%s%s""mysqldump -uroot ", db_list[i], " > ", db_list[i], ".sql"); 
  49. system(buf); 
  50. printf("%d,%s/n", i, buf); 
  51. break
  52. //等待子进程的结束 
  53. if (pid > 0) { 
  54. int stat_val; 
  55. pid_t child_pid; 
  56.  
  57. child_pid = wait(&stat_val); 
  58.  
  59. if (!WIFEXITED(stat_val)) { 
  60. fprintf(stdout, "Child terminated abnormaly/n"); 
  61. exit(1); 
  62.  
  63.  
  64. free_dblist(); 
  65.  
  66. exit(0); 
  67.  
  68.  
  69. void malloc_dblist() 
  70. int i = 0; 
  71. //malloc for db_list 
  72. for (i = 0; i < NUM; i++) { 
  73. db_list[i] = malloc(LEN); 
  74. memset(db_list[i], '/0', LEN); 
  75. void free_dblist() 
  76. int i; 
  77. //free db_list's memory 
  78. for (i = 0; i < NUM; i++) { 
  79. free(db_list[i]); 
  80.  
  81. void readDbFile() 
  82. FILE *fp; 
  83.  
  84. fp = fopen(DB_FILE, "r"); 
  85. if (!fp) { 
  86. fprintf(stderr, "%s not found/n", DB_FILE); 
  87. else { 
  88. malloc_dblist(); 
  89.  
  90. read_num = 0; 
  91. while (fscanf(fp, "%127[^/r/n]/n", db_list[read_num]) == 1) { 
  92. puts(db_list[read_num]); 
  93. read_num++; 
  94.  
  95. fclose(fp);  
  96.  

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表