Get process names linux

How to find process name?

Does every service that is active running have a process that can be seen by ps command on linux? If yes, how can I find the related process name? For example if ntp is running, should I see it by the name ntp in ps -aux | grep ntp ?

1 Answer 1

does every service that is active running have a process that can be seen by ps command on linux

for example if ntp is running, should I see it by the name ntp in ps -aux | grep ntp? thanks

$ ps -aux | grep ntp ntp 1142 0.0 0.0 40264 1456 ? Ss Feb25 5:07 /usr/sbin/ntpd -p /var/run/ntpd.pid -g -c /var/lib/ntp/ntp.conf.dhcp -u 105:112 

It will, at least, show the name of the daemon and the user. In the case of «ntp» that would be «ntpd» and «ntp». There are services that (by default) use another user name than the name of the process though: apache user «www-data» as a username and «apache2» is the process.

How can I find the exact process name of a service then?

I tend to know the names of all the processes running on my system. Apache does not work when searching through systemd:

$ ps -ef | grep apache www-data 9799 1638 0 11:21 ? 00:00:00 /usr/sbin/apache2 -k start www-data 12293 1638 0 12:00 ? 00:00:00 /usr/sbin/apache2 -k start www-data 12727 1638 0 12:02 ? 00:00:00 /usr/sbin/apache2 -k start www-data 13122 1638 0 12:08 ? 00:00:00 /usr/sbin/apache2 -k start www-data 13711 1638 0 12:18 ? 00:00:00 /usr/sbin/apache2 -k start www-data 14004 1638 0 12:20 ? 00:00:00 /usr/sbin/apache2 -k start www-data 14013 1638 0 12:20 ? 00:00:00 /usr/sbin/apache2 -k start www-data 14120 1638 0 12:22 ? 00:00:00 /usr/sbin/apache2 -k start www-data 15079 1638 0 12:41 ? 00:00:00 /usr/sbin/apache2 -k start www-data 15557 1638 0 12:51 ? 00:00:00 /usr/sbin/apache2 -k start www-data 15783 1638 0 12:57 ? 00:00:00 /usr/sbin/apache2 -k start www-data 15786 1638 0 12:57 ? 00:00:00 /usr/sbin/apache2 -k start $ sudo systemctl list-unit-files | grep apache $ sudo systemctl list-unit-files | grep https $ sudo systemctl list-unit-files | grep http 

No everything is a systemd service 😉

Источник

How to Find a Process Name Using PID Number in Linux

In this article, we will look at how to find a process name by its process identification number (PID). Before we dive into the actual solution, let us briefly talk about how processes are created and identified by Linux.

Every time a user or the system (Linux) launches a program, the kernel will create a process. A process holds execution details of the program in memory such as its input and output data, variables and so on.

Importantly, since Linux is a multitasking operating system, it executes several programs simultaneously, and this means each process process must be identified specifically.

The kernel identifies each process using a process ID (PID), a every instance of process must have a unique PID from other processes which is assigned when the process is invoked, to avoid any execution errors.

Читайте также:  Linux run with shared library

The /proc file system stores information about currently running processes on your system, it contains directories for each process.

Use the ls command to list its contents, however, the list may be long, so employ a pipeline and the less utility to view the /proc contents in a more convenient way as below:

$ ls /proc OR $ ls /proc | less
1 168 2230 25 329 584 7386 83 driver schedstat 10 169 2234 2503 33 603 74 830 execdomains scsi 1070 17 2247 2507 34 610 7411 833 fb self 1081 1702 2256 2523 349 611 7423 836 filesystems slabinfo 109 1714 2258 253 35 612 745 839 fs softirqs 11 173 2266 2551 36 613 746 84 interrupts stat 110 1760 2273 26 362 62 75 844 iomem swaps 1188 1763 2278 2688 3642 63 7533 85 ioports sys 12 1769 2282 2694 3643 64 7589 86 irq sysrq-trigger 1204 177 2283 2695 37 6436 76 860 kallsyms sysvipc 1209 1773 2285 2698 38 65 7619 87 kcore thread-self 1254 18 2287 2699 39 66 7689 9 keys timer_list 13 1847 2295 27 3974 67 7690 94 key-users timer_stats 15 1914 23 2702 3976 68 77 977 kmsg tty 152 1917 2308 28 4273 6897 7725 981 kpagecgroup uptime 153 1918 2309 280 4374 69 7729 987 kpagecount version 154 1938 2310 2815 4392 6969 7733 997 kpageflags version_signature 155 1956 2311 2817 44 6980 78 acpi loadavg vmallocinfo 156 1981 2315 282 45 7 79 asound locks vmstat 1565 1986 2316 283 4543 70 790 buddyinfo mdstat zoneinfo 1567 1988 2317 29 46 71 8 bus meminfo 157 2 2324 2935 461 7102 80 cgroups misc 1579 20 2347 2944 4686 72 808 cmdline modules 158 2010 2354 3 47 73 81 consoles mounts 1584 2043 2436 30 4700 7304 810 cpuinfo mtrr 159 2044 2437 3016 5 7311 815 crypto net 1590 21 2442 31 515 7322 82 devices pagetypeinfo 16 2167 2443 318 5273 7347 820 diskstats partitions 160 22 2492 32 5274 7367 823 dma sched_debug

From the screenshot above, the numbered directories store information files about the processes in execution, where each number corresponds to a PID.

Below is the list of files for systemd process with PID 1:

ls: cannot read symbolic link '/proc/1/cwd': Permission denied ls: cannot read symbolic link '/proc/1/root': Permission denied ls: cannot read symbolic link '/proc/1/exe': Permission denied attr coredump_filter gid_map mountinfo oom_score schedstat status autogroup cpuset io mounts oom_score_adj sessionid syscall auxv cwd limits mountstats pagemap setgroups task cgroup environ loginuid net personality smaps timers clear_refs exe map_files ns projid_map stack uid_map cmdline fd maps numa_maps root stat wchan comm fdinfo mem oom_adj sched statm

You can monitor processes and their PIDs using traditional Linux commands such as ps, top and relatively new glances command plus many more as in the examples below:

USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 1 0.0 0.0 185728 6268 ? Ss 10:15 0:01 /sbin/init splash root 2 0.0 0.0 0 0 ? S 10:15 0:00 [kthreadd] root 3 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/0] root 5 0.0 0.0 0 0 ? S< 10:15 0:00 [kworker/0:0H] root 7 0.0 0.0 0 0 ? S 10:15 0:09 [rcu_sched] root 8 0.0 0.0 0 0 ? S 10:15 0:00 [rcu_bh] root 9 0.0 0.0 0 0 ? S 10:15 0:00 [migration/0] root 10 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/0] root 11 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/1] root 12 0.0 0.0 0 0 ? S 10:15 0:00 [migration/1] root 13 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/1] root 15 0.0 0.0 0 0 ? S< 10:15 0:00 [kworker/1:0H] root 16 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/2] root 17 0.0 0.0 0 0 ? S 10:15 0:00 [migration/2] root 18 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/2] root 20 0.0 0.0 0 0 ? S< 10:15 0:00 [kworker/2:0H] root 21 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/3] root 22 0.0 0.0 0 0 ? S 10:15 0:00 [migration/3] root 23 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/3] root 25 0.0 0.0 0 0 ? S< 10:15 0:00 [kworker/3:0H] root 26 0.0 0.0 0 0 ? S 10:15 0:00 [kdevtmpfs] root 27 0.0 0.0 0 0 ? S< 10:15 0:00 [netns] root 28 0.0 0.0 0 0 ? S< 10:15 0:00 [perf] .

Monitor Linux processes using traditional top command.

Читайте также:  Поменять язык ввода линукс

Monitor Linux Processes with top Command

Monitor Linux processes using glances, a new real-time process monitoring tool for Linux.

Glances - Real Time Linux Processes Monitoring

Find Out Process PID Number

To find out the PID of a process, you can use pidof , a simple command to print out the PID of a process:

$ pidof firefox $ pidof python $ pidof cinnamon

Find Linux Process PID

Coming back to our point of focus, assuming you already know the PID of a process, you can print its name using the command form below:

Find Out Process Name Using PID Number

In this section, we will see how to find out a process name using its PID number with the help of user defined format i.e comm= which means command name, same as the process name.

$ ps -p 2523 -o comm= $ ps -p 2295 -o comm=

Find Linux Process Name

For additional usage information and options, look through the ps man page.

If you want to kill a process using its PID number, I suggest you to read Find and Kill Linux Processes Using its PID.

Thats it for the moment, if you know any other better way to find out a process name using PID, do share with us via our comment section below.

Источник

How to Find Process Name from its PID

If you know the PID of a process, here's how to get the process name in Linux command line.

If you know the process ID (PID), you can get the process name using the ps command:

The ps command is used for process related operations. In the above command, -p PID provides the process ID and -o comm= asks it to output the command associated with the given PID.

Get process name from process ID

Honestly, it's difficult to remember the weird ps -p PID -o comm= syntax. And if that's the case, you may either look into the man page of ps command or use other ways of getting the details.

You can list all running process using the ps command or top command and note the process ID and process name as desired.

List all running processes in Linux

If you know the PID, you can simply use the grep command to filter the output and get the details on that PID:

Читайте также:  Kali linux установка видеодрайвера

But as illustrated by the image below, the output gives other details along with the process name.

Use grep and ps command to get process name from PID

That's not an issue if you are manually reading it. However, if you have to use it in a script, it could be an issue.

This is where the ps -p PID -o comm= is better.

Bonus tip: Since we are talking about process name and PIDs, let me quickly show you the reverse method, i.e., to find PID from process name.

There is a dedicated command called pidof and you can use it like this if you know the exact process name:

So, you just learned how to find process name from its PID in Linux command line and you also learned to get the PID from the process name.

If something isn't working right, or you just have any comments in general, feel free to leave any of it in the comments below.

Источник

How to get current process name in linux?

How can I get the process name in C? The same name, which is in /proc/$pid/status . I do not want to parse that file. Is there any programmatic way of doing this?

8 Answers 8

If you're on using a glibc, then:

#define _GNU_SOURCE #include extern char *program_invocation_name; extern char *program_invocation_short_name; 

Under most Unices, __progname is also defined by the libc. The sole portable way is to use argv[0]

It's either pointed to by the argv[0] or indeed you can read /proc/self/status . Or you can use getenv("_") , not sure who sets that and how reliable it is.

Note that getenv("_") appears to return the process originally started by the shell -- if I call it in a process started by make , I see "/usr/bin/make", rather than my process name. This means that it's probably set by the shell.

You can use __progname . However it is not better than argv[0] as it may have portability issues. But as you do not have access to argv[0] it can work as follows:-

extern char *__progname; printf("\n%s", __progname); 

I often make use of following call,

char* currentprocname = getprogname(); 

That's BSD-specific. You can get it on Linux with libbsd , but it's not part of libc as it is on FreeBSD or OS X.

Look at the value of argv[0] which was passed to main . This should be the name under which your process was invoked.

This is a version that works on macOS, FreeBSD and Linux.

#if defined(__APPLE__) || defined(__FreeBSD__) const char * appname = getprogname(); #elif defined(_GNU_SOURCE) const char * appname = program_invocation_name; #else const char * appname = "?"; #endif 

If you cannot access argv[] in main(), because you are implementing a library, you can have a look at my answer on a similar question here.

It basically boils down into giving you access to argc, argv[] and envp[] outside of main(). Then you could, as others have already correctly suggested, use argv[0] to retrieve the process name.

Источник

Оцените статью
Adblock
detector