1 /*-------------------------------------------------------------------------
3 * pg_isready --- checks the status of the PostgreSQL server
5 * Copyright (c) 2013, PostgreSQL Global Development Group
7 * src/bin/scripts/pg_isready.c
9 *-------------------------------------------------------------------------
12 #include "postgres_fe.h"
15 #define DEFAULT_CONNECT_TIMEOUT "3"
18 help(const char *progname);
21 main(int argc, char **argv)
27 const char *pghost = NULL;
28 const char *pgport = NULL;
29 const char *pguser = NULL;
30 const char *pgdbname = NULL;
31 const char *connect_timeout = DEFAULT_CONNECT_TIMEOUT;
33 const char *pghost_str = NULL;
34 const char *pgport_str = NULL;
36 #define PARAMS_ARRAY_SIZE 7
38 const char *keywords[PARAMS_ARRAY_SIZE];
39 const char *values[PARAMS_ARRAY_SIZE];
44 PQconninfoOption *opts = NULL;
45 PQconninfoOption *defs = NULL;
46 PQconninfoOption *opt;
47 PQconninfoOption *def;
51 * We accept user and database as options to avoid useless errors from
52 * connecting with invalid params
55 static struct option long_options[] = {
56 {"dbname", required_argument, NULL, 'd'},
57 {"host", required_argument, NULL, 'h'},
58 {"port", required_argument, NULL, 'p'},
59 {"quiet", no_argument, NULL, 'q'},
60 {"timeout", required_argument, NULL, 't'},
61 {"username", required_argument, NULL, 'U'},
65 progname = get_progname(argv[0]);
66 set_pglocale_pgservice(argv[0], PG_TEXTDOMAIN("pgscripts"));
67 handle_help_version_opts(argc, argv, progname, help);
69 while ((c = getopt_long(argc, argv, "d:h:p:qt:U:", long_options, NULL)) != -1)
74 pgdbname = pg_strdup(optarg);
77 pghost = pg_strdup(optarg);
80 pgport = pg_strdup(optarg);
86 connect_timeout = pg_strdup(optarg);
89 pguser = pg_strdup(optarg);
92 fprintf(stderr, _("Try \"%s --help\" for more information.\n"), progname);
95 * We need to make sure we don't return 1 here because someone
96 * checking the return code might infer unintended meaning
98 exit(PQPING_NO_ATTEMPT);
104 fprintf(stderr, _("%s: too many command-line arguments (first is \"%s\")\n"),
105 progname, argv[optind]);
106 fprintf(stderr, _("Try \"%s --help\" for more information.\n"), progname);
109 * We need to make sure we don't return 1 here because someone
110 * checking the return code might infer unintended meaning
112 exit(PQPING_NO_ATTEMPT);
115 keywords[0] = "host";
117 keywords[1] = "port";
119 keywords[2] = "user";
121 keywords[3] = "dbname";
122 values[3] = pgdbname;
123 keywords[4] = "connect_timeout";
124 values[4] = connect_timeout;
125 keywords[5] = "fallback_application_name";
126 values[5] = progname;
131 * Get the host and port so we can display them in our output
135 opts = PQconninfoParse(pgdbname, &errmsg);
138 fprintf(stderr, _("%s: %s\n"), progname, errmsg);
139 exit(PQPING_NO_ATTEMPT);
143 defs = PQconndefaults();
146 fprintf(stderr, _("%s: could not fetch default options\n"), progname);
147 exit(PQPING_NO_ATTEMPT);
150 for (opt = opts, def = defs; def->keyword; def++)
152 if (strcmp(def->keyword, "hostaddr") == 0 ||
153 strcmp(def->keyword, "host") == 0)
156 pghost_str = opt->val;
160 pghost_str = def->val;
162 pghost_str = DEFAULT_PGSOCKET_DIR;
164 else if (strcmp(def->keyword, "port") == 0)
167 pgport_str = opt->val;
171 pgport_str = def->val;
178 rv = PQpingParams(keywords, values, 1);
182 printf("%s:%s - ", pghost_str, pgport_str);
187 printf("accepting connections\n");
190 printf("rejecting connections\n");
192 case PQPING_NO_RESPONSE:
193 printf("no response\n");
195 case PQPING_NO_ATTEMPT:
196 printf("no attempt\n");
207 help(const char *progname)
209 printf(_("%s issues a connection check to a PostgreSQL database.\n\n"), progname);
210 printf(_("Usage:\n"));
211 printf(_(" %s [OPTION]...\n"), progname);
213 printf(_("\nOptions:\n"));
214 printf(_(" -d, --dbname=DBNAME database name\n"));
215 printf(_(" -q, --quiet run quietly\n"));
216 printf(_(" -V, --version output version information, then exit\n"));
217 printf(_(" -?, --help show this help, then exit\n"));
219 printf(_("\nConnection options:\n"));
220 printf(_(" -h, --host=HOSTNAME database server host or socket directory\n"));
221 printf(_(" -p, --port=PORT database server port\n"));
222 printf(_(" -t, --timeout=SECS seconds to wait when attempting connection, 0 disables (default: %s)\n"), DEFAULT_CONNECT_TIMEOUT);
223 printf(_(" -U, --username=USERNAME user name to connect as\n"));
224 printf(_("\nReport bugs to <pgsql-bugs@postgresql.org>.\n"));