mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 00:02:34 -04:00 
			
		
		
		
	feat: lower disk usage during migration (#18440)
feat: less disk usage during migration
This commit is contained in:
		
							parent
							
								
									0b8fc7b493
								
							
						
					
					
						commit
						bc8e08f5e8
					
				| @ -247,8 +247,8 @@ export class DatabaseRepository { | |||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     const dimSize = await this.getDimensionSize(table); |     const dimSize = await this.getDimensionSize(table); | ||||||
|  |     await sql`DROP INDEX IF EXISTS ${sql.raw(indexName)}`.execute(this.db); | ||||||
|     await this.db.transaction().execute(async (tx) => { |     await this.db.transaction().execute(async (tx) => { | ||||||
|       await sql`DROP INDEX IF EXISTS ${sql.raw(indexName)}`.execute(tx); |  | ||||||
|       if (!rows.some((row) => row.columnName === 'embedding')) { |       if (!rows.some((row) => row.columnName === 'embedding')) { | ||||||
|         this.logger.warn(`Column 'embedding' does not exist in table '${table}', truncating and adding column.`); |         this.logger.warn(`Column 'embedding' does not exist in table '${table}', truncating and adding column.`); | ||||||
|         await sql`TRUNCATE TABLE ${sql.raw(table)}`.execute(tx); |         await sql`TRUNCATE TABLE ${sql.raw(table)}`.execute(tx); | ||||||
| @ -262,6 +262,11 @@ export class DatabaseRepository { | |||||||
|         SET DATA TYPE ${sql.raw(schema)}vector(${sql.raw(String(dimSize))})`.execute(tx);
 |         SET DATA TYPE ${sql.raw(schema)}vector(${sql.raw(String(dimSize))})`.execute(tx);
 | ||||||
|       await sql.raw(vectorIndexQuery({ vectorExtension, table, indexName, lists })).execute(tx); |       await sql.raw(vectorIndexQuery({ vectorExtension, table, indexName, lists })).execute(tx); | ||||||
|     }); |     }); | ||||||
|  |     try { | ||||||
|  |       await sql`VACUUM ANALYZE ${sql.raw(table)}`.execute(this.db); | ||||||
|  |     } catch (error: any) { | ||||||
|  |       this.logger.warn(`Failed to vacuum table '${table}'. The DB will temporarily use more disk space: ${error}`); | ||||||
|  |     } | ||||||
|     this.logger.log(`Reindexed ${indexName}`); |     this.logger.log(`Reindexed ${indexName}`); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user