




已阅读5页,还剩20页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
_操作系统实验 实验报告实验日期:11月23日实验名称:实验一一、实验目的1.学习LINUX操作系统2.熟悉UNIX/LINUX的常用基本命令3.理解fork()与clone()函数的区别和联系4.深入理解生产者和消费者问题二、实验内容(1)安装LINUX:(2)熟悉UNIX/LINUX的常用基本命令如ls、who、wc、pwd、ps、pstree、top,cat,cd,chgrp,chmod,chown,comm,cmp,cp,rm,diff,mv,rmdir等,了解环境。(3)比较fork()和clone()的功能,利用fork()生成子进程和clone()生成线程。(4)利用pthread库,通过其中的mutex来实现生产者和消费者问题。三、项目要求及分析基本要求:(1)安装LINUX:使用FEDORA11(2)熟悉UNIX/LINUX的常用基本命令如ls、who、wc、pwd、ps、pstree、top,cat,cd,chgrp,chmod,chown,comm,cmp,cp,rm,diff,mv,rmdir等,了解环境。(3)比较fork()和clone()的功能,利用fork()生成子进程和clone()生成线程。(4)利用pthread库,通过其中的mutex来实现生产者和消费者问题。四、具体实现1.linux常用指令 1.1 目录操作 和 DOS 相似,Linux 采用树型目录管理结构,由根目录开始一层层将子目录建 下去,各子目录以“/”隔开。用户login后,工作目录的位置称为home directory,由系统管理员设定。符号代表自己的home directory,例如:/myfile是指自己home目录下myfile这个文件。 Linux 的通配符有三种:*和?用法与DOS相同,代表区间内的任一字符,如test05即代表test0,test1,test5的集合。 (1)显示目录文件ls执行格式:ls atFlgR name (name 可为文件或目录名称) 例: ls 显示出当前目录下的文件ls a 显示出包含隐藏文件的所有文件 ls t 按照文件最后修改时间显示文件 ls F 显示出当前目录下的文件及其类型 ls l 显示目录下所有文件的许可权、拥有者、文件大小、修改时间及名称 ls lg 同上 ls R 显示出该目录及其子目录下的文件 注:ls与其它命令搭配使用可以生出很多技巧(最简单的如“ls -l | more”), 更多用法请输入ls -help查看,其它命令的更多用法请输入“命令名help“查看。 (2)建新目录:mkdir 执行格式:mkdir directoryname 例:mkdir dir1 (新建一名为 dir1 的目录) (3)删除目录:rmdir 执行格式:rmdir directoryname 或 rm directoryname 例:rmdir dir1 删除目录 dir1,但它必须是空目录,否则无法删除 Rm r dir1 删除目录 dir1 及其下所有文件及子目录 rm -rf dir1 不管是否空目录,统统删除,而且不给出提示,使用时 要小心 (4) 改变工作目录位置:cd 执行格式:cd name 例:cd 改变目录位置至用户 login 时的 working directory cd dir1 改变目录位置,至dir1目录 cd user 改变目录位置,至用户的working directory cd . 改变目录位置,至当前目录的上层目录 -4- 操作系统实验指导书 cd ./user 改变目录位置,至上一级目录下的user目录 cd /dir-name1/dir-name2 改变目录位置,至绝对路径(Full path) cd - 回到进入当前目录前的上一个目录 (5)显示当前所在目录 pwd 执行格式: pwd (6)查看目录大小 du 执行格式: du s directory 例: du dir1 显示目录 dir1 及其子目录容量(以 kb 为单位) 显示目录 dir1 的总容量 du s dir1 (7)显示环境变量 echo $HOME 显示家目录 echo $PATH 显示可执行文件搜索路径 env 显示所有环境变量(可能很多,最好用env | more,env | grep PATH等) (8)修改环境变量,在bash下用export,如: export PATH=$PATH:/usr/local/bin 想知道 export 的具体用法,可以用 shell 的 help 命令:help export 2、文件操作 (1)查看文件(可以是二进制的)内容 cat 执行格式:cat filename 或 more filename 或 cat filename|more 例: 以连续显示方式,查看文件 file1 的内容 cat file1 more file1 或 cat file1|more 以分页方式查看文件的内容 (2)删除文件 rm 执行格式: rm filename 例: rm file? rm f* (3)复制文件 cp 执行格式: cp r source destination 例: 将 file1 复制成 file2 cp file1 file2 将 file1 复制到目录 dir1 cp file1 dir1 将 file1 复制到当前目录 cp /tmp/file1 将 file1 复制到当前目录名为 file2 cp /tmp/file1 file2 cp r dir1 dir2 (recursive copy)复制整个目录。 (4)移动或更改文件、目录名称 mv 执行格式: mv source destination 例: 将文件 file1,更名为 file2 mv file1 file2 -5- 操作系统实验指导书 将文件 file1,移到目录 dir1 下 mv file1 dir1 mv dir1 dir2 (5)比较文件(可以是二进制的)或目录的内容 diff 执行格式: diff r name1 name2 (name1、name2 同为文件或目录) 例: diff file1 file2 比较 file1 与 file2 的不同处 比较 dir1 与 dir2 的不同处 diff r dir1 dir2 (6)文件中字符串的查找 grep 执行格式:grep string file 例: 查找并列出串 abc 所在的整行文字 grep abc file1 (7)文件或命令的路径寻找 执行格式一:whereis command 显示命令的路径 执行格式二:which command 显示路径及使用者所定义的别名 执行格式三:whatis command 显示命令的功能摘要 执行格式四:find search path name filename print 搜寻指定路径下某文件的路径 执行格式五:locate filename 根据系统预先生成的文件/目录数据库(/var/lib/slocate/slocate.db)查找匹 配的文件/目录,查找速度很快,如果有刚进行的文件改变而系统未到执行定时更新 数据库的时间,可以打入updatedb命令手动更新。 (8)建立文件或目录的链接 ln 例: ln source target1 建立source文件(已存在)的硬链接,命名为target1 ln -s source target2 建立source文件的符号链接,命名为target2 3、系统询问与权限口令 (1)查看系统中的使用者 执行格式: who (2)查看 username 执行格式: 查看自己的 username who am I (3)改变自己的 username 的帐号与口令 su 执行格式: su username 例: 输入帐号 su username 输入密码 password (4)文件属性的设置 chmod 改变文件或目录的读、写、执行的允许权 执行格式: chmod R mode name 其中:-R为递归处理,将指定目录下所有文件及子目录一并处理 mode为3-8位数字,是文件/目录读、写、执行允许权的缩写(r:read,数字代号为 4, w:write,数字代号为2, x:execute,数字代号为1) -6- 操作系统实验指导书 mode: rwx rwx rwx user group other 缩写: (u) (g) (o) 例:chmod 755 dir1 将目录dir1设定成任何人皆有读取及执行的权利,但只有拥有 者可作写修改。其中7=4+2+1,5=4+1 将 file1 设为拥有者可以读、写和执行 chmod 700 file1 将 file2,增加拥有者可执行的权利 chmod o+x file2 将 file3,增加组使用者可执行的权利 chmod g+x file3 将 file4,除去其它使用者可读取的权利 chmod or file4 (5)改变文件或目录所有权 chown 执行格式: chown R username name 例: chown user file1 将文件 file1 改为 user 所有 将目录dir1及其下所有文件和子目录,改为 chown R user dir1 user 所有 (6)检查用户所在组名称 groups 执行格式: groups (7)改变文件或目录的组拥有权 chgrp 执行格式: chgrp R groupname name 例:chgrp vlsi file1 将文件 file1 改为 vlsi 组所有 chgrp R image dir1 将目录 dir1 及其下所有文件和子目录,改为 image群组 (8)改变文件或目录的最后修改时间 touch执行格式: touch name 4、进程操作 (1)查看系统目前的进程 ps 执行格式: ps aux 例: ps 或 ps x 查看系统中属于自己的 process 查看系统中所有使用者的 process ps au 查看系统中包含系统内部及所有使用者的 process ps aux ps -aux|grep apache 找出系统中运行的所有名称中带有apache串的 process (2)查看正在 background 中执行的 process 执行格式: jobs (3)结束或终止进程 kill 执行格式: (PID 为利用 ps 命令所查出的 process ID) kill 9 PID 例: kill 456 或 kill 9 456 终止 process ID 为 456 的 process -7- 操作系统实验指导书 (4)后台(background)执行 process command 的命令 执行格式: command & (在命令后加上 &) 例: gcc file1 & 在后台编译 file1.c 注意: 按下Z, 暂停正在执行的 process。 键入”bg”,将所暂停的 process 置入 background 中继续执行。 例: gcc file1 & Z stopped bg (5)结束或终止在 background 中的进程 kill 执行格式: kill %n 例: kill %1 终止在 background 中的第一个 job 终止在 background 中的第二个 job kill %2 (6)显示系统中程序的执行状态 例: top -q 不断地更新、显示系统程序的执行状态 第一行显示的项目依次为当前时间、系统启动时间、当前系统登录用户数目、平均负载。 第二行为进程情况,依次为进程总数、休眠进程数、运行进程数、僵死进程数、终止进程数。 第三行为CPU状态,依次为用户占用、系统占用、优先进程占用、闲置进程占用。 第四行为内存状态,依次为平均可用内存、已用内存、空闲内存、共享内存、缓存使用内存。 第五行为交换状态,依次为平均可用交换容量、已用容量、闲置容量、高速缓存容量。 PID 每个进程的ID。 PPID 每个进程的父进程ID。 UID 每个进程所有者的UID 。 USER 每个进程所有者的用户名。 PRI 每个进程的优先级别。 NI 该进程的优先级值。 SIZE 该进程的代码大小加上数据大小再加上堆栈空间大小的总数。单位是KB。 TSIZE 该进程的代码大小。对于内核进程这是一个很奇怪的值。 DSIZE 数据和堆栈的大小。 TRS 文本驻留大小。 D 被标记为“不干净”的页项目。 LIB 使用的库页的大小。对于ELF进程没有作用。 RSS 该进程占用的物理内存的总数量,单位是KB。 SHARE 该进程使用共享内存的数量。 STAT 该进程的状态。其中S代表休眠状态;D代表不可中断的休眠状态;R代表运行状态;Z 代表僵死状态;T代表停止或跟踪状态。 TIME 该进程自启动以来所占用的总CPU时间。如果进入的是累计模式,那么该时间还包括这 个进程子进程所占用的时间。且标题会变成CTIME。 %CPU 该进程自最近一次刷新以来所占用的CPU时间和总时间的百分比。 %MEM 该进程占用的物理内存占总内存的百分比。 COMMAND 该进程的命令名称,如果一行显示不下,则会进行截取。内存中的进程会有一个完 整的命令行 -8- 操作系统实验指导书 按ctrl+c停止查看 (7)以树状图显示执行的程序 pstree 例: pstree -h 列出进程树并高亮标出当前执行的程序 (8)监视虚拟内存 vmstat vmstat对系统的虚拟内存、进程、CPU活动进行监视,同时它也对磁盘和forks和vforks操 作的个数进行汇总。 不足是:vmstat不能对某个进程进行深入分析,它仅是一对系统的整体情况进行分析。 例如:angelhome /angel# vmstat procs memory swap io system cpu r b w swpd free buff cache si so bi bo in cs us sy id 0 0 0 7180 1852 56092 48400 0 0 6 5 24 8 0 0 18 其中: Procs r: 等待运行的进程数 b: 处在非中断睡眠状态的进程数 w: 被交换出去的可运行的进程数。 Memory swpd: 虚拟内存使用情况,单位:KB free: 空闲的内存,单位 KB buff: 被用来做为缓存的内存数,单位:KB Swap si: 从磁盘交换到内存的交换页数量,单位:KB/秒 so: 从内存交换到磁盘的交换页数量, 单位:KB/秒 IO bi: 发送到块设备的块数,单位:块/秒 bo: 从块设备接收到的块数,单位:块/秒 System in: 每秒的中断数,包括时钟中断 cs: 每秒的环境(上下文)切换次数 CPU 按 CPU 的总使用百分比来显示 us: CPU 使用时间 sy: CPU 系统使用时间 id: 闲置时间 (9)分析共享内存、信号量和消息队列 ipcs(相关命令ipcrm:用于给有权限的用户清 除这些量,注意不要乱清除,除非该量确实失效了) 例如:angelhome /angel# ipcs - Shared Memory Segments - key shmid owner perms bytes nattch status 0x00280267 0 root 644 1048576 1 0x61715f01 1 root 666 32000 33 0x00000000 2 nobody 600 92164 11 dest - Semaphore Arrays - key semid owner perms nsems status 0x00280269 0 root 666 14 0x61715f02 257 root 777 1 - Message Queues - key msqid owner perms used-bytes messages (10)监视用户空间程序发出的全部系统调用 strace -9- 操作系统实验指导书 strace 还能显示调用的参数,以及用符号方式表示的返回值。 strace 从内核中接收信息,所以一个程序无论是否按调试方式编译(gcc -g)或 是否被去掉了调试信息,都可以被跟踪。 执行格式: strace -tTeo executable-program-name -t : 用来显示调用发生的时间 -T : 显示调用花费的时间 -e : 限定被跟踪的调用类型 -o : 将输出重定向到一个文件中 类似命令:ltrace -fiS executable-program-name 5、通信类 (1)本地工作站与 LINUX 服务器间的文件传输 ftp 执行格式: ftp 主机名 或 ftp 主机的 IP 地址 后续执行步骤: 输入帐号 name: 输入密码 password: 显示 ftp 可使用的所有命令 ftphelp 改变本地机当前目录为 dir1 ftplcd dir1 将 LINUX 服务器文件 file1 拷到本地机 ftpget file1 将本地文件 file2,拷到 LINUX 服务器 ftpput file2 显示本地机当前目录下所有文件 ftp!ls 显示本地机当前所在目录下所有文件 ftp!pwd 显示 LINUX 服务器当前目录下所有文件 ftpls 显示服务器当前目录下所有文件(略同于 LINUX 的 ftpdir ls l 指令) 显示 LINUX 服务器当前所有目录位置 ftppwd 更改 LINUX 服务器的目录至 dir1 下 ftpcd dir1 将服务器中 .c 文件拷到本地机中 ftpmget *.c 将所有 .txt 文件拷贝到服务器 ftpmput *.txt 结束 ftp 工作 ftpquit 结束 ftp 工作 ftpbye (2)检查与 LINUX 服务器连接是否正常 ping 执行格式: ping hostname 或 ping IPAddress 例: ping (3)将文件当做 Email 的内容送出 mail 执行格式:mail s “Subjictstring” usernameaddressfilename 例: mail s “program” user file.c 功能:将 file.c 当做 mail 的内容,送至 user,subject name 为 program (4)传送 Email 给本地 LINUX 服务器上的用户 mail -10- 操作系统实验指导书 执行格式: mail username (5)读取信件 mail 执行格式: mail (6)列出套接字使用情况 socklist (7)查看网络连接 netstat 6、I/O 命令 (1)管道(pipeline)的使用 执行格式: command1|command2 功能:将 command1 的执行结果送到 command2 作为输入 例: ls R1|more 以分页方式列出当前目录文件及子目录名称 以分页方式,列出 file1 的内容 cat file1|more (2)标准输入控制 执行格式: 将 file 作为 commandline 的输入 commandlinefile 例: mail s “mail test” .twfilename 功能:将 command 的执行结果送至指定的 filename 中 例: ls l list 将执行”ls l” 的结果写入文件 list 中 执行格式二: command!filename 功能:同上,若 filename 文件已存在,则强迫重写 执行格式三: command&filename 功能:将 command 执行所产生的任何信息写入 filename 执行格式四:commandfilename 功能:将 command 的执行结果,附加(append)到 filename 执行格式五:command&filename ?功能:将 command 执行所产生的任何信息附加于 filename 中 7、其它常用命令 (1)命令在线帮助 man 执行格式: man command 例: 查询 ls 这个指令的用法 man ls (2)设定命令记录表长度 history 执行格式一: set history=n 例: set history=40 功能:设定命令记录表长度为 40(可记载执行过的前面 40 个命令) 执行格式二: history 查看命令记录表的内容 -11- 操作系统实验指导书 (3)显示说明 info 执行格式: info command-name 例: info gcc 功能: 查看gcc的说明,按上下箭头选定菜单,回车进入,u键返回上级菜单. info不加参数则进入最上一级菜单. 四、用cat 命令查看 /proc 动态文件系统目录下的文件,辨识其中 的系统信息. 2.fork()与clone() 在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性,但是二者之间的通讯需要通过专门的通讯机制,如:pipe,fifo,System V IPC机制等,另外通过fork创建子进程系统开销很大,需要将上面描述的每种资源都复制一个副本。这样看来,fork是一个开销十分大的系统调用,这些开销并不是所有的情况下都是必须的,比如某进程fork出一个子进程后,其子进程仅仅是为了调用exec执行另一个执行文件,那么在fork过程中对于虚存空间的复制将是一个多余的过程(由于Linux中是采取了copy-on-write技术,所以这一步骤的所做的工作只是虚存管理部分的复制以及页表的创建,而并没有包括物理也面的拷贝);另外,有时一个进程中具有几个独立的计算单元,可以在相同的地址空间上基本无冲突进行运算,但是为了把这些计算单元分配到不同的处理器上,需要创建几个子进程,然后各个子进程分别计算最后通过一定的进程间通讯和同步机制把计算结果汇总,这样做往往有许多格外的开销,而且这种开销有时足以抵消并行计算带来的好处。在许多实现了MT的操作系统中线程和进程通过两种数据结构来抽象表示: 进程表项和线程表项,一个进程表项可以指向若干个线程表项, 调度器在进程的时间片内再调度线程。 但是在Linux中没有做这种区分, 而是统一使用task_struct来管理所有进程/线程,只是线程与线程之间的资源是共享的,这些资源是虚存、文件系统、文件I/O以及信号处理函数甚至PID中的几种。也就是说Linux中,每个线程都有一个task_struct,所以线程和进程可以使用同一调度器调度。其实Linux核心中,轻量级进程和进程没有质上的差别,因为Linux中进程的概念已经被抽象成了计算状态加资源的集合,这些资源在进程间可以共享。如果一个task独占所有的资源,则是一个HWP,如果一个task和其它task共享部分资源,则是LWP。clone系统调用就是一个创建轻量级进程的系统调用。看起来clone的用法和pthread_create有些相似,两者的最根本的差别在于clone是创建一个LWP,对核心是可见的,由核心调度,而pthread_create通常只是创建一个用户线程,对核心是不可见的,由线程库调度。五、调试运行结果生产者与消费者问题的解决:六、所遇问题及解决方法 通过对课后实验的学习、上网查一些相关资料、和同学讨论等途径,我基本了解了了pthread库和mutex和semaphone的实现以及功能,理解fork()与clone()函数的区别和联系也有了相应的认识,这也提高了我自主学习能力和协作能力。附:程序代码#include #include #include #include #include #define N 2 / 消费者或者生产者的数目#define M 10 / 缓冲数目int in = 0; / 生产者放置产品的位置int out = 0; / 消费者取产品的位置int buffM = 0; / 缓冲初始化为0, 开始时没有产品sem_t empty_sem; / 同步信号量, 当满了时阻止生产者放产品sem_t full_sem; / 同步信号量, 当没产品时阻止消费者消费pthread_mutex_t mutex; / 互斥信号量, 一次只有一个线程访问缓冲int product_id = 0; /生产者idint prochase_id = 0; /消费者id/* 打印缓冲情况 */void print()int i;for(i = 0; i M; i+) printf(%d , buffi);printf(n);/* 生产者方法 */ void *product()int id = +product_id;while(1) / 用sleep的数量可以调节生产和消费的速度,便于观察 sleep(1); /sleep(1); sem_wait(&empty_sem); pthread_mu
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 1.1 地球的宇宙环境 教学设计 2024-2025学年高一上学期 地理 人教版(2019)必修一
- 加油站安全培训经费课件
- 2024-2025学年七年级道德与法治上册 第二单元 友谊的天空 第五课 交友的智慧 第1框《让友谊之树常青》说课稿 新人教版
- 基础强化自考专业(小学教育)试卷及参考答案AB卷
- Unit 3 Fit for life Integrated skills 1 教学设计-2024-2025学年高中英语译林版(2020)选择性必修第二册
- 八年级地理下册 第九章 建设永续发展的美丽中国说课稿 (新版)湘教版
- 钨、钼、钴粉还原工工艺创新考核试卷及答案
- 静电成像显影材料墨粉(色调剂)制造工基础考核试卷及答案
- SaaS托管客户满意度研究-洞察及研究
- 1.5 等腰三角形教学设计-2025-2026学年初中数学苏科版2024八年级上册-苏科版2024
- 保密观考试题及答案2025保密观知识竞赛试题及答案
- 老年髋部骨折围手术期衰弱护理管理专家共识解读
- 2025版农业合作社成员个人借款合同范本
- 2025年乒乓球裁判证考试试题及答案
- 活动成都热波zebra音乐节营销策划方案5月1日5月3日
- 八年级历史上学期(2025版)导言课课件
- 2025-2026学年外研版(三起)(2024)小学英语三年级上册教学计划及进度表
- 2025年小学生“学宪法讲宪法”网络活动知识竞赛题库(含答案)
- 2025年部编版道德与法治六年级上册全册教案设计(共4个单元含有教学计划)
- 湖南地方文化常识 完整版PPT
- 读后续写:Emily with birth problems 文章分析+情节分析+续写段落赏析
评论
0/150
提交评论