【socket】在Linux下socket温度上报–客户端

socket通信客户端

socket函数

int socket(int domain,int type,int protocol);

参数:
domain:指定发送通信的域
   可取值:AF_UNIX:本地主机通信,与IPC类似
            AF_INET:Internet地址IPV4协议
            AF_INET6:Internet地址IPV6协议
type:指定socket类型
      可取值:SOCK_STREAM(流套接字)SOCK_DGRAM(数据报套接字)、SOCK_RAW(原始套接字)
protocol:指定该套接字描述符上的一个特殊的协议,如TCP,UDP等,一般设为0,会自动选择type的类型对应的协议

补充:SOCK_STREAM(流套接字)应用TCP协议,提供顺序的,可靠的,基于字节流的双向链接
   SOCK_DGRAM(数据报套接字)应用UDP协议,无链接,不可靠,不固定
   SOCK_RAW(原始套接字)提供访问互联网协议和Internal Network Interfaces的权限,只有超级用户才可使用。
int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
功能:
服务器端连接指定计算机端口
参数
    sockfd: 客户端的socket()创建的描述字
    addr: 要连接的服务器的socket地址信息,这里面包含有服务器的IP地址和端口等信息
    addrlen: socket地址的长度

更多socket函数

代码实现

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include

int socket_init(char *ip, int serv_port);
int get_temperature(float *temp);
void signal_stop(int signum);
static inline void print_usage(char *progname);
int get_ipaddr(char *interface,char *ipaddr, int ipaddr_size);
int get_time(char *datime,int len);

static int g_sigstop = 0;

int main (int argc, char **argv)
{
    float                       temp;
    int                         sock_fd = -1;
    char                        buf[2048];
    int                         serv_port = 0;
    int                         daemon_run = 0;
    char                        *progname = NULL;
    char                        *sock_ip;
    int                         opt;
    struct sockaddr_in          serv_addr;
    char                        ipaddr[16];
    char                        *interface = "eth0";
    char                        datime[32];
    int                         rv;
    int                         log_fd;
    int                         s_time;
    char                        *hostname;
    struct hostent              *getname = NULL;

    struct option  long_options[]=
    {
        {"daemon",no_argument,NULL,'b'},
        {"port", required_argument,NULL,'p'},
        {"time", required_argument,NULL,'t'},
        {"ip", required_argument,NULL,'i'},
        {"help",no_argument,NULL,'h'},
        {NULL,0,NULL,0}
    };

    progname = basename(argv[0]);

    if(daemon(1,1)< 0)
    {
        printf("Program daemon() failure:%s\n",strerror(errno));
        return -1;
    }

    log_fd = open("t.log", O_CREAT|O_RDWR,0666);
    if(log_fd < 0)
    {
        printf("Failed to open file/create:%s\n",strerror(errno));
        return -1;
    }
    dup2(log_fd,STDOUT_FILENO);
    dup2(log_fd,STDERR_FILENO);

    while((opt = getopt_long(argc,argv,"bp:t:i:h",long_options,NULL))!= -1)
    {
        switch(opt)
        {
            case 'b':
                daemon_run = 1;
                break;
            case 'p':
                serv_port = atoi(optarg);
                break;
            case 't':
                    s_time = atoi(optarg);
                    break;
            case 'i':
                    hostname = optarg;
                    break;
            case 'h':
                    print_usage(progname);
                    return EXIT_SUCCESS;

            default:
                break;
        }
    }

    if(!serv_port || !hostname)
    {
        print_usage(progname);
        return -2;
    }

    getname = gethostbyname(hostname);
    if(getname == NULL)
    {
        printf("Get hostname failure : %s\n", strerror(h_errno));
        return 0;
    }

    sock_ip = inet_ntoa(*(struct in_addr *)getname->h_addr);
    if(sock_ip == NULL)
    {
        printf("Get ser_ip failure : %s\n", strerror(errno));

        return 0;
    }
    printf("sock_ip[%s]\n",sock_ip);

    signal(SIGUSR1, signal_stop);
    signal(SIGPIPE, signal_stop);

    memset(buf,0,sizeof(buf));
    while(!g_sigstop)
    {
        get_temperature(&temp);
        if(temp < 0)
        {
            printf("Failed to read temperature:%s\n",strerror(errno));
            return -1;
        }

        memset(ipaddr,0,sizeof(ipaddr));
        get_ipaddr(interface,ipaddr,sizeof(ipaddr));
        if(ipaddr < 0)
        {
            printf("Failed to obtain the ID:%s\n",strerror(errno));
            return -2;
        }

        get_time(datime,sizeof(datime));
        if(datime < 0)
        {
            printf("Time acquisition failure:%s\n",strerror(errno));
            return -3;
        }

        snprintf(buf,sizeof(buf),"%s/%s/%f",ipaddr,datime,temp);

        if(sock_fd<0)
        {
            sock_fd = socket(AF_INET,SOCK_STREAM,0);
            if(sock_fd<0)
            {
                printf("Failed to connect to server:%s\n",strerror(errno));
                return -2;
            }
            printf("Server successful!\n");

            memset(&serv_addr,0,sizeof(&serv_addr));
            serv_addr.sin_family = AF_INET;
            serv_addr.sin_port = htons(serv_port);
            inet_aton(sock_ip,&serv_addr.sin_addr);

            if(connect(sock_fd,(struct sockaddr*)&serv_addr,sizeof(serv_addr))<0)
            {
                printf("Server connection failure:%s\n",strerror(errno));
                return -2;
            }
            printf("Server[%d] connection successful!\n",serv_port);
        }

        if(sock_fd >= 0)
            {

                rv = write(sock_fd,buf,sizeof(buf));
                if(rv >= 0)
                {
                    printf("Send messege to server successfully!\n");
                }
                else
                {
                    printf("Send messege to server failure:%s\n",strerror(errno));
                    close(sock_fd);
                    sock_fd = -1;
                }
            }
        sleep(s_time);
    }
    close(sock_fd);
    return 0;
}

static inline void print_usage(char *progname)
{

    printf("-b[daemon] set progname running background\n");
    printf("-p[port] socket servr port address\n");
    printf("-t[time] How often are they monitored\n");
    printf("-i[ip] Monitor the Ip address of the server\n");
    printf("-p[help] display this heip information\n");

    printf("\n exampla:%s -b -p 3400 -i 127.0.0.1 -t 30s \n",progname);
    return ;
}

void signal_stop(int signum)
{
    if(SIGUSR1 == signum)
    {
        printf("SIGTERM signal detected\n");
        g_sigstop = 1;
    }
    else if(SIGPIPE == signum)
    {
        printf("SIGINT signal detected\n");
        g_sigstop = 1;
    }
}

int get_temperature(float *temp)
{
    int             file_fd = -1;
    char            buf[1024];
    char            *ptr = NULL;
    DIR             *dirp = NULL;
    struct dirent   *direntp = NULL;
    char            w1_path[64]= "/sys/bus/w1/devices/";
    char            chip_sn[64];
    int             found = 0;

    dirp = opendir(w1_path);
    if(!dirp)
    {
        printf("Failed to open folder:%s\n",strerror(errno));
        return -1;
    }

    while(NULL !=(direntp = readdir(dirp)))
    {
        if(strstr(direntp->d_name,"28-"))
        {
            strncpy(chip_sn,direntp->d_name,sizeof(chip_sn));
            found = -1;
        }
    }
    closedir(dirp);

    if(!found)
    {
        printf("can not find ds18b20 chipset\n");
        return -2;
    }

    strncat(w1_path,chip_sn,sizeof(w1_path)-strlen(w1_path));
    strncat(w1_path,"/w1_slave",sizeof(w1_path)-strlen(w1_path));

    if((file_fd = open(w1_path,O_RDONLY))<0)
    {
        printf("File opening failure:%s\n",strerror(errno));
        return -3;
    }

    memset(buf,0,sizeof(buf));
    if(read(file_fd,buf,sizeof(buf))<0)
    {
        printf("read data from fd=%d failure:%s\n",file_fd,strerror(errno));
        return -4;
    }

    ptr = strstr(buf,"t=");
    if(!ptr)
    {
        printf("t=string\n");
        return -5;
    }

    ptr+=2;
    *temp = atof(ptr)/1000;
    close(file_fd);
    return 0;
}

int get_ipaddr(char *interface,char *ipaddr, int ipaddr_size)
{
    char        buf[1024];
    char        *ptr;
    char        *ip_start;
    char        *ip_end;
    FILE        *fd;
    int         len;
    int         rv;

    if(!interface || !ipaddr || ipaddr_size <16)
    {
        printf("Invalid input argument\n");
    }

    memset(buf,0,sizeof(buf));

    snprintf(buf,sizeof(buf),"ifconfig %s",interface);

    fd = popen(buf,"r");
    if(!fd)
    {
        printf("popen() to extern command failure:%s\n",strerror(errno));
    }

    rv = -3;

    while(fgets(buf,sizeof(buf),fd))
    {
        if(strstr(buf,"netmask"))
        {
            ptr = strstr(buf,"inet");
            if(!ptr)
            {
                break;
            }
            ptr +=strlen("inet");

            while(isblank(*ptr))
                ptr++;
            ip_start = ptr;

            while(!isblank(*ptr))
                ptr++;
            ip_end = ptr;

            memset(ipaddr,0,sizeof(ipaddr));
            len = ip_end - ip_start;
            len = len > ipaddr_size ? ipaddr_size:len;

            memcpy(ipaddr,ip_start,len);

            rv = 0;
            break;
        }
    }
    pclose(fd);
    return rv ;

}

int get_time(char *datime,int len)
{
    time_t          t;
    struct tm       *p;

    time(&t);
    p = gmtime(&t);

    snprintf(datime, 32, "%d-%d-%d %d:%d:%d", 1900+p->tm_year,1+p->tm_mon, p->tm_mday, (p->tm_hour + 8), p->tm_min, p->tm_sec);
    return 0 ;
}

Original: https://www.cnblogs.com/Ye-Wei/p/16728598.html
Author: 西故黄鹤楼
Title: 【socket】在Linux下socket温度上报–客户端

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/606350/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • MySQL实现备份(1)

    完全备份和部分备份 冷备份、热备份、温备份 温备份适用于:myisam 热备份适用于:innodb 物理备份和逻辑备份 完全备份:备份所有数据 部分备份:只备份部分数据内容 两者第…

    Linux 2023年6月7日
    0146
  • Pycharm快捷键设置(鼠标滚动控制字体大小)

    一、pycharm字体放大的设置 File —> setting —> Keymap —>在搜寻框中输入:increase —> Increase Font…

    Linux 2023年6月8日
    0103
  • ASP.NET Core 2.2 : 二十二. 多样性的配置方式

    大多数应用都离不开配置,本章将介绍ASP.NET Core中常见的几种配置方式及系统内部实现的机制。(ASP.NET Core 系列目录) 说到配置,第一印象可能就是”…

    Linux 2023年6月7日
    0112
  • Dubbo + ZooKeeper

    16 Dubbo + ZooKeeper 16.1 Dubbo下载 GigHub下载地址: https://github.com/apache/dubbo-admin/tree/m…

    Linux 2023年6月14日
    084
  • LeetCode-349. 两个数组的交集

    题目来源 题目详情 给定两个数组 nums1 和 nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。 示例 1: 输入: n…

    Linux 2023年6月7日
    081
  • 聊聊客户档案模型的设计与管理

    可以简单,更需要复杂; 一、基础描述 围绕客户管理通常分为售前、售中、售后、三个核心阶段,即营销、销售、服务三个核心流程与策略,在之前的文章中有聊过CDP系统的设计,本篇从客户档案…

    Linux 2023年6月14日
    083
  • CentOS7内置Realtek网卡驱动r8169降级r8168

    前几天装了几台服务器测试,在使用的过程中发现,每次重启系统,登录界面会弹出网卡提示 “r8169 0000:02:00 eth0 Invalid ocp reg 177…

    Linux 2023年6月6日
    0115
  • 十六.大数据平台及组件安装部署

    Hadoop全分布部署 Hadoop集群验证 使用jps查看各个节点启动的进程情况 [hadoop@master ~]$ jps 2224 ResourceManager 2487…

    Linux 2023年6月8日
    0120
  • 回忆我的第一个软件项目

    2009年大学毕业我去了成都,一番面试后,入职武侯区磨子桥附近的一个小型创业公司。公司的主营业务是代理销售用友或者金蝶的ERP软件,创业团队都是川大毕业的。公司的办公条件很差,两间…

    Linux 2023年6月6日
    0110
  • 最新超详细Linux下LNMP环境搭建

    一、了解LNMP系统 当前两个主要应用的架构:LNMP和LAMP,都是指一组通常一起使用来运行动态网站或者服务器的自由软件名称。 LAMP的全称是:Linux + Apache +…

    Linux 2023年6月15日
    0144
  • centos7安装zabbix-agent客户端

    1.官方下载zabbix-agent安装包链接:wget https://cdn.zabbix.com/zabbix/binaries/stable/5.4/5.4.6/zabbi…

    Linux 2023年6月13日
    0124
  • linux学习相关资料整理

    Posted on2022-09-08 13:09 brad1208 阅读(20 ) 评论() 编辑 linux常用指令记录 Python3.9.9安装 supervisor安装与…

    Linux 2023年6月6日
    094
  • 【转】 一条 SQL 的执行过程详解

    MySQL 体系架构 – 连接池组件 1、负责与客户端的通信,是半双工模式,这就意味着某一固定时刻只能由客户端向服务器请求或者服务器向客户端发送数据,而不能同时进行。 …

    Linux 2023年6月13日
    0128
  • sql注入

    一.原理 SQL注入攻击指的是通过构建特殊的输入作为参数传入Web应用程序,而这些输入大都是SQL语法里的一些组合,通过执行SQL语句进而执行攻击者所要的操作,其主要原因是程序没有…

    Linux 2023年6月6日
    091
  • SpringBoot 2.1.9 整合 Redisson分布式锁

    官方参考文档 redisson-spring-boot-starter 官方文档 通过YAML文件配置单节点模式 一)、引入Redisson整合Spring Boot依赖 二)、通…

    Linux 2023年5月28日
    0104
  • windows系统如何查看端口被占用、杀进程

    查看系统当前所有的端口使用情况 命令:netstat -ano 查看特定端口是否被占用: netstat -ano |findstr “端口号” 查看到对应…

    Linux 2023年6月13日
    0107
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球