{"id":316146,"date":"2021-01-10T15:01:06","date_gmt":"2021-01-10T15:01:06","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=316146"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=316146","title":{"rendered":"\u041a\u0430\u043a \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433 \u043b\u044e\u0431\u044b\u0445 \u0431\u0438\u0437\u043d\u0435\u0441-\u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0432, \u0432 \u0411\u0414 Oracle + \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u0435 \u0433\u0440\u0430\u0444\u0438\u043a\u043e\u0432, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0431\u0435\u0441\u043f\u043b\u0430\u0442\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e Grafana"},"content":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<h2>\u0412\u0432\u043e\u0434\u043d\u044b\u0435. \u0417\u0430\u0447\u0435\u043c \u043c\u043d\u0435 \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u043d\u0443\u0436\u043d\u043e<\/h2>\n<p>\u041b\u0438\u0447\u043d\u043e \u043c\u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433 \u0434\u043e\u043c\u0430\u0448\u043d\u0435\u0439 \u0441\u043e\u043b\u043d\u0435\u0447\u043d\u043e\u0439 \u044d\u043b\u0435\u043a\u0442\u0440\u043e\u0441\u0442\u0430\u043d\u0446\u0438\u0438.<\/p>\n<p>\u041a\u0440\u0430\u0442\u043a\u043e \u043e \u043c\u0430\u0442\u0447\u0430\u0441\u0442\u0438 (\u0445\u043e\u0442\u044f \u044d\u0442\u043e\u0442 \u043f\u043e\u0441\u0442 \u043d\u0435 \u043f\u0440\u043e \u043d\u0435\u0451):<\/p>\n<ul>\n<li>\n<p>\u0418\u043d\u0432\u0435\u0440\u0442\u043e\u0440 \u041c\u0410\u041f \u042d\u043d\u0435\u0440\u0433\u0438\u044f \u0438 3 \u0441\u043e\u043b\u043d\u0435\u0447\u043d\u044b\u0445 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 \u0442\u043e\u0433\u043e \u0436\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044f.<\/p>\n<\/li>\n<li>\n<p>\u0412\u043d\u0443\u0442\u0440\u0438 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440\u0430 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d \u043c\u0438\u043a\u0440\u043e\u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440 (\u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u0435\u0433\u043e \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442 &#171;\u041c\u0430\u043b\u0438\u043d\u0430&#187;), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043a\u043e\u0435-\u0447\u0442\u043e \u0443\u043c\u0435\u0435\u0442 \u0432 \u043f\u043b\u0430\u043d\u0435 \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433\u0430, \u043d\u043e \u043d\u0435 \u0432\u0441\u0451 \u0447\u0442\u043e \u043c\u043d\u0435 \u043d\u0443\u0436\u043d\u043e, \u0438 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u043e. \u0426\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u043c\u0438\u043a\u0440\u043e\u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u0441\u043d\u0438\u043c\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441 com-\u043f\u043e\u0440\u0442\u043e\u0432 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440\u0430 \u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u043e\u0432 \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u0442 \u0438\u0445 \u043d\u0430\u0441\u0432\u043e\u0451\u043c http-\u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u0432 \u0432\u0438\u0434\u0435 Json. \u0414\u0430\u043d\u043d\u044b\u0435 \u0432\u0435\u0431-\u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043a\u0430\u0436\u0434\u0443\u044e \u0441\u0435\u043a\u0443\u043d\u0434\u0443. \u0422\u0430\u043a\u0436\u0435 \u0435\u0441\u0442\u044c \u0432\u0435\u0431-\u0441\u0435\u0440\u0432\u0438\u0441\u044b \u0434\u043b\u044f \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c\u0438 \u0432 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u044b \u0438 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440 \u0440\u0435\u043b\u0435<\/p>\n<\/li>\n<li>\n<p>\u041f\u0430\u0440\u043e\u0447\u043a\u0430 Ethernet-\u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432 SR-201 \u044d\u0442\u043e \u0442\u0430\u043a\u0438\u0435 \u043f\u043b\u0430\u0442\u044b \u0441 \u0440\u0435\u043b\u044e\u0445\u0430\u043c\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0434\u043b\u044f \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u043e\u0439 \u0438 \u043a\u043e\u0435-\u0447\u0435\u043c \u0435\u0449\u0435, \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u043e \u043f\u0440\u043e\u0442\u043e\u043a\u043e\u043b\u0443 tcp \u0438 udp.<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u043c\u0430\u0448\u043d\u0438\u0439 \u0441\u0435\u0440\u0432\u0435\u0440 \u043f\u043e\u0434 \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435\u043c Centos-8, \u043d\u0430 \u043d\u0451\u043c \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d Oracle (\u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f Express Edition \u0441\u043e \u0432\u0441\u0435\u043c\u0438 \u0441\u0432\u043e\u0438\u043c\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438, \u043d\u043e \u0434\u043b\u044f \u0434\u043e\u043c\u0430\u0448\u043d\u0435\u0433\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e) <\/p>\n<\/li>\n<li>\n<p>\u0412 \u043e\u0440\u0430\u043a\u043b\u0435 \u043a\u0440\u0443\u0442\u044f\u0442\u0441\u044f 2 JOBa (\u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u044d\u0442\u043e persistent \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043a\u0440\u0443\u0442\u044f\u0442 \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u044b\u0439 \u0446\u0438\u043a\u043b \u0438 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u0430\u044e\u0442\u0441\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0440\u0430\u0437 \u0432 \u043f\u043e\u043b\u0447\u0430\u0441\u0430):<\/p>\n<ol>\n<li>\n<p>\u0420\u0430\u0437 \u0432 \u0441\u0435\u043a\u0443\u043d\u0443 \u0441\u043d\u0438\u043c\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432 &#171;\u041c\u0430\u043b\u0438\u043d\u044b&#187;, \u0442\u0435\u043a\u0443\u0449\u0435\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0440\u0435\u043b\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432 SR-201 \u0438 \u043f\u0438\u0448\u0435\u0442 \u044d\u0442\u043e \u0432\u0441\u0451 \u0432 \u0411\u0414 Oracle. \u0421 \u041c\u0430\u043b\u0438\u043d\u044b \u0441\u043d\u0438\u043c\u0430\u0435\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043d\u0435\u0441\u043b\u043e\u0436\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 utl_http, \u0441 \u0440\u0435\u044e\u0445 &#8212; \u0447\u0435\u0440\u0435\u0437 utl_tcp. \u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u044d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0430, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0431\u0443\u0434\u0435\u043c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u0442\u044c<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u043f\u0435\u0440\u0435\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0443 \u0437\u0430 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u043a \u0432\u0440\u0435\u043c\u0435\u043d\u0438, \u0438 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0445 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432, \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u043e\u0439 \u0438 \u0435\u0449\u0435 \u043a\u043e\u0435-\u0447\u0435\u043c \u0447\u0435\u0440\u0435\u0437 SR-201 \u0438 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0440\u0435\u043b\u0435 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440\u0430 \u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u043e\u0432.<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<\/ul>\n<p>\u0412\u043e\u0442 \u044d\u0442\u043e \u0432\u0441\u0451 \u0445\u043e\u0437\u044f\u0439\u0441\u0442\u0432\u043e \u043c\u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u0442\u044c. \u041f\u0440\u0438\u0447\u0435\u043c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u0442\u044c \u043d\u0435 \u0441\u043e\u0431\u044b\u0442\u0438\u044f (\u0441\u043e\u0431\u044b\u0442\u0438\u044f\u043c\u0438 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442\u0441 Job2), \u0430 \u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0433\u0440\u0430\u0444\u0438\u043a\u0438 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438, \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u043d\u0430 \u043a\u043e\u043c\u043f\u0435 \u0438 \u043c\u043e\u0431\u0438\u043b\u043a\u0435. \u0421\u0430\u043c\u0430 &#171;\u041c\u0430\u043b\u0438\u043d\u0430&#187; \u043a\u043e\u0435-\u0447\u0442\u043e \u0443\u043c\u0435\u0435\u0442, \u043d\u043e \u0432\u043e-\u043f\u0435\u0440\u0432\u044b\u0445 \u043d\u0435 \u0432\u0441\u0451 (\u043f\u0440\u043e \u043c\u043e\u0438 SR-201 \u043e\u043d\u0430 \u0442\u043e\u0447\u043d\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0437\u043d\u0430\u0435\u0442), \u0432\u043e-\u0432\u0442\u043e\u0440\u044b\u0445 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 &#8212; \u043d\u0435\u043b\u044c\u0437\u044f \u0432\u0441\u0451 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u043e\u0434\u043d\u043e\u043c \u044d\u043a\u0440\u0430\u043d\u0435 \u0432 \u0443\u0434\u043e\u043c\u043d\u043e\u043c \u043c\u043d\u0435 \u0432\u0438\u0434\u0435, \u0430 \u0432 \u0442\u0440\u0435\u0442\u044c\u0438\u0445 &#8212; \u0432 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043c\u0435\u0441\u0442\u0430\u0445 \u043a\u0440\u0438\u0432\u043e\u0432\u0430\u0442\u043e.<\/p>\n<p>\u0412\u043e\u043f\u0440\u043e\u0441\u044b: \u041f\u043e\u0447\u0435\u043c\u0443 Oracle \u0430 \u043d\u0435 Postgres \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440? \u041d\u0443 \u043f\u0440\u043e\u0441\u0442\u043e \u043b\u0435\u043d\u044c, \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0438\u0437 \u0442\u043e\u0433\u043e \u0447\u0442\u043e \u0443\u043c\u0435\u044e&#8230; \ud83d\ude42<\/p>\n<p>\u0412\u044b\u0431\u043e\u0440 \u043f\u0430\u043b \u043d\u0430 Grafana https:\/\/grafana.com &#8212; \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043e\u0449\u043d\u043e\u0435 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u0438 \u043f\u0440\u043e\u0447\u0435\u0439 \u0435\u0440\u0443\u043d\u0434\u044b. \u041b\u0435\u0433\u043a\u043e \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u0442\u0441\u044f, \u0443\u0434\u043e\u0431\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c. \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441 \u043c\u043d\u043e\u0433\u0438\u043c\u0438 \u0411\u0414&#8230;<\/p>\n<h2>\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u0430<\/h2>\n<p>\u0414\u0430\u043d\u043d\u044b\u0439 \u043f\u043e\u0441\u0442 \u043d\u0438 \u0440\u0430\u0437\u0443 \u043d\u0435 \u043f\u0440\u0435\u0442\u0435\u043d\u0434\u0443\u0435\u0442 \u043d\u0430 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0448\u0430\u0433\u043e\u0432\u044b\u0439 tutorial, \u044f \u043b\u0438\u0448\u044c \u0445\u043e\u0447\u0443 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u0443\u0442\u044c, \u043f\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u043c\u0443 \u0412\u0430\u043c \u0431\u0443\u0434\u0435\u0442 \u043b\u0435\u0433\u0447\u0435 \u0438\u0434\u0442\u0438.<\/p>\n<p>\u0418\u0442\u0430\u043a: <\/p>\n<p>\u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c grafana<\/p>\n<pre><code>$ sudo nano \/etc\/yum.repos.d\/grafana.repo [grafana] name=grafana baseurl=https:\/\/packages.grafana.com\/oss\/rpm repo_gpgcheck=1 enabled=1 gpgcheck=1 gpgkey=https:\/\/packages.grafana.com\/gpg.key sslverify=1 sslcacert=\/etc\/pki\/tls\/certs\/ca-bundle.crt<\/code><\/pre>\n<pre><code>dnf update dnf install grafana  systemctl daemon-reload systemctl enable --now grafana-server systemctl status grafana-server<\/code><\/pre>\n<p>Selinux \u0443 \u043c\u0435\u043d\u044f \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d, \u0444\u0430\u0439\u0440\u0432\u043e\u043b \u0442\u043e\u0436\u0435, \u0442\u0430\u043a \u0447\u0442\u043e \u0432 \u044d\u0442\u0438 \u043d\u044e\u0430\u043d\u0441\u044b \u0432\u0434\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0435 \u0431\u0443\u0434\u0443<\/p>\n<\/p>\n<p>\u0414\u0430\u043b\u0435\u0435 \u043e\u0434\u043d\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043a\u0430: Grafana \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0441 Oracle \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0443\u043c\u0435\u0435\u0442, \u043d\u043e \u0434\u0430\u043d\u043d\u0430\u044f \u043e\u043f\u0446\u0438\u044f (\u043f\u043b\u0430\u0433\u0438\u043d) \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0432 Enterprise \u0432\u0435\u0440\u0441\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u043e\u0442 24\u043a$ \u0438 \u044d\u0442\u043e \u0432 \u043c\u043e\u0438 \u043f\u043b\u0430\u043d\u044b \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u0442. \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u043f\u043b\u0430\u0433\u0438\u043d grafana-simple-json-datasource<\/p>\n<pre><code>grafana-cli plugins install grafana-simple-json-datasource systemctl restart grafana-server<\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u0433\u0440\u0430\u0444\u0430\u043d\u0430 \u0443 \u043d\u0430\u0441 \u0432 \u043e\u0440\u0430\u043a\u043b \u0445\u043e\u0434\u0438\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0435\u0442. \u041e\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0431\u0440\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441\u0430, \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u0435\u043b\u043e \u0437\u0430 \u043c\u0430\u043b\u044b\u043c &#8212; \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c.<\/p>\n<p>\u0412\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441 \u0431\u0443\u0434\u0435\u043c \u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0430 apache + php<\/p>\n<p>\u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0438 \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c:<\/p>\n<p>httpd, php \u0438 php-fpm (\u0443 \u043c\u0435\u043d\u044f php 7.2) \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d \u0438 \u0441\u043a\u043e\u043d\u0444\u0438\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u043d \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 freepbx \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0436\u0438\u0432\u0451\u0442 \u043d\u0430 \u0442\u043e\u043c \u0436\u0435 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \ud83d\ude42<\/p>\n<p>\u0414\u043b\u044f php \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 oci8 &#8212; \u0442\u0443\u0442 \u0435\u0441\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0434\u043b\u044f php 7.2 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c oci8 \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 pecl.<\/p>\n<p>\u0412 \u043e\u0431\u0449\u0435\u043c \u043f\u0443\u0442\u044c \u0442\u0430\u043a\u043e\u0439:<\/p>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439 remi, \u0438 \u043e\u0442\u0442\u0443\u0434\u0430:<\/p>\n<pre><code>dnf install php-pecl-oci8<\/code><\/pre>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c oci8 \u043a php<\/p>\n<p>\/etc\/hp.d\/20-oci8.ini<\/p>\n<p>\u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0440\u0430\u0441\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c 1 \u0441\u0442\u0440\u043e\u043a\u0443<\/p>\n<pre><code>extension=oci8.so<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u044d\u0442\u043e\u0442 oci8 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0447\u0435\u0442 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c\u0441\u044f, \u0442\u0443\u0442 \u043f\u043e\u043c\u043e\u0433\u0443\u0442 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a\u0438\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432 <\/p>\n<p>\/etc\/php-fpm.d\/www.conf<\/p>\n<pre><code>env[ORACLE_HOSTNAME] = myserver.localdomain env[ORACLE_UNQNAME] = mydb env[ORACLE_BASE] = \/u01\/app\/oracle env[ORACLE_HOME] = \/u01\/app\/oracle\/product\/18.4.0\/dbhome_1 env[ORA_INVENTORY] = \/u01\/app\/oraInventory env[ORACLE_SID] = mydb env[LD_LIBRARY_PATH] = \/u01\/app\/oracle\/product\/18.4.0\/dbhome_1\/lib:\/lib:\/usr\/lib env[NLS_LANG] = AMERICAN_CIS.UTF8 <\/code><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 php-\u0441\u043a\u0440\u0438\u043f\u0442\u0430 \u043d\u0430 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0435\u0440\u0435, oci8 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f<\/p>\n<p>\u0412\u044b\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u043c \u0441\u043a\u0440\u0438\u043f\u0442 \u043d\u0430 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0435\u0440<\/p>\n<p>\/var\/www\/html\/gr\/gr.php<\/p>\n<pre><code>&lt;?php  header(\"Content-Type: application\/json;\");  $conn = oci_pconnect('www', 'www$password', 'mydb', 'AL32UTF8'); if (!$conn) {     $e = oci_error();     trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); }  \/\/ \u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u044f $stid = oci_parse($conn, 'begin  LGRAFANA.GetJson(:vPath, :vInp, :vOut); end;'); if (!$stid) {     $e = oci_error($conn);     trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); }  \/\/ \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0434\u0435\u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0440\u044b $vInp = oci_new_descriptor($conn, OCI_DTYPE_LOB); $vOut = oci_new_descriptor($conn, OCI_DTYPE_LOB);  \/\/ \u041f\u0440\u0438\u0432\u044f\u0436\u0435\u043c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 $vPath = $_SERVER[\"PATH_INFO\"]; $postdata = file_get_contents(\"php:\/\/input\"); $vInp-&gt;writeTemporary($postdata, OCI_TEMP_BLOB);  oci_bind_by_name($stid, \":vPath\", $vPath); oci_bind_by_name($stid, \":vInp\", $vInp, -1, OCI_B_BLOB); oci_bind_by_name($stid, \":vOut\", $vOut, -1, OCI_B_BLOB);  \/\/ \u0412\u044b\u043f\u043e\u043b\u043d\u0438\u043c \u043b\u043e\u0433\u0438\u043a\u0443 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 $r = oci_execute($stid); if (!$r) {     $e = oci_error($stid);     trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); }  echo $vOut-&gt;load();   $vInp -&gt;close(); $vOut -&gt;close();  oci_free_statement($stid);  oci_commit($conn); oci_close($conn); ?&gt;<\/code><\/pre>\n<p>\u0412\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441 \u0433\u043e\u0442\u043e\u0432.<\/p>\n<p>\u0412 \u043d\u0430\u0448\u0435\u0439 \u0411\u0414 \u0435\u0441\u0442\u044c \u043f\u0430\u043a\u0435\u0442 LGRAFANA, \u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0430\u0440\u0443\u0436\u0443 \u0442\u043e\u0440\u0447\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u0430 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430<\/p>\n<pre><code>procedure GetJson(pPathInfo in varchar2, pInpPost in blob, pOutPost out blob);<\/code><\/pre>\n<p>\u043e\u043d\u0430 \u0438 \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c Json &#8212; \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043e\u0442 \u0433\u0440\u0430\u0444\u0430\u043d\u044b. \u042d\u0442\u0443 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443 \u0446\u0435\u043b\u0438\u043a\u043e\u043c \u043f\u0440\u0438\u0432\u0435\u0434\u0443 \u0447\u0443\u0442\u044c \u043d\u0438\u0436\u0435, \u0412\u044b \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u0442\u0435 \u0447\u0442\u043e \u044d\u0442\u043e \u043b\u0438\u0448\u044c \u043f\u0440\u0438\u043c\u0435\u0440 \u0434\u043b\u044f \u043c\u043e\u0435\u0439 \u044d\u043b\u0435\u043a\u0442\u0440\u043e\u0441\u0442\u0430\u043d\u0446\u0438\u0438, \u0430 \u0432 \u0446\u0435\u043b\u043e\u043c \u0444\u043e\u0440\u043c\u0430\u0442 Json \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432-\u043e\u0442\u0432\u0435\u0442\u043e\u0432 \u043e\u043f\u0438\u0441\u0430\u043d \u0442\u0443\u0442<\/p>\n<p>https:\/\/grafana.com\/grafana\/plugins\/grafana-simple-json-datasource<\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0432 \u0441\u0430\u043c\u043e\u0439 \u0433\u0440\u0430\u0444\u0430\u043d\u0435:<\/p>\n<p>Configuration &#8212; Data Sources &#8212; Add DataSource &#8212; Simple JSON<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7d8\/c33\/2b9\/7d8c332b9e8b811d41f472d9b5e34dd2.png\" width=\"627\" height=\"785\"><figcaption><\/figcaption><\/figure>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u043c\u043e\u0436\u043d\u043e \u0438\u0434\u0442\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c DashBoard \u0438 \u043d\u0430\u043a\u0438\u0434\u044b\u0432\u0430\u0442\u044c \u0442\u0443\u0434\u0430 \u043f\u0430\u043d\u0435\u043b\u0438 \u0441 \u043d\u0443\u0436\u043d\u044b\u043c\u0438 \u0433\u0440\u0430\u0444\u0438\u043a\u0430\u043c\u0438<\/p>\n<p>&#8230; \u0415\u0441\u043b\u0438 \u0443 \u0412\u0430\u0441 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u0430\u043a\u0435\u0442\u0430 LGRAFANA \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f.<\/p>\n<p>\u0414\u0430 \u043a\u0441\u0442\u0430\u0442\u0438 \u043f\u0440\u043e \u043f\u0430\u043a\u0435\u0442. \u041e\u043d \u0443 \u043c\u0435\u043d\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043d \u043d\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0430 PL\/SQL, \u043d\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u0412\u044b \u0441\u043c\u043e\u0436\u0435\u0442\u0435 \u044d\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u043d\u0430\u0434\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u0441\u0432\u043e\u0451\u043c \u043f\u0430\u043a\u0435\u0442\u0435. \u042d\u0442\u043e \u043b\u0435\u0433\u043a\u043e \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043d\u0430 pl\/sql.<\/p>\n<p>\u0412\u043a\u0440\u0430\u0442\u0446\u0435 \u0442\u0430\u043a:<\/p>\n<ol>\n<li>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u043c\u0435\u0442\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0435\u0430\u0433\u0438\u0440\u0443\u0435\u0442 \u043d\u0430 pahinfo=\/search \u0438 \u043e\u0442\u0434\u0430\u0451\u0442 \u043c\u0430\u0441\u0441\u0438\u0432 \u0438\u043c\u0451\u043d \u043c\u0435\u0442\u0440\u0438\u043a \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0443\u043c\u0435\u0435\u043c \u0441\u0447\u0438\u0442\u0430\u0442\u044c<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u043c\u0435\u0442\u043e\u0434 \/query \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442 \u043c\u0430\u0441\u0441\u0438\u0432 \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u043e \u043d\u0443\u0436\u043d\u044b\u043c \u043c\u0435\u0442\u0440\u0438\u043a\u0430\u043c<\/p>\n<\/li>\n<\/ol>\n<details class=\"spoiler\">\n<summary>\u041f\u043e\u043b\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u043f\u0430\u043a\u0435\u0442\u0430<\/summary>\n<div class=\"spoiler__content\">\n<pre><code>pragma include([DEBUG_TRIGGER]::[MACRO_LIB]);  CPALL const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0433\u0440.'; CPNET const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0441\u0435\u0442\u044c'; CPACB const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0410\u041a\u0411'; CPI2C const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c I2C'; CPADD const varchar2(30) := '\u0414\u043e\u043f. \u041d\u0430\u0433\u0440\u0443\u0437\u043a\u0430'; CPMP1 const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c MPPT1'; CPMP2 const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c MPPT2'; CPMP3 const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c MPPT3'; CEDAY const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0437\u0430 \u0434\u0435\u043d\u044c'; CEMP1 const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 MPPT1'; CEMP2 const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 MPPT2'; CEMP3 const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 MPPT3'; CETOB const varchar2(30) := '\u041d\u0430 \u0437\u0430\u0440\u044f\u0434 \u0431\u0430\u0442\u0430\u0440\u0435\u0438'; CEFRB const varchar2(30) := '\u0412\u0437\u044f\u0442\u043e \u043e\u0442 \u0431\u0430\u0442\u0430\u0440\u0435\u0438'; CEFRN const varchar2(30) := '\u0412\u0437\u044f\u0442\u043e \u043e\u0442 \u0441\u0435\u0442\u0438'; CUNET const varchar2(30) := '\u041d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u0441\u0435\u0442\u0438'; CUOUT const varchar2(30) := '\u041d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u0432\u044b\u0445\u043e\u0434'; CUACB const varchar2(30) := '\u041d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u0410\u041a\u0411';  public function TsToUTs(v_Ts in timestamp) return number is \tv_Dt date; begin \tv_Dt := v_ts; \treturn trunc((v_Dt - to_date('01.01.1970','DD.MM.YYYY')) -- \u041a\u043e\u043b-\u0432\u043e \u0434\u043d\u0435\u0439 \u0441 1 \u044f\u043d\u0432 1970 \t * (24 * 60 * 60)) -- \u0422\u0435\u043f\u0435\u0440\u044c \u044d\u0442\u043e \u043a\u043e\u043b-\u0432\u043e \u0441\u0435\u043a\u0443\u043d\u0434 \t * 1000 -- \u0422\u0435\u043f\u0435\u0440\u044c \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434 \t + to_number(to_char(v_ts,'FF3')); -- \u0414\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434\u044b end;  procedure get_query(pInp in out nocopy JSON_OBJECT_T, pOut in out nocopy JSON_ARRAY_T) is \ttype rtflag is record ( \t\t\t fTp varchar2(30) \t\t\t,fOb json_object_t \t\t\t,fAr json_array_t \t\t); \ttype ttflag is table of rtflag index by string; \ttflag ttflag; \t \tvTmpOb json_object_t; \tvTmpAr json_array_t; \tvTmpId varchar2(30); \t \tvDBeg timestamp; \tvDEnd timestamp; \tvDDBeg date; \tvDDEnd date; \t \tnum_tz number; \tcurts number; \t \tfunction GetFlag(pFlagName in varchar2) return boolean is \tbegin \t\tif tflag.exists(pFlagName) then \t\t\treturn true; \t\telse \t\t\treturn false; \t\tend if;\t \tend;  \t--function GetFlagType(pFlagName in varchar2) return varchar2 is \t--begin \t--\tif tflag.exists(pFlagName) then \t--\t\treturn tflag(pFlagName).fTp; \t--\telse \t--\t\tpragma error('\u041d\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f ['||pFlagName||'] \u0432 \u043c\u0432\u0441\u0441\u0438\u0432\u0435 tflag'); \t--\tend if;\t \t--end;  \tprocedure AddTrgData(pTrgName in varchar2, pStamp in number, pValue in number) is \tbegin \t\tvTmpAr := Json_Array_t; \t\tvTmpAr.append(pValue); \t\tvTmpAr.append(pStamp); \t\ttFlag(pTrgName).fAr.append(vTmpAr); \tend; begin \t&amp;debug('pInp='||pInp.to_string()) \t \tvTmpOb := pInp.get_Object('range'); \tnum_tz := to_number(::[GA_MAP_STAT].[LIB].GetSetting('MALINA_TIME_ZONE')); \t \tvDBeg := vTmpOb.get_Timestamp('from') + numtodsinterval(num_tz,'hour'); \tvDEnd := vTmpOb.get_Timestamp('to')   + numtodsinterval(num_tz,'hour'); \tvDDBeg := to_date(to_char(vDBeg,'dd.mm.yyyy hh24:mi:ss'),'dd.mm.yyyy hh24:mi:ss'); \tvDDEnd := to_date(to_char(vDEnd,'dd.mm.yyyy hh24:mi:ss'),'dd.mm.yyyy hh24:mi:ss'); \t \t&amp;debug('vDBeg='||to_char(vDBeg,'dd.mm.yyyy hh24:mi:ss:ff')) \t&amp;debug('vDEnd='||to_char(vDEnd,'dd.mm.yyyy hh24:mi:ss:ff'))  \tvTmpAr := pInp.get_Array('targets'); \tfor i in 0 .. vTmpAr.get_size - 1 loop \t\tvTmpOb := JSON_OBJECT_T(vTmpAr.get(i)); \t\tvTmpId := vTmpOb.get_string('target'); \t\ttflag(vTmpId).fTp := vTmpOb.get_string('type'); \t\ttflag(vTmpId).fOb := Json_object_t; \t\ttflag(vTmpId).fAr := Json_array_t; \t\ttflag(vTmpId).fOb.put('target',vTmpId); \tend loop; \t\t \t-- \u0412\u0437\u044f\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043c\u043e\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0438\u0437 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u041c\u0410\u041f \tif GetFlag(CPALL) or GetFlag(CPNET) or GetFlag(CPACB) or GetFlag(CPI2C) or GetFlag(CUNET) or GetFlag(CUOUT) or GetFlag(CUACB) then \t\tfor (select x(x.[QTIME]:qtime \t\t\t, x.[F__PNET_CALC]:pnet -- \u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0441\u0435\u0442\u044c \t\t\t, - x.[F__PLOAD_CALC] + x.[F__PNET_CALC]:pall -- \u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0433\u0440. \t\t\t, - x.[F__PLOAD_CALC]:pacb -- \u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0410\u041a\u0411 \t\t\t, x.[F__P_MPPT_AVG]:pi2c -- \u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c I2C \t\t\t, x.[F__UNET]:unet \t\t\t, x.[F__UOUTMED]:uout \t\t\t, x.[F__UACC]:uacb \t\t\t) in ::[GA_MAP_STAT] all \t\twhere x.[QTIME] &gt;= vDBeg and x.[QTIME] &lt;= vDEnd \t\torder by x.[QTIME] \t\t) loop \t\t\tcurts := TsToUTs(x.qtime - numtodsinterval(num_tz,'hour')); \t\t\t \t\t\tvTmpId := tflag.first; \t\t\twhile vTmpId is not null loop \t\t\t\tcase vTmpId of \t\t\t\t:CPALL: AddTrgData(vTmpId,curts,x.pall); \t\t\t\t:CPNET: AddTrgData(vTmpId,curts,x.pnet); \t\t\t\t:CPACB: AddTrgData(vTmpId,curts,x.pacb); \t\t\t\t:CPI2C: AddTrgData(vTmpId,curts,x.pi2c); \t\t\t\t:CUNET: AddTrgData(vTmpId,curts,x.unet); \t\t\t\t:CUOUT: AddTrgData(vTmpId,curts,x.uout); \t\t\t\t:CUACB: AddTrgData(vTmpId,curts,x.uacb); \t\t\t\tend; \t\t\t\tvTmpId := tflag.next(vTmpId); \t\t\tend loop; \t\tend loop; \tend if;  \t-- \u0412\u0437\u044f\u0442\u044c \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0443 \u043f\u0430\u043d\u0435\u043b\u0435\u0439 \tif GetFlag(CPMP1) or GetFlag(CPMP2) or GetFlag(CPMP3) then \t\tfor (select x(x.[QTIME]:qtime \t\t\t\t,x.[F_UID]:fuid \t\t\t\t,x.[F_P_CURR]:fpower -- \u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0437\u0430\u0440\u044f\u0434\u0430 \t\t\t) in ::[GA_MPPT_STAT] all \t\twhere x.[QTIME] &gt;= vDBeg and x.[QTIME] &lt;= vDEnd \t\torder by x.[QTIME], x.[F_UID] \t\t) loop \t\t\tcurts := TsToUTs(x.qtime - numtodsinterval(num_tz,'hour')); \t\t\tcase x.fuid of \t\t\t\t:1: if GetFlag(CPMP1) then AddTrgData(CPMP1,curts,x.fpower); end if; \t\t\t\t:2: if GetFlag(CPMP2) then AddTrgData(CPMP2,curts,x.fpower); end if; \t\t\t\t:3: if GetFlag(CPMP3) then AddTrgData(CPMP3,curts,x.fpower); end if; \t\t\tend; \t\tend loop; \tend if;  \t-- \u0412\u0437\u044f\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043c\u043e\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0438\u0437 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u0434\u043e\u043f\u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \tif GetFlag(CPADD) then \t\tdeclare \t\t\ttqend timestamp; \t\t\tpaend number; \t\tbegin \t\t\tfor (select x( \t\t\t\t  x.[QTIME]:qtime \t\t\t\t, x.[FPOWER]:padd -- \u0414\u043e\u043f. \u041d\u0430\u0433\u0440\u0443\u0437\u043a\u0430 \t\t\t\t) in ::[GA_LOAD_H] all \t\t\t\twhere x.[QTIME] &gt;= ( \t\t\t\t\tselect x(nvl(max(x.[QTIME]),to_timestamp('01.01.1970','dd.mm.yyyy'))) \t\t\t\t\tin ::[GA_LOAD_H] all \t\t\t\t\twhere x.[QTIME] &lt; vDBeg \t\t\t\t\t) \t\t\t\tand x.[QTIME] &lt; vDEnd \t\t\t\torder by x.[QTIME] \t\t\t) loop \t\t\t\tcurts := TsToUTs(x.qtime - numtodsinterval(num_tz,'hour')); \t\t\t\ttqend := x.qtime; \t\t\t\tpaend := x.padd; \t\t\t\tAddTrgData(CPADD,curts,x.padd); \t\t\tend loop; \t\t\tcurts := TsToUTs(vDEnd - numtodsinterval(num_tz,'hour')); \t\t\tAddTrgData(CPADD,curts,paend); \t\tend; \tend if;  \t-- \u0412\u0437\u044f\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043f\u043e \u0434\u0430\u0442\u0430\u043c \tif GetFlag(CEDAY) or GetFlag(CEMP1) or GetFlag(CEMP2) or GetFlag(CEMP3) or GetFlag(CEFRN) then \t\tdeclare \t\t\tvDEBeg date; \t\t\tvDEEnd date; \t\t\tvDECur date; \t\t\tcurEn number; \t\t\tprven number; \t\t\tvTSCur timestamp; \t\t\tcurEnToBat number; \t\t\tcurEnFromBat number; \t\t\tprocedure GetCeMp(vCeMp in varchar2, vMpUID in number) is \t\t\tbegin \t\t\t\tvDECur := vDEBeg; \t\t\t\twhile vDECur &lt;= vDEEnd loop \t\t\t\t\tvTSCur := to_timestamp(to_char(vDECur,'dd.mm.yyyy'),'dd.mm.yyyy');  \t\t\t\t\tselect x(nvl(max(x.[F_PWR_KW]),0)*1000) in ::[GA_MPPT_STAT] all \t\t\t\t\t\twhere x.[qtime] &gt;= vTSCur \t\t\t\t\t\tand x.[qtime] &lt; (vTSCur + numtodsinterval(1,'day')) \t\t\t\t\t\tand x.[F_TIMESTAMP] &gt;= vDECur \t\t\t\t\t\tand x.[F_TIMESTAMP] &lt; (vDECur+1) \t\t\t\t\t\tand x.[F_UID] = vMpUID \t\t\t\t\t\tinto curEn; \t\t\t\t\t \t\t\t\t\tcurts := TsToUTs(vTsCur - numtodsinterval(num_tz,'hour')); \t\t\t\t\tAddTrgData(vCeMp,curts,curen); \t\t\t\t\tvDECur := vDECur + 1; \t\t\t\tend loop; \t\t\tend; \t\tbegin \t\t\tvDEBeg := trunc(vDDBeg); \t\t\tvDEEnd := trunc(vDDEnd); \t\t\t \t\t\tif GetFlag(CEDAY) or GetFlag(CETOB) or GetFlag(CEFRB) then \t\t\t\tvDECur := vDEBeg; \t\t\t\twhile vDECur &lt;= vDEEnd loop \t\t\t\t\tvTSCur := to_timestamp(to_char(vDECur,'dd.mm.yyyy'),'dd.mm.yyyy'); \t\t\t\t\tselect x( \t\t\t\t\t\t nvl(max(x.[S1].[F_MPPT_DAY_E]),0) \t\t\t\t\t\t,nvl(max(x.[S1].[F_ESUM_TO_BAT]),0) \t\t\t\t\t\t,nvl(max(x.[S1].[F_ESUM_FROM_BAT]),0) \t\t\t\t\t) in ::[GA_BAT_STAT] all \t\t\t\t\t\twhere x.[qtime] &gt;= vTSCur \t\t\t\t\t\tand x.[qtime] &lt; (vTSCur + numtodsinterval(1,'day')) \t\t\t\t\t\tand x.[S1].[F_TIMESTAMP] &gt;= vDECur \t\t\t\t\t\tand x.[S1].[F_TIMESTAMP] &lt; (vDECur+1) \t\t\t\t\t\tinto curEn,curEnToBat,curEnFromBat; \t\t\t\t\tcurts := TsToUTs(vTsCur - numtodsinterval(num_tz,'hour')); \t\t\t\t\t \t\t\t\t\tif GetFlag(CEDAY) then AddTrgData(CEDAY,curts,curen); end if; \t\t\t\t\tif GetFlag(CETOB) then AddTrgData(CETOB,curts,curenToBat); end if; \t\t\t\t\tif GetFlag(CEFRB) then AddTrgData(CEFRB,curts,curenFromBat); end if;  \t\t\t\t\tvDECur := vDECur + 1; \t\t\t\tend loop; \t\t\tend if; \t\t\t \t\t\tif GetFlag(CEMP1) then \t\t\t\tGetCeMp(CEMP1,1); \t\t\tend if; \t\t\tif GetFlag(CEMP2) then \t\t\t\tGetCeMp(CEMP2,2); \t\t\tend if; \t\t\tif GetFlag(CEMP3) then \t\t\t\tGetCeMp(CEMP3,3); \t\t\tend if;  \t\t\t-- \u041f\u043e\u0441\u0447\u0438\u0442\u0430\u0442\u044c \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0437\u044f\u0442\u043e \u043e\u0442 \u0441\u0435\u0442\u0438 \t\t\tif GetFlag(CEFRN) then \t\t\t\tvDECur := vDEBeg-1; \t\t\t\tprven := null; \t\t\t\twhile vDECur &lt;= vDEEnd loop \t\t\t\t\tvTSCur := to_timestamp(to_char(vDECur,'dd.mm.yyyy'),'dd.mm.yyyy');  \t\t\t\t\tcuren := 0; \t\t\t\t\tfor ( \t\t\t\t\t\tselect x(x.[F__E_NET_B]*10:enet) \t\t\t\t\t\t\tin ::[GA_MAP_STAT] all \t\t\t\t\t\t\twhere x.[qtime] &gt;= vTSCur \t\t\t\t\t\t\tand x.[qtime] &lt; (vTSCur + numtodsinterval(1,'day')) \t\t\t\t\t\t\tand x.[F_TIMESTAMP] &gt;= vDECur \t\t\t\t\t\t\tand x.[F_TIMESTAMP] &lt; (vDECur+1) \t\t\t\t\t\t\torder by x.[qtime] desc \t\t\t\t\t) loop \t\t\t\t\t\tcuren := x.enet; \t\t\t\t\t\texit; \t\t\t\t\tend loop;\t \t\t\t\t\t \t\t\t\t\tif curen = 0 and prven != 0 then \t\t\t\t\t\tcuren := prven; \t\t\t\t\tend if;\t \t\t\t\t\t \t\t\t\t\tif prven is null then \t\t\t\t\t\tprven := curen; \t\t\t\t\telse\t \t\t\t\t\t\tif prven = 0 then \t\t\t\t\t\t\tprven := curen; \t\t\t\t\t\tend if; \t\t\t\t\t\tcurts := TsToUTs(vTsCur - numtodsinterval(num_tz,'hour'));  \t\t\t\t\t&amp;debug('1. dcur = '||to_char(vDECur,'dd.mm.yyyy')||' prven = '||prven||' curen ='||curen||' diff='||to_char(curen - prven)\t)   \t\t\t\t\t\tAddTrgData(CEFRN,curts,curen - prven); \t\t\t\t\t\tprven := curen; \t\t\t\t\tend if;\t \t\t\t\t\t \t\t\t\t\tvDECur := vDECur + 1; \t\t\t\tend loop; \t\t\tend if;  \t\t\t\t\t\t \t\tend; \tend if;  \t-- \u0412\u044b\u0433\u0440\u0443\u0437\u0438\u0442\u044c \u0441\u043e\u0431\u0440\u0430\u043d\u043d\u044b\u0435 \u043c\u0430\u0441\u0441\u0438\u0432\u044b  \u043e\u0442\u0432\u0435\u0442 \tvTmpId := tflag.first; \twhile vTmpId is not null loop \t\ttflag(vTmpId).fOb.put('datapoints',tflag(vTmpId).fAr); \t\ttflag(vTmpId).fAr := null; \t\tpOut.append(tflag(vTmpId).fOb); \t\ttflag(vTmpId).fOb := null; \t\tvTmpId := tflag.next(vTmpId); \tend loop; end;\t  procedure get_search(pInp in out nocopy JSON_OBJECT_T, pOut in out nocopy JSON_ARRAY_T) is \tvTarget varchar2(100); begin \t&amp;debug('pInp='||pInp.to_string()) \tvTarget := trim(pInp.get_String('target')); \tif vTarget is null then \t\tpOut.Append(CPALL); \t\tpOut.Append(CPNET); \t\tpOut.Append(CPACB); \t\tpOut.Append(CPI2C); \t\tpOut.Append(CPADD); \t\tpOut.Append(CPMP1); \t\tpOut.Append(CPMP2); \t\tpOut.Append(CPMP3); \t\tpOut.Append(CEDAY); \t\tpOut.Append(CEMP1); \t\tpOut.Append(CEMP2); \t\tpOut.Append(CEMP3); \t\tpOut.Append(CETOB); \t\tpOut.Append(CEFRB); \t\tpOut.Append(CEFRN); \t\tpOut.Append(CUNET); \t\tpOut.Append(CUOUT); \t\tpOut.Append(CUACB); \tend if;\t end;\t  public procedure GetJson(pPathInfo in varchar2, pInpPost in blob, pOutPost out blob) is \tvInp JSON_OBJECT_T; \tvOut JSON_ARRAY_T; begin \tvInp := JSON_OBJECT_T(pInpPost); \tvOut := JSON_ARRAY_T();  \t&amp;debug('pPathInfo='||pPathInfo) \t-- \u041c\u0430\u0440\u0448\u0440\u0443\u0442\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 pPathInfo \tif pPathInfo = '\/search' then \t\tget_search(vInp, vOut); \telsif pPathInfo = '\/query' then \t\tget_query(vInp, vOut); \tend if; \t \tpOutPost := vOut.to_Blob; end;  <\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p>\u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u044d\u0442\u043e \u043a\u043e\u043c\u0443-\u0442\u043e \u043e\u043a\u0430\u0436\u0435\u0442\u0441\u044f \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u043c \ud83d\ude42<\/p>\n<p>\u0412\u043e\u0442 \u0442\u0430\u043a\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/8df\/a79\/995\/8dfa79995e77edc8117a0e1e69f8ff12.png\" width=\"1139\" height=\"564\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a6f\/0f0\/719\/a6f0f0719c2ee25c64a58d73b9a26d54.png\" width=\"1139\" height=\"564\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/14b\/a3b\/0b1\/14ba3b0b13c346828bccff1c464f199a.png\" width=\"1139\" height=\"959\"><figcaption><\/figcaption><\/figure>\n<\/p>\n<\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/536640\/\"> https:\/\/habr.com\/ru\/post\/536640\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<h2>\u0412\u0432\u043e\u0434\u043d\u044b\u0435. \u0417\u0430\u0447\u0435\u043c \u043c\u043d\u0435 \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u043d\u0443\u0436\u043d\u043e<\/h2>\n<p>\u041b\u0438\u0447\u043d\u043e \u043c\u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433 \u0434\u043e\u043c\u0430\u0448\u043d\u0435\u0439 \u0441\u043e\u043b\u043d\u0435\u0447\u043d\u043e\u0439 \u044d\u043b\u0435\u043a\u0442\u0440\u043e\u0441\u0442\u0430\u043d\u0446\u0438\u0438.<\/p>\n<p>\u041a\u0440\u0430\u0442\u043a\u043e \u043e \u043c\u0430\u0442\u0447\u0430\u0441\u0442\u0438 (\u0445\u043e\u0442\u044f \u044d\u0442\u043e\u0442 \u043f\u043e\u0441\u0442 \u043d\u0435 \u043f\u0440\u043e \u043d\u0435\u0451):<\/p>\n<ul>\n<li>\n<p>\u0418\u043d\u0432\u0435\u0440\u0442\u043e\u0440 \u041c\u0410\u041f \u042d\u043d\u0435\u0440\u0433\u0438\u044f \u0438 3 \u0441\u043e\u043b\u043d\u0435\u0447\u043d\u044b\u0445 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 \u0442\u043e\u0433\u043e \u0436\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044f.<\/p>\n<\/li>\n<li>\n<p>\u0412\u043d\u0443\u0442\u0440\u0438 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440\u0430 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d \u043c\u0438\u043a\u0440\u043e\u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440 (\u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u0435\u0433\u043e \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442 &#171;\u041c\u0430\u043b\u0438\u043d\u0430&#187;), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043a\u043e\u0435-\u0447\u0442\u043e \u0443\u043c\u0435\u0435\u0442 \u0432 \u043f\u043b\u0430\u043d\u0435 \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433\u0430, \u043d\u043e \u043d\u0435 \u0432\u0441\u0451 \u0447\u0442\u043e \u043c\u043d\u0435 \u043d\u0443\u0436\u043d\u043e, \u0438 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u043e. \u0426\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u043c\u0438\u043a\u0440\u043e\u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u0441\u043d\u0438\u043c\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441 com-\u043f\u043e\u0440\u0442\u043e\u0432 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440\u0430 \u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u043e\u0432 \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u0442 \u0438\u0445 \u043d\u0430\u0441\u0432\u043e\u0451\u043c http-\u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u0432 \u0432\u0438\u0434\u0435 Json. \u0414\u0430\u043d\u043d\u044b\u0435 \u0432\u0435\u0431-\u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043a\u0430\u0436\u0434\u0443\u044e \u0441\u0435\u043a\u0443\u043d\u0434\u0443. \u0422\u0430\u043a\u0436\u0435 \u0435\u0441\u0442\u044c \u0432\u0435\u0431-\u0441\u0435\u0440\u0432\u0438\u0441\u044b \u0434\u043b\u044f \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c\u0438 \u0432 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u044b \u0438 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440 \u0440\u0435\u043b\u0435<\/p>\n<\/li>\n<li>\n<p>\u041f\u0430\u0440\u043e\u0447\u043a\u0430 Ethernet-\u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432 SR-201 \u044d\u0442\u043e \u0442\u0430\u043a\u0438\u0435 \u043f\u043b\u0430\u0442\u044b \u0441 \u0440\u0435\u043b\u044e\u0445\u0430\u043c\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0434\u043b\u044f \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u043e\u0439 \u0438 \u043a\u043e\u0435-\u0447\u0435\u043c \u0435\u0449\u0435, \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u043e \u043f\u0440\u043e\u0442\u043e\u043a\u043e\u043b\u0443 tcp \u0438 udp.<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u043c\u0430\u0448\u043d\u0438\u0439 \u0441\u0435\u0440\u0432\u0435\u0440 \u043f\u043e\u0434 \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435\u043c Centos-8, \u043d\u0430 \u043d\u0451\u043c \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d Oracle (\u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f Express Edition \u0441\u043e \u0432\u0441\u0435\u043c\u0438 \u0441\u0432\u043e\u0438\u043c\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438, \u043d\u043e \u0434\u043b\u044f \u0434\u043e\u043c\u0430\u0448\u043d\u0435\u0433\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e) <\/p>\n<\/li>\n<li>\n<p>\u0412 \u043e\u0440\u0430\u043a\u043b\u0435 \u043a\u0440\u0443\u0442\u044f\u0442\u0441\u044f 2 JOBa (\u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u044d\u0442\u043e persistent \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043a\u0440\u0443\u0442\u044f\u0442 \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u044b\u0439 \u0446\u0438\u043a\u043b \u0438 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u0430\u044e\u0442\u0441\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0440\u0430\u0437 \u0432 \u043f\u043e\u043b\u0447\u0430\u0441\u0430):<\/p>\n<ol>\n<li>\n<p>\u0420\u0430\u0437 \u0432 \u0441\u0435\u043a\u0443\u043d\u0443 \u0441\u043d\u0438\u043c\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432 &#171;\u041c\u0430\u043b\u0438\u043d\u044b&#187;, \u0442\u0435\u043a\u0443\u0449\u0435\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0440\u0435\u043b\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432 SR-201 \u0438 \u043f\u0438\u0448\u0435\u0442 \u044d\u0442\u043e \u0432\u0441\u0451 \u0432 \u0411\u0414 Oracle. \u0421 \u041c\u0430\u043b\u0438\u043d\u044b \u0441\u043d\u0438\u043c\u0430\u0435\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043d\u0435\u0441\u043b\u043e\u0436\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 utl_http, \u0441 \u0440\u0435\u044e\u0445 &#8212; \u0447\u0435\u0440\u0435\u0437 utl_tcp. \u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u044d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0430, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0431\u0443\u0434\u0435\u043c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u0442\u044c<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u043f\u0435\u0440\u0435\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0443 \u0437\u0430 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u043a \u0432\u0440\u0435\u043c\u0435\u043d\u0438, \u0438 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0445 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432, \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u043e\u0439 \u0438 \u0435\u0449\u0435 \u043a\u043e\u0435-\u0447\u0435\u043c \u0447\u0435\u0440\u0435\u0437 SR-201 \u0438 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0440\u0435\u043b\u0435 \u0438\u043d\u0432\u0435\u0440\u0442\u043e\u0440\u0430 \u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u043e\u0432.<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<\/ul>\n<p>\u0412\u043e\u0442 \u044d\u0442\u043e \u0432\u0441\u0451 \u0445\u043e\u0437\u044f\u0439\u0441\u0442\u0432\u043e \u043c\u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u0442\u044c. \u041f\u0440\u0438\u0447\u0435\u043c \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u0442\u044c \u043d\u0435 \u0441\u043e\u0431\u044b\u0442\u0438\u044f (\u0441\u043e\u0431\u044b\u0442\u0438\u044f\u043c\u0438 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442\u0441 Job2), \u0430 \u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0433\u0440\u0430\u0444\u0438\u043a\u0438 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438, \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u043d\u0430 \u043a\u043e\u043c\u043f\u0435 \u0438 \u043c\u043e\u0431\u0438\u043b\u043a\u0435. \u0421\u0430\u043c\u0430 &#171;\u041c\u0430\u043b\u0438\u043d\u0430&#187; \u043a\u043e\u0435-\u0447\u0442\u043e \u0443\u043c\u0435\u0435\u0442, \u043d\u043e \u0432\u043e-\u043f\u0435\u0440\u0432\u044b\u0445 \u043d\u0435 \u0432\u0441\u0451 (\u043f\u0440\u043e \u043c\u043e\u0438 SR-201 \u043e\u043d\u0430 \u0442\u043e\u0447\u043d\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0437\u043d\u0430\u0435\u0442), \u0432\u043e-\u0432\u0442\u043e\u0440\u044b\u0445 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 &#8212; \u043d\u0435\u043b\u044c\u0437\u044f \u0432\u0441\u0451 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u043e\u0434\u043d\u043e\u043c \u044d\u043a\u0440\u0430\u043d\u0435 \u0432 \u0443\u0434\u043e\u043c\u043d\u043e\u043c \u043c\u043d\u0435 \u0432\u0438\u0434\u0435, \u0430 \u0432 \u0442\u0440\u0435\u0442\u044c\u0438\u0445 &#8212; \u0432 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043c\u0435\u0441\u0442\u0430\u0445 \u043a\u0440\u0438\u0432\u043e\u0432\u0430\u0442\u043e.<\/p>\n<p>\u0412\u043e\u043f\u0440\u043e\u0441\u044b: \u041f\u043e\u0447\u0435\u043c\u0443 Oracle \u0430 \u043d\u0435 Postgres \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440? \u041d\u0443 \u043f\u0440\u043e\u0441\u0442\u043e \u043b\u0435\u043d\u044c, \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0438\u0437 \u0442\u043e\u0433\u043e \u0447\u0442\u043e \u0443\u043c\u0435\u044e&#8230; \ud83d\ude42<\/p>\n<p>\u0412\u044b\u0431\u043e\u0440 \u043f\u0430\u043b \u043d\u0430 Grafana https:\/\/grafana.com &#8212; \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043e\u0449\u043d\u043e\u0435 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u0438 \u043f\u0440\u043e\u0447\u0435\u0439 \u0435\u0440\u0443\u043d\u0434\u044b. \u041b\u0435\u0433\u043a\u043e \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u0442\u0441\u044f, \u0443\u0434\u043e\u0431\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c. \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441 \u043c\u043d\u043e\u0433\u0438\u043c\u0438 \u0411\u0414&#8230;<\/p>\n<h2>\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u0430<\/h2>\n<p>\u0414\u0430\u043d\u043d\u044b\u0439 \u043f\u043e\u0441\u0442 \u043d\u0438 \u0440\u0430\u0437\u0443 \u043d\u0435 \u043f\u0440\u0435\u0442\u0435\u043d\u0434\u0443\u0435\u0442 \u043d\u0430 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0448\u0430\u0433\u043e\u0432\u044b\u0439 tutorial, \u044f \u043b\u0438\u0448\u044c \u0445\u043e\u0447\u0443 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u0443\u0442\u044c, \u043f\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u043c\u0443 \u0412\u0430\u043c \u0431\u0443\u0434\u0435\u0442 \u043b\u0435\u0433\u0447\u0435 \u0438\u0434\u0442\u0438.<\/p>\n<p>\u0418\u0442\u0430\u043a: <\/p>\n<p>\u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c grafana<\/p>\n<pre><code>$ sudo nano \/etc\/yum.repos.d\/grafana.repo [grafana] name=grafana baseurl=https:\/\/packages.grafana.com\/oss\/rpm repo_gpgcheck=1 enabled=1 gpgcheck=1 gpgkey=https:\/\/packages.grafana.com\/gpg.key sslverify=1 sslcacert=\/etc\/pki\/tls\/certs\/ca-bundle.crt<\/code><\/pre>\n<pre><code>dnf update dnf install grafana  systemctl daemon-reload systemctl enable --now grafana-server systemctl status grafana-server<\/code><\/pre>\n<p>Selinux \u0443 \u043c\u0435\u043d\u044f \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d, \u0444\u0430\u0439\u0440\u0432\u043e\u043b \u0442\u043e\u0436\u0435, \u0442\u0430\u043a \u0447\u0442\u043e \u0432 \u044d\u0442\u0438 \u043d\u044e\u0430\u043d\u0441\u044b \u0432\u0434\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0435 \u0431\u0443\u0434\u0443<\/p>\n<\/p>\n<p>\u0414\u0430\u043b\u0435\u0435 \u043e\u0434\u043d\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043a\u0430: Grafana \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0441 Oracle \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0443\u043c\u0435\u0435\u0442, \u043d\u043e \u0434\u0430\u043d\u043d\u0430\u044f \u043e\u043f\u0446\u0438\u044f (\u043f\u043b\u0430\u0433\u0438\u043d) \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0432 Enterprise \u0432\u0435\u0440\u0441\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u043e\u0442 24\u043a$ \u0438 \u044d\u0442\u043e \u0432 \u043c\u043e\u0438 \u043f\u043b\u0430\u043d\u044b \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u0442. \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u043f\u043b\u0430\u0433\u0438\u043d grafana-simple-json-datasource<\/p>\n<pre><code>grafana-cli plugins install grafana-simple-json-datasource systemctl restart grafana-server<\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u0433\u0440\u0430\u0444\u0430\u043d\u0430 \u0443 \u043d\u0430\u0441 \u0432 \u043e\u0440\u0430\u043a\u043b \u0445\u043e\u0434\u0438\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0435\u0442. \u041e\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0431\u0440\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441\u0430, \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u0435\u043b\u043e \u0437\u0430 \u043c\u0430\u043b\u044b\u043c &#8212; \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c.<\/p>\n<p>\u0412\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441 \u0431\u0443\u0434\u0435\u043c \u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0430 apache + php<\/p>\n<p>\u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0438 \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c:<\/p>\n<p>httpd, php \u0438 php-fpm (\u0443 \u043c\u0435\u043d\u044f php 7.2) \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d \u0438 \u0441\u043a\u043e\u043d\u0444\u0438\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u043d \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 freepbx \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0436\u0438\u0432\u0451\u0442 \u043d\u0430 \u0442\u043e\u043c \u0436\u0435 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \ud83d\ude42<\/p>\n<p>\u0414\u043b\u044f php \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 oci8 &#8212; \u0442\u0443\u0442 \u0435\u0441\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0434\u043b\u044f php 7.2 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c oci8 \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 pecl.<\/p>\n<p>\u0412 \u043e\u0431\u0449\u0435\u043c \u043f\u0443\u0442\u044c \u0442\u0430\u043a\u043e\u0439:<\/p>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439 remi, \u0438 \u043e\u0442\u0442\u0443\u0434\u0430:<\/p>\n<pre><code>dnf install php-pecl-oci8<\/code><\/pre>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c oci8 \u043a php<\/p>\n<p>\/etc\/hp.d\/20-oci8.ini<\/p>\n<p>\u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0440\u0430\u0441\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c 1 \u0441\u0442\u0440\u043e\u043a\u0443<\/p>\n<pre><code>extension=oci8.so<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u044d\u0442\u043e\u0442 oci8 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0447\u0435\u0442 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c\u0441\u044f, \u0442\u0443\u0442 \u043f\u043e\u043c\u043e\u0433\u0443\u0442 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a\u0438\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432 <\/p>\n<p>\/etc\/php-fpm.d\/www.conf<\/p>\n<pre><code>env[ORACLE_HOSTNAME] = myserver.localdomain env[ORACLE_UNQNAME] = mydb env[ORACLE_BASE] = \/u01\/app\/oracle env[ORACLE_HOME] = \/u01\/app\/oracle\/product\/18.4.0\/dbhome_1 env[ORA_INVENTORY] = \/u01\/app\/oraInventory env[ORACLE_SID] = mydb env[LD_LIBRARY_PATH] = \/u01\/app\/oracle\/product\/18.4.0\/dbhome_1\/lib:\/lib:\/usr\/lib env[NLS_LANG] = AMERICAN_CIS.UTF8 <\/code><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 php-\u0441\u043a\u0440\u0438\u043f\u0442\u0430 \u043d\u0430 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0435\u0440\u0435, oci8 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f<\/p>\n<p>\u0412\u044b\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u043c \u0441\u043a\u0440\u0438\u043f\u0442 \u043d\u0430 \u0432\u0435\u0431\u0441\u0435\u0440\u0432\u0435\u0440<\/p>\n<p>\/var\/www\/html\/gr\/gr.php<\/p>\n<pre><code>&lt;?php  header(\"Content-Type: application\/json;\");  $conn = oci_pconnect('www', 'www$password', 'mydb', 'AL32UTF8'); if (!$conn) {     $e = oci_error();     trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); }  \/\/ \u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u044f $stid = oci_parse($conn, 'begin  LGRAFANA.GetJson(:vPath, :vInp, :vOut); end;'); if (!$stid) {     $e = oci_error($conn);     trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); }  \/\/ \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0434\u0435\u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0440\u044b $vInp = oci_new_descriptor($conn, OCI_DTYPE_LOB); $vOut = oci_new_descriptor($conn, OCI_DTYPE_LOB);  \/\/ \u041f\u0440\u0438\u0432\u044f\u0436\u0435\u043c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 $vPath = $_SERVER[\"PATH_INFO\"]; $postdata = file_get_contents(\"php:\/\/input\"); $vInp-&gt;writeTemporary($postdata, OCI_TEMP_BLOB);  oci_bind_by_name($stid, \":vPath\", $vPath); oci_bind_by_name($stid, \":vInp\", $vInp, -1, OCI_B_BLOB); oci_bind_by_name($stid, \":vOut\", $vOut, -1, OCI_B_BLOB);  \/\/ \u0412\u044b\u043f\u043e\u043b\u043d\u0438\u043c \u043b\u043e\u0433\u0438\u043a\u0443 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 $r = oci_execute($stid); if (!$r) {     $e = oci_error($stid);     trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); }  echo $vOut-&gt;load();   $vInp -&gt;close(); $vOut -&gt;close();  oci_free_statement($stid);  oci_commit($conn); oci_close($conn); ?&gt;<\/code><\/pre>\n<p>\u0412\u0435\u0431\u0441\u0435\u0440\u0432\u0438\u0441 \u0433\u043e\u0442\u043e\u0432.<\/p>\n<p>\u0412 \u043d\u0430\u0448\u0435\u0439 \u0411\u0414 \u0435\u0441\u0442\u044c \u043f\u0430\u043a\u0435\u0442 LGRAFANA, \u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0430\u0440\u0443\u0436\u0443 \u0442\u043e\u0440\u0447\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u0430 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430<\/p>\n<pre><code>procedure GetJson(pPathInfo in varchar2, pInpPost in blob, pOutPost out blob);<\/code><\/pre>\n<p>\u043e\u043d\u0430 \u0438 \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c Json &#8212; \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043e\u0442 \u0433\u0440\u0430\u0444\u0430\u043d\u044b. \u042d\u0442\u0443 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443 \u0446\u0435\u043b\u0438\u043a\u043e\u043c \u043f\u0440\u0438\u0432\u0435\u0434\u0443 \u0447\u0443\u0442\u044c \u043d\u0438\u0436\u0435, \u0412\u044b \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u0442\u0435 \u0447\u0442\u043e \u044d\u0442\u043e \u043b\u0438\u0448\u044c \u043f\u0440\u0438\u043c\u0435\u0440 \u0434\u043b\u044f \u043c\u043e\u0435\u0439 \u044d\u043b\u0435\u043a\u0442\u0440\u043e\u0441\u0442\u0430\u043d\u0446\u0438\u0438, \u0430 \u0432 \u0446\u0435\u043b\u043e\u043c \u0444\u043e\u0440\u043c\u0430\u0442 Json \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432-\u043e\u0442\u0432\u0435\u0442\u043e\u0432 \u043e\u043f\u0438\u0441\u0430\u043d \u0442\u0443\u0442<\/p>\n<p>https:\/\/grafana.com\/grafana\/plugins\/grafana-simple-json-datasource<\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0432 \u0441\u0430\u043c\u043e\u0439 \u0433\u0440\u0430\u0444\u0430\u043d\u0435:<\/p>\n<p>Configuration &#8212; Data Sources &#8212; Add DataSource &#8212; Simple JSON<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u043c\u043e\u0436\u043d\u043e \u0438\u0434\u0442\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c DashBoard \u0438 \u043d\u0430\u043a\u0438\u0434\u044b\u0432\u0430\u0442\u044c \u0442\u0443\u0434\u0430 \u043f\u0430\u043d\u0435\u043b\u0438 \u0441 \u043d\u0443\u0436\u043d\u044b\u043c\u0438 \u0433\u0440\u0430\u0444\u0438\u043a\u0430\u043c\u0438<\/p>\n<p>&#8230; \u0415\u0441\u043b\u0438 \u0443 \u0412\u0430\u0441 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u0430\u043a\u0435\u0442\u0430 LGRAFANA \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f.<\/p>\n<p>\u0414\u0430 \u043a\u0441\u0442\u0430\u0442\u0438 \u043f\u0440\u043e \u043f\u0430\u043a\u0435\u0442. \u041e\u043d \u0443 \u043c\u0435\u043d\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043d \u043d\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0430 PL\/SQL, \u043d\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u0412\u044b \u0441\u043c\u043e\u0436\u0435\u0442\u0435 \u044d\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u043d\u0430\u0434\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u0441\u0432\u043e\u0451\u043c \u043f\u0430\u043a\u0435\u0442\u0435. \u042d\u0442\u043e \u043b\u0435\u0433\u043a\u043e \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043d\u0430 pl\/sql.<\/p>\n<p>\u0412\u043a\u0440\u0430\u0442\u0446\u0435 \u0442\u0430\u043a:<\/p>\n<ol>\n<li>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u043c\u0435\u0442\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0435\u0430\u0433\u0438\u0440\u0443\u0435\u0442 \u043d\u0430 pahinfo=\/search \u0438 \u043e\u0442\u0434\u0430\u0451\u0442 \u043c\u0430\u0441\u0441\u0438\u0432 \u0438\u043c\u0451\u043d \u043c\u0435\u0442\u0440\u0438\u043a \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0443\u043c\u0435\u0435\u043c \u0441\u0447\u0438\u0442\u0430\u0442\u044c<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u043c\u0435\u0442\u043e\u0434 \/query \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442 \u043c\u0430\u0441\u0441\u0438\u0432 \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u043e \u043d\u0443\u0436\u043d\u044b\u043c \u043c\u0435\u0442\u0440\u0438\u043a\u0430\u043c<\/p>\n<\/li>\n<\/ol>\n<details class=\"spoiler\">\n<summary>\u041f\u043e\u043b\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u043f\u0430\u043a\u0435\u0442\u0430<\/summary>\n<div class=\"spoiler__content\">\n<pre><code>pragma include([DEBUG_TRIGGER]::[MACRO_LIB]);  CPALL const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0433\u0440.'; CPNET const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0441\u0435\u0442\u044c'; CPACB const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c \u0410\u041a\u0411'; CPI2C const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c I2C'; CPADD const varchar2(30) := '\u0414\u043e\u043f. \u041d\u0430\u0433\u0440\u0443\u0437\u043a\u0430'; CPMP1 const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c MPPT1'; CPMP2 const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c MPPT2'; CPMP3 const varchar2(30) := '\u041c\u043e\u0449\u043d\u043e\u0441\u0442\u044c MPPT3'; CEDAY const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0437\u0430 \u0434\u0435\u043d\u044c'; CEMP1 const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 MPPT1'; CEMP2 const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 MPPT2'; CEMP3 const varchar2(30) := '\u0412\u044b\u0440\u0430\u0431\u043e\u0442\u043a\u0430 MPPT3'; CETOB const varchar2(30) := '\u041d\u0430 \u0437\u0430\u0440\u044f\u0434 \u0431\u0430\u0442\u0430\u0440\u0435\u0438'; CEFRB const varchar2(30) := '\u0412\u0437\u044f\u0442\u043e \u043e\u0442 \u0431\u0430\u0442\u0430\u0440\u0435\u0438'; CEFRN const varchar2(30) := '\u0412\u0437\u044f\u0442\u043e \u043e\u0442 \u0441\u0435\u0442\u0438'; CUNET const varchar2(30) := '\u041d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u0441\u0435\u0442\u0438'; CUOUT const varchar2(30) := '\u041d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u0432\u044b\u0445\u043e\u0434'; CUACB const varchar2(30) := '\u041d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u0410\u041a\u0411';  public function TsToUTs(v_Ts in timestamp) return number is \tv_Dt date; begin \tv_Dt := v_ts; \treturn trunc((v_Dt - to_date('01.01.1970','DD.MM.YYYY')) -- \u041a\u043e\u043b-\u0432\u043e \u0434\u043d\u0435\u0439 \u0441 1 \u044f\u043d\u0432 1970 \t * (24 * 60 * 60)) -- \u0422\u0435\u043f\u0435\u0440\u044c \u044d\u0442\u043e \u043a\u043e\u043b-\u0432\u043e \u0441\u0435\u043a\u0443\u043d\u0434 \t * 1000 -- \u0422\u0435\u043f\u0435\u0440\u044c \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434 \t + to_number(to_char(v_ts,'FF3')); -- \u0414\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434\u044b end;  procedure get_query(pInp in out nocopy JSON_OBJECT_T, pOut in out nocopy JSON_ARRAY_T) is \ttype rtflag is record ( \t\t\t fTp varchar2(30) \t\t\t,fOb json_object_t \t\t\t,fAr json_array_t \t\t); \ttype ttflag is table of rtflag index by string; \ttflag ttflag; \t \tvTmpOb json_object_t; \tvTmpAr json_array_t; \tvTmpId varchar2(30); \t \tvDBeg timestamp; \tvDEnd timestamp; \tvDDBeg date; \tvDDEnd date; \t \tnum_tz number; \tcurts number; \t \tfunction GetFlag(pFlagName in varchar2) return boolean is \tbegin \t\tif tflag.exists(pFlagName) then \t\t\treturn true; \t\telse \t\t\treturn false; \t\tend if;\t \tend;  \t--function GetFlagType(pFlagName in varchar2) return varchar2 is \t--begin \t--\tif tflag.exists(pFlagName) then \t--\t\treturn tflag(pFlagName).fTp; \t--\telse \t--\t\tpragma error('\u041d\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f ['||pFlagName||'] \u0432 \u043c\u0432\u0441\u0441\u0438\u0432\u0435 tflag'); \t--\tend if;\t \t--end;  \tprocedure AddTrgData(pTrgName in varchar2, pStamp in number, pValue in number) is \tbegin \t\tvTmpAr := Json_Array_t; \t\tvTmpAr.append(pValue); \t\tvTmpAr.append(pStamp); \t\ttFlag(pTrgName).fAr.append(vTmpAr); \tend; begin \t&amp;debug('pInp='||pInp.to_string()) \t \tvTmpOb := pInp.get_Object('range'); \tnum_tz := to_number(::[GA_MAP_STAT].[LIB].GetSetting('MALINA_TIME_ZONE')); \t \tvDBeg := vTmpOb.get_Timestamp('from') + numtodsinterval(num_tz,'hour'); \tvDEnd := vTmpOb.get_Timestamp('to')   + numtodsinterval(num_tz,'hour'); \tvDDBeg := to_date(to_char(vDBeg,'dd.mm.yyyy hh24:mi:ss'),'dd.mm.yyyy hh24:mi:ss'); \tvDDEnd := to_date(to_char(vDEnd,'dd.mm.yyyy hh24:mi:ss'),'dd.mm.yyyy hh24:mi:ss'); \t \t&amp;debug('vDBeg='||to_char(vDBeg,'dd.mm.yyyy hh24:mi:ss:ff')) \t&amp;debug('vDEnd='||to_char(vDEnd,'dd.mm.yyyy hh24:mi:ss:ff'))  \tvTmpAr := pInp.get_Array('targets'); \tfor i in 0 .. vTmpAr.get_size - 1 loop \t\tvTmpOb := JSON_OBJECT_T(vTmpAr.get(i)); \t\tvTmpId := vTmpOb.get_string('target'); \t\ttflag(vTmpId).fTp := vTmpOb.get_string('type'); \t\ttflag(vTmpId).fOb := Json_object_t; \t\ttflag(vTmpId).fAr := Json_array_t; \t\ttflag(vTmpId).fOb.put('target',vTmpId); \tend loop; \t\t \t-- \u0412\u0437\u044f\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043c\u043e\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0438\u0437 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u041c\u0410\u041f<\/code><\/pre>\n<\/div>\n<\/details>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-316146","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/316146","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=316146"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/316146\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=316146"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=316146"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=316146"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}