File Storage: S3 (Pro)
Giới thiệu
Trên cơ sở plugin file management, hỗ trợ thêm kiểu file storage tương thích với giao thức S3. Bất kỳ dịch vụ object storage nào hỗ trợ giao thức S3 đều có thể dễ dàng tích hợp, ví dụ Amazon S3, Aliyun OSS, Tencent COS, MinIO, Cloudflare R2, v.v., nâng cao hơn nữa tính tương thích và linh hoạt của dịch vụ storage.
Đ ặc điểm chức năng
-
Upload phía client: Quá trình upload file không cần đi qua server NocoBase, kết nối trực tiếp với dịch vụ file storage, đem lại trải nghiệm upload hiệu quả và nhanh hơn.
-
Truy cập riêng tư: Khi truy cập file, tất cả URL đều là địa chỉ ủy quyền tạm thời được ký, đảm bảo tính bảo mật và thời hạn của việc truy cập file.
Tình huống sử dụng
-
Quản lý File Collection: Quản lý và lưu trữ tập trung tất cả file được upload, hỗ trợ nhiều kiểu file và cách lưu trữ, thuận tiện cho việc phân loại và tìm kiếm file.
-
Lưu trữ Field Attachment: Dùng để lưu trữ dữ liệu attachment được upload trong form hoặc bản ghi, hỗ trợ liên kết với bản ghi dữ liệu cụ thể.
Cấu hình Plugin
-
Bật plugin plugin-file-storage-s3-pro
-
Nhấn "Setting -> FileManager" để vào cài đặt File Manager
-
Nhấn nút "Add new", chọn "S3 Pro"

- Sau khi popup hiện ra, bạn sẽ thấy nội dung form cần điền khá nhiều. Có thể tham khảo tài liệu sau, lấy thông tin tham số liên quan đến dịch vụ file tương ứng, và điền đúng vào form.

Cấu hình nhà cung cấp dịch vụ
Amazon S3
Tạo Bucket
-
Mở https://ap-southeast-1.console.aws.amazon.com/s3/home để vào S3 Console
-
Nhấn nút "Create bucket" bên phải

- Điền Bucket Name (tên bucket), các field khác có thể giữ cài đặt mặc định, cuộn xuống cuối trang, nhấn nút "Create" để hoàn tất việc tạo.


Cấu hình CORS
- Vào danh sách buckets, tìm và nhấn vào Bucket vừa tạo để vào trang chi tiết của nó

- Nhấn tab "Permission", sau đó cuộn xuống tìm phần cấu hình CORS


- Điền cấu hình sau (có thể tinh chỉnh chi tiết), và lưu

Lấy AccessKey, SecretAccessKey
- Nhấn nút "Security credentials" ở góc trên bên phải trang

- Cuộn xuống, tìm phần "Access Keys", nhấn nút "Create Access Key".

- Nhấn Đồng ý (đây là demo cho main account, khuyến nghị sử dụng IAM trong môi trường chính thức).

- Lưu Access key và Secret access key được hiển thị trên trang

Lấy và cấu hình tham số
-
AccessKey ID và AccessKey Secret là các giá trị tương ứng bạn đã lấy được trong bước trước, vui lòng điền chính xác
-
Vào panel properties của trang chi tiết bucket, bạn có thể lấy được thông tin Bucket name và Region.

Truy cập công khai (tùy chọn)
Đây là cấu hình không bắt buộc, hãy cấu hình khi bạn cần công khai hoàn toàn file đã upload
- Vào panel Permissions, cuộn xuống Object Ownership, nhấn edit, bật ACLs

- Cuộn đến Block public access, nhấn edit, đặt thành cho phép ACLs control

- Trong NocoBase tích chọn Public access
Cấu hình Thumbnail (tùy chọn)
Cấu hình này là tùy chọn, dùng khi cần tối ưu kích thước hoặc hiệu ứng preview hình ảnh. Lưu ý, phương án triển khai này có thể phát sinh chi phí phụ, chi phí cụ thể vui lòng tham khảo các điều khoản liên quan của AWS.
-
Truy cập Dynamic Image Transformation for Amazon CloudFront.
-
Nhấn nút
Launch in the AWS Consoleở cuối trang, bắt đầu triển khai phương án.
-
Hoàn tất cấu hình theo hướng dẫn, các tùy chọn sau cần đặc biệt chú ý:
- Khi tạo stack, bạn cần chỉ định một tên Amazon S3 bucket chứa hình ảnh nguồn. Vui lòng điền tên bucket bạn đã tạo trước đó.
- Nếu bạn chọn triển khai demo UI, sau khi triển khai xong có thể test chức năng xử lý hình ảnh thông qua giao diện này. Trong AWS CloudFormation Console, chọn stack của bạn, vào tab "Outputs", tìm giá trị tương ứng với key DemoUrl, nhấn link đó để mở giao diện demo.
- Phương án này sử dụng thư viện
sharpNode.js để xử lý hình ảnh hiệu quả. Bạn có thể tải mã nguồn từ GitHub repo, tùy chỉnh theo nhu cầu.

-
Sau khi cấu hình xong, đợi trạng thái triển khai chuyển thành
CREATE_COMPLETElà được. -
Trong cấu hình NocoBase, có một số lưu ý sau:
Thumbnail rule: Điền tham số liên quan đến xử lý hình ảnh, ví dụ?width=100. Cụ thể có thể tham khảo Tài liệu AWS.Access endpoint: Điền giá trị Outputs -> ApiEndpoint sau khi triển khai.Full access URL style: Cần tích chọn Ignore (vì đã điền tên bucket khi cấu hình, không cần khi truy cập).

Ví dụ cấu hình

Aliyun OSS
Tạo Bucket
- Mở OSS Console https://oss.console.aliyun.com/overview

- Nhấn vào "Buckets" trong menu bên trái, sau đó nhấn nút "Create Bucket" để bắt đầu tạo bucket

-
Điền thông tin liên quan đến bucket, cuối cùng nhấn nút Create
-
Bucket Name phù hợp với business của bạn, tên tùy ý
-
Region chọn region gần nhất với người dùng của bạn
-
Nội dung khác có thể mặc định, hoặc tự cấu hình theo nhu cầu
-

Cấu hình CORS
- Vào trang chi tiết bucket vừa tạo

- Nhấn vào "Content Security -> CORS" trong menu giữa

- Nhấn nút "Create Rule", và điền nội dung liên quan, cuộn xuống dưới nhấn "OK". Có thể tham khảo screenshot bên dưới, hoặc thiết lập chi tiết hơn

Lấy AccessKey, SecretAccessKey
- Nhấn "AccessKey" bên dưới avatar góc trên bên phải

-
Để tiện demo, sử dụng main account để tạo AccessKey, trong tình huống sử dụng chính thức khuyến nghị dùng RAM để tạo, có thể tham khảo https://help.aliyun.com/zh/ram/user-guide/create-an-accesskey-pair-1?spm=5176.28366559.0.0.1b5c3c2fUI9Ql8#section-rjh-18m-7kp
-
Nhấn nút "Create AccessKey"

- Tiến hành xác minh tài khoản

- Lưu Access key và Secret access key được hiển thị trên trang

Lấy và cấu hình tham số
-
AccessKey ID và AccessKey Secret là các giá trị đã lấy được trong bước trước
-
Vào trang chi tiết bucket, lấy được Bucket

- Cuộn xuống, lấy được Region (phần ".aliyuncs.com" phía sau không cần)

- Lấy được địa chỉ endpoint, khi điền vào NocoBase cần thêm tiền tố https://

Cấu hình Thumbnail (tùy chọn)
Cấu hình này là tùy chọn, chỉ dùng khi cần tối ưu kích thước hoặc hiệu ứng preview hình ảnh.
-
Điền tham số liên quan
Thumbnail rule. Cài đặt tham số cụ thể có thể tham khảo Tham số xử lý hình ảnh. -
Full upload URL stylevàFull access URL stylegiữ giống nhau là được.
Ví dụ cấu hình

MinIO
Tạo Bucket
- Nhấn menu Buckets bên trái -> Nhấn Create Bucket, vào trang tạo
- Sau khi điền tên Bucket, nhấn nút save
Lấy AccessKey, SecretAccessKey
- Vào Access Keys -> Nhấn nút Create access key, vào trang tạo

- Nhấn nút save

- Lưu Access Key và Secret Key trong popup, dùng cho cấu hình sau

Cấu hình tham số
-
Vào trang NocoBase -> File manager
-
Nhấn nút Add new, chọn S3 Pro
-
Điền form
- AccessKey ID và AccessKey Secret là văn bản đã lưu ở bước trước
- Region: MinIO triển khai riêng tư không có khái niệm Region, có thể cấu hình thành "auto"
- Endpoint: Điền domain hoặc địa chỉ ip dịch vụ đã triển khai
- Cần đặt Full access URL style thành Path-Style
Ví dụ cấu hình

Tencent COS
Có thể tham khảo cấu hình các dịch vụ file ở trên, logic tương tự
Ví dụ cấu hình

Cloudflare R2
Có thể tham khảo cấu hình các dịch vụ file ở trên, logic tương tự
Ví dụ cấu hình

Sử dụng cho người dùng
Tham khảo cách dùng plugin file-manager https://docs.nocobase.com/data-sources/file-manager/

