PostgreSQL
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> PostgreSQL

Cách nâng cấp pg_restore trong docker postgres image 10.3 lên 10.5

Nếu tôi hiểu bạn đúng, bạn muốn khôi phục kết xuất định dạng tùy chỉnh được lấy bằng 10.5 vào cơ sở dữ liệu 10.3.

Điều đó sẽ không thể thực hiện được nếu định dạng lưu trữ đã thay đổi từ 10,3 đến 10,5.

Để giải quyết vấn đề này, bạn có thể sử dụng kết xuất “định dạng thuần túy” (tùy chọn --format=plain ) mà không có "phiên bản lưu trữ". Nhưng bất kỳ sự cố nào trong quá trình khôi phục đều do bạn giải quyết, vì không hỗ trợ hạ cấp PostgreSQL.

Bạn phải luôn sử dụng cùng một phiên bản để phát triển và sản xuất, đồng thời bạn phải luôn sử dụng phiên bản nhỏ mới nhất (hiện tại là 10.13). Mọi thứ khác đang gặp rắc rối.

  1. sao lưu dưới dạng văn bản thuần túy như sau:cảnh báo! tập tin sẽ rất lớn. Nhiều hơn khoảng 17 lần so với định dạng tùy chỉnh thông thường. 90mb thông thường của tôi hiện là 1,75Gb
  2. sao chép tệp sao lưu vào vùng chứa postgres docker cp ~/path/to/dump/in-host-system/2020-07-08-1.dump <name_of_postgres_container>:/backups
  3. chuyển đến phần bash của vùng chứa postgres của bạn docker exec -it <name_of_postgres_container> bash
  4. bên trong bash of postgres container:psql -U username -d dbname < backups/2020-07-08-1.dump

Điều đó sẽ hoạt động




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. org.postgresql.util.PSQLException:Chỉ mục cột nằm ngoài phạm vi:3, số cột:2

  2. ScaleGrid PostgreSQL trên Cơ sở hạ tầng đám mây VMware

  3. Cách tạo SUM mà không cần nhóm theo

  4. Cách Asind () hoạt động trong PostgreSQL

  5. Kết nối với phiên bản cục bộ của PostgreSql bằng JDBC