【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)

大家都在看

  • 回顾乐信集团工作经历

    2019年入职乐信用户增长部门,负责开发开放平台的需求和合作方技术支持。乐信金融开放平台提供了金融业务API以及配套SDK等组件,为合作商户的产品赋予分期支付和小额贷款能力,子系统…

    Linux 2023年6月6日
    0108
  • windows系统python3.6(Anaconda3)安装对应版本 torch、torchvision

    一、官网下载 .whl 文件 https://download.pytorch.org/whl/torch_stable.html 二、使用pip命令安装 打开你的anaconda…

    Linux 2023年6月14日
    098
  • docker安装rabbitmq

    安装镜像 docker pull rabbitmq:3.9-management-alpine 实例化容器 docker run -id –hostname rabbitmq -…

    Linux 2023年6月7日
    0124
  • Ceph创建一个新集群 报错: File “/usr/bin/ceph-deploy”, line 18, in……….

    [root@ceph-node1 ceph]# ceph-deploy new node1 Traceback (most recent call last): File &quo…

    Linux 2023年6月13日
    0110
  • 分布式系统架构理论与组件

    1.分布式系统的发展 在计算机发展的早期,一直都是集中式计算,计算能力依赖大型计算机。随着互联网的发展,繁重的业务需要巨大的计算能力才能完成,而集中式计算无法满足要求,大型计算机的…

    Linux 2023年6月6日
    0122
  • lambda跨账号调用elasticache redis调查结果

    1.本地lambda与被调用方的redis都要绑定一个VPC,至少设定一个子网和路由表,设定好安全组; 2.本地VPC创建对等连接,被调用方接受连接; 3.将各自的IPv4 CID…

    Linux 2023年5月28日
    087
  • supervisord 进程管理利器

    Supervisor概述 ​ supervisor是一个 Client/Server模式的系统,允许用户在类unix操作系统上监视和控制多个进程,或者可以说是多个程序。superv…

    Linux 2023年6月14日
    0131
  • @EnableFeignClients注解源码解析

    转载请注明出处: @EnableFeignClients 注解定义的源码 这个注解通过@Import注解导入一个配置类FeignClientsRegistrar.class ;Fe…

    Linux 2023年6月14日
    0118
  • java分布式(第四章)——Redis

    老套路 1、什么是Redis 2、为什么要用Redis 3、怎么用Redis 4、使用Redis过程中遇到的问题 1、什么是Redis 介绍Redis之前先了解一下Nosql(非关…

    Linux 2023年6月7日
    0102
  • 如何逃离框架孤井?

    前言 前面我发过一篇文章,脱离了Spring询问大家能不能继续开发,结果文章下面的评论和回复都告诉我大家伙的基础打得很牢固,该咋写还是咋写。看得我在这内卷的时代瞬间躺平。 那么今天…

    Linux 2023年6月13日
    0107
  • Ubuntu安装盘的制作

    准备工作 Ubuntu系统镜像 win32diskimager U盘(4G以上),对重要文件提前备份 制作 下载系统镜像 进入官网 我们下载的版本是18.04,不是20.04 在页…

    Linux 2023年6月14日
    0126
  • 多线程执行同一任务,不共享局部变量

    多线程执行同一任务,不共享局部变量 一、 代码展示 import threading import time 多线程执行同一任务时,局部变量是不共享的 def sum_num():…

    Linux 2023年6月14日
    0106
  • [转] OSDI, SOSP与美国著名计算机系的调查报告

    看到一个很久之前的文章,重新排版后转发一下,希望能带来一些帮助;文章有时效性,出现的数据多为历史数据。资源来源自网络,侵删。 序言 按照USnews的分类,Computer Sci…

    Linux 2023年6月13日
    0120
  • Linux Ubuntu 添加新用户

    1. 了解配置文件 Linux下与用户信息相关的配置文件有 /etc/passwd、 /etc/group、 /etc/shadow等,其权限分别如下: /etc/passwd:保…

    Linux 2023年5月27日
    0154
  • 实验一-密码引擎-商用密码算法实现2-交叉测试(选做)

    任务详情 把自己实现的商用密码算法SM2,SM3,SM4与OpenSSL交叉验证 自己实现的SM3算法的结果与OpenSSL的结果比对是否一致 自己实现的SM4算法加密的,Open…

    Linux 2023年6月8日
    0127
  • UE4在Windows下交叉编译打包Linux版本

    UE4在Windows下交叉编译打包Linux版本 我使用的是UE4.27.2,Windows 11,项目是一个 纯蓝图项目,所以打包过程没有什么阻碍。 首先上官网下载对应版本的工…

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