57 #include <unicode/ucol.h>
68 #include "catalog/pg_authid_d.h"
69 #include "catalog/pg_class_d.h"
70 #include "catalog/pg_collation_d.h"
71 #include "catalog/pg_database_d.h"
97 "trust",
"reject",
"scram-sha-256",
"md5",
"password",
"ident",
"radius",
119 "trust",
"reject",
"scram-sha-256",
"md5",
"password",
"peer",
"radius",
206 #define AUTHTRUST_WARNING \
207 "# CAUTION: Configuring the system for local \"trust\" authentication\n" \
208 "# allows any local user to connect as any PostgreSQL user, including\n" \
209 "# the database superuser. If you do not trust all your local users,\n" \
210 "# use another authentication method.\n"
224 static const char *
const backend_options =
"--single -F -O -j -c search_path=pg_catalog -c exit_on_error=true -c log_checkpoints=false";
231 "pg_wal/archive_status",
241 "pg_multixact/members",
242 "pg_multixact/offsets",
251 "pg_logical/snapshots",
252 "pg_logical/mappings"
261 const char *
token,
const char *replacement);
263 const char *guc_name,
const char *guc_value,
264 bool mark_as_comment);
266 static char **
readfile(
const char *path);
267 static void writefile(
char *path,
char **lines);
269 static char *
get_id(
void);
316 #define PG_CMD_DECL FILE *cmdfd
318 #define PG_CMD_OPEN(cmd) \
320 cmdfd = popen_check(cmd, "w"); \
325 #define PG_CMD_CLOSE() \
327 if (pclose_check(cmdfd)) \
331 #define PG_CMD_PUTS(line) \
333 if (fputs(line, cmdfd) < 0 || fflush(cmdfd) < 0) \
334 output_failed = true, output_errno = errno; \
337 #define PG_CMD_PRINTF(fmt, ...) \
339 if (fprintf(cmdfd, fmt, __VA_ARGS__) < 0 || fflush(cmdfd) < 0) \
340 output_failed = true, output_errno = errno; \
374 for (datap =
data; *datap; datap++)
393 newentry->
next = NULL;
394 if (*listhead == NULL)
395 *listhead = newentry;
398 for (oldentry = *listhead; oldentry->
next; oldentry = oldentry->
next)
400 oldentry->
next = newentry;
421 toklen = strlen(
token);
422 replen = strlen(replacement);
423 diff = replen - toklen;
425 for (
int i = 0; lines[
i];
i++)
432 if ((where = strstr(lines[
i],
token)) == NULL)
439 pre = where - lines[
i];
443 memcpy(
newline + pre, replacement, replen);
445 strcpy(
newline + pre + replen, lines[
i] + pre + toklen);
471 bool mark_as_comment)
473 int namelen = strlen(guc_name);
486 for (
i = 0; lines[
i];
i++)
489 const char *namestart;
498 while (*where ==
'#' || isspace((
unsigned char) *where))
504 while (isspace((
unsigned char) *where))
510 memcpy(&
newline->data[mark_as_comment ? 1 : 0], namestart, namelen);
513 where = strrchr(where,
'#');
524 for (ptr = lines[
i]; ptr < where; ptr++)
527 oldindent += 8 - (oldindent % 8);
534 oldindent =
Max(oldindent, newindent + 1);
535 while (newindent < oldindent)
537 int newindent_if_tab = newindent + 8 - (newindent % 8);
539 if (newindent_if_tab <= oldindent)
542 newindent = newindent_if_tab;
563 if (lines[
i] == NULL)
589 #define LETTERS "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
590 #define DIGITS "0123456789"
592 if (*guc_value ==
'\0')
594 if (strchr(
LETTERS, *guc_value))
600 if (strchr(
DIGITS, *guc_value))
603 guc_value += strspn(guc_value,
DIGITS);
605 if (strspn(guc_value,
LETTERS) == strlen(guc_value))
626 if ((
infile = fopen(path,
"r")) == NULL)
627 pg_fatal(
"could not open file \"%s\" for reading: %m", path);
632 result = (
char **)
pg_malloc(maxlines *
sizeof(
char *));
638 if (n >= maxlines - 1)
641 result = (
char **)
pg_realloc(result, maxlines *
sizeof(
char *));
670 if ((out_file = fopen(path,
"w")) == NULL)
671 pg_fatal(
"could not open file \"%s\" for writing: %m", path);
672 for (line = lines; *line != NULL; line++)
674 if (fputs(*line, out_file) < 0)
675 pg_fatal(
"could not write file \"%s\": %m", path);
678 if (fclose(out_file))
679 pg_fatal(
"could not close file \"%s\": %m", path);
693 cmdfd = popen(command,
mode);
695 pg_log_error(
"could not execute command \"%s\": %m", command);
719 pg_log_info(
"removing contents of data directory \"%s\"",
722 pg_log_error(
"failed to remove contents of data directory");
735 pg_log_error(
"failed to remove contents of WAL directory");
742 pg_log_info(
"data directory \"%s\" not removed at user's request",
746 pg_log_info(
"WAL directory \"%s\" not removed at user's request",
765 pg_log_error_hint(
"Please log in (using, e.g., \"su\") as the (unprivileged) user that will own the server process.");
792 if (encoding_name && *encoding_name)
797 pg_fatal(
"\"%s\" is not a valid server encoding name",
798 encoding_name ? encoding_name :
"(null)");
814 {
"arabic",
"Arabic"},
816 {
"armenian",
"Armenian"},
818 {
"basque",
"Basque"},
820 {
"catalan",
"Catalan"},
822 {
"danish",
"Danish"},
826 {
"english",
"POSIX"},
828 {
"english",
"English"},
830 {
"finnish",
"Finnish"},
832 {
"french",
"French"},
834 {
"german",
"German"},
840 {
"hungarian",
"Hungarian"},
841 {
"indonesian",
"id"},
842 {
"indonesian",
"Indonesian"},
846 {
"italian",
"Italian"},
847 {
"lithuanian",
"lt"},
848 {
"lithuanian",
"Lithuanian"},
850 {
"nepali",
"Nepali"},
852 {
"norwegian",
"Norwegian"},
853 {
"portuguese",
"pt"},
854 {
"portuguese",
"Portuguese"},
857 {
"russian",
"Russian"},
859 {
"serbian",
"Serbian"},
861 {
"spanish",
"Spanish"},
863 {
"swedish",
"Swedish"},
867 {
"turkish",
"Turkish"},
869 {
"yiddish",
"Yiddish"},
901 *ptr !=
'_' && *ptr !=
'-' && *ptr !=
'.' && *ptr !=
'@')
937 if (
stat(path, &statbuf) != 0)
942 pg_log_error_hint(
"This might mean you have a corrupted installation or identified the wrong directory with the invocation option -L.");
947 pg_log_error_hint(
"This might mean you have a corrupted installation or identified the wrong directory with the invocation option -L.");
953 pg_log_error(
"file \"%s\" is not a regular file", path);
954 pg_log_error_hint(
"This might mean you have a corrupted installation or identified the wrong directory with the invocation option -L.");
969 if (extrapath == NULL)
975 pg_fatal(
"could not open file \"%s\" for writing: %m", path);
978 pg_fatal(
"could not write file \"%s\": %m", path);
995 pg_fatal(
"could not open file \"%s\" for writing: %m", path);
997 pg_fatal(
"could not write file \"%s\": %m", path);
1018 #if defined(HAVE_SHM_OPEN) && !defined(__sun__)
1033 if ((
fd = shm_open(
name, O_CREAT | O_RDWR | O_EXCL, 0600)) != -1)
1039 if (errno != EEXIST)
1064 #define MIN_BUFS_FOR_CONNS(nconns) ((nconns) * 10)
1066 static const int trial_conns[] = {
1069 static const int trial_bufs[] = {
1070 16384, 8192, 4096, 3584, 3072, 2560, 2048, 1536,
1071 1000, 900, 800, 700, 600, 500,
1072 400, 300, 200, 100, 50
1075 const int connslen =
sizeof(trial_conns) /
sizeof(
int);
1076 const int bufslen =
sizeof(trial_bufs) /
sizeof(
int);
1086 printf(
_(
"selecting dynamic shared memory implementation ... "));
1095 printf(
_(
"selecting default \"max_connections\" ... "));
1098 for (
i = 0;
i < connslen;
i++)
1100 test_conns = trial_conns[
i];
1105 ok_buffers = test_buffs;
1115 printf(
_(
"selecting default \"shared_buffers\" ... "));
1118 for (
i = 0;
i < bufslen;
i++)
1121 test_buffs = (trial_bufs[
i] * 8192) / BLCKSZ;
1122 if (test_buffs <= ok_buffers)
1124 test_buffs = ok_buffers;
1133 if ((
n_buffers * (BLCKSZ / 1024)) % 1024 == 0)
1138 printf(
_(
"selecting default time zone ... "));
1159 "\"%s\" --check %s %s "
1160 "-c max_connections=%d "
1161 "-c shared_buffers=%d "
1162 "-c dynamic_shared_memory_type=%s",
1164 test_conns, test_buffs,
1170 gnames = gnames->
next, gvalues = gvalues->
next)
1177 " < \"%s\" > \"%s\" 2>&1",
1181 status = system(cmd.
data);
1185 return (status == 0);
1197 if ((sz % 1024) == 0)
1198 snprintf(result, 14,
"%dGB", sz / 1024);
1217 fputs(
_(
"creating configuration files ... "),
stdout);
1228 if ((
n_buffers * (BLCKSZ / 1024)) % 1024 == 0)
1229 snprintf(repltok,
sizeof(repltok),
"%dMB",
1232 snprintf(repltok,
sizeof(repltok),
"%dkB",
1252 strcpy(repltok,
"iso, ymd");
1255 strcpy(repltok,
"iso, dmy");
1259 strcpy(repltok,
"iso, mdy");
1265 snprintf(repltok,
sizeof(repltok),
"pg_catalog.%s",
1296 DEF_PGPORT_STR,
true);
1298 #if DEFAULT_BACKEND_FLUSH_AFTER > 0
1299 snprintf(repltok,
sizeof(repltok),
"%dkB",
1305 #if DEFAULT_BGWRITER_FLUSH_AFTER > 0
1306 snprintf(repltok,
sizeof(repltok),
"%dkB",
1312 #if DEFAULT_CHECKPOINT_FLUSH_AFTER > 0
1313 snprintf(repltok,
sizeof(repltok),
"%dkB",
1319 #ifndef USE_PREFETCH
1359 gnames = gnames->
next, gvalues = gvalues->
next)
1362 gvalues->
str,
false);
1370 pg_fatal(
"could not change permissions of \"%s\": %m", path);
1376 conflines[0] =
pg_strdup(
"# Do not edit this file manually!\n");
1377 conflines[1] =
pg_strdup(
"# It will be overwritten by the ALTER SYSTEM command.\n");
1378 conflines[2] = NULL;
1384 pg_fatal(
"could not change permissions of \"%s\": %m", path);
1391 conflines =
replace_token(conflines,
"@remove-line-for-nolocal@",
"");
1402 struct addrinfo *gai_result;
1403 struct addrinfo hints;
1410 err = WSAStartup(MAKEWORD(2, 2), &wsaData);
1414 hints.ai_flags = AI_NUMERICHOST;
1415 hints.ai_family = AF_UNSPEC;
1416 hints.ai_socktype = 0;
1417 hints.ai_protocol = 0;
1418 hints.ai_addrlen = 0;
1419 hints.ai_canonname = NULL;
1420 hints.ai_addr = NULL;
1421 hints.ai_next = NULL;
1424 getaddrinfo(
"::1", NULL, &hints, &gai_result) != 0)
1428 "#host all all ::1");
1430 "host replication all ::1",
1431 "#host replication all ::1");
1440 "@authmethodlocal@",
1451 pg_fatal(
"could not change permissions of \"%s\": %m", path);
1462 pg_fatal(
"could not change permissions of \"%s\": %m", path);
1481 printf(
_(
"running bootstrap script ... "));
1488 snprintf(headerline,
sizeof(headerline),
"# PostgreSQL %s\n",
1491 if (strcmp(headerline, *bki_lines) != 0)
1493 pg_log_error(
"input file \"%s\" does not belong to PostgreSQL %s",
1508 (
sizeof(
Pointer) == 4) ?
"i" :
"d");
1549 for (line = bki_lines; *line != NULL; line++)
1573 PG_CMD_PUTS(
"REVOKE ALL ON pg_authid FROM public;\n\n");
1597 pwd1 =
simple_prompt(
"Enter new superuser password: ",
false);
1599 if (strcmp(pwd1, pwd2) != 0)
1601 fprintf(stderr,
_(
"Passwords didn't match.\n"));
1619 pg_fatal(
"could not open file \"%s\" for reading: %m",
1625 pg_fatal(
"could not read password from file \"%s\": %m",
1628 pg_fatal(
"password file \"%s\" is empty",
1649 PG_CMD_PUTS(
"SELECT pg_stop_making_pinned_objects();\n\n");
1662 for (
char **line = lines; *line != NULL; line++)
1681 "SELECT p.oid as p_oid, o.oid as o_oid, oprname "
1682 "FROM pg_proc p JOIN pg_operator o ON oprcode = p.oid ) "
1683 "INSERT INTO pg_description "
1684 " SELECT p_oid, 'pg_proc'::regclass, 0, "
1685 " 'implementation of ' || oprname || ' operator' "
1687 " WHERE NOT EXISTS (SELECT 1 FROM pg_description "
1688 " WHERE objoid = p_oid AND classoid = 'pg_proc'::regclass) "
1689 " AND NOT EXISTS (SELECT 1 FROM pg_description "
1690 " WHERE objoid = o_oid AND classoid = 'pg_operator'::regclass"
1691 " AND description LIKE 'deprecated%');\n\n");
1705 PG_CMD_PUTS(
"UPDATE pg_collation SET collversion = pg_collation_actual_version(oid) WHERE collname = 'unicode';\n\n");
1708 PG_CMD_PUTS(
"SELECT pg_import_system_collations('pg_catalog');\n\n");
1734 " SET relacl = (SELECT array_agg(a.acl) FROM "
1735 " (SELECT E'=r/\"%s\"' as acl "
1736 " UNION SELECT unnest(pg_catalog.acldefault("
1737 " CASE WHEN relkind = " CppAsString2(RELKIND_SEQUENCE)
" THEN 's' "
1738 " ELSE 'r' END::\"char\"," CppAsString2(BOOTSTRAP_SUPERUSERID)
"::oid))"
1740 " WHERE relkind IN (" CppAsString2(RELKIND_RELATION)
", "
1743 " AND relacl IS NULL;\n\n",
1745 PG_CMD_PUTS(
"GRANT USAGE ON SCHEMA pg_catalog, public TO PUBLIC;\n\n");
1746 PG_CMD_PUTS(
"REVOKE ALL ON pg_largeobject FROM PUBLIC;\n\n");
1748 " (objoid, classoid, objsubid, initprivs, privtype)"
1751 " (SELECT oid FROM pg_class WHERE relname = 'pg_class'),"
1758 " relacl IS NOT NULL"
1759 " AND relkind IN (" CppAsString2(RELKIND_RELATION)
", "
1763 " (objoid, classoid, objsubid, initprivs, privtype)"
1766 " (SELECT oid FROM pg_class WHERE relname = 'pg_class'),"
1767 " pg_attribute.attnum,"
1768 " pg_attribute.attacl,"
1772 " JOIN pg_attribute ON (pg_class.oid = pg_attribute.attrelid)"
1774 " pg_attribute.attacl IS NOT NULL"
1775 " AND pg_class.relkind IN (" CppAsString2(RELKIND_RELATION)
", "
1779 " (objoid, classoid, objsubid, initprivs, privtype)"
1782 " (SELECT oid FROM pg_class WHERE relname = 'pg_proc'),"
1789 " proacl IS NOT NULL;\n\n");
1791 " (objoid, classoid, objsubid, initprivs, privtype)"
1794 " (SELECT oid FROM pg_class WHERE relname = 'pg_type'),"
1801 " typacl IS NOT NULL;\n\n");
1803 " (objoid, classoid, objsubid, initprivs, privtype)"
1806 " (SELECT oid FROM pg_class WHERE relname = 'pg_language'),"
1813 " lanacl IS NOT NULL;\n\n");
1815 " (objoid, classoid, objsubid, initprivs, privtype)"
1818 " (SELECT oid FROM pg_class WHERE "
1819 " relname = 'pg_largeobject_metadata'),"
1824 " pg_largeobject_metadata"
1826 " lomacl IS NOT NULL;\n\n");
1828 " (objoid, classoid, objsubid, initprivs, privtype)"
1831 " (SELECT oid FROM pg_class WHERE relname = 'pg_namespace'),"
1838 " nspacl IS NOT NULL;\n\n");
1840 " (objoid, classoid, objsubid, initprivs, privtype)"
1843 " (SELECT oid FROM pg_class WHERE "
1844 " relname = 'pg_foreign_data_wrapper'),"
1849 " pg_foreign_data_wrapper"
1851 " fdwacl IS NOT NULL;\n\n");
1853 " (objoid, classoid, objsubid, initprivs, privtype)"
1856 " (SELECT oid FROM pg_class "
1857 " WHERE relname = 'pg_foreign_server'),"
1862 " pg_foreign_server"
1864 " srvacl IS NOT NULL;\n\n");
1874 char *letterversion;
1882 ptr = vstr + (strlen(vstr) - 1);
1883 while (ptr != vstr && (*ptr < '0' || *ptr >
'9'))
1885 letterversion = ptr + 1;
1886 major = strtol(vstr, &endptr, 10);
1888 minor = strtol(endptr + 1, &endptr, 10);
1890 micro = strtol(endptr + 1, &endptr, 10);
1892 major, minor, micro, letterversion);
1903 PG_CMD_PRINTF(
"UPDATE information_schema.sql_implementation_info "
1904 " SET character_value = '%s' "
1905 " WHERE implementation_info_name = 'DBMS VERSION';\n\n",
1909 " (feature_id, feature_name, sub_feature_id, "
1910 " sub_feature_name, is_supported, comments) "
1957 PG_CMD_PUTS(
"CREATE DATABASE template0 IS_TEMPLATE = true ALLOW_CONNECTIONS = false"
1959 " STRATEGY = file_copy;\n\n");
1966 PG_CMD_PUTS(
"UPDATE pg_database SET datcollversion = NULL WHERE datname = 'template0';\n\n");
1971 PG_CMD_PUTS(
"UPDATE pg_database SET datcollversion = pg_database_collation_actual_version(oid) WHERE datname = 'template1';\n\n");
1977 PG_CMD_PUTS(
"REVOKE CREATE,TEMPORARY ON DATABASE template1 FROM public;\n\n");
1978 PG_CMD_PUTS(
"REVOKE CREATE,TEMPORARY ON DATABASE template0 FROM public;\n\n");
1980 PG_CMD_PUTS(
"COMMENT ON DATABASE template0 IS 'unmodifiable empty database';\n\n");
1999 " STRATEGY = file_copy;\n\n");
2000 PG_CMD_PUTS(
"COMMENT ON DATABASE postgres IS 'default administrative connection database';\n\n");
2046 printf(
_(
"could not write to child process: %s\n"),
2060 static inline size_t
2063 return strftime(s, max,
fmt,
tm);
2090 memset(&testtime, 0,
sizeof(testtime));
2091 testtime.tm_mday = 22;
2092 testtime.tm_mon = 10;
2093 testtime.tm_year = 133;
2103 posM = strstr(
buf,
"11");
2104 posD = strstr(
buf,
"22");
2105 posY = strstr(
buf,
"33");
2107 if (!posM || !posD || !posY)
2110 if (posY < posM && posM < posD)
2112 else if (posD < posM)
2156 if (
res && canonname)
2161 pg_fatal(
"failed to restore old locale \"%s\"", save);
2183 pg_fatal(
"invalid locale settings; check LANG and LC_* environment variables");
2201 if (!(locale_enc == user_enc ||
2211 "selected locale uses (%s) do not match. This would lead to "
2212 "misbehavior in various character string processing functions.",
2216 "or choose a matching combination.",
2234 pg_log_error_detail(
"The encoding you selected (%s) is not supported with the ICU provider.",
2237 "or choose a matching combination.",
2255 const bool strict =
true;
2266 status = U_ZERO_ERROR;
2267 uloc_toLanguageTag(loc_str, langtag, buflen, strict, &status);
2270 if (status == U_BUFFER_OVERFLOW_ERROR ||
2271 status == U_STRING_NOT_TERMINATED_WARNING)
2273 buflen = buflen * 2;
2281 if (U_FAILURE(status))
2285 pg_fatal(
"could not convert locale name \"%s\" to language tag: %s",
2286 loc_str, u_errorName(status));
2291 pg_fatal(
"ICU is not supported in this build");
2306 char lang[ULOC_LANG_CAPACITY];
2310 status = U_ZERO_ERROR;
2311 uloc_getLanguage(loc_str, lang, ULOC_LANG_CAPACITY, &status);
2312 if (U_FAILURE(status))
2314 pg_fatal(
"could not get language from locale \"%s\": %s",
2315 loc_str, u_errorName(status));
2320 if (strcmp(lang,
"") == 0 ||
2321 strcmp(lang,
"root") == 0 || strcmp(lang,
"und") == 0)
2325 for (int32_t
i = 0; !found &&
i < uloc_countAvailable();
i++)
2327 const char *otherloc = uloc_getAvailable(
i);
2328 char otherlang[ULOC_LANG_CAPACITY];
2330 status = U_ZERO_ERROR;
2331 uloc_getLanguage(otherloc, otherlang, ULOC_LANG_CAPACITY, &status);
2332 if (U_FAILURE(status))
2335 if (strcmp(lang, otherlang) == 0)
2340 pg_fatal(
"locale \"%s\" has unknown language \"%s\"",
2343 pg_fatal(
"ICU is not supported in this build");
2391 #if defined(LC_MESSAGES) && !defined(WIN32)
2401 pg_fatal(
"locale must be specified if provider is %s",
2408 else if (strcmp(
datlocale,
"C.UTF-8") == 0 ||
2410 canonname =
"C.UTF-8";
2412 pg_fatal(
"invalid locale name \"%s\" for builtin provider",
2423 printf(
_(
"Using language tag \"%s\" for ICU locale \"%s\".\n"),
2435 pg_fatal(
"ICU is not supported in this build");
2446 printf(
_(
"%s initializes a PostgreSQL database cluster.\n\n"),
progname);
2450 printf(
_(
" -A, --auth=METHOD default authentication method for local connections\n"));
2451 printf(
_(
" --auth-host=METHOD default authentication method for local TCP/IP connections\n"));
2452 printf(
_(
" --auth-local=METHOD default authentication method for local-socket connections\n"));
2453 printf(
_(
" [-D, --pgdata=]DATADIR location for this database cluster\n"));
2454 printf(
_(
" -E, --encoding=ENCODING set default encoding for new databases\n"));
2455 printf(
_(
" -g, --allow-group-access allow group read/execute on data directory\n"));
2456 printf(
_(
" --icu-locale=LOCALE set ICU locale ID for new databases\n"));
2457 printf(
_(
" --icu-rules=RULES set additional ICU collation rules for new databases\n"));
2458 printf(
_(
" -k, --data-checksums use data page checksums\n"));
2459 printf(
_(
" --locale=LOCALE set default locale for new databases\n"));
2460 printf(
_(
" --lc-collate=, --lc-ctype=, --lc-messages=LOCALE\n"
2461 " --lc-monetary=, --lc-numeric=, --lc-time=LOCALE\n"
2462 " set default locale in the respective category for\n"
2463 " new databases (default taken from environment)\n"));
2464 printf(
_(
" --no-locale equivalent to --locale=C\n"));
2465 printf(
_(
" --builtin-locale=LOCALE\n"
2466 " set builtin locale name for new databases\n"));
2467 printf(
_(
" --locale-provider={builtin|libc|icu}\n"
2468 " set default locale provider for new databases\n"));
2469 printf(
_(
" --pwfile=FILE read password for the new superuser from file\n"));
2470 printf(
_(
" -T, --text-search-config=CFG\n"
2471 " default text search configuration\n"));
2472 printf(
_(
" -U, --username=NAME database superuser name\n"));
2473 printf(
_(
" -W, --pwprompt prompt for a password for the new superuser\n"));
2474 printf(
_(
" -X, --waldir=WALDIR location for the write-ahead log directory\n"));
2475 printf(
_(
" --wal-segsize=SIZE size of WAL segments, in megabytes\n"));
2476 printf(
_(
"\nLess commonly used options:\n"));
2477 printf(
_(
" -c, --set NAME=VALUE override default setting for server parameter\n"));
2478 printf(
_(
" -d, --debug generate lots of debugging output\n"));
2479 printf(
_(
" --discard-caches set debug_discard_caches=1\n"));
2480 printf(
_(
" -L DIRECTORY where to find the input files\n"));
2481 printf(
_(
" -n, --no-clean do not clean up after errors\n"));
2482 printf(
_(
" -N, --no-sync do not wait for changes to be written safely to disk\n"));
2483 printf(
_(
" --no-instructions do not print instructions for next steps\n"));
2484 printf(
_(
" -s, --show show internal settings, then exit\n"));
2485 printf(
_(
" --sync-method=METHOD set method for syncing files to disk\n"));
2486 printf(
_(
" -S, --sync-only only sync database files to disk, then exit\n"));
2487 printf(
_(
"\nOther options:\n"));
2488 printf(
_(
" -V, --version output version information, then exit\n"));
2489 printf(
_(
" -?, --help show this help, then exit\n"));
2490 printf(
_(
"\nIf the data directory is not specified, the environment variable PGDATA\n"
2492 printf(
_(
"\nReport bugs to <%s>.\n"), PACKAGE_BUGREPORT);
2493 printf(
_(
"%s home page: <%s>\n"), PACKAGE_NAME, PACKAGE_URL);
2499 if (*authmethod == NULL)
2502 *authmethod =
"trust";
2509 const char *
const *p;
2511 for (p = valid_methods; *p; p++)
2513 if (strcmp(authmethod, *p) == 0)
2517 pg_fatal(
"invalid authentication method \"%s\" for \"%s\" connections",
2518 authmethod, conntype);
2531 pg_fatal(
"must specify a password for the superuser to enable password authentication");
2538 char *pgdata_get_env;
2542 pgdata_get_env = getenv(
"PGDATA");
2543 if (pgdata_get_env && strlen(pgdata_get_env))
2551 pg_log_error_hint(
"You must identify the directory where the data for this database system "
2552 "will reside. Do this with either the invocation option -D or the "
2553 "environment variable PGDATA.");
2568 pg_fatal(
"could not set environment");
2586 pg_fatal(
"program \"%s\" is needed by %s but was not found in the same directory as \"%s\"",
2589 pg_fatal(
"program \"%s\" was found by \"%s\" but was not the same version as %s",
2604 pg_fatal(
"input file location must be an absolute path");
2621 printf(
_(
"The database cluster will be initialized with locale \"%s\".\n"),
lc_ctype);
2624 printf(
_(
"The database cluster will be initialized with this locale configuration:\n"));
2630 " LC_MESSAGES: %s\n"
2631 " LC_MONETARY: %s\n"
2655 if (ctype_enc == -1)
2658 pg_log_error(
"could not find suitable encoding for locale \"%s\"",
2673 printf(
_(
"Encoding \"%s\" implied by locale is not allowed as a server-side encoding.\n"
2674 "The default database encoding will be set to \"%s\" instead.\n"),
2678 pg_log_error(
"locale \"%s\" requires unsupported encoding \"%s\"",
2690 printf(
_(
"The default database encoding has accordingly been set to \"%s\".\n"),
2704 pg_fatal(
"builtin provider locale \"%s\" requires encoding \"%s\"",
2732 "PGDATA=%s\nshare_path=%s\nPGPATH=%s\n"
2733 "POSTGRES_SUPERUSERNAME=%s\nPOSTGRES_BKI=%s\n"
2734 "POSTGRESQL_CONF_SAMPLE=%s\n"
2735 "PG_HBA_SAMPLE=%s\nPG_IDENT_SAMPLE=%s\n",
2766 pg_log_info(
"could not find suitable text search configuration for locale \"%s\"",
2775 if (checkmatch == NULL)
2777 pg_log_warning(
"suitable text search configuration for locale \"%s\" is unknown",
2782 pg_log_warning(
"specified text search configuration \"%s\" might not match locale \"%s\"",
2787 printf(
_(
"The default text search configuration will be set to \"%s\".\n"),
2830 printf(
_(
"creating directory %s ... "),
2844 printf(
_(
"fixing permissions on existing directory %s ... "),
2849 pg_fatal(
"could not change permissions of directory \"%s\": %m",
2865 pg_log_error_hint(
"If you want to create a new database system, either remove or empty "
2866 "the directory \"%s\" or run %s "
2867 "with an argument other than \"%s\".",
2894 pg_fatal(
"WAL directory location must be an absolute path");
2901 printf(
_(
"creating directory %s ... "),
2906 pg_fatal(
"could not create directory \"%s\": %m",
2916 printf(
_(
"fixing permissions on existing directory %s ... "),
2921 pg_fatal(
"could not change permissions of directory \"%s\": %m",
2937 pg_log_error_hint(
"If you want to store the WAL there, either remove or empty the directory \"%s\".",
2947 pg_fatal(
"could not create symbolic link \"%s\": %m",
2954 pg_fatal(
"could not create directory \"%s\": %m",
2966 pg_log_error_detail(
"It contains a dot-prefixed/invisible file, perhaps due to it being a mount point.");
2967 else if (
error == 3)
2968 pg_log_error_detail(
"It contains a lost+found directory, perhaps due to it being a mount point.");
2970 pg_log_error_hint(
"Using a mount point directly as the data directory is not recommended.\n"
2971 "Create a subdirectory under the mount point.");
2997 printf(
_(
"creating subdirectories ... "));
3011 pg_fatal(
"could not create directory \"%s\": %m", path);
3040 fputs(
_(
"performing post-bootstrap initialization ... "),
stdout);
3092 static struct option long_options[] = {
3140 char *effective_user;
3158 if (strcmp(argv[1],
"--help") == 0 || strcmp(argv[1],
"-?") == 0)
3163 if (strcmp(argv[1],
"--version") == 0 || strcmp(argv[1],
"-V") == 0)
3165 puts(
"initdb (PostgreSQL) " PG_VERSION);
3172 while ((
c =
getopt_long(argc, argv,
"A:c:dD:E:gkL:nNsST:U:WX:",
3173 long_options, &option_index)) != -1)
3199 char *equals = strchr(
buf,
'=');
3228 printf(
_(
"Running in debug mode.\n"));
3232 printf(
_(
"Running in no-clean mode. Mistakes will not be cleaned up.\n"));
3295 "-c debug_discard_caches=1");
3298 if (strcmp(
optarg,
"builtin") == 0)
3300 else if (strcmp(
optarg,
"icu") == 0)
3302 else if (strcmp(
optarg,
"libc") == 0)
3342 pg_log_error(
"too many command-line arguments (first is \"%s\")",
3349 pg_fatal(
"%s cannot be specified unless locale provider \"%s\" is chosen",
3350 "--builtin-locale",
"builtin");
3353 pg_fatal(
"%s cannot be specified unless locale provider \"%s\" is chosen",
3354 "--icu-locale",
"icu");
3357 pg_fatal(
"%s cannot be specified unless locale provider \"%s\" is chosen",
3358 "--icu-rules",
"icu");
3371 fputs(
_(
"syncing data to disk ... "),
stdout);
3379 pg_fatal(
"password prompt and password file cannot be specified together");
3390 pg_fatal(
"argument of %s must be a power of two between 1 and 1024",
"--wal-segsize");
3398 effective_user =
get_id();
3402 if (strncmp(
username,
"pg_", 3) == 0)
3403 pg_fatal(
"superuser name \"%s\" is disallowed; role names cannot begin with \"pg_\"",
username);
3405 printf(
_(
"The files belonging to this database system will be owned "
3407 "This user must also own the server process.\n\n"),
3421 printf(
_(
"Data page checksums are enabled.\n"));
3423 printf(
_(
"Data page checksums are disabled.\n"));
3434 fputs(
_(
"syncing data to disk ... "),
stdout);
3440 printf(
_(
"\nSync to disk skipped.\nThe data directory might become corrupt if the operating system crashes.\n"));
3445 pg_log_warning(
"enabling \"trust\" authentication for local connections");
3446 pg_log_warning_hint(
"You can change this by editing pg_hba.conf or using the option -A, or "
3447 "--auth-local and --auth-host, the next time you run initdb.");
3478 printf(
_(
"\nSuccess. You can now start the database server using:\n\n"
3480 start_db_cmd->
data);
#define PG_TEXTDOMAIN(domain)
int find_my_exec(const char *argv0, char *retpath)
void set_pglocale_pgservice(const char *argv0, const char *app)
int find_other_exec(const char *argv0, const char *target, const char *versionstr, char *retpath)
static void PGresult * res
bool is_encoding_supported_by_icu(int encoding)
void err(int eval, const char *fmt,...)
void * pg_realloc(void *ptr, size_t size)
char * pg_strdup(const char *in)
void * pg_malloc(size_t size)
#define pg_realloc_array(pointer, type, count)
#define pg_malloc_array(type, count)
void SetDataDirectoryCreatePerm(int dataDirMode)
#define PG_DIR_MODE_GROUP
@ DATA_DIR_SYNC_METHOD_FSYNC
int getopt_long(int argc, char *const argv[], const char *optstring, const struct option *longopts, int *longindex)
#define required_argument
static char * escape_quotes_bki(const char *src)
static void usage(const char *progname)
static const char * default_timezone
static char * superuser_password
int main(int argc, char *argv[])
static char * get_id(void)
void warn_on_mount_point(int error)
static void setup_depend(FILE *cmdfd)
static bool found_existing_pgdata
static bool found_existing_xlogdir
static char * pgdata_native
#define PG_CMD_PUTS(line)
static void check_authmethod_valid(const char *authmethod, const char *const *valid_methods, const char *conntype)
static char ** readfile(const char *path)
static bool icu_locale_specified
static bool noinstructions
void initialize_data_directory(void)
static void setup_collation(FILE *cmdfd)
static bool check_icu_locale_encoding(int user_enc)
static char backend_exec[MAXPGPATH]
static bool data_checksums
void setup_text_search(void)
static int get_encoding_id(const char *encoding_name)
static char infoversion[100]
static FILE * popen_check(const char *command, const char *mode)
static const char * authmethodhost
void create_data_directory(void)
static bool guc_value_requires_quotes(const char *guc_value)
static char * features_file
struct _stringlist _stringlist
void setup_bin_paths(const char *argv0)
static bool check_locale_encoding(const char *locale, int user_enc)
static void check_authmethod_unspecified(const char **authmethod)
static char locale_provider
static const char *const auth_methods_host[]
static int wal_segment_size_mb
static void bootstrap_template1(void)
const char * select_default_timezone(const char *share_path)
void setup_locale_encoding(void)
static void setup_run_file(FILE *cmdfd, const char *filename)
static char * icu_language_tag(const char *loc_str)
static const char *const auth_methods_local[]
static char ** replace_token(char **lines, const char *token, const char *replacement)
static size_t my_strftime(char *s, size_t max, const char *fmt, const struct tm *tm)
static void setlocales(void)
static bool made_new_xlogdir
static void setup_auth(FILE *cmdfd)
static void check_need_password(const char *authmethodlocal, const char *authmethodhost)
static int locale_date_order(const char *locale)
static void make_postgres(FILE *cmdfd)
static void test_config_settings(void)
static void cleanup_directories_atexit(void)
static const char *const backend_options
static void setup_config(void)
static char * lc_messages
static void setup_privileges(FILE *cmdfd)
static void write_version_file(const char *extrapath)
static void trapsig(SIGNAL_ARGS)
static bool output_failed
static char * system_views_file
static void setup_description(FILE *cmdfd)
static char * escape_quotes(const char *src)
#define PG_CMD_PRINTF(fmt,...)
static bool builtin_locale_specified
static void vacuum_db(FILE *cmdfd)
static const char *const subdirs[]
static void set_info_version(void)
static const struct tsearch_config_match tsearch_config_languages[]
static const char * choose_dsm_implementation(void)
void setup_data_file_paths(void)
static void set_input(char **dest, const char *filename)
static bool made_new_pgdata
static char ** replace_guc_value(char **lines, const char *guc_name, const char *guc_value, bool mark_as_comment)
#define MIN_BUFS_FOR_CONNS(nconns)
static DataDirSyncMethod sync_method
static char bin_path[MAXPGPATH]
void create_xlog_or_symlink(void)
static char * system_functions_file
static _stringlist * extra_guc_names
static const char * dynamic_shared_memory_type
static void check_input(char *path)
static char * encodingid_to_string(int enc)
static void add_stringlist_item(_stringlist **listhead, const char *str)
static bool caught_signal
static const char * progname
static _stringlist * extra_guc_values
static bool test_specific_config_settings(int test_conns, int test_buffs)
#define AUTHTRUST_WARNING
static char * dictionary_file
static void writefile(char *path, char **lines)
static void setup_schema(FILE *cmdfd)
static void check_ok(void)
static char * system_constraints_file
static void set_null_conf(void)
static char * extra_options
static const char * find_matching_ts_config(const char *lc_type)
static const char * authmethodlocal
static const char *const boot_options
static void make_template0(FILE *cmdfd)
static char * info_schema_file
static void load_plpgsql(FILE *cmdfd)
static const char * default_text_search_config
static char * pretty_wal_size(int segment_count)
static void check_locale_name(int category, const char *locale, char **canonname)
static char * lc_monetary
static void icu_validate_locale(const char *loc_str)
static void get_su_pwd(void)
static void const char * fmt
static void const char fflush(stdout)
void pg_logging_init(const char *argv0)
#define pg_log_error(...)
#define pg_log_error_hint(...)
#define pg_log_warning_hint(...)
#define pg_log_error_detail(...)
void pfree(void *pointer)
bool option_parse_int(const char *optarg, const char *optname, int min_range, int max_range, int *result)
bool parse_sync_method(const char *optarg, DataDirSyncMethod *sync_method)
static PgChecksumMode mode
#define DEFAULT_PGSOCKET_DIR
#define DEFAULT_XLOG_SEG_SIZE
#define DEFAULT_BACKEND_FLUSH_AFTER
#define DEFAULT_CHECKPOINT_FLUSH_AFTER
#define DEFAULT_BGWRITER_FLUSH_AFTER
static char * pg_ctl_path
static char version_file[MAXPGPATH]
char * pg_get_line(FILE *stream, PromptInterruptContext *prompt_ctx)
bool pg_get_line_buf(FILE *stream, StringInfo buf)
PGDLLIMPORT char * optarg
uint32 pg_prng_uint32(pg_prng_state *state)
void pg_prng_seed(pg_prng_state *state, uint64 seed)
#define pg_encoding_to_char
#define pg_valid_server_encoding_id
#define pg_valid_server_encoding
#define pg_log_warning(...)
void get_share_path(const char *my_exec_path, char *ret_path)
void join_path_components(char *ret_path, const char *head, const char *tail)
char * last_dir_separator(const char *filename)
int pg_mkdir_p(char *path, int omode)
#define is_absolute_path(filename)
int pg_strcasecmp(const char *s1, const char *s2)
void canonicalize_path(char *path)
void get_parent_directory(char *path)
int pg_check_dir(const char *dir)
const char * get_progname(const char *argv0)
pqsigfunc pqsignal(int signo, pqsigfunc func)
void make_native_path(char *filename)
#define PG_BACKEND_VERSIONSTR
int pg_get_encoding_from_locale(const char *ctype, bool write_message)
size_t strlcpy(char *dst, const char *src, size_t siz)
char * escape_single_quotes_ascii(const char *src)
int pg_strncasecmp(const char *s1, const char *s2, size_t n)
void printfPQExpBuffer(PQExpBuffer str, const char *fmt,...)
PQExpBuffer createPQExpBuffer(void)
void initPQExpBuffer(PQExpBuffer str)
void appendPQExpBuffer(PQExpBuffer str, const char *fmt,...)
void destroyPQExpBuffer(PQExpBuffer str)
void appendPQExpBufferChar(PQExpBuffer str, char ch)
void appendPQExpBufferStr(PQExpBuffer str, const char *data)
void termPQExpBuffer(PQExpBuffer str)
static int fd(const char *x, int i)
static pg_prng_state prng_state
char * psprintf(const char *fmt,...)
void get_restricted_token(void)
bool rmtree(const char *path, bool rmtopdir)
char * simple_prompt(const char *prompt, bool echo)
int pg_strip_crlf(char *str)
void appendShellString(PQExpBuffer buf, const char *str)
void initStringInfo(StringInfo str)
struct _stringlist * next
const char * get_user_name_or_exit(const char *progname)
#define symlink(oldpath, newpath)
#define IsValidWalSegSize(size)
#define DEFAULT_MAX_WAL_SEGS
#define DEFAULT_MIN_WAL_SEGS
static void infile(const char *name)