整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

CentOS 7环境下利用pgcluu生成动态报告(CGI)

、安装PostgreSQL

二、安装性能监控工具sysstat

yum -y install sysstat

三、安装Apache

# yum -y install httpd

# rpm -qa | grep httpd

四、安装pgcluu

pgClu是一个Perl程序,可用于对PostgreSQL群集和系统性能执行完全审计。它分为两个部分:一个是使用psql命令行实用程序和sysstat包中的sar获取PostgreSQL服务器上的统计信息的收集器;另一个是一个纯Perl绘图器,将生成所有HTML和图表输出。

1、安装依赖包

# yum install perl-ExtUtils-MakeMaker perl-CGI -y

2、安装pgcluu

# cd /software/

# wget -c https://github.com/darold/pgcluu/archive/refs/tags/v3.5.tar.gz -O pgcluu-v3.5.tar.gz

# mkdir -p /etc/apache2/conf-enabled/

# tar xzvf pgcluu-v3.5.tar.gz

# cd pgcluu-3.5/

# perl Makefile.PL

# make && make install

五、配置

# vi /etc/httpd/conf/httpd.conf

编辑为:

LoadModule cgid_module modules/mod_cgid.so

<Directory "/var/www/cgi-bin">

AllowOverride None

Options ExecCGI

Require all granted

Allow from all

</Directory>

AddHandler cgi-script .cgi

ScriptAlias /cgi-bin/ "/var/www/cgi-bin/"

加入pgcluu相关配置,转到项目根目录

# mkdir /var/www/html/pgcluu/

# cd /software/pgcluu-3.5

# cp -rf cgi-bin/rsc/ /var/www/html/pgcluu/

# cp cgi-bin/pgcluu.cgi /var/www/cgi-bin/

//修改文件权限

# chown -R apache: /var/www/html/pgcluu/

# chown -R postgres:apache /var/lib/pgcluu/data/

# chmod -R u=rwX,g=rsX,o= /var/lib/pgcluu/data/

vi /var/www/cgi-bin/pgcluu.cgi

将此行注释(否则会报错cgi-error):

no warnings 'redundant';

启动web服务

# systemctl enable httpd

# service httpd start

su - postgres

$ /usr/local/bin/pgcluu_collectd -D -i 60 --rotate-daily /var/lib/pgcluu/data

$ /usr/local/bin/pgcluu --cache /var/lib/pgcluu/data

如果报如下错误:

FATAL: can't read file /var/lib/pgcluu/data/2023/12/20/end-pg_stat_user_indexes.csv: No such file or directory

不用紧张,稍等一会儿就生成这个文件了。

$ crontab -e

加入下面内容:

*/5 * * * * /usr/local/bin/pgcluu --cache /var/lib/pgcluu/data


访问下面地址:

http://localhost/cgi-bin/pgcluu.cgi

如果发现信息不是很完整,稍等一会儿再查看就完整了。

备注:

如果pgcluu_collectd启动失败(/var/run/postgresql/pgcluu_collectd.pid文件不存在,ps也看不到pgcluu_collectd的进程),则可以尝试:

# mkdir -p /var/run/postgresql/

# chown postgres:postgres /var/run/postgresql/

# su - postgres

$ /usr/local/bin/pgcluu_collectd -D -i 60 --rotate-daily /var/lib/pgcluu/data

为了在系统重启后,pgcluu仍能收集PostgreSQL集群上的统计信息,可以把pgcluu_collectd放在自启动服务中:

# chmod a+x /etc/rc.d/rc.local

# vi /etc/rc.d/rc.local

添加如下内容:

# start to grab statistics on the PostgreSQL cluster

/bin/mkdir -p /var/run/postgresql/

/bin/chown postgres:postgres /var/run/postgresql/

/bin/su - postgres -c '/usr/local/bin/pgcluu_collectd -D -i 60 --rotate-daily /var/lib/pgcluu/data

家好,我是ZhengN。

上一篇实用 | 10分钟教你搭建一个嵌入式web服务器我们已经基于我们的开发板搭好了一个基于boa的web服务器。这一篇接着分享如何使用网页来点灯。

网页点灯的整个流程大致为:

从上到下,前面两部分我们就是我们上一篇做的实验,已经打通了。而第三部分就是本篇笔记的重点,我们要点灯,自然需要写一个程序来解析数据及进行点灯操作,即这里的CGI程序。

什么是CGI?

CGI即通用网关接口(Common Gateway Interface),是一个Web服务器主机提供信息服务的标准接口。通过CGI接口,Web服务器就能够获取客户端提交的信息,转交给服务器端的CGI程序进行处理,最后返回结果给客户端。

根据CGI标准,编写外部扩展应用程序,可以对客户端浏览器输入的数据进行处理,完成客户端与服务器的交互操作。CGI规范定义了Web服务器如何向扩展应用程序发送消息,在收到扩展应用程序的信息后又如何进行处理等内容。

一般情况下,服务器和CGI程序之间是通过标准输入输出来进行数据传递的,CGI程序中的标准输出stdout是经过重定义了的,它并没有在服务器上产生任何的输出内容,而是被重定向到客户浏览器。即我们的CGI程序是在我们的板子服务器里运行,但实际调用printf输出信息时并不会输出到我们的板子终端,而是输出到客户端浏览器。

CGI程序小例子

CGI程序可以使用多种语言来实现,这里我们选用我们比较熟悉的C语言来实现。先来看一个简单的示例:

test.c:

#include <stdio.h>

int main()
 {
    printf("Content-type: text/html\n\n") ;  // 这一句是必须的,设定输出到HTML
    printf("Hello CGI\n") ;
    return 0;
}

利用交叉编译工具,编译上述文件:

arm-linux-gnueabihf-gcc test.c -o test.cgi

把test.cgi程序传到开发板上的/www/cgi-bin目录

scp test.cgi root@192.168.1.8:/www/cgi-bin

修改权限;

chmod 777 test.cgi

浏览器进行访问:

http://192.168.1.8/www/cgi-bin/test.cgi

网页点灯

我们已经知道了CGI程序是什么了。下面我们来进行网页点灯。首先,需要说明的是,我们有两种方式来编写CGI程序。一种是借助环境变量来获取相关信息;另一种是使用CGIC库。

方法一:

对于CGI程序来说,它继承了系统的环境变量。CGI环境变量在CGI程序启动时初始化,在结束时销毁。当一个CGI程序不是被服务器调用时,它的环境变量几乎是系统环境变量的复制。当这个CGI程序被服务器调用时,它的环境变量就会多了以下关于服务器、客户端、CGI传输过程等项目。如:

方法二:

用C语言写CGI程序还可以有比较简单的方式,那就是我们可以借助使用第三方库CGIC(CGIC是一个功能比较强大的支持CGI开发的标准C库,并支持Linux, Unix 和Windows等多操作系统)来编写,省去了必须自己去遵循CGI规范来编码的痛苦。

CGIC库下载地址:

https://github.com/boutell/cgic

这里只是简单地介绍了两种方法。还不理解没关系,下面我们通过具体的实例来认识这两种方法。

首先,我们需要点灯,自然需要先设计一个简单的led.html网页。我们要通过网页控制开发板上的led,需要两条信息:led的序号及led的状态。在网上找到了现成的html代码,稍微修改一下就直接拿来用了(文末给出参考的博客)。

led.html:

<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />    
    <title>led control</title>
    </head>
    
    <body>
    <h1 align="center">基于ARM的web控制LED灯</h1>
        <!--新建一个表单,动作链接到开发板的/cgi-bin/led.cgi,采用的方法为GET-->   
        <form action="/cgi-bin/led.cgi" method="get">  
            <p align="center">Web端的led的控制测试</p>
            <p align="center">请输入需要控制的led <input type="text" name="led_num"/></p>
            <p align="center">请输入控制led的动作 <input type="text" name="led_state"/></p>
            <p align="center"><input type="submit" value="sure"/>        
                              <input type="reset" value="back"/>
            </p>
        </form>
    </body>
</html>

把led.html放到我们开发板上的/www/中,通过浏览器访问:

http://192.168.1.8/led.html

实际效果如:

下面我们编写我们的CGI程序。

方法一:借助环境变量来获取相关信息。

#include<stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/ioctl.h>
#include <linux/limits.h>
#include <errno.h>

int main(int argc, const char *argv[])
{
    int led_num,led_state;
    char *data;

    printf("Content-type: text/html;charset=utf-8\n\n");
    printf("<html>\n");
    printf("<head><title>cgi control led web</title></head>\n");
    printf("<body>\n");
    printf("<p>led is setted successful! you can watch the led's change</p>\n");
    printf("<p><a herf=led.html><button>get back</button></a></p>\n");
    printf("</body>\n");

    data = getenv("QUERY_STRING");   //getenv()读取环境变量的当前值的函数 

    if(sscanf(data, "led_num=%d&led_state=%d", &led_num, &led_state) != 2)
    {   //利用sscnaf()函数的特点将环境变量分别提取出led_num和led_state这两个值
        printf("<p>please input right"); 
        printf("</p>");
    } 
    printf("<p>led_num = %d,led_state =  %d</p>",  led_num,  led_state);
    if(led_num < 2 || led_num > 5) 
    { 
        printf("<p>Please input 2<=led_num<=5!"); 
        printf("</p>");
    } 
    if(led_state>1)
    {
        printf("<p>Please input 0<=led_state<=1!"); 
        printf("</p>"); 
    }

    printf("</html>\n");

    return 0;
}

这里的getenv函数就是获取环境变量当前值的函数,其中,各环境变量的意义可以参考上面的表。这里的QUERY_STRING环境变量就是采用GET时所传输的信息。在这个例子中就是:

led_num=3&led_state=1

上面的CGI程序把收到网页发送过来的led_num及led_state的至再使用printf返回至网页中显示。从网页中也可以看到相关信息,整个流程也就打通了。

方法二:使用CGIC库。

第二种方法我们使用CGIC库来编写我们的CGI程序。首先我们需要下载CGIC库,下载地址如:

https://github.com/boutell/cgic

下载得到:

整个包的内容不多,就几个文件。其中:

  • cgic.c 函数库。
  • capture.c 一个很简单的CGI例子。仅仅输出两行提示文字。
  • cgictest.c 一个演示读取form表单数据的CGI例子。

因为我们的CGI程序要运行在我们的arm板中,当然要交叉编译,首先需要修改Makefile文件,需要修改如下几处内容:

第①个修改点:

CFLAGS=-g -Wall
CC=gcc
AR=ar
RANLIB=ranlib
LIBS=-L./ -lcgic

修改为:

CFLAGS=-g -Wall
CC=arm-linux-gnueabihf-gcc
AR=arm-linux-gnueabihf-ar
RANLIB=arm-linux-gnueabihf-ranlib
LIBS=-L./ -lcgic

第②个修改点:

gcc cgictest.o -o cgictest.cgi ${LIBS}

修改为:

arm-linux-gnueabihf-gcc cgictest.o -o cgictest.cgi ${LIBS}

第③个修改点:

gcc capture.o -o capture ${LIBS}

修改为:

arm-linux-gnueabihf-gcc cgictest.o -o cgictest.cgi ${LIBS} capture.o -o capture ${LIBS}

第④个修改点:

gcc -D UNIT_TEST=1 cgic.c -o cgicunittest

修改为:

arm-linux-gnueabihf-gcc -D UNIT_TEST=1 cgic.c -o cgicunittest

这里我的编译器是arm-linux-gnueabihf-gcc,大家需根据自己的实际环境进行修改。make编译得到cgictest.cgi及capture程序,大家可以自行传到板子上进行测试。下面我们在这个文件夹下新增一个led.c文件,用于编写我们的leg cgi程序:

// 微信公众号:嵌入式大杂烩
#include "cgic.h"

// cgic程序以cgiMain作为入口点, cgic的函数库会自动把cgiMain连接到相应的main()上去
int cgiMain() 
{ 
	char led_num[10];  
	char led_state[10]; 
	cgiFormString("led_num",  led_num, 10);    // 从表单中的led_num字段获取值存入到led_num
	cgiFormString("led_state",  led_state, 10);// 从表单中的led_state字段获取值存入到led_state
	cgiHeaderContentType("text/html");         // 设定输出的内容格式 这里我们要输出HTML
	fprintf(cgiOut,"<title>LED Test</title>");   
	fprintf(cgiOut,"<p>recv from arm:</p>");
	fprintf(cgiOut,"led_num: %s", led_num);
	fprintf(cgiOut,"<br>");                    
	fprintf(cgiOut,"led_state: %s", led_state);
	return 0;
}

修改Makefile,把我们的led.c也加入编译。编译得到led.cgi,传入到板子中的/www/cgi-bin文件夹下:

浏览器访问:

http://192.168.1.8/led.html

led cgi程序可以正确地解析led_num及led_state。有了这两个信息,我们就可以愉快地点灯了,这里没有加上点灯相关的操作,大家可以自己加上。

以上就是本次关于网页点灯的实战笔记,如有错误,欢迎指出,谢谢!

巨人肩膀:

1、https://blog.csdn.net/weixin_39148042/article/details/81252538

2、https://blog.csdn.net/yaomianfa/article/details/103575425

3、https://blog.csdn.net/kaloha3/article/details/8548027

4、https://www.cnblogs.com/lidabo/p/4736216.html

5、https://blog.csdn.net/qq_695538007/article/details/9153187

猜你喜欢:

实用 | 10分钟教你搭建一个嵌入式web服务器

实用 | 如何远程登录开发板?


1024G 嵌入式资源大放送!包括但不限于C/C++、单片机、Linux等。私信回复1024,即可免费获取!

于30000了


不知不觉,已经3w粉丝了,2020年8月8日到现在一共1年零6个月。

到目前为止,原创文章一共 194 篇,

文章头条阅读量基本在1000-3000,

也终于有了两篇文章阅读过万

此外: 头条号粉丝:1.3W 抖音粉丝: 1.4w csdn粉丝:2.1w

彭老师所有平台的账号都是一口Linux,

欢迎大家关注起来。

在这里感谢所有肯定和支持我的读者,

还有众多支持我的号主,

彭老师一直铭记于心,

人数实在太过众多,

在此就不一一感谢了。

对于很多很厉害的号主,这点粉丝量实在不值一提,

但是通过坚持换来这一点点的成绩,

还是多少有点欣慰的,

毕竟嵌入式是一个小众群体,

涉及到的又技术五花八门,

每一块知识点想搞得清清楚楚都要花费很多时间和精力。

也许写个十篇、二十篇没有问题,但是想持续输出上百篇高质量原创,

难度相当大。

无论如何,一口君会持续学习,持续写作,持续分享。

我写过的所有原创,汇总如下,并且已经做了分类,

建议大家收藏。

《彭老师所有原创》

我的gitee仓库

为了大家查找代码方便,我把之前写的一些文章用到的实例代码上传到了gitee,

https://gitee.com/yikoulinux

有需要的朋友可以直接下载学习,

名字也很好记,是我的公众号的拼音。

二、后续更文计划

之前所更新的文章,

主要以ARM、驱动为主,这两个方向实在太过小众,

后续的更文,会把重点放到基础编程知识、科普、职场为主,

穿插写一些底层的文章,

下面就简单说下今年的一些计划。

1. 视频计划

B站《从0学Linux驱动第一期》已经更新完毕,一共32期

地址如下:

https://space.bilibili.com/661326452/channel/collectiondetail?sid=84559


该套视频把Linux内核常见机制做了一个详细的梳理,

暂时没有把硬件操作加入进去,

只需要安装ubuntu即可学习,

非常适合有一定C基础的想入门和研究Linux内核的朋友。

通过B站认识了相当多的朋友,

从反馈来看,效果还算不错,

评论大家可以自己去查看。

《从0学ARM第一期》目前更新到23期,

https://space.bilibili.com/661326452/channel/collectiondetail?sid=71603


该套视频主要是讲解ARM指令、架构、异常、混合汇编等基础知识点,

该套视频是学习ARM裸机开发、Linux驱动必须的基础知识点,

预计第一期还会有6-10期视频。

后续计划,是录制完毕《从0学ARM第一期》,

然后录制**《从0学ARM第二期》《从0学Linux驱动第二期》**。

因为工作实在太忙,

估计全部录制完毕,可能要1年甚至更多的时间。

至于再往后的视频计划,最终是将嵌入式的所有入门视频全部录制完毕,

希望大家多多支持,各大平台如果推送了我的视频或者文章给大家,大家一定要点赞啊!

你们的支持是我坚持下去的动力。

2. 文章计划

后续彭老师仍然会一如既往的编写系列文章,

根据众多读者朋友的反馈,

目前初定两个方向:

  1. 《物联网综合实验》

该系列打算从最基础的画电路板、到备料、到贴片、到软件开发,

带着大家从0开始,来看一款简单电子产品前后到底是如何开发出来的。

其中软件部分可能涉及到的知识点: 传感器驱动、串口通信、多进程、进程间通信、多线程、socket、计算机网络、sqlite数据库、web server、CGI、html,也可能会涉及JAVA、QT、Android等知识。

一口君会把这个项目开发过程中用到的技术写成文章,分享给大家,

通过这个项目,可以让大家掌握嵌入式涉及到的绝大部分知识。

该项目比较适合初学者,还有一些想拓展自己知识面的老鸟。

  1. 网络方向

还记得很久之前写过几篇专利:

之前参与过的网络相关的项目还是挺多的,

设计的范围有应用层、协议栈支撑层、驱动层,链路层

平台有Linux、vxworks、ThreadX

但是写过的网络的文章其实很少,甚至有的粉丝怀疑是不是彭老师不懂网络,只懂驱动,

其实主要原因是做的越多,

越感觉网络技术博大精深, 越觉得自己比较无知,

还有就是一直没有找到一个很好的思路,

没有完全想好该如何把这浩如烟海的知识体系讲的通俗易懂。

再者就是网上关于网络的文章铺天盖地,

有的在整体性把握的很好,

有的在某个领域写的比较深入,

有的写的比较风趣幽默,

可以说各种风格的都有,

想写的有自己的特色比较困难。

网络知识软件部分主要包括以下几大块:

  1. 网络系统编程(socket)
  2. TCP/IP协议栈
  3. 网络组网
  4. 网卡驱动

这几大块知识点每一块都需要花费很多时间、写无数的代码来验证学习,

没有个几年功夫想精通还是有一定难度的。

后面一口君会不定期更新网络相关的文章,

文章会遵循一个主线,

并一如既往的坚持奶妈式写作风格,

附上各种操作截图、代码实例。

好了,暂时说这么多了,

希望各位老铁继续支持彭老师。

一起学习一起卷,

共同涨薪爽翻天;

熟读内核千百遍,

不破楼兰誓不还!