linux下怎么运行程序查看程序是否在运行 linux

Linux SUSE上怎么使用zypper命令检测某个软件包是否已安装
Zypper是SUSE Linux下用于管理软件的程序,拥有多种功能,那么Linux下要如何使用Zypper命令来管理软件呢?下面小编就给大家介绍下SUSE Linux使用Zypper命令的方法,感兴趣的朋友可以来了解下。
Linux SUSE上我怎么检测某个软件包已经安装过了呢?
Note: 比如我现在想查看一下tightvn是否已经安装在我系统上了 - 我尝试用了这个命令:dbus-launch vncserver 最后显示找不到命令。
Zypper是SUSE Linux下用于管理软件的程序,拥有多种功能,那么Linux下要如何使用Zypper命令来管理软件呢?下面小编就给大家介绍下SUSE Linux使用Zypper命令的方法,感兴趣的朋友可以来了解下。  
Zypper是SUSE Linux中用于安装,升级,卸载,管理仓库、进行各种包查询的命令行接口。本篇将会讨论zypper的几个不同命令的例子。
  # zypper [--global-opts] 《command》 [--command-opts] [command-arguments]
  中括号中的部分可以不需要。执行zypper最简单的方法是输入 zypper 及 。
对于SLES11 SP1, 关键的命令是 zypper
server:/ # zypper se tightvnc
Loading repository data...
Reading installed packages...
--+----------+----------------------------------+--------
i | tightvnc | A virtual X-Window System server | package
&se&是 'search'的简写. 或者可以是同更标准的命令:rpm -q tightvnc
server:/ # rpm -q tightvnc
tightvnc-1.3.10-2.1.x86_64
下面就说下更多关于zypper命令的资料,希望能帮到大家。
例子1:列出可用的全局选项和命令
  打开终端,输入zypper并按回车,它会显示所有可用的全局选项和命令。
  linux-xa3t:~# zypper
  例子2:获得zypper的某个命令的帮助
  语法: zypper help [command]
  linux-xa3t:~# zypper help remove
  remove (rm)[options]《capability》。。.
  Remove packages with specified capabilities.
  A capability is NAME[.ARCH][OP《VERSION》],where OP is one of 《,《=,=,》=,》。
  Command options:
  -r,--repo 《alias|#|URI》Load only the specified repository.
  -t,--type 《type》Type of package(package, patch, pattern, product)。
  Default:package.
  -n,--name Select packages by plain name,notby capability.
  -C,--capability Select packages by capability.
  --debug-solver Create solver test casefor debugging.
  -R,--no-force-resolution Donot force the solver to find solution,let it ask.
  --force-resolution Force the solver to find a solution (even an aggressive one)。
  -u,--clean-deps Automatically remove unneeded dependencies.
  -U,--no-clean-deps No automatic removal of unneeded dependencies.
  -D,--dry-run Test the removal,donot actually remove.
  例子3:打开zypper shell/会话
  linux-xa3t:~# zypper sh
  zypper》
  linux-xa3t:~# zypper shell
  zypper》
  例子4:列出已定义的仓库
  linux-xa3t:~# zypper repos
  linux-xa3t:~# zypper lr
  4.1) 以表格的形式列出仓库的URI
  4.2) 以优先级列出仓库
  linux-xa3t:~# zypper lr -p
  例子5:刷新仓库
  linux-xa3t:~# zypper ref
  Repository&openSUSE-13.1-Non-Oss&is up to date.
  Repository&openSUSE-13.1-Oss&is up to date.
  Repository&openSUSE-13.1-Update&is up to date.
  Repository&openSUSE-13.1-Update-Non-Oss&is up to date.
  All repositories have been refreshed.
  例子6:修改zypper仓库
  zypper仓库可以通过别名、数字或者URI或者通过&&all、 &remote、 &local、 &medium-type&这些选项修改。
  linux-xa3t:~ # zypper mr -d 6 #禁用6号仓库 linux-xa3t:~ # zypper mr -rk -p 70 upd #启用自动书信并为&upd&仓库设置rpm文件&缓存&,且设置它的优先级为70 linux-xa3t:~ # zypper mr -Ka #为所有的仓库禁用rpm文件缓存 linux-xa3t:~ # zypper mr -kt #为远程仓库设置rpm文件缓存
  例子7:添加仓库
  语法: zypper addrepo 或者 zypper ar 《仓库的URL或者别名》
  linux-xa3t:~# zypper ar http://download.opensuse.org/update/13.1/ update
  Adding repository &update&。。.。。.。。.。。.。。.。。.。。.。。.。。.。。.。。.。。.。。.。。.。。.[done]
  Repository&update& successfully added
  Enabled:Yes
  Autorefresh:No
  GPG check:Yes
  URI: http://download.opensuse.org/update/13.1/
  例子8:移除仓库
  语法: zypper removerepo 《仓库名》 《别名》
  zypper rr 《仓库名》 《别名》
  linux-xa3t:~# zypper rr openSUSE-13.1-1.10 openSUSE-13.1-1.10
  Removing repository &openSUSE-13.1-1.10&。。.。。.。。.。。.。。.。。.。。.。。.。。.。[done]
  Repository&openSUSE-13.1-1.10& has been removed.
  例子9:安装软件包
  语法: zypper install 《包名》 或者 zypper in 《包名》
  linux-xa3t:~# zypper install vlc
  例子10:卸载软件包
  语法: zypper remove 《包名》 或者 zypper rm 《包名》
  linux-xa3t:~# zypper remove sqlite
  例子11:导出和导入仓库
  导出仓库的语法 : zypper repos &export 或者 zypper lr -e
  linux-xa3t:~# zypper lr --export repo-backup/back.repo
  Repositories have been successfully exported to repo-backup/back.repo.
  导入仓库的语法 :
  linux-xa3t:~# zypper ar repo-backup/back.repo
  例子12:更新一个软件包
  语法: zypper update 《包名》 或者 zypper up 《包名》
  linux-xa3t:~# zypper update bash
  例子13:安装源码包
  语法: zypper source-install 《源码包》 或 zypper si 《源码包》
  linux-xa3t:~# zypper source-install zypper
  例子14:只安装依赖包
  例子13中的命令会安装和构建特定包的依赖。如果你想要安装源码包就用-D选项
  # zypper source-install -D package_name
  只安装依赖就使用-d
  # zypper source-install -d package_name
  上面就是SUSE Linux系统中Zypper命令操作实例的相关介绍了,通过这些实例想必你已经对Zypper命令有一定的了解,希望对你有所帮助。
------分隔线----------------------------
海外媒体日前称 谷歌的一个团队悄悄披露了一个新的操作系统Fuchsia 从理论上讲 这个系...
rdiff-backup 是一个用于本地/远程增量备份的强大而易用的 Python 脚本,它适用于任何...
5月10日,红帽公司宣布,宝马集团已经部署了红帽OpenShift容器平台,以支持其交付业务...
红帽和思科公司今天宣布,他们将共同合作提供一个与红帽企业Linux软件和思科整合计算...
部署环境:操作系统:CentOS release 6.5 (Final)Python版本:Python 2.7.10 (default, ...Linux下查看进程打开的文件句柄数和如何修改
我的图书馆
Linux下查看进程打开的文件句柄数和如何修改
& & 修改文件句柄数在Linux下,我们使用ulimit -n
命令可以看到单个进程能够打开的最大文件句柄数量(socket连接也算在里面)。系统默认值1024。
对于一般的应用来说(象Apache、系统进程)1024完全足够使用。但是如何象squid、mysql、java等单进程处理大量请求的应用来说就有
点捉襟见肘了。如果单个进程打开的文件句柄数量超过了系统定义的值,就会提到“too many files
open”的错误提示。如何知道当前进程打开了多少个文件句柄呢?下面一段小脚本可以帮你查看:
lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr|more
在系统访问高峰时间以root用户执行上面的脚本,可能出现的结果如下:
# lsof -n|awk '{print $2}'|sort|uniq -c |sort -nr|more
其中第一行是打开的文件句柄数量,第二行是进程号。得到进程号后,我们可以通过ps命令得到进程的详细内容。
ps -aef|grep 24204&&
mysql&&&&24204
?&&&&&&&&00:24:25
/usr/sbin/mysqld&&
哦,原来是mysql进程打开最多文件句柄数量。但是他目前只打开了131个文件句柄数量,远远底于系统默认值1024。
但是如果系统并发特别大,尤其是squid服务器,很有可能会超过1024。这时候就必须要调整系统参数,以适应应用变化。Linux有硬性限制和软性限制。可以通过ulimit来设定这两个参数。方法如下,以root用户运行以下命令:
ulimit -HSn 4096&&
上命令中,H指定了硬性大小,S指定了软性大小,n表示设定单个进程最大的打开文件句柄数量。个人觉得最好不要超过4096,毕竟打开的文件句柄数越多响
应时间肯定会越慢。设定句柄数量后,系统重启后,又会恢复默认值。如果想永久保存下来,,可以修改 /etc/profile
把上面命令加到最后。(findsun提出的办法比较合理)
/////////////////////////////////////////////////////////////////////////////
在 Linux下面部署应用的时候,有时候会遇上Socket/File: Can’t open so many
files的问题,其实Linux是有文件句柄限制的(就像WinXP?),而且默认不是很高,一般都是1024,作为一台生产服务器,其实很容易就达到
这个数量,因此我们需要把这个值改大一些。
大概知道ulimit这个命令是相关的,上Google搜索了一下,大多数说的很含糊,也没有统一说一下,经过两个小时看了不少文章终于弄清楚ulimit相关的一些配置问题。
我们可以用ulimit -a来查看所有限制值,我只关心文件句柄数量的问题
open files (-n) 1024
这个就是限制数量
这里,有很多ulimit的文章都说的很含糊,究竟这个1024是系统的限制,还是用户的限制呢。其实,这个是用户限制来的,完整的说法,应该是当前用户准备要运行的程序的限制。
1、这个限制是针对单个程序的限制
2、这个限制不会改变之前已经运行了的程序的限制
3、对这个值的修改,退出了当前的shell就会消失
比如说,我先运行了一个程序A,然后通过ulimit修改了限制为2048,然后运行B,然后退出了shell再登录,然后运行C。那就只有B可以打开2048个句柄。
如果我们需要改变整体的限制值,或者我们运行的程序是系统启动的,应该怎么处理呢
其中一个方法,是想ulimit修改命令放入/etc/profile里面,但是这个做法并不好
正确的做法,应该是修改/etc/security/limits.conf
里面有很详细的注释,比如
* soft nofile 2048
* hard nofile 32768
就可以将文件句柄限制统一改成软2048,硬32768
这里涉及另外一个问题,什么是软限制,什么是硬限制
硬限制是实际的限制,而软限制,是warnning限制,只会做出warning
其实ulimit命令本身就有分软硬设置,加-H就是硬,加-S就是软
默认显示的是软限制,如果修改的时候没有加上的话,就是两个一起改
配置文件最前面的一位是domain,设置为星号代表全局,另外你也可以针对不同的用户做出不同的限制
修改了,重新登录用ulimit一开就立刻生效了,不过之前启动过的程序要重新启动才能使用新的值。我用的是CentOS,似乎有些系统需要重启才能生效。
ulimit其实就是对单一程序的限制
那系统总限制呢
其实是在这里,/proc/sys/fs/file-max
可以通过cat查看目前的值,echo来立刻修改
另外还有一个,/proc/sys/fs/file-nr
只读,可以看到整个系统目前使用的文件句柄数量
查找文件句柄问题的时候,还有一个很实用的程序lsof
可以很方便看到某个进程开了那些句柄
也可以看到某个文件/目录被什么进程占用了。
TA的最新馆藏[转]&
喜欢该文的人也喜欢如何在Linux中查看所有正在运行的进程 - 博客频道 - CSDN.NET
Daniel的专栏
Daniel的技术随笔
分类:Linux
你可以使用ps命令。它能显示当前运行中进程的相关信息,包括进程的PID。Linux和UNIX都支持ps命令,显示所有运行中进程的相关信息。ps命令能提供一份当前进程的快照。如果你想状态可以自动刷新,可以使用top命令。
输入下面的ps命令,显示所有运行中的进程:
# ps aux | less
-A:显示所有进程
a:显示终端中包括其它用户的所有进程
x:显示无控制终端的进程
任务:查看系统中的每个进程。
任务:查看非root运行的进程
# ps -U root -u root -N
任务:查看用户vivek运行的进程
# ps -u vivek
任务:top命令
top命令提供了运行中系统的动态实时视图。在命令提示行中输入top:
图1:top命令:显示Linux任务
按q退出,按h进入帮助。
任务:显示进程的树状图。
pstree以树状显示正在运行的进程。树的根节点为pid或init。如果指定了用户名,进程树将以用户所拥有的进程作为根节点。
输出示例:
图2:pstree - 显示进程的树状图
任务:使用ps列印进程树
任务:获得线程信息
输入下列命令:
任务:获得安全信息
输入下列命令:
# ps -eo euser,ruser,suser,fuser,f,comm,label
任务:将进程快照储存到文件中
输入下列命令:
# top -b -n1 & /tmp/process.log
你也可以将结果通过邮件发给自己:
# top -b -n1 | mail -s 'Process snapshot'
任务:查找进程
使用pgrep命令。pgrep能查找当前正在运行的进程并列出符合条件的进程ID。例如显示firefox的进程ID:
$ pgrep firefox
下面命令将显示进程名为sshd、所有者为root的进程。
$ pgrep -u root sshd
向htop和atop说hello
htop是一个类似top的交互式进程查看工具,但是可以垂直和水平滚动来查看所有进程和他们的命令行。进程的相关操作(killing,renicing)不需要输入PID。要安装htop输入命令:
# apt-get install htop
# yum install htop
在命令提示行中输入htop:
输出示例:
图3:htop - Interactive Linux / UNIX process viewer
atop是一个用来查看Linux系统负载的交互式监控工具。它能展现系统层级的关键硬件资源(从性能角度)的使用情况,如CPU、内存、硬盘和网络。
它也可以根据进程层级的CPU和内存负载显示哪个进程造成了特定的负载;如果已经安装内核补丁可以显示每个进程的硬盘和网络负载。输入下面的命令启动atop:
输出示例:
图4:AT Computing's System & Process Monitor
原文链接:
排名:第15838名
(14)(3)(11)(5)(18)(2)(42)(8)(4)(21)(1)(1)(1)(1)(1)(1)(7)(6)(1)(2)(2)(2)(3)(1)(1)(3)推荐这篇日记的豆列
&&&&&&&&&&&&

我要回帖

更多关于 linux运行c程序 的文章

 

随机推荐