欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

c實(shí)現(xiàn)linux下的數(shù)據(jù)庫(kù)備份

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊: 次

Linux下c實(shí)現(xiàn)的數(shù)據(jù)庫(kù)備份,只要修改數(shù)據(jù)庫(kù)列表文件的信息即可。

db_list.txt把后綴去掉即可,一個(gè)數(shù)據(jù)庫(kù)一行。

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>
 
//待備份的數(shù)據(jù)表文件(一個(gè)數(shù)據(jù)庫(kù)一行)
#define DB_FILE "./db_list"
//最多可以備份的數(shù)據(jù)庫(kù)數(shù)量
#define NUM 20
//一個(gè)數(shù)據(jù)庫(kù)名字的最長(zhǎng)字符數(shù)
#define LEN 128
//保存從DB_FILE中讀取到的數(shù)據(jù)庫(kù)
char *db_list[NUM];
//從DB_FILE文件中讀取到的數(shù)據(jù)庫(kù)數(shù)量
int read_num;
//請(qǐng)求內(nèi)存函數(shù)
void malloc_dblist();
//釋放內(nèi)存函數(shù)
void free_dblist();
//讀取數(shù)據(jù)庫(kù)文件
void readDbFile();
 
int main(int argc, char *argv[]) {
  pid_t pid;
  int i;
  char buf[LEN];
 
  //從文件讀取數(shù)據(jù)庫(kù)信息
  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:
      //子進(jìn)程進(jìn)行數(shù)據(jù)庫(kù)的備份
      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;
  }
  //等待子進(jìn)程的結(jié)束
  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>
 
//待備份的數(shù)據(jù)表文件(一個(gè)數(shù)據(jù)庫(kù)一行)
#define DB_FILE "./db_list"
//最多可以備份的數(shù)據(jù)庫(kù)數(shù)量
#define NUM 20
//一個(gè)數(shù)據(jù)庫(kù)名字的最長(zhǎng)字符數(shù)
#define LEN 128
//保存從DB_FILE中讀取到的數(shù)據(jù)庫(kù)
char *db_list[NUM];
//從DB_FILE文件中讀取到的數(shù)據(jù)庫(kù)數(shù)量
int read_num;
//請(qǐng)求內(nèi)存函數(shù)
void malloc_dblist();
//釋放內(nèi)存函數(shù)
void free_dblist();
//讀取數(shù)據(jù)庫(kù)文件
void readDbFile();
 
int main(int argc, char *argv[]) {
  pid_t pid;
  int i;
  char buf[LEN];
 
  //從文件讀取數(shù)據(jù)庫(kù)信息
  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:
      //子進(jìn)程進(jìn)行數(shù)據(jù)庫(kù)的備份
      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;
  }
  //等待子進(jìn)程的結(jié)束
  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); 
  }
   
}

以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有