1 线程栈空间
我的 linux机器上默认是8192 kbytes。
[admin@host]$ ulimit -s
8192
[admin@host]$ ulimit -a
core file size (blocks, -c) unlimited
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 1545653
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1048576
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 307200
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
2 并发
2.1 多进程并发
相同主机上的不同进程之间的通信方式:
- 管道
- 文件
- 消息队列
- 共享内存
不同主机上的进程的通信方式:
- socket通信技术
什么是管道?
管道是一种最基本的IPC(进程间通信)机制,作用于有血缘关系的进程之间,完成数据传递。调用pipe系统函数即可创建一个管道。
2.2 多线程并发
同一进程中的多条线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和信号处理等等。但同一进程中的多个线程有各自的调用栈(call stack),自己的寄存器环境(register context),自己的线程本地存储(thread-local storage)。