UCL-IIOT - Hệ thống báo động với cơ sở dữ liệu và nút đỏ: 7 bước
UCL-IIOT - Hệ thống báo động với cơ sở dữ liệu và nút đỏ: 7 bước
Anonim
UCL-IIOT - Hệ thống báo động với cơ sở dữ liệu và nút đỏ
UCL-IIOT - Hệ thống báo động với cơ sở dữ liệu và nút đỏ
UCL-IIOT - Hệ thống báo động với cơ sở dữ liệu và nút đỏ
UCL-IIOT - Hệ thống báo động với cơ sở dữ liệu và nút đỏ

Mục đích của bản dựng này là dạy về cách kết nối Arduino với Node-red và cơ sở dữ liệu, vì vậy bạn có thể ghi dữ liệu và cũng thu thập nó để sử dụng sau này.

Đối với bản dựng này, tôi sử dụng một hệ thống cảnh báo arduino đơn giản xuất ra 5 số dữ liệu, mỗi số được phân tách bằng dấu phẩy.

Không nhất thiết phải có lượng dữ liệu chính xác đó và chương trình có thể là bất cứ thứ gì.

Phần quan trọng là dữ liệu được phân tách bằng dấu phẩy như trên ảnh chụp màn hình này.

Ví dụ: đầu ra có thể giống như sau: "324, 0, 0, 1, 1"

(phần lập trình đã hoàn thành và hướng dẫn tạo arduino được liên kết ở cuối hướng dẫn này)

Bước 1: Bắt đầu với Node-red

Bắt đầu với Node-red
Bắt đầu với Node-red

Đối với hướng dẫn này, chúng tôi giả sử bạn đã cài đặt Node-red, nhưng có một số bảng bổ sung được sử dụng cho dự án này mà chúng tôi cần để nó hoạt động

Tìm nút "Quản lý Bảng màu" và cài đặt các bảng màu sau.

  • node-red-dashboard
  • node-red-node-mysql
  • node-red-node-arduino
  • node-red-node-serialport

Nó sẽ hiển thị một số bảng màu mới ở bên cạnh menu nút Node-red.

Bước 2: Tách dữ liệu trong Node-red

Tách dữ liệu bằng Node-red
Tách dữ liệu bằng Node-red

Bây giờ Node-red đã sẵn sàng hoạt động, chúng ta cần bắt đầu bằng cách chia dữ liệu của mình thành các phần riêng biệt.

Đây là lý do tại sao chúng tôi đảm bảo phân tách chúng bằng dấu phẩy bên trong mã Arduino.

Đầu tiên, hãy bắt đầu bằng cách đặt nút Đầu vào Arduino, được tìm thấy ở bảng điều khiển bên trái.

Bạn cần đảm bảo rằng nó có cổng nối tiếp chính xác (của tôi sử dụng cổng COM4) và tốc độ truyền (trong chương trình của tôi, tôi sử dụng tốc độ truyền 9600)

Nếu được thiết lập chính xác, nó sẽ thông báo rằng nó đã được kết nối.

Tiếp theo, chúng tôi tạo một khối chức năng Javascript và kết nối nó sau nút đầu vào Arduino. Khối này cho phép chúng tôi lập trình bằng Javascript và ở đây chúng tôi viết mã có thể phân chia dữ liệu của chúng tôi cho mỗi dấu phẩy.

Trong khối chức năng này, tôi chia 5 dữ liệu của mình bằng đoạn mã sau:

var m1 = {topic: "light1", payload: msg.payload.split (",") [0]}; var m2 = {topic: "light2", payload: msg.payload.split (",") [1]}; var m3 = {topic: "light3", payload: msg.payload.split (",") [2]}; var m4 = {topic: "millis", payload: msg.payload.split (",") [3]}; var m5 = {topic: "onoff", payload: msg.payload.split (",") [4]}; return [m1, m2, m3, m4, m5];

(thay đổi mã nếu cần)

Đảm bảo rằng nút được đặt thành 5 đầu ra (hoặc tương đương của bạn)

Như đã thấy trong ảnh chụp màn hình, bây giờ chúng ta có 5 đầu ra mà mỗi đầu ra chúng ta liên kết với một nút gỡ lỗi và một nút bảng điều khiển văn bản. Điều này sẽ hữu ích khi chúng ta cần xem nó trên giao diện người dùng.

Bước 3: Cơ sở dữ liệu với Wampserver

Cơ sở dữ liệu với Wampserver
Cơ sở dữ liệu với Wampserver

Để cơ sở dữ liệu của chúng tôi hoạt động, bạn cần cài đặt Wampserver. trước đó đã thay đổi nó, chỉ cần nhập "root" trong tên người dùng và đăng nhập.

Nhấn nút phpmyadmin bên dưới các công cụ ở thanh bên trái và nó sẽ mở menu cơ sở dữ liệu, trông giống như trong hình trên.

Tạo một cơ sở dữ liệu mới và đặt tên cho nó một cái gì đó liên quan đến dự án của bạn, của tôi được đặt tên là "hệ thống báo động" (những tên này sẽ phân biệt chữ hoa chữ thường)

Trong cơ sở dữ liệu đó, hãy tạo một bảng mới và đặt tên cho nó, của tôi có tên là "alertdata"

nó sẽ hỏi bạn có muốn sử dụng "latin1_swedish_ci" hay không và chúng tôi chỉ giữ nguyên như vậy.

Bây giờ bạn tạo 6 bảng (nhiều hơn 1 bảng so với dữ liệu chúng tôi có)

Bảng đầu tiên cần sử dụng kiểu dữ liệu "longtext"

và phần còn lại của tập dữ liệu sử dụng "mediumtext"

Đảm bảo đặt tên cho chúng. (tập dữ liệu đầu tiên phải được đặt tên là "thời gian"

Bước 4: Cơ sở dữ liệu

Cơ sở dữ liệu
Cơ sở dữ liệu

Tập dữ liệu Wampserver sẽ trông giống như thế này.

(nhưng không có dữ liệu thực tế, vì chúng tôi chưa đạt được điều đó)

Bước 5: Nút đỏ cho Wampserver

Node-red thành Wampserver
Node-red thành Wampserver

Bây giờ chúng tôi muốn dữ liệu chúng tôi đang xuất ra từ arduino của chúng tôi chuyển đến Wampserver của chúng tôi.

Bắt đầu bằng cách tạo một khối chức năng Javascript khác và kết nối nó với nút đầu vào arduino của chúng tôi.

Trong khối script này, chúng tôi một lần nữa chia nhỏ dữ liệu của mình, nhưng chúng tôi cũng chèn nó vào cơ sở dữ liệu của mình.

var data = msg.payload.split (","); var Green1 = data [0]; var Green2 = data [1]; var Alarm = data [2]; var Millis = data [3]; var IsActive = data [4]; var out = "INSERT INTO alertmsystem.alarmdata (Time, Green1, Green2, Alarm, Millis, IsActive) VALUES ('" + new Date (). toISOString (). slice (0, 19).replace (' T ',' ') + "', '" + Green1 + "', '" + Green2 + "', '" + Alarm + "', '" + Millis + "', '" + IsActive + "')"; msg.topic = out; trả về tin nhắn;

Lưu ý rằng tôi nhập "INSERT INTO alertmsystem.alarmdata", đây là tên mà chúng tôi đã đặt cho cơ sở dữ liệu và bảng của mình, hãy đảm bảo bạn viết chính xác tên mà bạn đã đặt cho cơ sở dữ liệu của mình.

Bây giờ kết nối khối Javascript với một nút gỡ lỗi và cũng là một nút "mysql" được tìm thấy dưới bảng lưu trữ ở phía bên trái.

dưới khối mysql, bạn đặt tên nó giống như "hệ thống báo động" trong cơ sở dữ liệu của bạn

thay đổi người dùng thành "root" (tên chúng tôi đã sử dụng để đăng nhập vào máy chủ của mình)

máy chủ, cổng và cơ sở dữ liệu phải được điền sẵn với:

Máy chủ: 127.0.0.1

Cảng: 3306

Cơ sở dữ liệu: hệ thống báo động

Nếu tất cả được thực hiện đúng, nó sẽ được kết nối sau khi bạn triển khai các thay đổi của mình.

Bạn cũng có thể thấy rằng cơ sở dữ liệu hiện ghi trực tiếp dữ liệu của bạn từ Arduino.

Bước 6: Sử dụng dữ liệu từ Wampserver sang Node-red

Sử dụng dữ liệu từ Wampserver sang Node-red
Sử dụng dữ liệu từ Wampserver sang Node-red
Sử dụng dữ liệu từ Wampserver sang Node-red
Sử dụng dữ liệu từ Wampserver sang Node-red

Đối với đoạn cuối cùng, chúng tôi muốn xem liệu chúng tôi có thể lấy dữ liệu chúng tôi đã lưu và đặt nó trở lại Node-red của chúng tôi và hy vọng hiển thị nó hay không.

Bắt đầu bằng cách đặt một nút "tiêm"

Theo chủ đề trong nút này, chúng tôi đặt mã: CHỌN * TỪ alertmsystem.alarmdata

Điều này sẽ có thể tìm thấy cơ sở dữ liệu của chúng tôi khi chúng tôi nhấn nó.

Kết nối nút tiêm với một nút "mysql" mới được thiết lập chính xác như nút chúng ta đã làm trong bước trước.

Kết nối nút mysql với nút gỡ lỗi và nút mẫu được tìm thấy trong bảng điều khiển.

Nút mẫu sẽ là bảng của chúng ta mà chúng ta có thể cập nhật để hiển thị dữ liệu từ cơ sở dữ liệu khi nó được tạo ra.

Nhập mã được hiển thị trong ảnh chụp màn hình ở trên (thay đổi nếu cần) và bây giờ nó sẽ hiển thị bảng dữ liệu trong giao diện người dùng Node-red của chúng tôi.

Chúng tôi cũng có thể thêm nút trang tổng quan để cập nhật bảng từ chính giao diện người dùng.

Bắt đầu bằng cách tạo một nút nút.

kết nối nút nút với một khối chức năng Javascript.

trong khối chức năng, chúng tôi chèn đoạn mã sau.

msg.topic = "CHỌN * TỪ LỆNH dữ liệu báo động THEO GIỚI HẠN MÔ TẢ Green1 20"; return msg;

(Green1 là biến dữ liệu đầu tiên trong bảng)

khối chức năng này sau đó cần được kết nối với đầu vào của nút mysql của chúng tôi mà chúng tôi đã thực hiện trước đó trong bước này.

Bước 7: Hoàn thiện

Đang hoàn thiện
Đang hoàn thiện

Bây giờ giao diện người dùng của chúng tôi sẽ bao gồm một bản cập nhật trực tiếp dữ liệu của chúng tôi và một bảng với dữ liệu từ chính máy chủ của chúng tôi.

Điều này có nghĩa là chúng tôi đã tạo kết nối giữa Arduino, một chương trình dựa trên giao diện người dùng và cơ sở dữ liệu.

Nếu bạn quan tâm đến cách Hệ thống cảnh báo Arduino của tôi hoạt động, tôi đã thêm tài liệu giải thích cách lập trình và thiết lập hệ thống này.

Cũng như xuất toàn bộ chương trình nút đỏ.

Đề xuất: