mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	This patch essentially reverts commit4c6780fd17, in favor of a much simpler solution for the case where the new cluster would choose to create a TOAST table but the old cluster doesn't have one: just don't create a TOAST table. The existing code failed in at least two different ways if the situation arose: (1) ALTER TABLE RESET didn't grab an exclusive lock, so that the lock sanity check in create_toast_table failed; (2) pg_upgrade did not provide a pg_type OID for the new toast table, so that the crosscheck in TypeCreate failed. While both these problems were introduced by later patches, they show that the hack being used to cause TOAST table creation is overwhelmingly fragile (and untested). I also note that before the TypeCreate crosscheck was added, the code would have resulted in assigning an indeterminate pg_type OID to the toast table, possibly causing a later OID conflict in that catalog; so that it didn't really work even when committed. If we simply don't create a TOAST table, there will only be a problem if the code tries to store a tuple that's wider than a page, and field compression isn't sufficient to get it under a page. Given that the TOAST creation threshold is intended to be about a quarter of a page, it's very hard to believe that cross-version differences in the do-we-need-a-toast- table heuristic could result in an observable problem. So let's just follow the old version's conclusion about whether a TOAST table is needed. (If we ever do change needs_toast_table() so much that this conclusion doesn't apply, we can devise a solution at that time, and hopefully do it in a less klugy way than4c6780fd17did.) Back-patch to 9.3, like the previous patch. Discussion: <8110.1462291671@sss.pgh.pa.us>
		
			
				
	
	
		
			71 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *	dump.c
 | |
|  *
 | |
|  *	dump functions
 | |
|  *
 | |
|  *	Copyright (c) 2010-2014, PostgreSQL Global Development Group
 | |
|  *	contrib/pg_upgrade/dump.c
 | |
|  */
 | |
| 
 | |
| #include "postgres_fe.h"
 | |
| 
 | |
| #include "pg_upgrade.h"
 | |
| 
 | |
| #include <sys/types.h>
 | |
| 
 | |
| 
 | |
| void
 | |
| generate_old_dump(void)
 | |
| {
 | |
| 	int			dbnum;
 | |
| 	mode_t		old_umask;
 | |
| 
 | |
| 	prep_status("Creating dump of global objects");
 | |
| 
 | |
| 	/* run new pg_dumpall binary for globals */
 | |
| 	exec_prog(UTILITY_LOG_FILE, NULL, true,
 | |
| 			  "\"%s/pg_dumpall\" %s --globals-only --quote-all-identifiers "
 | |
| 			  "--binary-upgrade %s -f %s",
 | |
| 			  new_cluster.bindir, cluster_conn_opts(&old_cluster),
 | |
| 			  log_opts.verbose ? "--verbose" : "",
 | |
| 			  GLOBALS_DUMP_FILE);
 | |
| 	check_ok();
 | |
| 
 | |
| 	prep_status("Creating dump of database schemas\n");
 | |
| 
 | |
| 	/*
 | |
| 	 * Set umask for this function, all functions it calls, and all
 | |
| 	 * subprocesses/threads it creates.  We can't use fopen_priv() as Windows
 | |
| 	 * uses threads and umask is process-global.
 | |
| 	 */
 | |
| 	old_umask = umask(S_IRWXG | S_IRWXO);
 | |
| 
 | |
| 	/* create per-db dump files */
 | |
| 	for (dbnum = 0; dbnum < old_cluster.dbarr.ndbs; dbnum++)
 | |
| 	{
 | |
| 		char		sql_file_name[MAXPGPATH],
 | |
| 					log_file_name[MAXPGPATH];
 | |
| 		DbInfo	   *old_db = &old_cluster.dbarr.dbs[dbnum];
 | |
| 
 | |
| 		pg_log(PG_STATUS, "%s", old_db->db_name);
 | |
| 		snprintf(sql_file_name, sizeof(sql_file_name), DB_DUMP_FILE_MASK, old_db->db_oid);
 | |
| 		snprintf(log_file_name, sizeof(log_file_name), DB_DUMP_LOG_FILE_MASK, old_db->db_oid);
 | |
| 
 | |
| 		parallel_exec_prog(log_file_name, NULL,
 | |
| 				   "\"%s/pg_dump\" %s --schema-only --quote-all-identifiers "
 | |
| 				  "--binary-upgrade --format=custom %s --file=\"%s\" \"%s\"",
 | |
| 						 new_cluster.bindir, cluster_conn_opts(&old_cluster),
 | |
| 						   log_opts.verbose ? "--verbose" : "",
 | |
| 						   sql_file_name, old_db->db_name);
 | |
| 	}
 | |
| 
 | |
| 	/* reap all children */
 | |
| 	while (reap_child(true) == true)
 | |
| 		;
 | |
| 
 | |
| 	umask(old_umask);
 | |
| 
 | |
| 	end_progress_output();
 | |
| 	check_ok();
 | |
| }
 |