首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Linux高性能服务器编程》学习小结3

socket的ip4地址和端口号; 下面的每一个logical指定一个实际运行着的服务器,如前面小结1 2 中所述的多进程或者多线程服务器;三个字段分别指定:服务器的ip4地址,服务器服务端口,以及进程池中的进程与这个服务器保持多少个连接...bool m_srv_closed; }; 每个子进程与实际处理业务的服务器所保持的连接,都对应一个conn类,它负责维持客户端 同 子进程 以及 子进程 同 服务器之间的数据转发,子进程只做一个数据的搬运工...m_sub_process ); for( int i = 0; i < process_number; ++i ) { int ret = socketpair( PF_UNIX...= -1 ); int ret = socketpair( PF_UNIX, SOCK_STREAM, 0, sig_pipefd ); assert( ret !...最后感谢 游双 的《Linux高性能服务器编程

3.1K10

Linux高性能服务器编程》读书笔记:linux服务器程序规范

服务器程序规范,需要强化和遵守的,作者给列了4条规范: 1、Linux服务器程序一般以后台进程形式运行,也就是以daemon守护进程的方式,守护进程的父进程通常是init进程(PID进程为1),作者在7.6...后台进程形式运行,也就是通过fork一个子进程,结束父进程的方式运行,这样避免很多前台启动,随着操作终端界面的关闭而结束服务器程序的运行; Linux服务器程序的用户信息也是容易忽略和出问题的地方,UID...2、Linux服务器程序通常有一套日志系统,至少能输出日志到文件,有的高级服务器还能输出日志到专门的UDP服务器,大部分后台进程都在/var/log目录下拥有自己的日志目录。...,系统响应缓慢的事故; 3、Linux服务器程序通常是可配置的,通常能处理很多命令行选项,如果一次运行的选项太多,则可以用配置文件进行管理。...通过使用ulimit命令修改当前shell环境下的软限制或者硬限制,这种修改对该shell启动过的所有后续程序有效,也可以通过修改配置文件来改变系统软限制和硬限制,并且是永久的,比如ulimit: 修改Linux

1.1K20

UNIX环境编程

linux函数分析查询工具 1.优先推荐linux 中man命令 2.一个不错的中文Linux手册:http://cpp.ezbty.org/manpage 3.在线查英文Man手册: http://www.kernel.org.../doc/man-pages/ http://man7.org/linux/man-pages/dir_all_alphabetic.html http://linux.about.com/od/commands...man2 用来访问 UNIX 内核提供的服务的系统调用或函数。例如 fork 系统,它从一个现有的进程生成一个新进程。输入 man fork 显示它的手册页。使用系统软件的程序员常常参考这个部分。...UNIX 几乎完全使用文本配置文件定制系统的操作。有大量配置文件,包括网络服务的列表 (/etc/services) 和可用的 shell 列表 (/etc/shells) 等等。...Unix下的设备有“块设备”和“字符设备”的概念,所谓块设备,就是以一块一块的数据存取的设备,字符设备是一次存取一个字符的设备。磁盘、内存都是块设备,字符设备如键盘和串口。

1.3K20

shell编程入门_unix编程

1.Shell的概念 shell是一个命令行解释器,它为客户提供了一个Linux内核发送请求一边运行程序界面系统级程序,用汉语可以通过shell启动、挂起、停止甚至编写一些程序。...shell还是一个功能强大的编程语言,易于编辑,易于调试,灵活性强,shell是结识知识性的脚本语言,在我们shell中直接调用Linux的系统命令操作即可。 2....Shell的分类 (1)Bourne Shell(bshell) 从1979年在unix系统就开始使用了。...Linux中支持的shell (1)查看Linux中的shell脚本 4....Shell脚本的执行方式 (1)回显的命令:echo (2)在Linux的家目录下创建sh目录存放脚本语言 (3)在sh目录下写一个.sh类型的shell脚本语言hell.sh

1.3K10

开源软件实践之linux高性能服务器编程框架和选型

很多人学习编程技术一般都通过一本编程语言的入门书籍,然后尝试做一些例子和小项目。...我目前就正在做这样一件事情,我选择的是实现一个类似nginx的高性能http服务器。...说了这么多一点儿也没有和标题扯上关系,今天就是为我这个开源软件写的第一个博客,实现一个高性能的网络服务器的第一个就需要选择一个很好的高性能编程框架,今天就分析这个,这个也算自己开始前的准备,学习高性能服务器编程框架...:       网络服务器编程步骤就不需要多介绍了,有网络编程知识的都很清楚。...首先对网络服务器组成的基本软件模块做一个简单的说明,如下表: 服务器基本软件模块 模块 单机 集群 I/O处理单元 处理客户端连接,读写网络数据 作为介入服务器,实现负载均衡 逻辑单元 业务进程或者线程

1.5K50

Unix-Linux编程实践教程-chapter08-sh

第8章 进程和程序:编写命令解释器sh Unix通过将可执行代码装入进程并执行它来运行一个程序.进程是 一个程序所需的内存空间和其他资源的集合 每个运行中的程序在自己的进程中运行.每个进程都有一个唯一的...一个程序通过调用exec函数族在当前进程中执行一个新的程序 一个程序能通过调用wait来等待子进程的结束 调用程序能将一个字符串列表传给新程序的main函数.新的程序能通过 调用exit来回传一个8位长的值 Unix...execvp/exit call/return 这种通过参数和返回值在拥有私有数据的函数间通信的模式是结构化程序 设计的基础 全局变量和fork/exec 全局变量会破坏封装原则,但有时候去掉会更糟糕.Unix

98620

Unix-Linux编程实践教程-chapter13-udp

第13章 基于数据报(Datagram)的编程:编写许可证服务器 数据报是从一个socket发送到另一个socket的短消息.数据报socket是不连接的, 每个消息包含有目的地址.数据报(UDP)socket...许可证服务器是用来对被许可程序实施许可证验证规则的,许可证服务器发布许可, 以短消息的形式发送给客户....许可证服务器必须记住哪个进程使用了哪个票据,必须维持一个内部的数据库.因此, 许可证服务器不同于简单的服务器. 记录系统状态的服务器必须设计成可以处理服务器和客户端的崩溃事件....有些许可证服务器为一个网络上的多个机器提供服务.有几种设计方法,各有优缺点. socket可以有两种类型的地址:网络或者本地.本地的socket地址叫做Unix域socket 或名字socket.这种socket

33410

Unix-Linux编程实践教程-chapter11-socket

第11章 连接到近端或远端的进程:服务器与Socket(套接字) 一些程序被作为单独的进程建立起来来接受和发送数据.在客户/服务器模型中, 服务器进程为客户进程提供处理或数据服务 客户/服务器系统包含通信系统和协议...的连接使用文件描述符.文件描述符为程序提供了与文件,设备和 其他的进程通信的统一编程接口 Unix中的计算器:bc bc在内部启动了dc计算器程序,并通过管道与其进行通信 从bc方法中得到的思想: 1 ...客户/服务器模型 bc/dc程序对是客户/服务器模型程序设计的一个实例.bc通过用户界面, 并使用dc提供的服务.这里bc被称为dc的客户 2 双向通信 客户/服务器模型不同于生产线的数据处理模型,他要求一个进程既跟另...服务器是提供服务的程序,是一个进程,等待请求,处理请求,然后循环回去 等下一个请求.客户端进程只要建立连接,与服务器交换数据即可 主机名和端口 运行于因特网上的服务器其实是某台计算器上运行的一个进程....服务器在该 主机拥有一个端口.主机和端口的组合才标识了一个服务器 协议 协议是服务器和客户之间交互的规则.每个客户/服务器模型都必须定义一个 协议并遵守,只要两者相互认可就行,比如约定数据的格式等 /etc

51520

Unix-Linux编程实践教程-chapter02-who

第2章 用户 文件操作与联机帮助:编写who命令 who 命令通过读系统日志的内容显示当前已登陆的用户 Unix 系统把数据存放在文件中,可以通过以下系统调用来操作文件: open(filename,...每次系统调用都会导致用户模式与内核模式的切换以及执行内核代码,所以减少 程序中的系统调用的次数可以提高程序的运行效率 程序可以通过缓冲技术来减少系统调用的次数,仅当写缓冲区满或者读缓冲区空时才调用 内核服务 Unix...内核可以通过内核缓冲来减少访问磁盘IO 的次数 Unix 中时间的处理方式是记录从某一个时间开始经过的秒数 当系统调用出错时会把全局变量errno 的值设为相应的错误代码,然后返回-1 程序可以 通过检查...errno 来确定错误的类型,并采取相应的措施 这一章涉及的知识在系统中都可以找到,联机帮助中有命令的说明,有些还会涉及命令的 实现,头文件中有结构和系统常量的定义,还有函数原型的说明 在Unix 中增加命令很简单...usr/bin /usr/local/bin 或者通过alias 添加到~/.bashrc 使用系统调用open 来打开文件,如果文件被顺利打开,内核会返回一个正整数的值, 这个数值就叫做文件描述符 Unix

1.2K10
领券