apt-get软件包管理

转自: http://blog.csdn.net/chenji001/article/details/5815580

软件包安装

  • apt-get install 软件包名称 – 安装一个新软件包 (参见下面的 Aptitude)。
  • aptitude – Ncurses (译注:一种 API,在命令行模式下做出类似GUI的界面)制作的已安装和可安装的软件包查看器。 Aptitude 也可以像 apt-get 一样在命令行下使用,不过它只包含 apt-get 一部分的指令,例如常用的 install 和 remove 之类。不过因为 Aptitude 能比 apt-get 显示更多信息,因此在安装和卸载软件的时候要更好用一些。
auto-apt 命令

auto-apt run 命令 – 这条命令可以自动安装包含缺失文件的软件包。如果这里的“命令”在运行的时候访问了一个系统中没有的文件,那么 auto-apt 会用 apt-get 来安装包含缺失文件的的软件包。这项功能需要有 APT 以及 sudo 来工作。比如说你在编译一个软件,但是弹出一个错误说你缺少某个文件,那么 auto-apt 就会询问你是否要安装包含这个缺少的文件的软件包。同样它也会暂停相应的编译进程,并且在安装完毕之后恢复它。例如可以这样用:

这样如果缺少文件,auto-apt 就会自动使用 apt-get 来安装它。如果 X 服务器正在运行,也会有相应的图形界面。 auto-apt 有一个数据库,需要必要的更新以适应不断的变化。更新的命令为 auto-apt updatedb 以及 auto-apt update-local

 软件包维护

  • apt-get update – 在你更改了/etc/apt/sources.list 或 /etc/apt/preferences 后,需要运行这个命令以令改动生效。同时也要定期运行该命令,以确保你的源列表是最新的。该命令等价于新立得软件包管理器中的“刷新”,或者是 Windows和OS X 下的 Adept 软件包管理器的 “check for updates”。
  • apt-get upgrade – 更新所有已安装的软件包。类似一条命令完成了新立得软件包管理器中的“标记所有软件包以便升级”并且“应用”。
  • apt-get dist-upgrade – 更新整个系统到最新的发行版。等价于在新立得软件包管理器中“标记所有更新”,并在首选项里选择“智能升级” — 这是告诉APT更新到最新包,甚至会删除其他包(注:不建议使用这种方式更新到新的发行版)。
  • apt-get -f install — 等同于新立得软件包管理器中的“编辑->修正(依赖关系)损毁的软件包”再点击“应用。如果提示“unmet dependencies”的时候,可执行这行命令。
  • apt-get autoclean – 如果你的硬盘空间不大的话,可以定期运行这个程序,将已经删除了的软件包的.deb安装文件从硬盘中删除掉。如果你仍然需要硬盘空间的话,可以试试apt-get clean,这会把你已安装的软件包的安装包也删除掉,当然多数情况下这些包没什么用了,因此这是个为硬盘腾地方的好办法。
  • apt-get clean 类似上面的命令,但它删除包缓存中的所有包。这是个很好的做法,因为多数情况下这些包没有用了。但如果你是拨号上网的话,就得重新考虑了。
  • 包缓存的路径为/var/cache/apt/archives,因此,du -sh /var/cache/apt/archives将告诉你包缓存所占用的硬盘空间。
  • dpkg-reconfigure foo – 重新配置“foo”包。这条命令很有用。当一次配置很多包的时候, 要回答很多问题,但有的问题事先并不知道。例如,dpkg-reconfigure fontconfig-config,在Ubuntu系统中显示字体配置向导。每次我安装完一个 Ubuntu 系统,我都会运行这行命令,因为我希望位图字体在我的所有应用程序上都有效。
  • echo “foo hold” | dpkg –set-selections – 设置包“foo”为hold,不更新这个包,保持当前的版本,当前的状态,当前的一切。类似新立得软件包管理器中的“软件包->锁定版本”。
  • 注: apt-get dist-upgrade 会复盖上面的设置,但会事先提示。 另外,你必须使用 sudo。输入命令echo “foo hold” | sudo dpkg –set-selections而不是sudo echo “foo hold” | dpkg –set-selections
  • echo “foo install — 删除“hold”“locked package”状态设置。命令行为echo “foo install” | sudo dpkg –set-selections

软件包删除

  • apt-get remove 软件包名称 – 删除已安装的软件包(保留配置文件)
  • apt-get –purge remove 软件包名称 – 删除已安装包(不保留配置文件)
  • 特别技巧:如果你想在删除‘foo’包同时安装‘bar’: apt-get –purge remove foo bar+
  • apt-get autoremove – 删除为了满足其他软件包的依赖而安装的,但现在不再需要的软件包。

软件包搜索

  • apt-cache search foo – 搜索和”foo”匹配的包。
  • apt-cache show foo – 显示”foo”包的相关信息,例如描述、版本、大小、依赖以及冲突。
  • dpkg –print-avail 软件包名称 – 与上面类似。
  • dpkg -l *foo* – 查找包含有”foo”字样的包。与apt-cache show foo类似,但是还会显示每个包是安装了还是没安装。
  • dpkg -l package-name-pattern – 列出名为package-name-pattern的软件包。除非你知道软件包的正确全称,否则可以使用“*package-name-pattern*”.
  • dpkg -L foo – 显示名为“foo”的包都安装了哪些文件以及它们的路径,很有用的命令。
  • dlocate foo – 在已安装的包中搜索“foo”的文件。对于回答“这个文件来源于哪个包”这个问题,是非常实用的。dlocate是一个软件包,必须安装它才能使用本命令。
  • dpkg -S foo – 和上面的命令一样,但相比更慢一些。他只能在Debian或Ubuntu系统下运行。另外,不需要安装dlocate包。
  • apt-file search foo – 类似dlocate和dpkg -S,但搜索所有有效软件包包,不单单只是你系统上的已安装的软件包。– 它所回答的问题是“哪些软件包提供这些文件”。你必须安装有apt-file软件包,并且确保apt-file数据库是最新的。
  • dpkg -c foo.deb – “foo.deb”包含有哪些文件?注:foo.deb是含路径的文件名。– 这个是针对你自己下载的.deb包。
  • apt-cache dumpavail – 显示所有可用软件包,以及它们各自的详细信息(会产生很多输出)。
  • apt-cache show 软件包名称 – 显示软件包记录,类似dpkg –print-avail 软件包名称
  • apt-cache pkgnames – 快速列出已安装的软件包名称。
  • apt-file search filename – 查找包含特定文件的软件包(不一定是已安装的),这些文件的文件名中含有指定的字符串。apt-file是一个独立的软件包。您必须先使用 apt-get install 来安装它,然后运行 apt-file update。如果 apt-file search filename 输出的内容太多,您可以尝试使用 apt-file search filename | grep -w filename(只 显示指定字符串作为完整的单词出现在其中的那些文件名)或者类似方法,例如:apt-file search filename | grep /bin/(只显示位于诸如/bin或/usr/bin这些文件夹中的文件,如果您要查找的是某个特定的执行文件的话,这样做是有帮助的)。

apt与dpkg

dpkg本身是一个底层的工具。上层的工具,如APT,被用于从远程获取软件包以及处理复杂的软件包关系。 “dpkg”是“Debian Package”的简写。

http://baike.baidu.com/view/1314054.htm

并发socket程序设计

套接字相关函数默认是采用阻塞方式操作, 而大多数情况下, 程序不仅仅只拥有一个套接字。因此当进程以阻塞方式操作其中之一时,必将导致不能使用其它的套接字。如果用户希望这些套接字同时工作,就必须设计并发的套接字程序,即在一个套接字读写的同时保证另一个套接字也能正常地操作。

并发实现的几种方式:

1. 非阻塞方式

2. 信号驱动方式

3. 超时并发模型

另:超时的实现也有多种方式

4. 多路复用

 

参考资料:

《精通UNIX下C语言编程与项目实践》 17章

 

摘要:

1.  可以通过socket选项SO_SNDTIMEO/SO_RCVTIMEO 来设置套接字的读写超时,但是没有可以设置连接超时、accept超时的套接字选项;所以连接超时、accept超时都需要通过其它手段来实现

关于rsyslog的几个测试

测试目的

如果syslog函数的调用并发很大的话,可能会因为syslogd消费太慢而阻塞;本实验观察其阻塞的几个决定因素:

1. 未消费报文数超过多少个会阻塞

2. 报文的长度允许最大多大

3. 如果报文数为超过最大值,则数据超过多少会阻塞

测试平台

ubuntu12

测试1:

1. kill -19 syslogd-pid

2. i=1; while :; do ((i++)); logger a; done

结论: 默认值为10, 可以通过修改net.unix.max_dgram_qlen来调的更大一些;

注意: 修改net.unix.max_dgram_qlen 后需要重启进程才能生效,或者kill rsyslogd (rsyslogd会自己重启的)

 

测试2:

1. while [ i < 65536 ]; do ((i++)); echo -n a>>a.txt; done

2. while :; do logger <a.txt; done

发现一条日志重复了64次,说明,单个数据包的最大数据量为1k; 但是,很有可能是logger程序故意做了这种1k的切割(通过logger的源代码确认了一下,是这样的); 使用PHP的syslog函数来写日志,只截取了其中2k的数据记录进去了,其它的就给丢弃了,不过,这个也可能是PHP给做了2k的限制; 看了下PHP的源码,没有做这样的限制,或许unix数据报的报文大小就是2k的限制了,不过,这个也太小了,难道unixsocket可以显式定义数据报的大小?

 

测试3:

创建了一个200字节的文件,并且把net.unix.max_dgram_qlen 修改为1000,kill -19 syslogd_pid 后,使用logger写了1000次文件后才阻塞,说明还是受到了net.unix.max_dgram_qlen的限制,而没有收到一个buffer的限制。猜测,难道没有这么一个buffer?

 (后测试发现写入84k的数据就开始阻塞了)

=======================

关于丢数据的问题

rsyslog的日志中发现如下日志:

Jan 1 21:19:44 phpor-VirtualBox rsyslogd-2177: imuxsock begins to drop messages from pid 2297 due to rate-limiting

 

 

一种有趣的死锁

死锁步骤

1. 使用sudo把syslogd给pause掉,就是: sudo kill -19 syslogd-pid

2. 使用logger写一些日志,自然是写不进去的,一般写10条就够了

3. 在使用sudo让syslogd继续运行: sudo kill -18 syslogd-pid

 

现象:

发现第三步怎么也执行不了,不知道卡死在什么地方了; 使用strace跟踪一下吧: strace sudo kill -18 syslog-pid; 发现没有权限,自然还要对strace使用sudo执行,于是: sudo  strace sudo kill -18 syslog-pid ; 什么也没看见,继续卡死。

问题原因:

因为syslogd的buffer已经写满了,sudo是要写日志的,阻塞在了写日志的地方了; 于是就不好玩了,关机吧!

但是关机也是要写日志的呀,关机也关不了了,只能断电了

xhprof 的实现机制

缘起

正文

1. 下载xhprof源代码: http://pecl.php.net/package/xhprof

2. 参看: xhprof-x.x.x/extention/xhprof.c 中函数:hp_begin

说明: xhprof 代理了zend的一些函数,在这些函数的开始和结束记录所关心的信息