Linux编程接口里的插图
[TOC]
Some useful commands
$ ldd /bin/ls | grep libc
libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb75e6000)
$ /lib/i386-linux-gnu/libc.so.6
Setps in the execution of a system call
data:image/s3,"s3://crabby-images/7a114/7a114335ab71f6db2a6a27320f523a352c166e74" alt=""
Relationship between file descriptors, open file descriptions, and i-nodes
data:image/s3,"s3://crabby-images/2e9c8/2e9c8ef0107d3344b0f36fbd2b36fe2415b1711e" alt=""
Typical memory layout of a process on Linux/x86-32
data:image/s3,"s3://crabby-images/d0df1/d0df19fddb6edf7c84eb03d5c87fc0884bd94da2" alt=""
Overview of virtual memory
data:image/s3,"s3://crabby-images/5ea30/5ea3005f68a9a40fe9d8bb15a35e049b0992b627" alt=""
Heap containing allocated blocks and a free list
data:image/s3,"s3://crabby-images/67bfc/67bfcd1db001beb3f052f0d37c8598b84e541a7d" alt=""
Selected files in each /proc/PID directory
data:image/s3,"s3://crabby-images/60ebd/60ebd30e62e431c7e4c206655b8d653b1ef75cea" alt=""
Summary of I/O buffering
data:image/s3,"s3://crabby-images/9364f/9364ff325a256a91253d5c3be4f293dc46c28370" alt=""
Structure of the file blocks for a file in an ext2 file system
data:image/s3,"s3://crabby-images/e1c8c/e1c8c077dc9dc35a4475548c28535b1059b4c694" alt=""
I-node flags
data:image/s3,"s3://crabby-images/7f650/7f6500385c4fbcd5a100de65015fb25a40ceac96" alt=""
From the shell, i-node flags can be set and viewed using the chattr and lsattr commands.
ACL (Access Control List)
An ACL is a series of ACL entries, each of which defines the file permissions for an individual user or group of users:
data:image/s3,"s3://crabby-images/2e890/2e8907e47ed44ae9e708d8f0a98c78f2996258e0" alt=""
Relationship between i-node and directory structures
data:image/s3,"s3://crabby-images/c696b/c696bba95e399143298cb1752482cd090bd5f66b" alt=""
Representation of hard and symbolic links
data:image/s3,"s3://crabby-images/34bec/34bec043872bc77287825491bf22c5e97a0d06c9" alt=""
Linux signals
data:image/s3,"s3://crabby-images/49f06/49f06cd85e250172ed1bc9d93d80901eb3a360e9" alt=""
Signal delivery and handler execution
data:image/s3,"s3://crabby-images/126e7/126e72d82a07d7ccdff9ea470a03185e4f44eb62" alt=""
Run for a few seconds elapsed time
for (startTime = time(NULL); time(NULL) < startTime + 4; )
continue; /* Run for a few seconds elapsed time */
Overview of the use of fork(), exit(), wait() and execve()
data:image/s3,"s3://crabby-images/1c7dd/1c7dd58bf33fb34b245342df2b09a2ed3b54484c" alt=""
Value returned in the status argument of wait() and waitpid()
data:image/s3,"s3://crabby-images/af403/af4032f447d15a7fde207860ca3bfb5f17e0973a" alt=""
void handler(int sig)
{
/* Perform cleanup steps */
signal(sig, SIG_DFL); /* Disestablish handler */
raise(sig); /* Raise signal again */
}
The argument list supplied to an execed script
data:image/s3,"s3://crabby-images/d3ad5/d3ad5d80988f3f1afd699b30bb0d94935cc7ec01" alt=""
execution of system("sleep 20")
data:image/s3,"s3://crabby-images/ae1c9/ae1c9b602ff7b298d15ee9c7168ce692cdacce26" alt=""
As an efficiency measure, when the string given to the -c option is a simple command (as opposed to a pipeline or a sequence), some shells (including bash) directly exec the command, rather than forking a child shell. For shells that perform such an optimization, Figure 27-2 is not strictly accurate, since there will be only two processes (the calling process and sleep).
Four threads executing in a process (Linux/x86-32)
data:image/s3,"s3://crabby-images/7aae0/7aae0024d5d3355d9742b54eeaf12ba96743d4cf" alt=""
We have simplified things somewhat in Figure 29-1. In particular, the location of the per-thread stacks may be intermingled with shared libraries and shared memory regions, depending on the order in which threads are created, shared libraries loaded, and shared memory regions attached. Further more, the location of the per-thread stacks can vary depending on the Linux distribution.
/* When using threads, errno is a per-thread value. */
#define errno (*__errno_location ())
Each reference to errno in a threaded program carries the overhead of a function call.
Thread-specific data (TSD) provides per-thread storage for a function
data:image/s3,"s3://crabby-images/d370d/d370d86d749783d8e7b43a781da5e41b8739c05c" alt=""
Relationships between process groups, sessions, and the controlling terminal
data:image/s3,"s3://crabby-images/0e249/0e249bdc01f0cf6494e1e364de8488f1ee3508df" alt=""
Job-control states
data:image/s3,"s3://crabby-images/1c504/1c504fe60a2dde4734fcd1a5a5ef64c221de4a7d" alt=""
Resources values for getrlimit() and setrlimit()
data:image/s3,"s3://crabby-images/6408a/6408a92f349c4fd1857ba1872125928f70df9b9f" alt=""
Overview of system logging
data:image/s3,"s3://crabby-images/894a2/894a298d7beae69a0774ca83a90a613a15851b82" alt=""
Creating a shared library and linking a program against it
data:image/s3,"s3://crabby-images/7842b/7842be2fb40b5e85febd89c4aca1528ef512cfa3" alt=""
Execution of a program that loads a shared library
data:image/s3,"s3://crabby-images/52ac2/52ac23a5eb0d14c2a341267acb932c814485e8ed" alt=""
real name, soname, linker name
data:image/s3,"s3://crabby-images/00a65/00a65d3df7d7e28c042a847d783a74c8218de1fc" alt=""
Finding Shared Libraries at Run Time
data:image/s3,"s3://crabby-images/75a08/75a08cd481941df6bbaa135591b0e36c2234e53e" alt=""
A taxonomy of UNIX facilities
data:image/s3,"s3://crabby-images/12e36/12e3625d921aa331f59c4d0d7e74476224ab069c" alt=""
Identifiers and handles for various types of IPC facilities
data:image/s3,"s3://crabby-images/f4774/f4774ad5bbd7c22aa276959f339f78d18a0b27ef" alt=""
Setting up a pipe to transfer data from parent to a child
data:image/s3,"s3://crabby-images/42484/42484d3421c088083257f4cc333b7d070ca5f84a" alt=""
popen()
data:image/s3,"s3://crabby-images/a6ab7/a6ab7cab037afbc1a6b2f8f18f64b9391b2f7c02" alt=""
Using a FIFO and tee(1) to create a dual pipeline
$ mkfifo myfifo
$ wc -l < myfifo &
$ ls -l | tee myfifo | sort -k5n
data:image/s3,"s3://crabby-images/d5f30/d5f3057b8fb633edcb62ed769a3327e508a3769b" alt=""
Separating messages in a byte stream
data:image/s3,"s3://crabby-images/18284/182843b840fcb35669e88a254969901f72107ed8" alt=""
Overview of memory-mapped file
data:image/s3,"s3://crabby-images/0d266/0d2661620d05865efe3f97d7e21a441f0318a078" alt=""
Two processes with a shared mapping of the same region of a file
data:image/s3,"s3://crabby-images/03ce4/03ce4d5d89b151f575019ac43640ef8e4477500f" alt=""
We simplify things in this diagram by omitting to show that the mapped pages are typically not contiguous in physical memory.
Memory mapping whose length is not a multiple of the system page size
data:image/s3,"s3://crabby-images/a0c88/a0c8879d0ce8a409501d335f87c2005916902136" alt=""
Memory mapping extending beyond end of mapped file
data:image/s3,"s3://crabby-images/15036/15036cdf1f3286e95173e25e0d98f85788c75041" alt=""
Summary of programming interfaces for POSIX IPC objects
data:image/s3,"s3://crabby-images/61582/61582eb593692a90e54c2ad57b15e27dbb5cc2ef" alt=""
Socket domains
data:image/s3,"s3://crabby-images/fa8ac/fa8ac65540a0e7d70e29f40622b9613bc558d45b" alt=""
Socket types and their properties
data:image/s3,"s3://crabby-images/e2ea9/e2ea9f1187cad3642d63207dcfe107fe3182bf92" alt=""
Overview of system calls used with stream sockets
data:image/s3,"s3://crabby-images/38c7f/38c7f07125831d0714362776c9d0a5d8bf8b5213" alt=""
A pending socket connection
data:image/s3,"s3://crabby-images/31b18/31b18802fba5c4e1205f8ac725996e382bbecc47" alt=""
Overview of system calls used with datagram sockets
data:image/s3,"s3://crabby-images/cca57/cca577539b3365eed2cc2cc513b46ada83b34988" alt=""
Generic address structure, struct sockaddr
struct sockaddr {
sa_family_t sa_family;
char sa_data[14];
}
/* UNIX domain */
#define UNIX_PATH_MAX 108
struct sockaddr_un {
sa_family_t sun_family; /* AF_UNIX */
char sun_path[UNIX_PATH_MAX]; /* pathname */
};
/* IPv4 domain */
struct sockaddr_in {
sa_family_t sin_family; /* address family: AF_INET */
in_port_t sin_port; /* port in network byte order */
struct in_addr sin_addr; /* internet address */
/* pad to size of 'struct sockaddr' */
unsigned char __pad[sizeof (struct sockaddr) -
sizeof (sa_family_t) -
sizeof (in_port_t) -
sizeof(struct in_addr)];
};
/* Internet address. */
struct in_addr {
uint32_t s_addr; /* address in network byte order */
};
/* IPv6 domain */
struct sockaddr_in6 {
sa_family_t sin6_family; /* AF_INET6 */
in_port_t sin6_port; /* port number */
uint32_t sin6_flowinfo; /* IPv6 flow information */
struct in6_addr sin6_addr; /* IPv6 address */
uint32_t sin6_scope_id; /* Scope ID (new in 2.4) */
};
/* IPv6 address */
struct in6_addr
{
union
{
uint8_t __u6_addr8[16];
#ifdef __USE_MISC
uint16_t __u6_addr16[8];
uint32_t __u6_addr32[4];
#endif
} __in6_u;
#define s6_addr __in6_u.__u6_addr8
#ifdef __USE_MISC
# define s6_addr16 __in6_u.__u6_addr16
# define s6_addr32 __in6_u.__u6_addr32
#endif
};
#define IN6ADDR_ANY_INIT { { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 } } }
#define IN6ADDR_LOOPBACK_INIT { { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1 } } }
TCP/IP protocol layers
data:image/s3,"s3://crabby-images/1b9ed/1b9ed7c8dfbb030e6bd66f4811bf45fe4a72ce3f" alt=""
Format of an IPv4-mapped IPv6 address
data:image/s3,"s3://crabby-images/7d22f/7d22ff9bee697e1212650c46b72ecf67145c83d7" alt=""
Connected TCP sockets
data:image/s3,"s3://crabby-images/ea790/ea79075fc10686ccf782312fdc8b19643f80abfa" alt=""
Transferring the contents of a file to a socket
data:image/s3,"s3://crabby-images/f0f0e/f0f0e20c0a67800a8cfd38b22d1a88925deb2c4a" alt=""
Format of a TCP segment
data:image/s3,"s3://crabby-images/05de3/05de3b99a2bbdab2c891c323347f67cec154780e" alt=""
TCP state transition diagram
data:image/s3,"s3://crabby-images/8f442/8f442539c6f0f04e4bfc377952fa005061779c6b" alt=""
Three-way handshake for TCP connection establishment
data:image/s3,"s3://crabby-images/db00f/db00f96d61e5a39eeb918ade250cf159c997ea31" alt=""
Thye connection termination
data:image/s3,"s3://crabby-images/68aaa/68aaa4b918b271bc2ef9cb9d3265864c1db0c778" alt=""
Input and output queues for a terminal device
data:image/s3,"s3://crabby-images/01a10/01a103a83989b67c3ac061a5e67631bce9ddd221" alt=""
Terminal Special characters
data:image/s3,"s3://crabby-images/177be/177be00f867635bd0c728882cea5050d2dad04f6" alt=""
select() and poll indication for sockets
data:image/s3,"s3://crabby-images/372f9/372f970ba281983e23931f086c01af46e7f0f7e7" alt=""
Times taken by poll(), select() and epoll for 100,000 monitoring operations
data:image/s3,"s3://crabby-images/ed2bb/ed2bb2132540be147e2892754d0aebf51064e96a" alt=""
Two programs communicating via a pseudoterminal
data:image/s3,"s3://crabby-images/cb823/cb823a80703d479121c0631d0ce44cddb07bb78a" alt=""
How ssh uses a pseudoterminal
data:image/s3,"s3://crabby-images/a69f3/a69f385eede3bf5f7661c2c15d0b663ed1dbb2df" alt=""
Figure 64-3 shows a specific example: the use of pseudoterminal by ssh, an application that allows a user to securely run a login session on a remote system connected via a network. On the remote host, the driver program for the pseudoterminal master is the ssh server (sshd), and the terminal-oriented program connected to the pseudoterminal slave is the login shell. The ssh server is the glue that connects the pseudoterminal via a socket to the ssh client. Once all of the details of logging in have been completed, the primary purpose of the ssh server and client is to relay characters in either direction between the user's terminal on the local host and the shell on the remote host.
data:image/s3,"s3://crabby-images/ad623/ad62368d9471011f1a5e4ca100fd3ffa16f8c21e" alt=""