3 * Program to test batch mode
5 * Eric Bollengier, March 2007
11 Bacula® - The Network Backup Solution
13 Copyright (C) 2001-2006 Free Software Foundation Europe e.V.
15 The main author of Bacula is Kern Sibbald, with contributions from
16 many others, a complete list can be found in the file AUTHORS.
17 This program is Free Software; you can redistribute it and/or
18 modify it under the terms of version two of the GNU General Public
19 License as published by the Free Software Foundation plus additions
20 that are listed in the file LICENSE.
22 This program is distributed in the hope that it will be useful, but
23 WITHOUT ANY WARRANTY; without even the implied warranty of
24 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
25 General Public License for more details.
27 You should have received a copy of the GNU General Public License
28 along with this program; if not, write to the Free Software
29 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
32 Bacula® is a registered trademark of John Walker.
33 The licensor of Bacula is the Free Software Foundation Europe
34 (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
35 Switzerland, email:ftf@fsfeurope.org.
41 for i in $(seq 10000 99999) ; do
42 j=$((($i % 1000) + 555))
43 echo "$i;/tmp/totabofds$j/fiddddle${j}$i;xxxLSTATxxxx;xxxxxxxMD5xxxxxx"
49 find / | while read a; do
51 echo "$j;$a;xxxLSTATxxxx;xxxxxxxMD5xxxxxx"
56 #include "stored/stored.h"
57 #include "findlib/find.h"
58 #include "cats/cats.h"
60 /* Forward referenced functions */
61 static void do_batch();
67 static const char *db_name = "bacula";
68 static const char *db_user = "bacula";
69 static const char *db_password = "";
70 static const char *db_host = NULL;
80 "\nVersion: %s (%s)\n\n"
81 "Usage: bbatch [ options ] -w working/dir -f datafile\n"
82 " -d <nn> set debug level to nn\n"
83 " -n <name> specify the database name (default bacula)\n"
84 " -u <user> specify database user name (default bacula)\n"
85 " -P <password specify database password (default none)\n"
86 " -h <host> specify database host (default NULL)\n"
87 " -w <working> specify working directory\n"
89 " -f <file> specify data file\n"
90 " -? print this message\n\n"), 2001, VERSION, BDATE);
94 int main (int argc, char *argv[])
97 setlocale(LC_ALL, "");
98 bindtextdomain("bacula", LOCALEDIR);
102 my_name_is(argc, argv, "bbatch");
103 init_msg(NULL, NULL);
107 while ((ch = getopt(argc, argv, "c:d:n:P:Su:vf:w:?")) != -1) {
109 case 'd': /* debug level */
110 debug_level = atoi(optarg);
111 if (debug_level <= 0)
124 working_directory = optarg;
132 db_password = optarg;
153 Pmsg0(0, _("Wrong number of arguments: \n"));
158 Pmsg0(0, _("You must specified a data file\n"));
162 #ifdef HAVE_BATCH_FILE_INSERT
163 printf("With new Batch mode\n");
165 printf("Without new Batch mode\n");
168 bjcr = new_jcr(sizeof(JCR), NULL);
170 bjcr->VolSessionId = 1;
171 bjcr->VolSessionTime = (uint32_t)time(NULL);
172 bjcr->NumReadVolumes = 0;
173 bjcr->NumWriteVolumes = 0;
174 bjcr->JobId = getpid();
175 bjcr->JobType = JT_CONSOLE;
176 bjcr->JobLevel = L_FULL;
177 bjcr->JobStatus = JS_Running;
178 bjcr->where = bstrdup("");
179 bjcr->job_name = get_pool_memory(PM_FNAME);
180 pm_strcpy(bjcr->job_name, "Dummy.Job.Name");
181 bjcr->client_name = get_pool_memory(PM_FNAME);
182 pm_strcpy(bjcr->client_name, "Dummy.Client.Name");
183 bstrncpy(bjcr->Job, "bbatch", sizeof(bjcr->Job));
184 bjcr->fileset_name = get_pool_memory(PM_FNAME);
185 pm_strcpy(bjcr->fileset_name, "Dummy.fileset.name");
186 bjcr->fileset_md5 = get_pool_memory(PM_FNAME);
187 pm_strcpy(bjcr->fileset_md5, "Dummy.fileset.md5");
189 if ((db=db_init_database(NULL, db_name, db_user, db_password,
190 db_host, 0, NULL, 0)) == NULL) {
191 Emsg0(M_ERROR_TERM, 0, _("Could not init Bacula database\n"));
193 if (!db_open_database(NULL, db)) {
194 Emsg0(M_ERROR_TERM, 0, db_strerror(db));
196 Dmsg0(200, "Database opened\n");
198 Pmsg2(000, _("Using Database: %s, User: %s\n"), db_name, db_user);
208 static void fill_attr(ATTR_DBR *ar, char *data)
213 ar->Stream = STREAM_UNIX_ATTRIBUTES;
214 ar->JobId = getpid();
216 for(p = b = data; *p; p++) {
221 ar->FileIndex = str_to_int64(b);
239 static void do_batch()
244 memset(&ar, 0, sizeof(ar));
245 btime_t begin = get_current_btime();
247 FILE *fd = fopen(datafile, "r");
249 Emsg1(M_ERROR_TERM, 0, _("Error opening datafile %s\n"), datafile);
251 while (fgets(data, sizeof(data)-1, fd)) {
252 strip_trailing_newline(data);
254 if (verbose && ((lineno % 5000) == 1)) {
255 printf("\r%i", lineno);
257 fill_attr(&ar, data);
258 if (!db_create_file_attributes_record(bjcr, bjcr->db, &ar)) {
259 Emsg0(M_ERROR_TERM, 0, _("Error while inserting file\n"));
263 db_write_batch_file_records(bjcr);
264 btime_t end = get_current_btime();
266 char ed1[200], ed2[200];
267 printf("\rbegin = %s, end = %s\n", edit_int64(begin, ed1),edit_int64(end, ed2));
268 printf("Insert time = %llims\n", (end - begin) / 10000);
269 printf("Create %u files at %.2f/s\n", lineno,
270 (lineno / ((float)((end - begin) / 1000000))));