Để có thể phát huy được hết sức mạnh của blockchain, Oracle là một yếu tố rất quan trọng để kết nối giữa các hợp đồng thông minh và thế giới bên ngoài.
Nguồn cung cấp dữ liệu (Oracle) trên blockchain là gì?
Nguồn cấp dữ liệu (Oracle) trên blockchain là các dịch vụ của bên thứ ba cung cấp cho các hợp đồng thông minh những thông tin bên ngoài. Chúng đóng vai trò là cầu nối giữa các blockchain và thế giới bên ngoài.
Tầm quan trọng của Oracle đối với blockchain
Các blockchain và hợp đồng thông minh không thể truy cập dữ liệu ngoài chuỗi (dữ liệu nằm ngoài mạng). Tuy nhiên, một số thỏa thuận hợp đồng yêu cầu phải có thông tin liên quan từ thế giới bên ngoài để thực thi các thỏa thuận đó.
Đây là lúc cần đến các Oracle trên blockchain, vì chúng cung cấp một liên kết giữa dữ liệu ngoài chuỗi và dữ liệu trên chuỗi. Các Oracle có vai trò thiết yếu trong hệ sinh thái blockchain vì chúng mở rộng phạm vi hoạt động của các hợp đồng thông minh. Nếu không có chúng, các hợp đồng thông minh sẽ có sử dụng hạn chế vì chỉ có quyền truy cập vào dữ liệu từ trong mạng của mình.
Bản thân các Oracle trên blockchain không phải là nguồn dữ liệu, mà là một lớp để truy vấn, xác minh và xác thực các nguồn dữ liệu bên ngoài, sau đó chuyển tiếp thông tin đi. Dữ liệu mà các Oracle truyền đi dưới nhiều dạng: thông tin về giá cả, thông tin báo việc thanh toán được hoàn thành hoặc thông tin nhiệt độ được đo bằng cảm biến, …
Để gọi dữ liệu từ các nguồn bên ngoài, hợp đồng thông minh phải được dẫn ra và các tài nguyên mạng được sử dụng. Một số Oracle ngoài khả năng chuyển thông tin đến các hợp đồng thông minh, còn có thể gửi lại cho các nguồn bên ngoài.
Phân loại
Có thể phân loại các Oracle trên blockchain tùy thuộc vào các tính chất của chúng:
- Nguồn – dữ liệu có nguồn gốc từ phần mềm hay phần cứng?
- Hướng của thông tin – thông tin đến hay thông tin đi?
- Độ tin cậy – dữ liệu là tập trung hay phi tập trung?
Một Oracle có thể thuộc vào nhiều phân loại. Ví dụ, một Oracle lấy thông tin từ trang web của công ty là Oracle phần mềm, phi tập trung lấy thông tin từ bên trong.
Oracle phần mềm
Các oracle phần mềm tương tác với các nguồn thông tin trực tuyến và truyền nó đến blockchain. Thông tin này có thể đến từ các cơ sở dữ liệu trực tuyến, các máy chủ, trang web – về cơ bản là bất kỳ nguồn dữ liệu nào trên Web.
Việc các Oracle phần mềm được kết nối với mạng Internet không chỉ cho phép chúng cung cấp thông tin cho các hợp đồng thông minh mà còn truyền các thông tin đó đi theo thời gian thực. Điều này làm cho chúng trở thành một trong những loại oracle trên blockchain phổ biến nhất.
Các oracle phần mềm có thể cung cấp các thông tin bao gồm tỉ giá hối đoái, giá tài sản kỹ thuật số hoặc thông tin chuyến bay theo thời gian thực.
Oracle phần cứng
Một số hợp đồng thông minh cần tương tác với thế giới thực. Các Oracle phần cứng được thiết kế để thu thập thông tin từ thế giới vật lý và cung cấp nó cho các hợp đồng thông minh. Những thông tin này có thể được chuyển từ các cảm biến điện tử, máy quét mã vạch và các thiết bị đọc thông tin khác.
Nói cách khác, một Oracle phần cứng về cơ bản “chuyển đổi” các sự kiện trong thế giới thực thành các giá trị kỹ thuật số mà các hợp đồng thông minh có thể hiểu được.
Oracle phần cứng có thể là một cảm biến có khả năng kiểm tra xem liệu một chiếc xe tải vận chuyển hàng hóa đã đến vịnh chất hàng hay chưa. Nếu xe đã đến, nó sẽ chuyển thông tin này đến hợp đồng thông minh và hợp đồng thông minh này sau đó sẽ ra các quyết định dựa trên thông tin đó.
Các Oracle nhận thông tin và các Oracle gửi thông tin
Các oracle nhận thông tin đảm nhiệm việc gửi các thông tin từ các nguồn bên ngoài đến các hợp đồng thông minh, còn các oracle gửi thông tin sẽ gửi thông tin từ các hợp đồng thông minh ra bên ngoài.
Ví dụ, một oracle nhận thông tin sẽ cung cấp cho hợp đồng thông minh thông tin về nhiệt độ mà cảm biến đo được. Một oracle gửi thông tin có thể được kết hợp sử dụng với khóa thông minh. Khi tiền đã được gửi vào địa chỉ , hợp đồng thông minh sẽ gửi thông tin này qua một oracle gửi thông tin đến một hệ thống để mở khóa thông minh.
Các Oracle tập trung và phi tập trung
Oracle tập trung được kiểm soát bởi một tổ chức duy nhất và là nhà cung cấp thông tin duy nhất cho hợp đồng thông minh. Việc chỉ sử dụng một nguồn thông tin có thể là một việc rủi ro – tính hiệu quả của hợp đồng phụ thuộc hoàn toàn vào tổ chức kiểm soát Oracle đó. Ngoài ra, bất kỳ sự can thiệp nào từ một kẻ xấu sẽ có tác động trực tiếp đến hợp đồng thông minh.
Các Oracle phi tập trung có các mục tiêu tương tự như các blockchain công khai – tránh các rủi ro từ phía đối tác không hoàn thành nghĩa vụ. Chúng giúp tăng độ tin cậy của thông tin được cung cấp cho các hợp đồng thông minh bằng cách không dựa vào một nguồn sự thật duy nhất. Hợp đồng thông minh truy vấn nhiều oracle để xác định tính hợp lệ và chính xác của dữ liệu – đây là lý do tại sao các Oracle phi tập trung cũng có thể được gọi là các Oracle đồng thuận.
Một số dự án blockchain cung cấp các dịch vụ Oracle phi tập trung cho các blockchain khác. Các Oracle phi tập trung cũng có thể hữu ích trong các thị trường dự đoán, trong đó tính hợp lệ của một kết quả nhất định có thể được xác minh bằng sự đồng thuận xã hội.
Các Oracle cụ thể theo hợp đồng
Một Oracle cụ thể theo hợp đồng là một Oracle được thiết kế cho một hợp đồng thông minh duy nhất. Điều này có nghĩa là nếu một người muốn triển khai một số hợp đồng thông minh, thì người đó cần phải phát triển một số lượng tương ứng các Oracle cụ thể theo hợp đồng.
Để duy trì loại Oracle này rất tốn thời gian và tốn kém chi phí. Các công ty muốn trích xuất dữ liệu từ nhiều nguồn khác nhau có thể thấy cách tiếp cận này rất không thực tế. Mặt khác, do các Oracle cụ thể theo hợp đồng có thể được thiết kế từ đầu để phục vụ một trường hợp sử dụng cụ thể, nên các nhà phát triển có thể linh hoạt điều chỉnh chúng theo các yêu cầu cụ thể.
Các Oracle con người
Đôi khi những người có kiến thức chuyên ngành trong một lĩnh vực cụ thể cũng có thể đóng vai trò như một Oracle. Họ có thể nghiên cứu và xác minh tính xác thực của thông tin từ nhiều nguồn khác nhau và chuyển các thông tin đó đến các hợp đồng thông minh. Vì các Oracle con người có thể xác minh danh tính của họ bằng cách sử dụng mật mã, nên nguy cơ họ bị giả mạo danh tính và cung cấp dữ liệu lỗi là tương đối thấp.
Vấn đề của nguồn cung cấp dữ liệu
Trong khi các blockchain Oracles đóng vai trò cầu nối giữa các blockchain và các nhà cung cấp dữ liệu bên ngoài, thì bảo mật vẫn là một vấn đề quan trọng khi xem xét blockchain Oracles có thể trở thành xu hướng phổ biến hay không.
Vì các Oracle bị loại trừ khỏi các cơ chế đồng thuận của blockchain, nên nó không được bảo vệ bởi các cơ chế bảo mật của blockchain đã nói. Điều này làm cho blockchain trở thành mục tiêu cho các hacker tìm cách khai thác các lỗi định giá, như được minh họa bằng các sự cố bảo mật của Synthetix và BZX.
Cuộc tấn công xen giữa (man-in-the-middle attack), trong đó tác nhân độc hại giành quyền truy cập vào luồng dữ liệu giữa Oracle và hợp đồng thông minh, là một mối đe dọa bảo mật khác đối với blockchain Oracles. Sau đó, tác nhân này sẽ sửa đổi hoặc làm sai lệch dữ liệu, điều này làm giảm chất lượng dữ liệu do blockchain Oracles cung cấp.
Lời kết
Để áp dụng blockchain trên phạm vi toàn cầu, cần có một cơ chế đáng tin cậy cho việc tương tác giữa các hợp đồng thông minh và thế giới bên ngoài. Nếu không có Oracle trên blockchain, các hợp đồng thông minh sẽ chỉ có thể dựa vào những thông tin có sẵn trong mạng của chúng, điều này sẽ hạn chế đáng kể tiềm năng của chúng.
Oracle phi tập trung có thể tích hợp các cơ chế bảo vệ để loại bỏ nhiều rủi ro hệ thống khỏi hệ sinh thái blockchain.
Oracle trên blockchain vẫn là một trong những yếu tố nền tảng quan trọng cần được triển khai theo cách an toàn, đáng tin cậy và theo cách thức không cần sự tin tưởng giữa các bên tham gia để phát triển hệ sinh thái blockchain.
PCB Tổng hợp