linux進程名字
1. linux獲取進程id和進程名稱
linux獲取進程id和進程名稱作為一個共享庫,應該需要統計使用本庫的各種應用程序的使用頻率,使用方法等信息。才能針對主要應用做出更好的改進。
www.dnjsb.com
那麼就需要記錄調用者的進程id或者進程名稱,並且保存下來。保存的動作可以採用共享內存,也可以採用文件,這個在下篇博文描述,本文描述如何獲取進程id和進程名稱。範例:#include
<stdio.h>#include
<unistd.h>#define
CFGMNG_TASK_NAME_LEN
256int
main(){
int
ret;
char
ac_tmp[CFGMNG_TASK_NAME_LEN];
ret
=
cfgmng_get_taskname(ac_tmp,
CFGMNG_TASK_NAME_LEN);
if
(0
!=
ret)
{
printf(Call
cfgmng_get_taskname
fail./n);
return
-1;
}
printf(The
running
task
name
is
%s./n,
ac_tmp);
return
0;}int
cfgmng_get_taskname(char
*ac,
int
len){
int
count
=
0;
int
nIndex
=
0;
char
chPath[CFGMNG_TASK_NAME_LEN]
=
{0};
char
cParam[100]
=
{0};
char
*cTem
=
chPath;
int
tmp_len;
pid_t
pId
=
getpid();
sprintf(cParam,/proc/%d/exe,pId);/*
printf(cParam
=
%s./n,
cParam);*/
count
=
readlink(cParam,
chPath,
CFGMNG_TASK_NAME_LEN);/*
printf(count
=
%d./n,
count);*/
if
(count
<
0
||
count
>=
CFGMNG_TASK_NAME_LEN)
{
printf(Current
System
Not
Surport
Proc./n);
return
-1;
}
else
{
nIndex
=
count
-
1;
for(
;
nIndex
>=
0;
nIndex--)
{
if(
chPath[nIndex]
==
'/'
)//篩選出進程名
{
nIndex++;
cTem
+=
nIndex;
break;
}
}
}
tmp_len
=
strlen(cTem);
if
(0
==
tmp_len)
{
printf(Get
task
fail./n);
return
-1;
}
if
(len
<=
tmp_len
+1)
{
printf(len(%d)
is
less
than
taskname(%s)'s
len./n,
len,
cTem);
return
-1;
}
strcpy(ac,
cTem);
return
0;}從上面的實驗範例可以看出,主要使用的函數是getpid獲取本進程的id,再到/proc/pid/exe
中去找到對應的進程名稱。在/proc目錄中有很多跟進程相關的東西,都可以用這種方法觸類旁通地實現。
2. 關於linux下的tomcat應用的進程名如何查找
這個不同應用應該是不同的埠吧?
那就用root運行netstat -anp | grep 埠號
找到那個對應的pid。
比如我運行在9292埠上,那就這樣:
# netstat -anp | grep 9292
tcp 0 0 :::9292 :::* LISTEN 32630/java
對應tomcat的pid就是32630。
用root運行不是必須的,但如果不用root,那你就必須用運行tomcat的相同用戶運行,要不然別的用戶沒有許可權,會獲取不到相應的信息。
3. Linux 怎麼根據進程號,找對應的進程!
Linux根據進程號查詢相應的進程信息,可以使用ps命令的-q參數來進行查詢。
有很多用戶喜歡用兩個屏幕,尤其是程序員、游戲玩家、視頻製作者等,可以說雙屏顯示,游戲工作,兩不誤。那麼電腦設置雙屏顯示或多屏顯示有什麼用?怎麼設置雙屏或多屏顯示呢?下面小編簡單介紹一下它的作用以及具體的操作方法吧!
雙屏顯示器有什麼好處(電腦)
1、大屏幕拼接
(拼接計算機圖形,拼接動態視頻)投影牆;公安、軍事、鐵路、交通、航天、郵電、衛星發射等指揮調度系統;圖形圖像編輯,三維動畫,多媒體設計;工業領域的過程式控制制;證券交易、期貨、銀行信息顯示;CAD/CAM設計,排版編輯系統,視頻圖象編輯。
2、文件編輯:
製作企劃案文件資料時,同時參考搜尋相關網路資料,不會因為切換視窗而造成資料混亂。
3、繪圖編輯:
使用繪圖軟體設計案件時,同時開啟參考文案窗口,也可以延伸桌面,方便處理大型設計稿製作,與校對的窗口完全不重疊。
4、影視娛樂:
(1)收看網路電視,同時瀏覽其它頻道的節目介紹,精彩節目不錯過。
(2)玩在線游戲時,可同步對照游戲攻略的密技。
5、 辦公室 :
(1)橫跨兩個以上的屏幕檢視大型表格(如EXCEL圖表)。
(2)在延伸出的桌面空間上同時開啟多個程序,不需頻繁地切換使用窗。
(3)讀取電子郵件並同時在其它屏幕開啟附件檔案。
6、程序設計:
撰寫復雜的程序時,另外一個窗口同時檢視程序執行結果畫面,方便進行更新修改。
以上就是雙屏電腦的好處了,大家現在對於雙屏電腦是不是也有所了解了呢?看到小編為大家列舉的都是雙屏電腦的好處是不是有些心動呢?下面一起來看看如何設置吧!
一、硬體要求(以Win10系統為案例)
1、電腦主機必須具備VGA/DVI/HDMI任意兩路輸出的獨立顯卡介面(一般入門級顯卡就支持),如下圖所示:
2、准備VGA/DVI/HDMI任意兩根線,顯示輸出介面對應的連接線外觀圖如下所示:
3、兩個顯示器,支持VGA/DVI/HDMI任意兩種介面(否則需要VGA轉換器接頭)
二、雙屏操作步驟
1、首先把外接顯示器與電腦顯卡介面通過VGA/DVI/HDMI任意兩種線相連接。
2、連接成功後,進入電腦系統桌面,滑鼠右擊桌面空白處選擇【顯示設置】
3、如果連接成功就可以看到顯示器有2個
4、顯示界面找到【多顯示器設置】下方選擇【擴展這些顯示器】,然後兩個顯示器就可以正常顯示了。
5、如果線路檢測沒問題仍然顯示不出來,那麼滑鼠 右擊桌面選擇【 NVIDIA 控制面板 】
6、找到【設置多個顯示器】,然後勾選我們希望使用的顯示器,這樣就可以 了。
三、多屏顯示方法
硬體要求:
除了支持雙屏的硬體條件之外,部分電腦需要進BIOS設置查找相關選項,若無法找到,說明主板不支持,請參考下面操作。
進BIOS操作步驟:
1、開機進入BIOS,找到【Devices】-【Video Setup】選項,敲擊Enter回車按鍵;
2、選擇【Select Active Video】選項設置成【IGD】模式,並將【Multi-Monitor Support】選項設置成【Enabled】模式;
3、設置完成後,點擊F10鍵,選擇【Yes】進行保存;
4、重啟進入操作系統後,在桌面空白處右鍵,從菜單中找到集成顯卡控制台程序,進行多屏顯示設置即可。
4. linux查看進程id命令(linux查看進程id)
1、linux查看進程ID。
2、Linux查看進程。
3、linux什麼命令查看進程。
4、linux系統進程查看。
1."linux查看進程id,為您提供linux查看進程id圖文信息,第一登錄linux伺服器。
2.輸入pgrep+進程名稱可獲取到pid列表。
3.使用ps-ef|grep+進程名也可查看id。
4.使用top命令查看進程pid。
5.通過ls/proc命令查看進程pid。
進程信息
/proc目錄包含了所有正運行的進程目錄。這些目錄的名字和進程的標識符是一樣的。所以,如果你遍歷/proc目錄下那些使用數字作為它們的名字的目錄,你就會獲得所有現在正在運行的進程列表。在下面的代碼中process_list()函數返回所有現在正在運行的進程的標識符列表。當你執行這個程序後,這個列表的長度就是在系統上運行的總進程數。
復制代碼 代碼如下:
#!/usr/bin/env python
"""
List of all process IDs currently active
"""
from __future__ import print_function
import os
def process_list():
pids = []
for subdir in os.listdir('/proc'):
if subdir.isdigit():
pids.append(subdir)
return pids
if __name__=='__main__':
pids = process_list()
print('Total number of running processes:: {0}'.format(len(pids)))
上面的程序當執行後會顯示和下面類似的輸出:
復制代碼 代碼如下:
Total number of running processes:: 229
每個進程目錄包含了一些其他文件和目錄,如進程命令的調用,它正使用的共享庫以及其它的。
建議看看《Linux就該這么學》這本書
6. 在LINUX內核中,進程標識符PID為1,2 ,3,4,5的進程的名稱是什麼基本功能是什麼
pid=1 :init進程,系統啟動的第一個用戶級進程,是所有其它進程的父進程,引導用戶空間服務。
pid=2 :kthreadd:用於內核線程管理。
pid=3 :migration,用於進程在不同的CPU間遷移。
pid=4 :ksoftirqd,內核里的軟中斷守護線程,用於在系統空閑時定時處理軟中斷事務。
pid=5 :watchdog,此進程是看門狗進程,用於監聽內核異常。當系統出現宕機,可以利用watchdog進程將宕機時的一些堆棧信息寫入指定文件,用於事後分析宕機的原因。
7. linux怎麼查詢進程和進程的id
用top -u 命令查看進程以及PID。
命令如下:
$ top -u
PID — 進程id
USER — 進程所有者
PR — 進程優先順序
NI — nice值。負值表示高優先順序,正值表示低優先順序
VIRT — 進程使用的虛擬內存總量,單位kb。VIRT=SWAP+RES
RES — 進程使用的、未被換出的物理內存大小,單位kb。RES=CODE+DATA
SHR — 共享內存大小,單位kb
S — 進程狀態。D=不可中斷的睡眠狀態 R=運行 S=睡眠 T=跟蹤/停止 Z=僵屍進程
%CPU — 上次更新到現在的CPU時間佔用百分比
%MEM — 進程使用的物理內存百分比
TIME+ — 進程使用的CPU時間總計,單位1/100秒
COMMAND — 進程名稱(命令名/命令行)
8. 如何修改 Linux 中的進程名
在編寫網路伺服器程序時,為了響應客戶端的請求,我們經常需要新建進程來處理業務流程;而且又是為了關閉某個非法請求或者關閉長連接的客戶端,這時就需要殺死進程 killall proc_name。 但是在新建進程時,子進程名與父進程名相同。因此需要由進程名及參數來區分客戶端連接。
在linux中prctl可以滿足這個要求,下滿是man手冊:
PR_SET_NAME (since Linux 2.6.9)
Set the process name for the calling process, using the value in
the location pointed to by (char *) arg2. The name can be up to
16 bytes long, and should be null terminated if it contains
fewer bytes.
但是prctl修改的進程名,只能是16個位元組(包括'\0')。下面是修改的代碼(changetitle.c):
#include <stdio.h>
#include <sys/prctl.h>
int main(int argc, char *argv[], char *envp[])
{
char *new_name = "abcdefghijklmnopqrstuvwxyz";
getchar();
prctl(PR_SET_NAME, new_name);
getchar();
return 0;
}
當新名稱長度大於16時就會截斷,上面的新名字截斷後是abcdefghijklmno。這對於我們來說是有缺陷的。而且通過ps -aux 查看,進程名稱並沒有改變,改變的只是/prco/$(PID)/stat和
/prco/$(PID)/status的值,而/prco/$(PID)/cmdline並沒有改變。這種方式使用起來也是不方便的。
下面介紹另一種方式,可以與上面的方式互補。
首先看一下main函數的原型:int main(int argc, char *argv[]);
argv[0]存放的是終端執行的程序名稱也就是進程名。argv[1...argc-1]存放的是命令行參數。
linux中main()還有一個隱藏參數就是環境變數信息,存放了運行時所需要的環境變數。
我們可以通過以下來訪問這個變數
extern char **environ;
argv與environ是連續存放在棧區的。下面代碼可以查看參數信息:
#include <stdio.h>
#include <string.h>
extern char **environ;
int main(int argc , char *argv[])
{
int i;
printf("argc:%d\n" , argc);
for (i = 0; i < argc; ++i)
{
printf("argv[%d](0x%x):%s\n" , i , (unsigned int)argv[i], argv[i]);
}
printf("evriron=0x%x\n" , (unsigned int)environ[0]);
return 0;
}
通過上面可以看出,我們只需要修改argv[0]所指向的內存空間的內容,就可以修改進程名。但是如果新名稱比argv[0]的長度小,我們可以直接修改,並把多餘的部分請0,如果新名稱
比argv[0]長我們需要兩步:
1、申請新內存保存環境變數信息和argv[1...argc-1]參數信息
2、修改argv[0],將新名稱往後到environ的最後一項清0
以下是參考代碼:
#include <unistd.h>
#include <stdio.h>
#include <stdarg.h>
#include <string.h>
#include <stdlib.h>
#include <sys/prctl.h>
# define MAXLINE 2048
extern char **environ;
static char **g_main_Argv = NULL; /* pointer to argument vector */
static char *g_main_LastArgv = NULL; /* end of argv */
void setproctitle_init(int argc, char **argv, char **envp)
{
int i;
for (i = 0; envp[i] != NULL; i++) // calc envp num
continue;
environ = (char **) malloc(sizeof (char *) * (i + 1)); // malloc envp pointer
for (i = 0; envp[i] != NULL; i++)
{
environ[i] = malloc(sizeof(char) * strlen(envp[i]));
strcpy(environ[i], envp[i]);
}
environ[i] = NULL;
g_main_Argv = argv;
if (i > 0)
g_main_LastArgv = envp[i - 1] + strlen(envp[i - 1]);
else
g_main_LastArgv = argv[argc - 1] + strlen(argv[argc - 1]);
}
void setproctitle(const char *fmt, ...)
{
char *p;
int i;
char buf[MAXLINE];
extern char **g_main_Argv;
extern char *g_main_LastArgv;
va_list ap;
p = buf;
va_start(ap, fmt);
vsprintf(p, fmt, ap);
va_end(ap);
i = strlen(buf);
if (i > g_main_LastArgv - g_main_Argv[0] - 2)
{
i = g_main_LastArgv - g_main_Argv[0] - 2;
buf[i] = '\0';
}
(void) strcpy(g_main_Argv[0], buf);
p = &g_main_Argv[0][i];
while (p < g_main_LastArgv)
*p++ = '\0';
g_main_Argv[1] = NULL;
prctl(PR_SET_NAME,buf);
}
int main(int argc, char *argv[])
{
char argv_buf[MAXLINE] = {0}; // save argv paramters
for(int i = 1; i < argc; i++)
{
strcat(argv_buf, argv[i]);
strcat(argv_buf, " ");
}
setproctitle_init(argc, argv, environ);
setproctitle("%s@%s %s", "new_name", "ip", argv_buf);
for (int i = 0; environ[i] != NULL; i++)
free(environ[i]);
getchar();
return 0;
}
上面的代碼使用了prctl和修改argv[0]兩種修改方法的結合,通過ps -a 、 ps -ef 、ps -aux、 top 等等命令都只能查詢到新進程名,/proc/$PID/ 下的文件也顯示了新進程名的信息。
應用場景:
1、標識父子進程名稱,防止被誤殺
2、構造假的進程名及參數,引導非法進入人員到蜜罐系統,取證