现在的位置: 首页 > 综合 > 正文

百度公开课 – linux后台服务开发 – 笔记整理

2013年09月01日 ⁄ 综合 ⁄ 共 838字 ⁄ 字号 评论关闭

昨晚听完百度校园公开课,还得了个保温杯,好开心.

现在把抄到的笔记整理下,东西不会很详细,但足够引出很多知识点

感谢运维部的颜工来湖大讲课!

1 环游linux

一些常用的linux命令: ssh cd pwd ls tab mkdir rm cp mv cat more less 

文本处理:head tail cat sort diff grep sed awk

重定向: | > >>

其它: alias find scp wget ps top vmstat netstat  watch

vim

gcc 版本我特意问了 ,原来他们部门在用3.4.5版本

gcc常见错误:

underfind reference 找不到库 -l库名 -L库目录   

no such file or directory  找不到头文件 -I 头文件路径 (i的大写)

项目管理工具: Makefile 还有开源的Autoconf 百度的Commake

常用开发工具: valgrind strace Ltrace ccov Gtest

2 多线程

多线程:共享内存空间

优点:数据访问方便 缺点:线程问题会影响整体,线程安全问题

多进程:独立内存空间 

线程切换有开销

开几个线程的要点:线程数不要超过CPU个数

线程安全问题:线程调度的先后是由操作系统决定的,和代码复杂度无关

互斥与同步: (1)访问同一个资源,使用互斥锁程序的串行 (2)使用条件变量保持同步

开销: 锁比运算要慢,但比磁盘IO要快

锁的使用原则:

IO密集型程序:不要让高速设备等待低速设备

CPU密集型程序:放大锁的粒度,减少锁的使用

线程池模型:

(1)单队列:无序,池中的线程能够运行任何任务,能够最大化利用CPU

(2)多队列:某些任务只能由特定的线程来运行,这个需要负载均衡

3 高性能网络编程

网络编程中有很多慢的地方

accept() 在等待

recv() 在等待

send() 在发送到网卡时 在空转

(1)多线程同步IO设计模式

效率低 用于原理验证

(2)单线程异步IO设计模式 (单核时代最快)

(3)多线程异步IO模式 多进程异步IO模式 :充分发挥多核优势

4多机系统和分布式系统

有点累, 没抄笔记 

【上篇】
【下篇】

抱歉!评论已关闭.