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

docker postgres với dữ liệu ban đầu không được duy trì qua các lần cam kết

Vấn đề là postgres Dockerfile khai báo "/ var / lib / postgresql / data" dưới dạng một ổ đĩa. Đây chỉ là một thư mục bình thường nằm ngoài Hệ thống Tệp Liên minh được sử dụng bởi hình ảnh. Các tập sẽ tồn tại cho đến khi không có vùng chứa nào liên kết đến chúng và chúng bị xóa rõ ràng.

Bạn có một số lựa chọn:

  • Sử dụng --volumes-from lệnh chia sẻ dữ liệu với các vùng chứa mới. Cách này sẽ chỉ hoạt động nếu chỉ có một hình ảnh postgres đang chạy tại một thời điểm, nhưng đó là giải pháp tốt nhất.
  • Viết Dockerfile của riêng bạn để tạo dữ liệu trước khi khai báo ổ đĩa. Sau đó, dữ liệu này sẽ được sao chép vào ổ đĩa khi vùng chứa được tạo.
  • Viết một entrypoint hoặc tập lệnh cmd sẽ điền vào cơ sở dữ liệu tại thời điểm chạy.

Tất cả các đề xuất này đều yêu cầu bạn sử dụng Khối lượng để quản lý dữ liệu khi vùng chứa đang chạy. Ngoài ra, bạn có thể viết Dockerfile của riêng mình và chỉ cần không khai báo một ổ đĩa. Sau đó, bạn có thể sử dụng docker commit để tạo một hình ảnh mới sau khi thêm dữ liệu. Điều này có thể sẽ hiệu quả trong ngắn hạn, nhưng chắc chắn không phải là cách bạn nên làm việc với vùng chứa - nó không thể lặp lại và cuối cùng bạn sẽ sử dụng hết các lớp trong Hệ thống tệp Union.

Hãy xem tài liệu Docker chính thức về quản lý dữ liệu trong vùng chứa để biết thêm thông tin.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Truy vấn cho các phần tử mảng bên trong kiểu JSON

  2. lưu trữ kết quả postgresql trong biến bash

  3. Các trường cập nhật SQL của một bảng từ các trường của một bảng khác

  4. Nhóm người dùng PostgreSQL NL

  5. Điều kiện đếm ở đâu PostgreSQL