client  and  server Demo of socket.

client send data to server.

server send data to client.

// this is client

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define BUFF_SIZE 1024 int main(int argc, char* argv[])
{
if(argc<=)
{
printf("usage:%s ip_address port_number \r\n", basename(argv[]));
return ;
} char* ip = argv[];
int port = atoi(argv[]); struct sockaddr_in address;
bzero(&address, sizeof(address));
address.sin_family = AF_INET;
address.sin_port = htons(port);
inet_pton(AF_INET,ip, &address.sin_addr); int sockfd = socket(PF_INET, SOCK_STREAM, );
assert(sockfd>=); struct sockaddr_in client; int connfd = connect(sockfd, (struct sockaddr*)&address, sizeof(address));
if(connfd < )
{
printf("errno is : %d...connection failed.\r\n", errno );
}
else
{ printf("client:----send-----start\r\n");
char data1[] = "C2S:hello server..";
char data2[] = "C2S:I am client.";
char data3[] = "C2S:centos6 system.Bye-Bye";
send(sockfd, data1, strlen(data1)+, );
sleep();
send(sockfd, data2, strlen(data2)+, );
sleep();
send(sockfd, data3, strlen(data3)+, );
sleep();
printf("client:----send-----finish\r\n"); printf("client:----recv-----start\r\n");
char buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
int ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer);
printf("client:----recv-----finish\r\n"); //========================================== buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); close(connfd);
} printf("-----connect closed----\r\n"); close(sockfd); return ;
}

this is  server:

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define BUFF_SIZE 1024 int main(int argc, char* argv[])
{
if(argc<=)
{
printf("usage:%s ip_address port_number \r\n", basename(argv[]));
return ;
} char* ip = argv[];
int port = atoi(argv[]); struct sockaddr_in address;
bzero(&address, sizeof(address));
address.sin_family = AF_INET;
address.sin_port = htons(port);
inet_pton(AF_INET,ip, &address.sin_addr); int sockfd = socket(PF_INET, SOCK_STREAM, );
assert(sockfd>=); int ret = bind(sockfd,(struct sockaddr*)&address, sizeof(address));
assert(ret!=-); ret = listen(sockfd,);
assert(ret!=-); struct sockaddr_in client;
socklen_t client_addlength = sizeof(client);
int connfd = accept(sockfd, (struct sockaddr*)&client, &client_addlength);
if(connfd < )
{
printf("errno is : %d\r\n", errno );
}
else
{
printf("server:----recv-----start\r\n");
char buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
int ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer);
printf("server:----recv-----finish\r\n");
sleep(); printf("server:----send-----start\r\n");
char data1[] = "S2C:hello client..";
char data2[] = "S2C:I am server.";
char data3[] = "S2C:centos7 system.Bye-Bye";
send(connfd, data1, strlen(data1)+, ); sleep();
send(connfd, data2, strlen(data2)+, );
sleep();
send(connfd, data3, strlen(data3)+, );
sleep();
printf("server:----send-----finish\r\n"); //======================================== close(STDOUT_FILENO);
dup(connfd); //N messages , once recv.
printf("S2C:==dup==I am server.centos7.");
printf("S2C:==dup==Hello client...");
printf("S2C:==dup==bye-bye."); close(connfd);
} printf("server----------connection closed--------"); close(sockfd); return ;
}

Linux socket program Demo1(client & server)的更多相关文章

  1. AndroidAsync :异步Socket,http(client+server),websocket和socket.io的Android类库

    AndroidAsync是一个用于Android应用的异步Socket,http(client+server),websocket和socket.io的类库.基于NIO,没有线程.它使用java.ni ...

  2. Linux SocketCan client server demo hacking

    /*********************************************************************** * Linux SocketCan client se ...

  3. Client/Server 模型 与socket

    Client/Server 模型  Sockets 是以 Client 和 Server 交互通信方式来使用的.典型的系统配置是把 Server 放在一台机器中,而把 Client 放在另一台机器中, ...

  4. 深入浅出 Redis client/server交互流程

    综述 最近笔者阅读并研究redis源码,在redis客户端与服务器端交互这个内容点上,需要参考网上一些文章,但是遗憾的是发现大部分文章都断断续续的非系统性的,不能给读者此交互流程的整体把握.所以这里我 ...

  5. Network client/server

    <Beginning Linux Programming_4th>  chapter 15 Sockets 1  A simple local client/server 1)  clie ...

  6. linux socket高性能服务器处理框架

    这个博客很多东西 http://blog.csdn.net/luozhonghua2014/article/details/37041765   思考一种高性能的服务器处理框架 1.首先需要一个内存池 ...

  7. Linux socket编程 DNS查询IP地址

    本来是一次计算机网络的实验,但是还没有完全写好,DNS的响应请求报文的冗余信息太多了,不只有IP地址.所以这次的实验主要就是解析DNS报文.同时也需要正确的填充请求报文.如果代码有什么bug,欢迎指正 ...

  8. [Python]再学 socket 之非阻塞 Server

    再学 socket 之非阻塞 Server 本文是基于 python2.7 实现,运行于 Mac 系统下 本篇文章是上一篇初探 socket 的续集, 上一篇文章介绍了:如何建立起一个基本的 sock ...

  9. Linux Socket 编程简介

    在 TCP/IP 协议中,"IP地址 + TCP或UDP端口号" 可以唯一标识网络通讯中的一个进程,"IP地址+端口号" 就称为 socket.本文以一个简单的 ...

随机推荐

  1. openpyxl常用API

    worksheet.cell(self, row, column, value=None)描述:给指定位置的单元格赋值参数: row&column:必须参数,单元格的坐标 value:可选参数 ...

  2. MQ的深入理解

    MQ的深入理解 MQ的作用: 解耦合,降低系统与系统之间的频繁改动 MQ的特点: 复杂的系统解耦合 (主系统将数据放入mq,子系统需要的时候直接从mq中取出数据)复杂链路的异步调用(将必要的链路执行完 ...

  3. Jenkins—Master/Slave模式

    Jenkins可部署在windows或者linux平台上,项目系统的用户多数为windows系统.如果Jenkins部署在linux上,而自动化任务要在windows平台执行,那么就需要使用Jenki ...

  4. 【总结】《氨基酸新晋管理者领导力培训》第一次课_Day2_学习心得

    7月26日第二天学习心得: 今天主要学习了执行贯彻和绩效反馈两大块内容,我的心得有: 一.执行层面有两大原则:--理解员工需求: 回顾了一下自己以往的经历,一般这块我用的最多的一般是在接到一个新项目的 ...

  5. Alpine Linux 安装 lxml Pillow 失败

    lixm 需要编译安装,因此需要先安装gcc g++ RUN apk add --update --no-cache g++ gcc libxslt-dev python3-dev openssl-d ...

  6. asp.net core web api 生成 swagger 文档

    asp.net core web api 生成 swagger 文档 Intro 在前后端分离的开发模式下,文档就显得比较重要,哪个接口要传哪些参数,如果一两个接口还好,口头上直接沟通好就可以了,如果 ...

  7. 123: The filename, directory name, or volume label syntax is incorrect今天玩nginx的时候报错

    今天在win下玩nginx的时候 提示500错误 看了下nginx的logs  提示 123: The filename, directory name, or volume label syntax ...

  8. Core源码(三) Lazy<T>

    Lazy<T>解决什么问题? 1.大对象加载 考虑下面的需求,有个对象很大,创建耗时,并且要在托管堆上分配一大块空间.我们当然希望,用到它的时候再去创建.也就是延迟加载,等到真正需要它的时 ...

  9. Flask笔记:上下文

    线程隔离Thread Local: 如果一个对象具有线程隔离的特性,就可以称之为“Thread Local”,线程隔离是指该对象在不同的线程中都是独立的,在一个线程中对该对象的操作不会影响另一个线程对 ...

  10. Linux性能分析——分析系统性能相关的命令

    Linux性能分析——分析系统性能相关的命令 摘要:本文主要学习了Linux系统中分析性能相关的命令. ps命令 ps命令用来显示系统中进程的运行情况,显示的是当前系统的快照. 基本语法 ps [选项 ...