波奇学Linux:网络套接字

2024-03-24 00:04
文章标签 linux 网络 接字 波奇学

本文主要是介绍波奇学Linux:网络套接字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

domain:ipv4 还是ipv6

type:面向字节流还是...

虚拟机

云服务器禁止直接bind公网ip

服务器可以有多个ip,如果只绑定一个ip,只能收到来自一个ip的信息

任意地址绑定

关于port的问题

[0,1024]:系统内定的端口号,一般要用固定的应用层协议,http:80 err string : Permission denied

网络通信时,顾客端通信往往要指定端口号,一般ip地址和端口号会被封装成网站的形式

UdpClient.cc

#include <iostream>
#include <cstdlib>
#include <unistd.h>
#include <strings.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>using namespace std;void Usage(std::string proc)
{std::cout << "\n\rUsage: " << proc << " serverip serverport\n"<< std::endl;
}
// int argc表参数数量, argv是参数内容
int main(int argc,char* argv[])
{if(argc!=3){Usage(argv[0]);exit(0);}// 获取目标ipstd::string serverip=argv[1];uint16_t serverport=std::stoi(argv[2]);struct sockaddr_in server;//将server的内容置空bzero(&server,sizeof(server));//套间字类型server.sin_family=AF_INET;//端口server.sin_port=htons(serverport);//ip地址server.sin_addr.s_addr=inet_addr(serverip.c_str());socklen_t len=sizeof(server);//SOCK_DGRAM 表示 udp ,AF_INET 表示网落通信// 像是创建网卡文件返回文件的描述符int sockfd=socket(AF_INET,SOCK_DGRAM,0);if(sockfd<0){cout<<"socker error"<<endl;return 1;}// client 也要绑定,有自己的ip和端口// 不需要自己绑定,让os自由随机选择//系统什么时候绑定的? 首次发送数据时string message;char buffer[1024];while(true){cout<<"Please Enter@";std::getline(cin,message);std::cout<<"client sent message: "<<message.c_str()<<std::endl;//从网卡文件中发送信息sendto(sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)&server, len);// 从网卡文件中获取信息struct sockaddr_in temp;socklen_t len = sizeof(temp);ssize_t s = recvfrom(sockfd, buffer, 1023, 0, (struct sockaddr*)&temp, &len);if(s > 0){buffer[s] = 0;cout << buffer << endl;}}close(sockfd);return 0;
}

udpServer.hpp

#pragma once
#include<iostream>
#include<sys/types.h>
#include<sys/socket.h>
#include<cstdlib>
#include<string.h>
#include<netinet/in.h>
#include<arpa/inet.h>
#include <functional>
#include<unistd.h>
// using func_t = std::function<std::string(const std::string&)>;
typedef std::function<std::string(const std::string&)> func_t;
uint16_t defaultport=8089;
std::string defaultip="0.0.0.0";
#define Size 1024
class UdpServer
{
public:UdpServer(const uint16_t &port=defaultport,const std::string &ip=defaultip):sockfd_(0),port_(port),ip_(ip),isrunning_(false){}void Init(){//创建网络文件sockfd_=socket(AF_INET,SOCK_DGRAM,0);if(sockfd_<0){printf("socket creaate error");exit(1);}// bind socket 绑定网络文件struct sockaddr_in local;bzero(&local,sizeof(local));local.sin_family=AF_INET;//表明网络类型local.sin_port=htons(port_); //端口号是来回发送的 htons保证端口号是网络字节序列->大端local.sin_addr.s_addr=inet_addr(ip_.c_str()); //string->uint32_t ip也是来回发送的 也要转为网络字节序列->大端int n=bind(sockfd_,(const struct sockaddr *)&local,sizeof(local));if(n<0){printf("bind error");}}void Run(func_t func){isrunning_=true;char inbuffer[Size];while(isrunning_){struct sockaddr_in client;socklen_t len=sizeof(client);//接收信息ssize_t n=recvfrom(sockfd_,inbuffer,sizeof(inbuffer)-1,0,(struct sockaddr*)&client,&len);if(n<0){printf("recvfrom error");}inbuffer[n]=0;std::cout<<"receive message: "<<inbuffer<<std::endl;std::string echo_string = inbuffer;// std::string echo_string = func(info);sendto(sockfd_,echo_string.c_str(),echo_string.size(),0,(const sockaddr*)&client,len);}}~UdpServer(){if(sockfd_>0) close(sockfd_);}
private:int sockfd_; //网络文件描述符uint16_t port_; //服务器端口号std::string ip_;bool isrunning_;
};

这篇关于波奇学Linux:网络套接字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/839928

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念